diff options
author | Schala | 2016-10-25 00:57:53 -0700 |
---|---|---|
committer | Schala | 2016-10-25 00:57:53 -0700 |
commit | bdd98cfe4db106c19ec10daea52ea98c2152fc8e (patch) | |
tree | 1d7be4a1fb8c14871c1def0494c6843b54afbb26 | |
parent | 56c388475f9110e41219fe770471bdb4d6e35167 (diff) | |
download | aur-bdd98cfe4db106c19ec10daea52ea98c2152fc8e.tar.gz |
5.0 and genlib build
-rw-r--r-- | .SRCINFO | 12 | ||||
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | 0001-widl-Relocate-DEFAULT_INCLUDE_DIR.patch | 768 | ||||
-rw-r--r-- | PKGBUILD | 22 | ||||
-rw-r--r-- | mingw-w64-tools-2.0.999-s390.patch | 63 |
5 files changed, 14 insertions, 852 deletions
@@ -1,8 +1,8 @@ # Generated by mksrcinfo v8 -# Sun Apr 17 20:50:00 UTC 2016 +# Tue Oct 25 07:57:16 UTC 2016 pkgbase = mingw-w64-tools pkgdesc = MinGW-w64 utilities - pkgver = 4.0.6 + pkgver = 5.0.0 pkgrel = 1 url = http://mingw-w64.sourceforge.net arch = i686 @@ -12,12 +12,8 @@ pkgbase = mingw-w64-tools license = LGPL2 options = !libtool options = !emptydirs - source = http://sourceforge.net/projects/mingw-w64/files/mingw-w64/mingw-w64-release/mingw-w64-v4.0.6.tar.bz2 - source = mingw-w64-tools-2.0.999-s390.patch - source = 0001-widl-Relocate-DEFAULT_INCLUDE_DIR.patch - md5sums = e3998f1192ea44049685059225074952 - md5sums = 85a915187d7092c659a56fca102da04c - md5sums = 4881e9b6cb7640e3542f45b88bd53a5e + source = http://sourceforge.net/projects/mingw-w64/files/mingw-w64/mingw-w64-release/mingw-w64-v5.0.0.tar.bz2 + md5sums = c9f4bb72a87d9be2cc98e0d7e1868c88 pkgname = mingw-w64-tools diff --git a/.gitignore b/.gitignore index 79ffea0ccae6..886033bef767 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,5 @@ pkg/ src/ *.bz2 +*.tar *.xz diff --git a/0001-widl-Relocate-DEFAULT_INCLUDE_DIR.patch b/0001-widl-Relocate-DEFAULT_INCLUDE_DIR.patch deleted file mode 100644 index bebdc69eb3b0..000000000000 --- a/0001-widl-Relocate-DEFAULT_INCLUDE_DIR.patch +++ /dev/null @@ -1,768 +0,0 @@ -From 807e422aeb7e6c803edd07298b693a8e72a7158f Mon Sep 17 00:00:00 2001 -From: Ray Donnelly <mingw.android@gmail.com> -Date: Sat, 18 Jul 2015 13:53:41 +0100 -Subject: [PATCH] widl: Relocate DEFAULT_INCLUDE_DIR - ---- - mingw-w64-tools/widl/Makefile.am | 6 +- - mingw-w64-tools/widl/Makefile.in | 26 +- - mingw-w64-tools/widl/include/pathtools.h | 53 +++ - mingw-w64-tools/widl/src/pathtools.c | 547 +++++++++++++++++++++++++++++++ - mingw-w64-tools/widl/src/widl.c | 14 +- - 5 files changed, 640 insertions(+), 6 deletions(-) - create mode 100644 mingw-w64-tools/widl/include/pathtools.h - create mode 100644 mingw-w64-tools/widl/src/pathtools.c - -diff --git a/mingw-w64-tools/widl/Makefile.am b/mingw-w64-tools/widl/Makefile.am -index 44013fe..1e348c7 100644 ---- a/mingw-w64-tools/widl/Makefile.am -+++ b/mingw-w64-tools/widl/Makefile.am -@@ -36,6 +36,7 @@ widl_SOURCES = src/widl.h \ - src/wpp/ppy.tab.c \ - src/wpp/preproc.c \ - src/wpp/wpp.c \ -+ src/pathtools.c \ - include/pshpack1.h \ - include/pshpack2.h \ - include/winbase.h \ -@@ -54,9 +55,10 @@ widl_SOURCES = src/widl.h \ - include/pshpack4.h \ - include/winnt.h \ - include/winnls.h \ -+ include/pathtools.h \ - include/winnt.rh - --widl_CPPFLAGS = -I$(top_srcdir)/include -DDEFAULT_INCLUDE_DIR=\"$(includedir)/../$(target)/include\" --widl_CFLAGS = -O3 -g -Wall -Wformat -Wpacked -Wmissing-declarations -Wimplicit-function-declaration -Wmissing-prototypes -Wstrict-aliasing=2 -+widl_CPPFLAGS = -I$(top_srcdir)/include -DDEFAULT_INCLUDE_DIR=\"$(includedir)/../$(target)/include\" -DDEFAULT_BINDIR=\"$(bindir)\" -+widl_CFLAGS = -Wall -Wformat -Wpacked -Wmissing-declarations -Wimplicit-function-declaration -Wmissing-prototypes -Wstrict-aliasing=2 - - DISTCHECK_CONFIGURE_FLAGS = --host=$(host) --target=$(target) -diff --git a/mingw-w64-tools/widl/Makefile.in b/mingw-w64-tools/widl/Makefile.in -index 013ccf0..d76c66c 100644 ---- a/mingw-w64-tools/widl/Makefile.in -+++ b/mingw-w64-tools/widl/Makefile.in -@@ -85,7 +85,8 @@ am_widl_OBJECTS = src/widl-client.$(OBJEXT) src/widl-expr.$(OBJEXT) \ - src/widl-typetree.$(OBJEXT) src/widl-utils.$(OBJEXT) \ - src/widl-widl.$(OBJEXT) src/widl-write_msft.$(OBJEXT) \ - src/wpp/widl-ppl.yy.$(OBJEXT) src/wpp/widl-ppy.tab.$(OBJEXT) \ -- src/wpp/widl-preproc.$(OBJEXT) src/wpp/widl-wpp.$(OBJEXT) -+ src/wpp/widl-preproc.$(OBJEXT) src/wpp/widl-wpp.$(OBJEXT) \ -+ src/widl-pathtools.$(OBJEXT) - widl_OBJECTS = $(am_widl_OBJECTS) - widl_LDADD = $(LDADD) - widl_LINK = $(CCLD) $(widl_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) \ -@@ -262,6 +263,7 @@ widl_SOURCES = src/widl.h \ - src/wpp/ppy.tab.c \ - src/wpp/preproc.c \ - src/wpp/wpp.c \ -+ src/pathtools.c \ - include/pshpack1.h \ - include/pshpack2.h \ - include/winbase.h \ -@@ -280,10 +282,11 @@ widl_SOURCES = src/widl.h \ - include/pshpack4.h \ - include/winnt.h \ - include/winnls.h \ -+ include/pathtools.h \ - include/winnt.rh - --widl_CPPFLAGS = -I$(top_srcdir)/include -DDEFAULT_INCLUDE_DIR=\"$(includedir)/../$(target)/include\" --widl_CFLAGS = -O3 -g -Wall -Wformat -Wpacked -Wmissing-declarations -Wimplicit-function-declaration -Wmissing-prototypes -Wstrict-aliasing=2 -+widl_CPPFLAGS = -I$(top_srcdir)/include -DDEFAULT_INCLUDE_DIR=\"$(includedir)/../$(target)/include\" -DDEFAULT_BINDIR=\"$(bindir)\" -+widl_CFLAGS = -Wall -Wformat -Wpacked -Wmissing-declarations -Wimplicit-function-declaration -Wmissing-prototypes -Wstrict-aliasing=2 - DISTCHECK_CONFIGURE_FLAGS = --host=$(host) --target=$(target) - all: all-am - -@@ -440,6 +443,8 @@ src/wpp/widl-preproc.$(OBJEXT): src/wpp/$(am__dirstamp) \ - src/wpp/$(DEPDIR)/$(am__dirstamp) - src/wpp/widl-wpp.$(OBJEXT): src/wpp/$(am__dirstamp) \ - src/wpp/$(DEPDIR)/$(am__dirstamp) -+src/widl-pathtools.$(OBJEXT): src/$(am__dirstamp) \ -+ src/$(DEPDIR)/$(am__dirstamp) - widl$(EXEEXT): $(widl_OBJECTS) $(widl_DEPENDENCIES) $(EXTRA_widl_DEPENDENCIES) - @rm -f widl$(EXEEXT) - $(widl_LINK) $(widl_OBJECTS) $(widl_LDADD) $(LIBS) -@@ -459,6 +464,7 @@ distclean-compile: - @AMDEP_TRUE@@am__include@ @am__quote@src/$(DEPDIR)/widl-header.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@src/$(DEPDIR)/widl-parser.tab.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@src/$(DEPDIR)/widl-parser.yy.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@src/$(DEPDIR)/widl-pathtools.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@src/$(DEPDIR)/widl-proxy.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@src/$(DEPDIR)/widl-register.Po@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@src/$(DEPDIR)/widl-server.Po@am__quote@ -@@ -800,6 +806,20 @@ src/wpp/widl-wpp.obj: src/wpp/wpp.c - @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ - @am__fastdepCC_FALSE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(widl_CPPFLAGS) $(CPPFLAGS) $(widl_CFLAGS) $(CFLAGS) -c -o src/wpp/widl-wpp.obj `if test -f 'src/wpp/wpp.c'; then $(CYGPATH_W) 'src/wpp/wpp.c'; else $(CYGPATH_W) '$(srcdir)/src/wpp/wpp.c'; fi` - -+src/widl-pathtools.o: src/pathtools.c -+@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(widl_CPPFLAGS) $(CPPFLAGS) $(widl_CFLAGS) $(CFLAGS) -MT src/widl-pathtools.o -MD -MP -MF src/$(DEPDIR)/widl-pathtools.Tpo -c -o src/widl-pathtools.o `test -f 'src/pathtools.c' || echo '$(srcdir)/'`src/pathtools.c -+@am__fastdepCC_TRUE@ $(am__mv) src/$(DEPDIR)/widl-pathtools.Tpo src/$(DEPDIR)/widl-pathtools.Po -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='src/pathtools.c' object='src/widl-pathtools.o' libtool=no @AMDEPBACKSLASH@ -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -+@am__fastdepCC_FALSE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(widl_CPPFLAGS) $(CPPFLAGS) $(widl_CFLAGS) $(CFLAGS) -c -o src/widl-pathtools.o `test -f 'src/pathtools.c' || echo '$(srcdir)/'`src/pathtools.c -+ -+src/widl-pathtools.obj: src/pathtools.c -+@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(widl_CPPFLAGS) $(CPPFLAGS) $(widl_CFLAGS) $(CFLAGS) -MT src/widl-pathtools.obj -MD -MP -MF src/$(DEPDIR)/widl-pathtools.Tpo -c -o src/widl-pathtools.obj `if test -f 'src/pathtools.c'; then $(CYGPATH_W) 'src/pathtools.c'; else $(CYGPATH_W) '$(srcdir)/src/pathtools.c'; fi` -+@am__fastdepCC_TRUE@ $(am__mv) src/$(DEPDIR)/widl-pathtools.Tpo src/$(DEPDIR)/widl-pathtools.Po -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='src/pathtools.c' object='src/widl-pathtools.obj' libtool=no @AMDEPBACKSLASH@ -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -+@am__fastdepCC_FALSE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(widl_CPPFLAGS) $(CPPFLAGS) $(widl_CFLAGS) $(CFLAGS) -c -o src/widl-pathtools.obj `if test -f 'src/pathtools.c'; then $(CYGPATH_W) 'src/pathtools.c'; else $(CYGPATH_W) '$(srcdir)/src/pathtools.c'; fi` -+ - ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) - list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ - unique=`for i in $$list; do \ -diff --git a/mingw-w64-tools/widl/include/pathtools.h b/mingw-w64-tools/widl/include/pathtools.h -new file mode 100644 -index 0000000..139b7c2 ---- /dev/null -+++ b/mingw-w64-tools/widl/include/pathtools.h -@@ -0,0 +1,53 @@ -+/* -+ .Some useful path tools. -+ .ASCII only for now. -+ .Written by Ray Donnelly in 2014. -+ .Licensed under CC0 (and anything. -+ .else you need to license it under). -+ .No warranties whatsoever. -+ .email: <mingw.android@gmail.com>. -+ */ -+ -+#ifndef PATHTOOLS_H -+#define PATHTOOLS_H -+ -+#include <unistd.h> -+#if defined(__APPLE__) -+#include <stdlib.h> -+#else -+#include <malloc.h> -+#endif -+#include <stdio.h> -+ -+char * malloc_copy_string(char const * original); -+ -+/* In-place replaces any '\' with '/' and any '//' with '/' */ -+void sanitise_path(char * path); -+ -+/* Uses a host OS specific function to determine the path of the executable, -+ if IMPLEMENT_SYS_GET_EXECUTABLE_PATH is defined, otherwise uses argv0. */ -+int get_executable_path(char const * argv0, char * result, ssize_t max_size); -+ -+/* Where possible, in-place removes occourances of '.' and 'path/..' */ -+void simplify_path(char * path); -+ -+/* Allocates (via malloc) and returns the path to get from from to to. */ -+char * get_relative_path(char const * from, char const * to); -+ -+size_t split_path_list(char const * path_list, char split_char, char *** arr); -+ -+/* Advances path along by the amount that removes n prefix folders. */ -+char const * -+strip_n_prefix_folders(char const * path, size_t n); -+ -+/* NULL terminates path to remove n suffix folders. */ -+void -+strip_n_suffix_folders(char * path, size_t n); -+ -+char const * get_relocated_path (char const * from, char const * to, char const * actual_from); -+char * get_relocated_path_list(char const * from, char const * to_path_list); -+ -+char * single_path_relocation(const char *from, const char *to); -+char * pathlist_relocation(const char *from_path, const char *to_path_list); -+ -+#endif /* PATHTOOLS_H */ -diff --git a/mingw-w64-tools/widl/src/pathtools.c b/mingw-w64-tools/widl/src/pathtools.c -new file mode 100644 -index 0000000..d150cd3 ---- /dev/null -+++ b/mingw-w64-tools/widl/src/pathtools.c -@@ -0,0 +1,547 @@ -+/* -+ .Some useful path tools. -+ .ASCII only for now. -+ .Written by Ray Donnelly in 2014. -+ .Licensed under CC0 (and anything. -+ .else you need to license it under). -+ .No warranties whatsoever. -+ .email: <mingw.android@gmail.com>. -+ */ -+ -+#if defined(__APPLE__) -+#include <stdlib.h> -+#else -+#include <malloc.h> -+#endif -+#include <limits.h> -+#include <stdio.h> -+#include <string.h> -+#if defined(__linux__) || defined(__CYGWIN__) || defined(__MSYS__) -+#include <alloca.h> -+#endif -+#include <unistd.h> -+ -+/* If you don't define this, then get_executable_path() -+ can only use argv[0] which will often not work well */ -+#define IMPLEMENT_SYS_GET_EXECUTABLE_PATH -+ -+#if defined(IMPLEMENT_SYS_GET_EXECUTABLE_PATH) -+#if defined(__linux__) || defined(__CYGWIN__) || defined(__MSYS__) -+/* Nothing needed, unistd.h is enough. */ -+#elif defined(__APPLE__) -+#include <mach-o/dyld.h> -+#elif defined(_WIN32) -+// widl can't include the normal Windows headers due to providing its own winnt.h (and others). -+#ifdef __x86_64__ -+__attribute__((dllimport)) long GetModuleFileNameA (long hModule, void* lpFilename, long nSize); -+#else -+__attribute__((dllimport)) long __attribute__((__stdcall__)) GetModuleFileNameA (long hModule, void* lpFilename, long nSize); -+#endif -+#endif -+#else -+#define PATH_MAX 260 -+#endif /* defined(IMPLEMENT_SYS_GET_EXECUTABLE_PATH) */ -+ -+#include "pathtools.h" -+ -+char * -+malloc_copy_string(char const * original) -+{ -+ char * result = (char *) malloc (sizeof (char*) * strlen (original)+1); -+ if (result != NULL) -+ { -+ strcpy (result, original); -+ } -+ return result; -+} -+ -+void -+sanitise_path(char * path) -+{ -+ size_t path_size = strlen (path); -+ -+ /* Replace any '\' with '/' */ -+ char * path_p = path; -+ while ((path_p = strchr (path_p, '\\')) != NULL) -+ { -+ *path_p = '/'; -+ } -+ /* Replace any '//' with '/' */ -+ path_p = path; -+ while ((path_p = strstr (path_p, "//")) != NULL) -+ { -+ memmove (path_p, path_p + 1, path_size--); -+ } -+ return; -+} -+ -+char * -+get_relative_path(char const * from_in, char const * to_in) -+{ -+ size_t from_size = (from_in == NULL) ? 0 : strlen (from_in); -+ size_t to_size = (to_in == NULL) ? 0 : strlen (to_in); -+ size_t max_size = (from_size + to_size) * 2 + 4; -+ char * scratch_space = (char *) alloca (from_size + 1 + to_size + 1 + max_size + max_size); -+ char * from; -+ char * to; -+ char * common_part; -+ char * result; -+ size_t count; -+ -+ /* No to, return "./" */ -+ if (to_in == NULL) -+ { -+ return malloc_copy_string ("./"); -+ } -+ -+ /* If alloca failed or no from was given return a copy of to */ -+ if ( from_in == NULL -+ || scratch_space == NULL ) -+ { -+ return malloc_copy_string (to_in); -+ } -+ -+ from = scratch_space; -+ strcpy (from, from_in); -+ to = from + from_size + 1; -+ strcpy (to, to_in); -+ common_part = to + to_size + 1; -+ result = common_part + max_size; -+ simplify_path (from); -+ simplify_path (to); -+ -+ result[0] = '\0'; -+ -+ size_t match_size_dirsep = 0; /* The match size up to the last /. Always wind back to this - 1 */ -+ size_t match_size = 0; /* The running (and final) match size. */ -+ size_t largest_size = (from_size > to_size) ? from_size : to_size; -+ int to_final_is_slash = (to[to_size-1] == '/') ? 1 : 0; -+ char from_c; -+ char to_c; -+ for (match_size = 0; match_size < largest_size; ++match_size) -+ { -+ /* To simplify the logic, always pretend the strings end with '/' */ -+ from_c = (match_size < from_size) ? from[match_size] : '/'; -+ to_c = (match_size < to_size) ? to[match_size] : '/'; -+ -+ if (from_c != to_c) -+ { -+ if (from_c != '\0' || to_c != '\0') -+ { -+ match_size = match_size_dirsep; -+ } -+ break; -+ } -+ else if (from_c == '/') -+ { -+ match_size_dirsep = match_size; -+ } -+ } -+ strncpy (common_part, from, match_size); -+ common_part[match_size] = '\0'; -+ from += match_size; -+ to += match_size; -+ size_t ndotdots = 0; -+ char const* from_last = from + strlen(from) - 1; -+ while ((from = strchr (from, '/')) && from != from_last) -+ { -+ ++ndotdots; -+ ++from; -+ } -+ for (count = 0; count < ndotdots; ++count) -+ { -+ strcat(result, "../"); -+ } -+ if (strlen(to) > 0) -+ { -+ strcat(result, to+1); -+ } -+ /* Make sure that if to ends with '/' result does the same, and -+ vice-versa. */ -+ size_t size_result = strlen(result); -+ if ((to_final_is_slash == 1) -+ && (!size_result || result[size_result-1] != '/')) -+ { -+ strcat (result, "/"); -+ } -+ else if (!to_final_is_slash -+ && size_result && result[size_result-1] == '/') -+ { -+ result[size_result-1] = '\0'; -+ } -+ -+ return malloc_copy_string (result); -+} -+ -+void -+simplify_path(char * path) -+{ -+ ssize_t n_toks = 1; /* in-case we need an empty initial token. */ -+ ssize_t i, j; -+ size_t tok_size; -+ size_t in_size = strlen (path); -+ int it_ended_with_a_slash = (path[in_size - 1] == '/') ? 1 : 0; -+ char * result = path; -+ sanitise_path(result); -+ char * result_p = result; -+ -+ do -+ { -+ ++n_toks; -+ ++result_p; -+ } while ((result_p = strchr (result_p, '/')) != NULL); -+ -+ result_p = result; -+ char const ** toks = (char const **) alloca (sizeof (char const*) * n_toks); -+ n_toks = 0; -+ do -+ { -+ if (result_p > result) -+ { -+ *result_p++ = '\0'; -+ } -+ else if (*result_p == '/') -+ { -+ /* A leading / creates an empty initial token. */ -+ toks[n_toks++] = result_p; -+ *result_p++ = '\0'; -+ } -+ toks[n_toks++] = result_p; -+ } while ((result_p = strchr (result_p, '/')) != NULL); -+ -+ /* Remove all non-leading '.' and any '..' we can match -+ with an earlier forward path (i.e. neither '.' nor '..') */ -+ for (i = 1; i < n_toks; ++i) -+ { -+ int removals[2] = { -1, -1 }; -+ if ( strcmp (toks[i], "." ) == 0) -+ { -+ removals[0] = i; -+ } -+ else if ( strcmp (toks[i], ".." ) == 0) -+ { -+ /* Search backwards for a forward path to collapse. -+ If none are found then the .. also stays. */ -+ for (j = i - 1; j > -1; --j) -+ { -+ if ( strcmp (toks[j], "." ) -+ && strcmp (toks[j], ".." ) ) -+ { -+ removals[0] = j; -+ removals[1] = i; -+ break; -+ } -+ } -+ } -+ for (j = 0; j < 2; ++j) -+ { -+ if (removals[j] >= 0) /* Can become -2 */ -+ { -+ --n_toks; -+ memmove (&toks[removals[j]], &toks[removals[j]+1], (n_toks - removals[j])*sizeof (char*)); -+ --i; -+ if (!j) -+ { -+ --removals[1]; -+ } -+ } -+ } -+ } -+ result_p = result; -+ for (i = 0; i < n_toks; ++i) -+ { -+ tok_size = strlen(toks[i]); -+ memcpy (result_p, toks[i], tok_size); -+ result_p += tok_size; -+ if ((!i || tok_size) && ((i < n_toks - 1) || it_ended_with_a_slash == 1)) -+ { -+ *result_p = '/'; -+ ++result_p; -+ } -+ } -+ *result_p = '\0'; -+} -+ -+/* Returns actual_to by calculating the relative path from -> to and -+ applying that to actual_from. An assumption that actual_from is a -+ dir is made, and it may or may not end with a '/' */ -+char const * -+get_relocated_path (char const * from, char const * to, char const * actual_from) -+{ -+ char const * relative_from_to = get_relative_path (from, to); -+ char * actual_to = (char *) malloc (strlen(actual_from) + 2 + strlen(relative_from_to)); -+ return actual_to; -+} -+ -+int -+get_executable_path(char const * argv0, char * result, ssize_t max_size) -+{ -+ char * system_result = (char *) alloca (max_size); -+ ssize_t system_result_size = -1; -+ ssize_t result_size = -1; -+ -+ if (system_result != NULL) -+ { -+#if defined(IMPLEMENT_SYS_GET_EXECUTABLE_PATH) -+#if defined(__linux__) || defined(__CYGWIN__) || defined(__MSYS__) -+ system_result_size = readlink("/proc/self/exe", system_result, max_size); -+#elif defined(__APPLE__) -+ uint32_t bufsize = (uint32_t)max_size; -+ if (_NSGetExecutablePath(system_result, &bufsize) == 0) -+ { -+ system_result_size = (ssize_t)bufsize; -+ } -+#elif defined(_WIN32) -+ unsigned long bufsize = (unsigned long)max_size; -+ system_result_size = GetModuleFileNameA(0, system_result, bufsize); -+ if (system_result_size == 0 || system_result_size == (ssize_t)bufsize) -+ { -+ /* Error, possibly not enough space. */ -+ system_result_size = -1; -+ } -+ else -+ { -+ /* Early conversion to unix slashes instead of more changes -+ everywhere else .. */ -+ char * winslash; -+ system_result[system_result_size] = '\0'; -+ while ((winslash = strchr (system_result, '\\')) != NULL) -+ { -+ *winslash = '/'; -+ } -+ } -+#else -+#warning "Don't know how to get executable path on this system" -+#endif -+#endif /* defined(IMPLEMENT_SYS_GET_EXECUTABLE_PATH) */ -+ } -+ /* Use argv0 as a default in-case of failure */ -+ if (system_result_size != -1) -+ { -+ strncpy (result, system_result, system_result_size); -+ result[system_result_size] = '\0'; -+ } -+ else -+ { -+ if (argv0 != NULL) -+ { -+ strncpy (result, argv0, max_size); -+ char *slash; -+ while ((slash = strchr(result, '\\')) != NULL) { -+ *slash++ = '/'; -+ } -+ result[max_size-1] = '\0'; -+ } -+ else -+ { -+ result[0] = '\0'; -+ } -+ } -+ result_size = strlen (result); -+ return result_size; -+} -+ -+char const * -+strip_n_prefix_folders(char const * path, size_t n) -+{ -+ if (path == NULL) -+ { -+ return NULL; -+ } -+ -+ if (path[0] != '/') -+ { -+ return path; -+ } -+ -+ char const * last = path; -+ while (n-- && path != NULL) -+ { -+ last = path; -+ path = strchr (path + 1, '/'); -+ } -+ return (path == NULL) ? last : path; -+} -+ -+void -+strip_n_suffix_folders(char * path, size_t n) -+{ -+ if (path == NULL) -+ { -+ return; -+ } -+ while (n--) -+ { -+ if (strrchr (path + 1, '/')) -+ { -+ *strrchr (path + 1, '/') = '\0'; -+ } -+ else -+ { -+ return; -+ } -+ } -+ return; -+} -+ -+size_t -+split_path_list(char const * path_list, char split_char, char *** arr) -+{ -+ size_t path_count; -+ size_t path_list_size; -+ char const * path_list_p; -+ -+ path_list_p = path_list; -+ if (path_list == NULL || path_list[0] == '\0') -+ { -+ return 0; -+ } -+ path_list_size = strlen (path_list); -+ -+ path_count = 0; -+ do -+ { -+ ++path_count; -+ ++path_list_p; -+ } -+ while ((path_list_p = strchr (path_list_p, split_char)) != NULL); -+ -+ /* allocate everything in one go. */ -+ char * all_memory = (char *) malloc (sizeof (char *) * path_count + strlen(path_list) + 1); -+ if (all_memory == NULL) -+ return 0; -+ *arr = (char **)all_memory; -+ all_memory += sizeof (char *) * path_count; -+ -+ path_count = 0; -+ path_list_p = path_list; -+ char const * next_path_list_p = 0; -+ do -+ { -+ next_path_list_p = strchr (path_list_p, split_char); -+ if (next_path_list_p != NULL) -+ { -+ ++next_path_list_p; -+ } -+ size_t this_size = (next_path_list_p != NULL) -+ ? next_path_list_p - path_list_p - 1 -+ : &path_list[path_list_size] - path_list_p; -+ memcpy (all_memory, path_list_p, this_size); -+ all_memory[this_size] = '\0'; -+ (*arr)[path_count++] = all_memory; -+ all_memory += this_size + 1; -+ } while ((path_list_p = next_path_list_p) != NULL); -+ -+ return path_count; -+} -+ -+char * -+get_relocated_path_list(char const * from, char const * to_path_list) -+{ -+ char exe_path[PATH_MAX]; -+ char * temp; -+ get_executable_path (NULL, &exe_path[0], sizeof (exe_path) / sizeof (exe_path[0])); -+ if ((temp = strrchr (exe_path, '/')) != NULL) -+ { -+ temp[1] = '\0'; -+ } -+ -+ char **arr = NULL; -+ /* Ask Alexey why he added this. Are we not 100% sure -+ that we're dealing with unix paths here? */ -+ char split_char = ':'; -+ if (strchr (to_path_list, ';')) -+ { -+ split_char = ';'; -+ } -+ size_t count = split_path_list (to_path_list, split_char, &arr); -+ int result_size = 1 + (count - 1); /* count - 1 is for ; delim. */ -+ size_t exe_path_size = strlen (exe_path); -+ size_t i; -+ /* Space required is: -+ count * (exe_path_size + strlen (rel_to_datadir)) -+ rel_to_datadir upper bound is: -+ (count * strlen (from)) + (3 * num_slashes (from)) -+ + strlen(arr[i]) + 1. -+ .. pathalogically num_slashes (from) is strlen (from) -+ (from = ////////) */ -+ size_t space_required = (count * (exe_path_size + 4 * strlen (from))) + count - 1; -+ for (i = 0; i < count; ++i) -+ { -+ space_required += strlen (arr[i]); -+ } -+ char * scratch = (char *) alloca (space_required); -+ if (scratch == NULL) -+ return NULL; -+ for (i = 0; i < count; ++i) -+ { -+ char * rel_to_datadir = get_relative_path (from, arr[i]); -+ scratch[0] = '\0'; -+ arr[i] = scratch; -+ strcat (scratch, exe_path); -+ strcat (scratch, rel_to_datadir); -+ simplify_path (arr[i]); -+ size_t arr_i_size = strlen (arr[i]); -+ result_size += arr_i_size; -+ scratch = arr[i] + arr_i_size + 1; -+ } -+ char * result = (char *) malloc (result_size); -+ if (result == NULL) -+ { -+ return NULL; -+ } -+ result[0] = '\0'; -+ for (i = 0; i < count; ++i) -+ { -+ strcat (result, arr[i]); -+ if (i != count-1) -+ { -+#if defined(_WIN32) -+ strcat (result, ";"); -+#else -+ strcat (result, ":"); -+#endif -+ } -+ } -+ free ((void*)arr); -+ return result; -+} -+ -+char * -+single_path_relocation(const char *from, const char *to) -+{ -+#if defined(__MINGW32__) -+ char exe_path[PATH_MAX]; -+ get_executable_path (NULL, &exe_path[0], sizeof(exe_path)/sizeof(exe_path[0])); -+ if (strrchr (exe_path, '/') != NULL) -+ { -+ strrchr (exe_path, '/')[1] = '\0'; -+ } -+ char * rel_to_datadir = get_relative_path (from, to); -+ strcat (exe_path, rel_to_datadir); -+ simplify_path (&exe_path[0]); -+ return malloc_copy_string(exe_path); -+#else -+ return malloc_copy_string(to); -+#endif -+} -+ -+char * -+pathlist_relocation(const char *from_path, const char *to_path_list) -+{ -+#if defined(__MINGW32__) -+ static char stored_path[PATH_MAX]; -+ static int stored = 0; -+ if (stored == 0) -+ { -+ char const * relocated = get_relocated_path_list(from_path, to_path_list); -+ strncpy (stored_path, relocated, PATH_MAX); -+ stored_path[PATH_MAX-1] = '\0'; -+ free ((void *)relocated); -+ stored = 1; -+ } -+ return stored_path; -+#else -+ return (to_path_list); -+#endif -+} -diff --git a/mingw-w64-tools/widl/src/widl.c b/mingw-w64-tools/widl/src/widl.c -index dfe2341..51186d1 100644 ---- a/mingw-w64-tools/widl/src/widl.c -+++ b/mingw-w64-tools/widl/src/widl.c -@@ -42,6 +42,7 @@ - #include "parser.h" - #include "wine/wpp.h" - #include "header.h" -+#include "pathtools.h" - - /* future options to reserve characters for: */ - /* A = ACF input filename */ -@@ -540,6 +541,7 @@ int main(int argc,char *argv[]) - int opti = 0; - char *output_name = NULL; - -+ - signal( SIGTERM, exit_on_signal ); - signal( SIGINT, exit_on_signal ); - #ifdef SIGHUP -@@ -695,7 +697,17 @@ int main(int argc,char *argv[]) - } - - #ifdef DEFAULT_INCLUDE_DIR -- wpp_add_include_path(DEFAULT_INCLUDE_DIR); -+ char exe_path[PATH_MAX]; -+ get_executable_path (argv[0], &exe_path[0], sizeof (exe_path) / sizeof (exe_path[0])); -+ char * rel_to_includedir = get_relative_path (DEFAULT_BINDIR, DEFAULT_INCLUDE_DIR); -+ if (strrchr (exe_path, '/') != NULL) { -+ strrchr (exe_path, '/')[1] = '\0'; -+ } -+ char relocated_default_include_dir[PATH_MAX]; -+ strcpy (relocated_default_include_dir, exe_path); -+ strcat (relocated_default_include_dir, rel_to_includedir); -+ simplify_path (&relocated_default_include_dir[0]); -+ wpp_add_include_path(relocated_default_include_dir); - #endif - - /* if nothing specified, try to guess output type from the output file name */ --- -2.4.5 - @@ -1,5 +1,5 @@ pkgname=mingw-w64-tools -pkgver=4.0.6 +pkgver=5.0.0 _pkgver=${pkgver/rc/-rc} pkgrel=1 pkgdesc="MinGW-w64 utilities" @@ -8,21 +8,11 @@ url="http://mingw-w64.sourceforge.net" license=("GPL3" "LGPL2") groups=(mingw-w64) options=(!libtool !emptydirs) -source=("http://sourceforge.net/projects/mingw-w64/files/mingw-w64/mingw-w64-release/mingw-w64-v${_pkgver}.tar.bz2" -"mingw-w64-tools-2.0.999-s390.patch" -"0001-widl-Relocate-DEFAULT_INCLUDE_DIR.patch") -md5sums=('e3998f1192ea44049685059225074952' - '85a915187d7092c659a56fca102da04c' - '4881e9b6cb7640e3542f45b88bd53a5e') +source=("http://sourceforge.net/projects/mingw-w64/files/mingw-w64/mingw-w64-release/mingw-w64-v${_pkgver}.tar.bz2") +md5sums=('c9f4bb72a87d9be2cc98e0d7e1868c88') _architectures="i686-w64-mingw32 x86_64-w64-mingw32" -prepare() { - cd "${srcdir}/mingw-w64-v$_pkgver" - patch -p2 -i ../mingw-w64-tools-2.0.999-s390.patch - patch -p1 -i ../0001-widl-Relocate-DEFAULT_INCLUDE_DIR.patch -} - build() { cd "${srcdir}" mkdir -p "${srcdir}"/gendef-build && cd "${srcdir}"/gendef-build @@ -31,6 +21,9 @@ build() { mkdir -p "${srcdir}"/genidl-build && cd "${srcdir}"/genidl-build "${srcdir}"/mingw-w64-v${_pkgver}/mingw-w64-tools/genidl/configure --prefix=/usr make + mkdir -p "${srcdir}"/genlib-build && cd "${srcdir}"/genlib-build + "${srcdir}"/mingw-w64-v${_pkgver}/mingw-w64-tools/genlib/configure --prefix=/usr + make mkdir -p "${srcdir}"/genpeimg-build && cd "${srcdir}"/genpeimg-build "${srcdir}"/mingw-w64-v${_pkgver}/mingw-w64-tools/genpeimg/configure --prefix=/usr make @@ -47,6 +40,8 @@ package() { make DESTDIR="${pkgdir}" install cd ../genidl-build make DESTDIR="${pkgdir}" install + cd ../genlib-build + make DESTDIR="${pkgdir}" install cd ../genpeimg-build make DESTDIR="${pkgdir}" install for _arch in ${_architectures}; do @@ -55,6 +50,7 @@ package() { done install -Dm644 "${srcdir}/mingw-w64-v${_pkgver}/mingw-w64-tools/gendef/COPYING" "${pkgdir}/usr/share/licenses/${pkgname}/COPYING.gendef" install -m644 "${srcdir}/mingw-w64-v${_pkgver}/mingw-w64-tools/genidl/COPYING" "${pkgdir}/usr/share/licenses/${pkgname}/COPYING.genidl" + install -m644 "${srcdir}/mingw-w64-v${_pkgver}/mingw-w64-tools/genlib/COPYING" "${pkgdir}/usr/share/licenses/${pkgname}/COPYING.genlib" install -m644 "${srcdir}/mingw-w64-v${_pkgver}/mingw-w64-tools/genpeimg/COPYING" "${pkgdir}/usr/share/licenses/${pkgname}/COPYING.genpeimg" } diff --git a/mingw-w64-tools-2.0.999-s390.patch b/mingw-w64-tools-2.0.999-s390.patch deleted file mode 100644 index 06c5926657fc..000000000000 --- a/mingw-w64-tools-2.0.999-s390.patch +++ /dev/null @@ -1,63 +0,0 @@ -diff -up mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/basetsd.h.s390 mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/basetsd.h ---- mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/basetsd.h.s390 2012-01-24 11:11:33.000000000 +0100 -+++ mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/basetsd.h 2012-03-28 14:18:17.000000000 +0200 -@@ -36,7 +36,7 @@ - * 64-bit. - */ - --#if (defined(__x86_64__) || defined(__powerpc64__) || defined(__sparc64__) || defined(__aarch64__)) && !defined(_WIN64) -+#if (defined(__x86_64__) || defined(__powerpc64__) || defined(__sparc64__) || defined(__aarch64__) || defined(__s390x__)) && !defined(_WIN64) - #define _WIN64 - #endif - -@@ -305,6 +305,10 @@ typedef ULONG_PTR KAFFINITY, *PKAFFINITY - # undef WORDS_BIGENDIAN - # undef BITFIELDS_BIGENDIAN - # undef ALLOW_UNALIGNED_ACCESS -+#elif defined(__s390__) -+# define WORDS_BIGENDIAN -+# define BITFIELDS_BIGENDIAN -+# define ALLOW_UNALIGNED_ACCESS - #elif !defined(RC_INVOKED) && !defined(__WIDL__) && !defined(__midl) - # error Unknown CPU architecture! - #endif -diff -up mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/winnt.h.s390 mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/winnt.h ---- mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/winnt.h.s390 2012-01-24 11:11:33.000000000 +0100 -+++ mingw-w64-v2.0.999/mingw/mingw-w64-tools/widl/include/winnt.h 2012-03-28 14:20:07.000000000 +0200 -@@ -1910,6 +1910,36 @@ typedef struct _CONTEXT - - #endif /* __powerpc__ */ - -+#ifdef __s390__ -+ -+/* -+ * FIXME: -+ * -+ * There is no official CONTEXT structure defined for the S/390 -+ * architecture, so I just made one up. -+ * -+ * This structure is completely dummy, made just to build widl. -+ * -+ */ -+ -+#define CONTEXT_S390 0x10000000 -+ -+#define CONTEXT_CONTROL (CONTEXT_S390 | 0x00000001) -+#define CONTEXT_FLOATING_POINT (CONTEXT_S390 | 0x00000002) -+#define CONTEXT_INTEGER (CONTEXT_S390 | 0x00000004) -+ -+#define CONTEXT_FULL (CONTEXT_CONTROL | CONTEXT_FLOATING_POINT | CONTEXT_INTEGER) -+ -+#define EXCEPTION_READ_FAULT 0 -+#define EXCEPTION_WRITE_FAULT 1 -+#define EXCEPTION_EXECUTE_FAULT 8 -+ -+typedef struct _CONTEXT -+{ -+} CONTEXT; -+ -+#endif /* __s390__ */ -+ - #if !defined(CONTEXT_FULL) && !defined(RC_INVOKED) - #error You need to define a CONTEXT for your CPU - #endif |