Jordan Petridis [Thu, 11 Jul 2019 04:48:08 +0000 (07:48 +0300)]
Add Windows CI for msvc 2017 and msys2
Currently the container is based upon a windows 1607 image
and requires a runner with a server/hyper-v 1607 host
to be able to execute.
There are plan on moving the runner to a 1807 later.
Nirbheek Chauhan [Tue, 7 May 2019 14:48:34 +0000 (20:18 +0530)]
uwp: workaround a false positive in certification of orc
It seems that the Windows App Certification Kit searches all files and
binaries for the regex '\<reg\>' (or something like it) and throws
errors if it exists. Supposedly this is for preventing apps from
running REG.EXE
https://blogs.msdn.microsoft.com/appconsult/2017/08/16/how-to-validate-if-your-application-is-compliant-with-the-windows-store-polices-windows-10-and-windows-10-s/
Xavier Claessens [Fri, 12 Apr 2019 15:34:33 +0000 (11:34 -0400)]
Meson: Do not always generate static library
Since Meson 0.46.0 'default_library' can be set to 'both' when user
wants both shared and static libraries.
Tim-Philipp Müller [Mon, 15 Apr 2019 08:27:24 +0000 (09:27 +0100)]
Back to development
Tim-Philipp Müller [Sun, 14 Apr 2019 22:47:03 +0000 (23:47 +0100)]
Release 0.4.29
Tim-Philipp Müller [Fri, 22 Mar 2019 19:36:24 +0000 (19:36 +0000)]
orc: fix C++ style comment
Tim-Philipp Müller [Tue, 5 Mar 2019 14:21:04 +0000 (14:21 +0000)]
configure.ac: no more bugzilla
Tim-Philipp Müller [Tue, 5 Mar 2019 13:52:54 +0000 (13:52 +0000)]
Update news file for upcoming release
Tim-Philipp Müller [Tue, 5 Mar 2019 11:05:43 +0000 (11:05 +0000)]
Add pkg-config file for orc-test library
Fixes #16
Nirbheek Chauhan [Tue, 5 Feb 2019 13:29:11 +0000 (18:59 +0530)]
Fix warnings with Cerbero's mingw (gcc 4.7)
orcutils.h:59:38: error: "__STDC_VERSION__" is not defined [-Werror=undef]
Seungha Yang [Mon, 28 Jan 2019 13:12:46 +0000 (22:12 +0900)]
meson: Make orcc detectable from other subprojects
If we are a subproject (e.g., gst-build), this can make it possible
to use orcc by other subprojects.
A. Wilcox [Tue, 10 Jul 2018 02:18:07 +0000 (21:18 -0500)]
PowerPC: Support ELFv2 ABI
The ELFv2 ABI does not use function descriptors. This change has been
tested on Power Mac G5, IBM POWER6, and Raptor Talos II, all using the
musl libc on Linux kernel 4.14.
Michel Normand [Mon, 2 Mar 2015 11:14:03 +0000 (12:14 +0100)]
Add support for ppc64le
Fixes https://gitlab.freedesktop.org/gstreamer/orc/issues/6
Tim-Philipp Müller [Wed, 2 Jan 2019 00:47:42 +0000 (00:47 +0000)]
ci: add minimal ci
Edward Hervey [Mon, 17 Dec 2018 10:26:21 +0000 (11:26 +0100)]
orc: Remove dead assignments
All those temporary registry were not used and instead were being
assigned constant values.
Nirbheek Chauhan [Wed, 14 Nov 2018 09:49:42 +0000 (15:19 +0530)]
meson: Maintain macOS ABI compatibility
Need to use the correct dylib versioning.
Tim-Philipp Müller [Sat, 6 Oct 2018 12:04:01 +0000 (13:04 +0100)]
meson: add option to disable orc-test library
https://bugzilla.gnome.org/show_bug.cgi?id=736785
Tim-Philipp Müller [Wed, 3 Oct 2018 09:31:47 +0000 (10:31 +0100)]
meson: rename "enable-backend" option to "orc-backend"
More consistent with the Meson option naming conventions.
Tim-Philipp Müller [Wed, 3 Oct 2018 08:28:53 +0000 (09:28 +0100)]
meson: add options to disable benchmarks, examples, tools
Like we have in other modules.
Tim-Philipp Müller [Wed, 3 Oct 2018 08:13:31 +0000 (09:13 +0100)]
meson: make "tests" option an auto feature option
Consistent with the rest of GStreamer and gst-build.
Tim-Philipp Müller [Mon, 30 Jul 2018 09:06:04 +0000 (10:06 +0100)]
meson: rename 'disable_gtkdoc' option to 'gtk_doc' and make it an auto/feature option
Tim-Philipp Müller [Mon, 30 Jul 2018 08:56:14 +0000 (09:56 +0100)]
meson: rename option disable_tests=false -> tests=true
Bring it in line with convention.
Nicolas Dufresne [Sun, 22 Jul 2018 13:53:39 +0000 (09:53 -0400)]
meson: Bump required version to 0.46
Christoph Reiter [Mon, 21 May 2018 15:06:12 +0000 (17:06 +0200)]
meson: pass the right header when testing for posix_memalign
has_function() needs to know the header to correctly detect the function in
all cases.
This fixes the build under mingw-w64 where posix_memalign was wrongfully being
detected as available.
See this glib bug for a similar fix:
https://bugzilla.gnome.org/show_bug.cgi?id=795876
https://bugzilla.gnome.org/show_bug.cgi?id=796309
Tim-Philipp Müller [Fri, 18 May 2018 08:49:01 +0000 (09:49 +0100)]
Fix MSVC compiler warning
The isnan() macro was redefined to _isnan() on MSVC, but it's
been in math.h since vs2013, so it should be safe to rely on
it unconditionally nowadays, and we have no intention of
supporting ancient vs versions anyway.
Tim-Philipp Müller [Fri, 18 May 2018 08:10:17 +0000 (09:10 +0100)]
orc: fix static build on windows
Orc users mustn't use __declspec(dllimport) when
linking against a static liborc.
Edward Hervey [Fri, 4 May 2018 07:21:16 +0000 (09:21 +0200)]
orctest: Allow enough room for sprintf()
We were writing more than 300 characters in some cases. Thanks gcc
8 for pointing that out :)
Tim-Philipp Müller [Sat, 28 Apr 2018 22:48:39 +0000 (23:48 +0100)]
meson: use add_project_arguments() instead of add_global_arguments()
The latter won't play nice when being used as a subproject.
Tim-Philipp Müller [Sat, 28 Apr 2018 12:06:34 +0000 (13:06 +0100)]
orc: update some generated files
Tim-Philipp Müller [Sat, 28 Apr 2018 12:04:11 +0000 (13:04 +0100)]
orcfunctions.h: include orcutils.h for ORC_API define
Fixes build for users that just include orcfunctions.h
directly instead of orc/orc.h, like libs in gst-plugins-base.
Tim-Philipp Müller [Sat, 28 Apr 2018 00:10:59 +0000 (01:10 +0100)]
orc: remove empty and unused orcrules-x86.c
Tim-Philipp Müller [Fri, 27 Apr 2018 23:37:35 +0000 (00:37 +0100)]
orc: move unusable orc_code_chunk_free() declaration to internal header
Nothing in any public header ever returned or used an OrcCodeChunk.
Tim-Philipp Müller [Fri, 27 Apr 2018 17:42:29 +0000 (18:42 +0100)]
autotools: control symbol visibility via -fvisibility
All symbols are hidden by default unless exported
explicitly via our public API decorators.
Tim-Philipp Müller [Fri, 27 Apr 2018 16:45:23 +0000 (17:45 +0100)]
meson: fix symbol export with MSVC and use -fvisibility elsewhere
Use newly-added ORC_API decorators to export symbols explicitly.
Get rid of orc.map file and the ORC_EXPORT stuff that never did
anything anyway (define was unused).
Tim-Philipp Müller [Fri, 27 Apr 2018 15:56:11 +0000 (16:56 +0100)]
orc: decorate public symbols with ORC_API
We'll use that later to control symbol visibility and
exported symbols.
Tim-Philipp Müller [Fri, 27 Apr 2018 13:00:54 +0000 (14:00 +0100)]
orc-test: decorate public symbols with ORC_TEST_API
We'll use that later to control symbol visibility and
exported symbols.
Tim-Philipp Müller [Fri, 27 Apr 2018 16:02:18 +0000 (17:02 +0100)]
orcc: add --decorator command line argument
So we can add things like FOO_API if the functions are
supposed to be public, for example.
Tim-Philipp Müller [Fri, 27 Apr 2018 11:47:42 +0000 (12:47 +0100)]
meson: use -Bsymbolic-functions when linking if available
cc.has_linker_argument() requires Meson 0.46, so guard
against older Meson versions for now.
Tim-Philipp Müller [Fri, 27 Apr 2018 23:06:03 +0000 (00:06 +0100)]
orc: make more functions static
All of these are only used internally and are
not in any header files, but were still exported
by accident because they start with orc_*.
Tim-Philipp Müller [Fri, 20 Apr 2018 11:34:17 +0000 (12:34 +0100)]
gtk-doc: get rid of templates
gtkdoc-mktmpl was removed in recent gtk-doc versions.
Update gtk-doc.make to 1.27, but modify to generate
xml/version.entities (i.e. add copy in right dir).
All a bit cargo-culted, but seems to work.
James Cowgill [Fri, 6 Apr 2018 14:26:43 +0000 (15:26 +0100)]
orcmips: only enable if the DSPr2 ASE is present
The mips target uses various instructions that a part of the MIPS DSPr2
ASE which is not present on all processors. The easiest solution is to
gate the target on the presense of DSPr2 at runtime.
Unfortunately there isn't a "nice" way to detect if DSPr2 is present, so
resort to parsing /proc/cpuinfo to get the information.
https://bugzilla.gnome.org/show_bug.cgi?id=760834
James Cowgill [Fri, 6 Apr 2018 14:24:47 +0000 (15:24 +0100)]
orcutils: refactor /proc/cpuinfo reading code from orccpu-arm.c
This code will later be used by mips target, so it makes sense
to use a common function instead of duplicating the code.
https://bugzilla.gnome.org/show_bug.cgi?id=760834
Tim-Philipp Müller [Mon, 9 Apr 2018 18:14:05 +0000 (19:14 +0100)]
configure: don't check for functions that aren't used anywhere
And remove some unneeded includes.
James Cowgill [Fri, 6 Apr 2018 14:38:54 +0000 (15:38 +0100)]
meson: fix mips cpu_family test
The cpu family "mipsel" does not exist in meson so the current test to
enable the HAVE_MIPSEL macro is always false. The real cpu family is
"mips" but this also matches big endian platforms so also check that the
endian is little.
https://bugzilla.gnome.org/attachment.cgi?id=370595
Edward Hervey [Wed, 29 Nov 2017 08:19:20 +0000 (09:19 +0100)]
orccpu-arm: Allow 'cpuinfo' fallback on non-android
Reading the cpu flags from cpuinfo is also useful on non-android
ARM platforms which might have mechanisms that prevent /proc/*/auxv
from being read.
Nirbheek Chauhan [Tue, 21 Nov 2017 20:12:23 +0000 (01:42 +0530)]
meson: Always build both shared and static libraries
This reuses objects from the shared library for the static library, so
it should not affect the build time at all.
orc_dep and orc_test_dep will still contain the library selected by
--default-library
Sebastian Dröge [Mon, 20 Nov 2017 17:16:55 +0000 (19:16 +0200)]
Build liborc-test also as a properly versioned library with meson
Sebastian Dröge [Mon, 20 Nov 2017 16:41:01 +0000 (18:41 +0200)]
Add meson configuration for disabling tests and gtk-doc docs
https://bugzilla.gnome.org/show_bug.cgi?id=790626
Sebastian Dröge [Mon, 20 Nov 2017 16:36:20 +0000 (18:36 +0200)]
Allow building shared/static library based on configuration
Before only a shared library was possible
Edward Hervey [Mon, 20 Nov 2017 15:47:00 +0000 (16:47 +0100)]
Back to development
Edward Hervey [Mon, 20 Nov 2017 15:15:58 +0000 (16:15 +0100)]
Release 0.4.28
Edward Hervey [Mon, 20 Nov 2017 14:08:57 +0000 (15:08 +0100)]
orcutils: Use compiler offsetof() when available
The way we were calculating the offset of a structure entry was
undefined behaviour.
Instead, use 'offsetof()' (defined in C89) when available
Edward Hervey [Sun, 19 Nov 2017 17:21:34 +0000 (18:21 +0100)]
orccpu-x86: Fix undefined behaviour compilation issue
runtime error: left shift of 1 by 31 places cannot be represented in type 'int'
Edward Hervey [Sun, 19 Nov 2017 17:19:22 +0000 (18:19 +0100)]
configure.ac: Print configuration after configuration
Makes it easier to spot/review detected flags
Edward Hervey [Sun, 19 Nov 2017 17:18:19 +0000 (18:18 +0100)]
orc: Add a configure option to disable tests
For targets where it doesn't make sense.
Note that this will disable the build of orc-bugreport since it
depends on the the orc_test helper library
Edward Hervey [Sun, 19 Nov 2017 17:15:31 +0000 (18:15 +0100)]
tesuite: Fix some leaks
Edward Hervey [Sat, 21 Oct 2017 07:26:39 +0000 (09:26 +0200)]
orcprogram-c.c: Don't cast constant
Clang compilers would complain with constant-conversion error (trying
to fit a 'int' into another type)
This was introduced to fix a warning in gcc ... which doesn't happen
Edward Hervey [Sat, 21 Oct 2017 07:25:39 +0000 (09:25 +0200)]
orc: Cast maximum constants
Avoids constant-conversion warnings as such:
/src/orc/orc/orcemulateopcodes.c:158:13: error: implicit conversion from 'int' to 'orc_int8' (aka 'signed char') changes value from 255 to -1 [-Werror,-Wconstant-conversion]
var34 = ORC_CLAMP_UB((orc_uint8)var32 + (orc_uint8)var33);
~ ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/src/orc/orc/orcemulateopcodes.c:29:48: note: expanded from macro 'ORC_CLAMP_UB'
^~~~~~~~~~
/src/orc/orc/orcemulateopcodes.c:18:20: note: expanded from macro 'ORC_UB_MAX'
^~~
/src/orc/orc/orcemulateopcodes.c:12:55: note: expanded from macro 'ORC_CLAMP'
^
Tim-Philipp Müller [Tue, 18 Jul 2017 11:33:15 +0000 (12:33 +0100)]
Dist meson files with autotools make dist
Tim-Philipp Müller [Mon, 17 Jul 2017 15:42:02 +0000 (16:42 +0100)]
Back to development
Tim-Philipp Müller [Mon, 17 Jul 2017 15:16:35 +0000 (16:16 +0100)]
Release 0.4.27
Tim-Philipp Müller [Tue, 27 Jun 2017 08:43:07 +0000 (09:43 +0100)]
orcc: make coverity happy
Use typedefed enum so static analysis tools like coverity can know
we covered all possibilities in switch/case statements. CID 1413336.
Matej Knopp [Mon, 19 Jun 2017 02:00:31 +0000 (04:00 +0200)]
orc: preserve non volatile sse registers
required for MSVC
https://msdn.microsoft.com/en-us/library/9z1stfyw.aspx
orc already marks these register in compiler->save_regs,
but the actual saving and restoring was not done
https://bugzilla.gnome.org/show_bug.cgi?id=783931
Nirbheek Chauhan [Fri, 23 Sep 2016 11:01:11 +0000 (16:31 +0530)]
meson: Only use --version-script if not using MSVC
Tim-Philipp Müller [Sun, 28 May 2017 18:13:04 +0000 (19:13 +0100)]
meson: use find_library() on compiler object
The old stand-alone find_library() was deprecated.
Tim-Philipp Müller [Thu, 15 Oct 2015 19:29:15 +0000 (20:29 +0100)]
meson: add meson build
Includes contributions from Nirbheek Chauhan <nirbheek@centricular.com>
Igor Rondarev [Tue, 28 Feb 2017 09:23:55 +0000 (12:23 +0300)]
orcx86: Don't hard-code register size to zero in orc_x86_emit_*() functions
Instead use the size passed as argument. Fixes segmentation fault on QNX.
https://bugzilla.gnome.org/show_bug.cgi?id=779319
Jan Schmidt [Fri, 28 Oct 2016 12:37:51 +0000 (23:37 +1100)]
orcx86: use HAVE_AMD64 and HAVE_I386 defines everywhere
Some places were checking for __amd64__ and __i386__ explicitly,
but MSVC doesn't define __amd64__ in 64-bit mode, so use the
define from config.h instead. Fixes incorrect asm generation
on 64-bit Windows
Sebastian Dröge [Wed, 31 Aug 2016 10:13:29 +0000 (13:13 +0300)]
Back to development
Sebastian Dröge [Wed, 31 Aug 2016 10:13:04 +0000 (13:13 +0300)]
Release 0.4.26
Josep Torra [Thu, 25 Aug 2016 13:45:57 +0000 (15:45 +0200)]
pkgconfig: add orc-test path to the -uninstalled .pc file
Expose orc-test library in the uninstalled pkgconfig file.
Wim Taymans [Wed, 24 Aug 2016 08:10:09 +0000 (10:10 +0200)]
use 64bit arithmetic to increment the stride
Fixes https://bugzilla.gnome.org/show_bug.cgi?id=770295
Sebastian Dröge [Wed, 24 Aug 2016 16:11:18 +0000 (19:11 +0300)]
orcx86: Fix generation of ModR/M / SIB bytes for the EBP, R12, R13 registers
See http://wiki.osdev.org/X86-64_Instruction_Encoding#ModR.2FM
ESP and R12 are to be handled exactly the same, that is the addressing is
done with SIB instead of directly.
EBP and R13 have a special case for Mod 00, where they're expecting RIP/EIP
plus 32 bit displacement. If we handle them like all other registers, we would
instead of addressing offset 0, address something relative to the instruction
pointer and make part of the following instruction the 32 bit displacement.
Instead of using Mod 00 for offset 0 like for all other registers, we use Mod
01 and a 8 bit displacement of 0.
On Windows this rather low-level bug caused problems at a rather
high-level in the ORC video conversion code, where a movdqu was eating the
following paddw instruction and tried to load data from a rather random memory
location.
For whatever reason this didn't cause any other big problems in other ORC
generated code, and it also only seemed to have caused problems on Windows.
https://bugzilla.gnome.org/show_bug.cgi?id=765713
Josep Torra [Sun, 24 Jul 2016 16:09:50 +0000 (18:09 +0200)]
tests: fix a warning spotted when building in osx
orctest.c:730:19: error: logical not is only applied to the left hand side of this comparison
if (!float_compare (dest_emul[l-ORC_VAR_D1], dest_exec[l-ORC_VAR_D1], i, j) != 0) {
It seems some sort of typo. Fixing by removing the potentially leftover condition.
Pascal Terjan [Wed, 4 May 2016 09:36:21 +0000 (09:36 +0000)]
Fix test_parse with no executable backend
https://bugzilla.gnome.org/show_bug.cgi?id=765953
Tim-Philipp Müller [Sat, 5 Mar 2016 00:32:19 +0000 (00:32 +0000)]
Back to development
Tim-Philipp Müller [Sat, 5 Mar 2016 00:01:25 +0000 (00:01 +0000)]
Release 0.4.25
Tim-Philipp Müller [Fri, 4 Mar 2016 23:58:09 +0000 (23:58 +0000)]
configure: fix bug report url
Tim-Philipp Müller [Wed, 2 Mar 2016 19:04:35 +0000 (19:04 +0000)]
orcc: check version of liborc to make sure the right lib is being used
Interesting compilation failures might otherwise ensue.
Tim-Philipp Müller [Wed, 2 Mar 2016 19:04:24 +0000 (19:04 +0000)]
Add orc_version_string()
Julien Isorce [Thu, 18 Feb 2016 14:18:32 +0000 (14:18 +0000)]
uninstalled.pc: add support for non libtool build systems
Currently the .la path is provided which requires to use libtool as
mentioned in the GStreamer manual section-helloworld-compilerun.html.
It is fine as long as the application is built using libtool.
So currently it is not possible to compile a GStreamer application
within gst-uninstalled with CMake or other build system different
than autotools.
This patch allows to do the following in gst-uninstalled env:
gcc test.c -o test $(pkg-config --cflags --libs orc-uninstalled)
Previously it required to prepend libtool --mode=link
https://bugzilla.gnome.org/show_bug.cgi?id=720778
Luis de Bethencourt [Mon, 14 Dec 2015 16:20:18 +0000 (16:20 +0000)]
orcprogram-c: check array bound in get_varname_stride()
https://bugzilla.gnome.org/show_bug.cgi?id=759840
Luis de Bethencourt [Wed, 17 Feb 2016 15:05:49 +0000 (15:05 +0000)]
Revert "orcprogram-c: avoid running out of bounds of varnames"
This reverts commit
951091788b8496868bf86b2f853f5214659e782a.
This isn't a proper fix and the risk of bringing in a regression is too
high for the small and incomplete improvement.
Sebastian Dröge [Wed, 30 Dec 2015 18:52:58 +0000 (20:52 +0200)]
configure: Only check for Android's liblog on Android targets
https://bugzilla.gnome.org/show_bug.cgi?id=760008
Koop Mast [Sun, 20 Dec 2015 23:43:49 +0000 (00:43 +0100)]
configure: Make -Bsymbolic check work with clang.
Update the -Bsymbolic check with the version glib has. This version
works with clang.
https://bugzilla.gnome.org/show_bug.cgi?id=759713
Luis de Bethencourt [Mon, 14 Dec 2015 13:46:52 +0000 (13:46 +0000)]
orcprogram-c: avoid running out of bounds of varnames
These two for loops use varnames[i], since varname has 48 items avoid
running out of bounds by running the for loop up to that limit.
CID 1147004
Tim-Philipp Müller [Tue, 20 Oct 2015 10:28:52 +0000 (11:28 +0100)]
doc: update from entropywave locations to gstreamer
The entropywave website isn't even up any longer.
Docs have been uploaded to gstreamer website too now.
Tim-Philipp Müller [Tue, 20 Oct 2015 09:58:23 +0000 (10:58 +0100)]
doc: update generated opcode tables
Tim-Philipp Müller [Thu, 15 Oct 2015 23:05:03 +0000 (00:05 +0100)]
tools: remove unused test.orc
Tim-Philipp Müller [Thu, 15 Oct 2015 10:15:01 +0000 (11:15 +0100)]
build: fix detection of AMD Kn host cpu
Not that anyone noticed in all these years, so
the check is probably bogus.
Wim Taymans [Mon, 7 Sep 2015 13:30:36 +0000 (15:30 +0200)]
executor: fix load of parameters smaller than 64 bits
Parameters less than 64 bits are passed in just one param register.
Fixes crashes on ldresnearb and friends in emulated code.
Wim Taymans [Mon, 7 Sep 2015 11:43:55 +0000 (13:43 +0200)]
compiler: also prefer the backup function when no target
If we don't have a compiler target (like for ppc64), prefer to use the
backup function instead of doing full emulation.
Wim Taymans [Wed, 12 Aug 2015 11:16:28 +0000 (13:16 +0200)]
test-limits: improve test without target
When there is no target available, the unit test would fail with a
non-fatal error (because emulation would be done). The non-fatal error
would however not be overwritten by the real error when we exceed the
limits.
First relax the first compilation test to check for FATAL errors. Then
reset the program (and clear any non-fatal errors) before triggering
the next error.
Sebastian Dröge [Wed, 24 Jun 2015 20:26:31 +0000 (22:26 +0200)]
Back to development
Sebastian Dröge [Wed, 24 Jun 2015 20:19:53 +0000 (22:19 +0200)]
Release 0.4.24
Wim Taymans [Mon, 22 Jun 2015 14:42:58 +0000 (16:42 +0200)]
parse: increase array size
Increase the size of the array to hold our variable name and use
snprintf to avoid overflows.
Wim Taymans [Mon, 22 Jun 2015 11:13:36 +0000 (13:13 +0200)]
program: only reuse constants of the same size and value
When reusing an existing constant, make sure not only the value but also
the size is the same. We then also need to make a name based on the size
and value so that we can store the same value for different sizes.
Fixes problem with the bayer functions that used 255 as a 16 and 8 bit
constant. This was not detected in the unit test because both the backup
and asm functions do the same error, but it could be seen when a new
backup function was checked against a older ORC.
Tim-Philipp Müller [Fri, 22 May 2015 13:11:32 +0000 (14:11 +0100)]
testsuite: fix reading .orc files with win32 line endings on windows
Just read them in binary form with win32 line endings and
parse them to the orc parser as-is now that the parser
can handle win32 line endings.
Tim-Philipp Müller [Fri, 22 May 2015 12:55:46 +0000 (13:55 +0100)]
testsuite: add parsing test case for win32 line endings
Should handle \r\n as well as \n instead of relying on
the file reader to translate it.
Tim-Philipp Müller [Fri, 22 May 2015 13:07:09 +0000 (14:07 +0100)]
orcc: fix reading .orc files with win32 line endings on windows
We used to open the files in text/translation mode, which
makes fread() convert all windows-style line endings (\r\n)
to unix style line endings (\n) under the hood. However, the
file size we get from the seek is apparently still the original
binary size, and then we just get less data because the \r have
been removed. This means we put our zero terminator in the wrong
place, and there might be some junk between the end of the
text data and the zero terminator.
Fix this by reading the file in binary mode (who knows what
else the text mode might mess up or trip over, e.g. unicode
chars in comments or such) and pass it to the orc parser
as-is now that the parser can handle win32 line endings.
Spotted by Ray Molenkamp.