summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVolker Grabsch <vog@notjusthosting.com>2009-10-27 13:33:05 (GMT)
committerVolker Grabsch <vog@notjusthosting.com>2009-10-27 13:33:05 (GMT)
commita5e1a67929749881a1c973d5394685a2ca06076c (patch)
treec581fc7b70090b3413e1929fdcf8d40aa71e9085
parent913cbf5c15daeb4e8fb97ac4b1bbbcb9a86f4d02 (diff)
downloadmxe-a5e1a67929749881a1c973d5394685a2ca06076c.zip
mxe-a5e1a67929749881a1c973d5394685a2ca06076c.tar.gz
mxe-a5e1a67929749881a1c973d5394685a2ca06076c.tar.bz2
improved structure of the gcc-* packages
-rw-r--r--src/gcc-core.mk37
-rw-r--r--src/gcc-fortran.mk37
-rw-r--r--src/gcc-objc.mk37
-rw-r--r--src/gcc-tdm.mk (renamed from src/gcc-g++.mk)20
-rw-r--r--src/gcc.mk54
5 files changed, 38 insertions, 147 deletions
diff --git a/src/gcc-core.mk b/src/gcc-core.mk
deleted file mode 100644
index ba10434..0000000
--- a/src/gcc-core.mk
+++ /dev/null
@@ -1,37 +0,0 @@
-# Copyright (C) 2009 Volker Grabsch
-#
-# Permission is hereby granted, free of charge, to any person obtaining
-# a copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish,
-# distribute, sublicense, and/or sell copies of the Software, and to
-# permit persons to whom the Software is furnished to do so, subject
-# to the following conditions:
-#
-# The above copyright notice and this permission notice shall be
-# included in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
-# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
-# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
-# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
-# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-# GCC core
-PKG := gcc-core
-$(PKG)_IGNORE := 4.4.1
-$(PKG)_VERSION := 4.4.0
-$(PKG)_CHECKSUM := 081c5a1e49157b9c48fe97497633b6ff39032eb5
-$(PKG)_SUBDIR := gcc-$($(PKG)_VERSION)
-$(PKG)_FILE := gcc-core-$($(PKG)_VERSION).tar.bz2
-$(PKG)_WEBSITE := http://gcc.gnu.org/
-$(PKG)_URL := http://$(SOURCEFORGE_MIRROR)/project/tdm-gcc/Sources/Vanilla Sources/_Deprecated/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE)
-$(PKG)_DEPS :=
-
-define $(PKG)_UPDATE
- $(call SOURCEFORGE_FILES,http://sourceforge.net/projects/tdm-gcc/files/Sources/) | \
- $(SED) -n 's,.*gcc-core-\([0-9][^>]*\)\.tar.*,\1,p' | \
- tail -1
-endef
diff --git a/src/gcc-fortran.mk b/src/gcc-fortran.mk
deleted file mode 100644
index 07b2cb9..0000000
--- a/src/gcc-fortran.mk
+++ /dev/null
@@ -1,37 +0,0 @@
-# Copyright (C) 2009 Volker Grabsch
-#
-# Permission is hereby granted, free of charge, to any person obtaining
-# a copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish,
-# distribute, sublicense, and/or sell copies of the Software, and to
-# permit persons to whom the Software is furnished to do so, subject
-# to the following conditions:
-#
-# The above copyright notice and this permission notice shall be
-# included in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
-# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
-# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
-# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
-# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-# GCC fortran
-PKG := gcc-fortran
-$(PKG)_IGNORE := 4.4.1
-$(PKG)_VERSION := 4.4.0
-$(PKG)_CHECKSUM := 5f9e32d9061937e7706d35d2d5458675352b1368
-$(PKG)_SUBDIR := gcc-$($(PKG)_VERSION)
-$(PKG)_FILE := gcc-fortran-$($(PKG)_VERSION).tar.bz2
-$(PKG)_WEBSITE := http://gcc.gnu.org/
-$(PKG)_URL := http://$(SOURCEFORGE_MIRROR)/project/tdm-gcc/Sources/Vanilla Sources/_Deprecated/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE)
-$(PKG)_DEPS :=
-
-define $(PKG)_UPDATE
- $(call SOURCEFORGE_FILES,http://sourceforge.net/projects/tdm-gcc/files/Sources/) | \
- $(SED) -n 's,.*gcc-fortran-\([0-9][^>]*\)\.tar.*,\1,p' | \
- tail -1
-endef
diff --git a/src/gcc-objc.mk b/src/gcc-objc.mk
deleted file mode 100644
index 789c62b..0000000
--- a/src/gcc-objc.mk
+++ /dev/null
@@ -1,37 +0,0 @@
-# Copyright (C) 2009 Volker Grabsch
-#
-# Permission is hereby granted, free of charge, to any person obtaining
-# a copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish,
-# distribute, sublicense, and/or sell copies of the Software, and to
-# permit persons to whom the Software is furnished to do so, subject
-# to the following conditions:
-#
-# The above copyright notice and this permission notice shall be
-# included in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
-# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
-# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
-# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
-# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-# GCC objc
-PKG := gcc-objc
-$(PKG)_IGNORE := 4.4.1
-$(PKG)_VERSION := 4.4.0
-$(PKG)_CHECKSUM := 21cd70e01c211553c59123c62b4f33330ad212c4
-$(PKG)_SUBDIR := gcc-$($(PKG)_VERSION)
-$(PKG)_FILE := gcc-objc-$($(PKG)_VERSION).tar.bz2
-$(PKG)_WEBSITE := http://gcc.gnu.org/
-$(PKG)_URL := http://$(SOURCEFORGE_MIRROR)/project/tdm-gcc/Sources/Vanilla Sources/_Deprecated/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE)
-$(PKG)_DEPS :=
-
-define $(PKG)_UPDATE
- $(call SOURCEFORGE_FILES,http://sourceforge.net/projects/tdm-gcc/files/Sources/) | \
- $(SED) -n 's,.*gcc-objc-\([0-9][^>]*\)\.tar.*,\1,p' | \
- tail -1
-endef
diff --git a/src/gcc-g++.mk b/src/gcc-tdm.mk
index 75787ed..6885ad8 100644
--- a/src/gcc-g++.mk
+++ b/src/gcc-tdm.mk
@@ -19,19 +19,19 @@
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-# GCC g++
-PKG := gcc-g++
-$(PKG)_IGNORE := 4.4.1
-$(PKG)_VERSION := 4.4.0
-$(PKG)_CHECKSUM := 063d5acca79ec00276cf6ebdba414804abf3fcb6
-$(PKG)_SUBDIR := gcc-$($(PKG)_VERSION)
-$(PKG)_FILE := gcc-g++-$($(PKG)_VERSION).tar.bz2
-$(PKG)_WEBSITE := http://gcc.gnu.org/
-$(PKG)_URL := http://$(SOURCEFORGE_MIRROR)/project/tdm-gcc/Sources/Vanilla Sources/_Deprecated/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE)
+# TDM-GCC
+PKG := gcc-tdm
+$(PKG)_IGNORE := 4.4.1-tdm-2
+$(PKG)_VERSION := 4.4.0-tdm-1
+$(PKG)_CHECKSUM := ec1c81acf0581b4f1e2d5498ce9cd015b63e917b
+$(PKG)_SUBDIR := .
+$(PKG)_FILE := gcc-$($(PKG)_VERSION)-srcbase-2.zip
+$(PKG)_WEBSITE := http://www.tdragon.net/recentgcc/
+$(PKG)_URL := http://$(SOURCEFORGE_MIRROR)/project/tdm-gcc/Sources/TDM Sources/$($(PKG)_VERSION)/$($(PKG)_FILE)
$(PKG)_DEPS :=
define $(PKG)_UPDATE
$(call SOURCEFORGE_FILES,http://sourceforge.net/projects/tdm-gcc/files/Sources/) | \
- $(SED) -n 's,.*gcc-g++-\([0-9][^>]*\)\.tar.*,\1,p' | \
+ $(SED) -n 's,.*gcc-\([0-9][^>]*\)-srcbase[-0-9]*\.zip.*,\1,p' | \
tail -1
endef
diff --git a/src/gcc.mk b/src/gcc.mk
index 70473ca..6231e4b 100644
--- a/src/gcc.mk
+++ b/src/gcc.mk
@@ -19,21 +19,24 @@
# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-# TDM-GCC
+# GCC
PKG := gcc
-$(PKG)_IGNORE := 4.4.1-tdm-2
-$(PKG)_VERSION := 4.4.0-tdm-1
-$(PKG)_CHECKSUM := ec1c81acf0581b4f1e2d5498ce9cd015b63e917b
-$(PKG)_SUBDIR := .
-$(PKG)_FILE := gcc-$($(PKG)_VERSION)-srcbase-2.zip
-$(PKG)_WEBSITE := http://www.tdragon.net/recentgcc/
-$(PKG)_URL := http://$(SOURCEFORGE_MIRROR)/project/tdm-gcc/Sources/TDM Sources/$($(PKG)_VERSION)/$($(PKG)_FILE)
-$(PKG)_DEPS := pkg_config mingwrt mingwrt-dll w32api binutils gcc-gmp gcc-mpfr gcc-core gcc-g++ gcc-objc gcc-fortran gcc-pthreads
+$(PKG)_IGNORE := 4.4.2
+$(PKG)_VERSION := 4.4.0
+$(PKG)_CHECKSUM := 9215af6beb900ca1eef1d6a40c3dabe990203b25
+$(PKG)_SUBDIR := gcc-$($(PKG)_VERSION)
+$(PKG)_FILE := gcc-$($(PKG)_VERSION).tar.bz2
+$(PKG)_WEBSITE := http://gcc.gnu.org/
+$(PKG)_URL := ftp://ftp.gnu.org/pub/gnu/gcc/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE)
+$(PKG)_URL_2 := ftp://ftp.cs.tu-berlin.de/pub/gnu/gcc/gcc-$($(PKG)_VERSION)/$($(PKG)_FILE)
+$(PKG)_DEPS := pkg_config mingwrt mingwrt-dll w32api binutils gcc-gmp gcc-mpfr gcc-tdm gcc-pthreads
define $(PKG)_UPDATE
- $(call SOURCEFORGE_FILES,http://sourceforge.net/projects/tdm-gcc/files/Sources/) | \
- $(SED) -n 's,.*gcc-\([0-9][^>]*\)-srcbase[-0-9]*\.zip.*,\1,p' | \
- tail -1
+ wget -q -O- 'http://gcc.gnu.org/viewcvs/tags/?sortby=date' | \
+ grep '<a name="gcc_' | \
+ $(SED) -n 's,.*<a name="gcc_\([0-9][^"]*\)_release".*,\1,p' | \
+ $(SED) 's,_,.,g' | \
+ head -1
endef
$(PKG)_CONFIGURE_OPTIONS := \
@@ -51,24 +54,23 @@ $(PKG)_CONFIGURE_OPTIONS := \
--enable-sjlj-exceptions
define $(PKG)_BUILD
- # unpack GCC
- cd '$(1)' && $(call UNPACK_PKG_ARCHIVE,gcc-core)
- cd '$(1)' && $(call UNPACK_PKG_ARCHIVE,gcc-g++)
- cd '$(1)' && $(call UNPACK_PKG_ARCHIVE,gcc-objc)
- cd '$(1)' && $(call UNPACK_PKG_ARCHIVE,gcc-fortran)
- # apply TDM patches to GCC
- cd '$(1)/$(gcc-core_SUBDIR)' && \
- for p in '$(1)'/*.patch; do \
- patch -p1 < "$$p"; \
+ # unpack TDM-GCC
+ mkdir '$(1)/gcc-tdm'
+ cd '$(1)/gcc-tdm' && $(call UNPACK_PKG_ARCHIVE,gcc-tdm)
+ # apply TDM-GCC patches
+ cd '$(1)' && \
+ for p in '$(1)'/gcc-tdm/*.patch; do \
+ $(SED) 's,\r$$,,' -i "$$p" || exit 1; \
+ patch -p1 < "$$p" || exit 1; \
done
# unpack support libraries
cd '$(1)' && $(call UNPACK_PKG_ARCHIVE,gcc-gmp)
- mv '$(1)/$(gcc-gmp_SUBDIR)' '$(1)/$(gcc-core_SUBDIR)/gmp'
+ mv '$(1)/$(gcc-gmp_SUBDIR)' '$(1)/gmp'
cd '$(1)' && $(call UNPACK_PKG_ARCHIVE,gcc-mpfr)
- mv '$(1)/$(gcc-mpfr_SUBDIR)' '$(1)/$(gcc-core_SUBDIR)/mpfr'
+ mv '$(1)/$(gcc-mpfr_SUBDIR)' '$(1)/mpfr'
# build everything of GCC except libgomp and libmudflap
mkdir '$(1)/build'
- cd '$(1)/build' && '$(1)/$(gcc-core_SUBDIR)/configure' \
+ cd '$(1)/build' && '$(1)/configure' \
$(gcc_CONFIGURE_OPTIONS) \
--enable-threads=win32 \
--disable-libgomp \
@@ -87,9 +89,9 @@ define $(PKG)_BUILD
$(INSTALL) -m664 '$(1)/$(gcc-pthreads_SUBDIR)/sched.h' '$(PREFIX)/$(TARGET)/include/'
$(INSTALL) -m664 '$(1)/$(gcc-pthreads_SUBDIR)/semaphore.h' '$(PREFIX)/$(TARGET)/include/'
# build libgomp
- $(SED) 's,cross_compiling=no,cross_compiling=yes,' -i '$(1)/$(gcc-core_SUBDIR)/libgomp/configure'
+ $(SED) 's,cross_compiling=no,cross_compiling=yes,' -i '$(1)/libgomp/configure'
mkdir '$(1)/build/$(TARGET)/libgomp'
- cd '$(1)/build/$(TARGET)/libgomp' && '$(1)/$(gcc-core_SUBDIR)/libgomp/configure' \
+ cd '$(1)/build/$(TARGET)/libgomp' && '$(1)/libgomp/configure' \
$(gcc_CONFIGURE_OPTIONS) \
--host='$(TARGET)' \
LIBS='-lws2_32'