[26857] trunk/dports/cross
source_changes at macosforge.org
source_changes at macosforge.org
Mon Jul 9 18:49:04 PDT 2007
Revision: 26857
http://trac.macosforge.org/projects/macports/changeset/26857
Author: pguyot at kallisys.net
Date: 2007-07-09 18:49:04 -0700 (Mon, 09 Jul 2007)
Log Message:
-----------
New port: cross/arm-none-linux-gnueabi-gcc (gcc for Nokia Internet Tablet 770/800)
Added Paths:
-----------
trunk/dports/cross/arm-none-linux-gnueabi-gcc/
trunk/dports/cross/arm-none-linux-gnueabi-gcc/Portfile
Added: trunk/dports/cross/arm-none-linux-gnueabi-gcc/Portfile
===================================================================
--- trunk/dports/cross/arm-none-linux-gnueabi-gcc/Portfile (rev 0)
+++ trunk/dports/cross/arm-none-linux-gnueabi-gcc/Portfile 2007-07-10 01:49:04 UTC (rev 26857)
@@ -0,0 +1,255 @@
+# $Id: Portfile 20558 2006-11-06 23:28:39Z blair at macports.org $
+
+PortSystem 1.0
+name arm-none-linux-gnueabi-gcc
+version 2005q3-2
+
+# Parameters for this port.
+set gccversion 2005q3
+set scratchboxversion 1.0.5
+set crossgcc-target arm-none-linux-gnueabi
+set default-languages --enable-languages="c,c++,objc"
+
+description gcc 3.x cross-compilers for arm-none-linux-gnueabi.
+long_description gnu compilers collection version 3.x (including c++ and objc) for \
+ arm-none-linux-gnueabi, Nokia Internet Tablet version from Code Sourcery
+homepage http://www.codesourcery.com/gnu_toolchains/arm
+platforms darwin
+categories cross devel
+maintainers pguyot at kallisys.net
+master_sites macports:pguyot
+distfiles gcc-${version}.tar.bz2
+worksrcdir gcc-${gccversion}
+checksums gcc-${version}.tar.bz2 \
+ md5 8fb231e1d8573b9e14e4d518a1c781a2 \
+ sha1 99334733b0e0b2befd7f5eb9c6fac407a71f563e \
+ rmd160 8d08aa976a84e9058ae95616c25e2c5a00ac9b4c
+
+# Download everything to gcc/
+dist_subdir gcc
+
+depends_lib bin:${crossgcc-target}-ar:${crossgcc-target}-binutils \
+ bin:${crossgcc-target}-as:${crossgcc-target}-binutils \
+ bin:${crossgcc-target}-ld:${crossgcc-target}-binutils \
+ bin:${crossgcc-target}-nm:${crossgcc-target}-binutils \
+ bin:${crossgcc-target}-ranlib:${crossgcc-target}-binutils \
+ port:${crossgcc-target}-runtime
+depends_build bin:msgfmt:gettext
+
+use_bzip2 yes
+
+# Since we don't build gcc and binutils at the same time, gcc's Makefile will try to transform
+# program names as gcc's name (add -${version} with ${version} being the version of gcc).
+# But it won't work because binutils binaries don't have the ${version} suffix, and even if they
+# had, they would actually have the binutils' version suffix (and not gcc's version).
+# So let's tell gcc's Makefile not to do that mistake.
+
+set environment [list AR_FOR_TARGET=${crossgcc-target}-ar \
+ AS_FOR_TARGET=${crossgcc-target}-as \
+ LD_FOR_TARGET=${crossgcc-target}-ld \
+ NM_FOR_TARGET=${crossgcc-target}-nm \
+ RANLIB_FOR_TARGET=${crossgcc-target}-ranlib]
+
+# Build in a different directory, as advised in the README file.
+pre-configure {
+ file mkdir "${workpath}/build"
+}
+configure.dir ${workpath}/build
+configure.cmd ${worksrcpath}/configure
+configure.env CC="cc -no-cpp-precomp" \
+ ${environment}
+configure.args --infodir='${prefix}/share/info' \
+ --mandir='${prefix}/share/man' \
+ --target=${crossgcc-target} \
+ --program-prefix=${crossgcc-target}- \
+ --program-suffix=-${gccversion} \
+ --with-included-gettext \
+ --with-headers=${prefix}/${crossgcc-target}/usr/include \
+ --with-libs=${prefix}/${crossgcc-target}/usr/lib \
+ --enable-shared \
+ --enable-threads \
+ --disable-checking \
+ --enable-symvers=gnu \
+ --enable-__cxa_atexit \
+ --disable-libssp \
+ --disable-libstdcxx-pch \
+ --with-cpu= \
+ --enable-interwork \
+ --with-gxx-include-dir=${prefix}/${crossgcc-target}/include/c++/${version}/ \
+ ${default-languages}
+
+build.dir ${workpath}/build
+
+build.args ${environment}
+destroot.args ${environment}
+
+# Variant to include java tools.
+# I'm not exactly sure what the interest of this variant is except to measure
+# the speed of your Xserve G5 farm. Or your patience if you don't have such
+# a farm.
+variant java {
+ configure.args-delete ${default-languages}
+}
+
+patch {
+ namespace eval crossgcc {}
+
+ # Fix the info pages and related stuff.
+ #
+ # path: path to the doc directory (e.g. gas/doc/)
+ # makefile: path to Makefile.in (e.g. gas/doc/Makefile.in)
+ # name: name of the info page (e.g. as)
+ # suffix: suffix of the souce page (texinfo or texi)
+ proc crossgcc::fixinfo { path makefile name suffix } {
+ global crossgcc-target worksrcpath
+
+ # Fix the source
+ if { [ file exists ${worksrcpath}/${path}/${name}.${suffix} ] } {
+ reinplace "s|setfilename ${name}.info|setfilename ${crossgcc-target}-${name}.info|g" \
+ ${worksrcpath}/${path}/${name}.${suffix}
+ reinplace "s|(${name})|(${crossgcc-target}-${name})|g" \
+ ${worksrcpath}/${path}/${name}.${suffix}
+ reinplace "s|@file{${name}}|@file{${crossgcc-target}-${name}}|g" \
+ ${worksrcpath}/${path}/${name}.${suffix}
+ # Rename the source
+ file rename ${worksrcpath}/${path}/${name}.${suffix} \
+ ${worksrcpath}/${path}/${crossgcc-target}-${name}.${suffix}
+ }
+
+ # Fix the Makefile
+ reinplace "s| ${name}.info| ${crossgcc-target}-${name}.info|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s|/${name}.info|/${crossgcc-target}-${name}.info|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s|/${name}.1|/${crossgcc-target}-${name}.1|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s|^${name}.info|${crossgcc-target}-${name}.info|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s| ${name}.pod| ${crossgcc-target}-${name}.pod|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s|/${name}.pod|/${crossgcc-target}-${name}.pod|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s|^${name}.pod|${crossgcc-target}-${name}.pod|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s| ${name}.${suffix}| ${crossgcc-target}-${name}.${suffix}|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s|/${name}.${suffix}|/${crossgcc-target}-${name}.${suffix}|g" \
+ ${worksrcpath}/${makefile}
+ reinplace "s|^${name}.${suffix}|${crossgcc-target}-${name}.${suffix}|g" \
+ ${worksrcpath}/${makefile}
+
+ # Fix install-info's dir.
+ # (note: this may be effectless if there was no info dir to be fixed)
+ reinplace "s|--info-dir=\$(DESTDIR)\$(infodir)|--dir-file=\$(DESTDIR)\$(infodir)/${crossgcc-target}-gcc-dir|g" \
+ "${worksrcpath}/${makefile}"
+ }
+
+ # Fix the gettext files and related stuff.
+ #
+ # module: name of the module (e.g. gas)
+ proc crossgcc::fixgettext { module } {
+ global crossgcc-target worksrcpath
+
+ if { [ file exists "${worksrcpath}/${module}/Makefile.in" ] } {
+ reinplace "s|@PACKAGE@|${crossgcc-target}- at PACKAGE@|g" \
+ "${worksrcpath}/${module}/Makefile.in"
+ }
+ if { [ file exists "${worksrcpath}/${module}/doc/Makefile.in" ] } {
+ reinplace "s|@PACKAGE@|${crossgcc-target}- at PACKAGE@|g" \
+ "${worksrcpath}/${module}/doc/Makefile.in"
+ }
+ if { [ file exists "${worksrcpath}/${module}/po/Make-in" ] } {
+ reinplace "s|@PACKAGE@|${crossgcc-target}- at PACKAGE@|g" \
+ "${worksrcpath}/${module}/po/Make-in"
+ }
+ }
+
+ # gcc/doc/cpp.texi
+ crossgcc::fixinfo gcc/doc/ gcc/Makefile.in cpp texi
+
+ # gcc/doc/cppinternals.texi
+ crossgcc::fixinfo gcc/doc/ gcc/Makefile.in cppinternals texi
+
+ # gcc/doc/gcc.texi
+ crossgcc::fixinfo gcc/doc/ gcc/Makefile.in gcc texi
+ crossgcc::fixinfo gcc/cp/ gcc/cp/Make-lang.in gcc texi
+ crossgcc::fixinfo gcc/cp/ gcc/cp/Make-lang.in g++ texi
+
+ # gcc/doc/gccint.texi
+ crossgcc::fixinfo gcc/doc/ gcc/Makefile.in gccint texi
+
+ # gcc/f/g77.texi
+ crossgcc::fixinfo gcc/f/ gcc/f/Make-lang.in g77 texi
+
+ # gcc/java/gcj.texi
+ crossgcc::fixinfo gcc/java/ gcc/java/Make-lang.in gcj texi
+
+ # fastjar/fastjar.texi
+ crossgcc::fixinfo fastjar/ fastjar/Makefile.in fastjar texi
+
+ # gettext stuff.
+ crossgcc::fixgettext gcc
+ crossgcc::fixgettext fastjar
+}
+
+pre-destroot {
+ # gcc needs the cross directory structure to be present
+ # in order to fill it during installation.
+ file mkdir "${destroot}/${prefix}/${crossgcc-target}/bin"
+ file mkdir "${destroot}/${prefix}/${crossgcc-target}/lib"
+}
+
+post-destroot {
+ namespace eval crossgcc {}
+
+ # Rename a man page if it exists.
+ #
+ # section: section of the man page (e.g. 1)
+ # manpage: name of the man page (e.g. cpp)
+ proc crossgcc::rename_man_page { section manpage } {
+ global crossgcc-target destroot prefix
+
+ set manpage_path "${destroot}/${prefix}/share/man/man${section}/${manpage}.${section}"
+ if { [ file exists ${manpage_path} ] } {
+ file rename ${manpage_path} \
+ "${destroot}/${prefix}/share/man/man${section}/${crossgcc-target}-${manpage}.${section}"
+ }
+ }
+
+ # Stuff I don't want (either because they're in the system
+ # or because they would conflict with other FSF ports)
+ # (it's easier for maintainability purposes to fix things here)
+
+ # aliases for locales (should be on the system)
+ file delete "${destroot}/${prefix}/share/locale/locale.alias"
+
+ # FSF propaganda (should already be there or would conflict)
+ file delete -force "${destroot}/${prefix}/share/man/man7"
+
+ # (host) libiberty
+ file delete "${destroot}/${prefix}/lib/libiberty.a"
+
+ # aliases for charsets (should already be there)
+ file delete "${destroot}/${prefix}/lib/charset.alias"
+
+ # Remove man pages for tools that are not built as part of cross-gcc
+ file delete "${destroot}/${prefix}/share/man/man1/rmic.1"
+ file delete "${destroot}/${prefix}/share/man/man1/rmiregistry.1"
+ file delete "${destroot}/${prefix}/share/man/man1/jv-convert.1"
+ file delete "${destroot}/${prefix}/share/man/man1/gij.1"
+
+ # For some reason, some man pages are not prefixed while they should have been
+ # (to avoid conflicting).
+ crossgcc::rename_man_page 1 cpp
+ crossgcc::rename_man_page 1 gcjh
+ crossgcc::rename_man_page 1 gcov
+ crossgcc::rename_man_page 1 jcf-dump
+ crossgcc::rename_man_page 1 jv-scan
+
+ # There is a bug in gcc/Makefile::install-driver
+ # For cross compilers, $(GCC_INSTALL_NAME) is equal to
+ # $(target_noncanonical)-gcc-$(version)
+ # and hence the driver isn't installed.
+ xinstall -c "${workpath}/build/gcc/xgcc" \
+ "${destroot}/${prefix}/bin/${crossgcc-target}-gcc-${version}"
+}
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.macosforge.org/pipermail/macports-changes/attachments/20070709/5d3363a1/attachment.html
More information about the macports-changes
mailing list