Commit graph

616 commits

Author SHA1 Message Date
Dimitry Andric
0e14fd9299 When building the gcc ports using a full bootstrap, tell the configure
script to assume the BUILD_CONFIG is set to bootstrap-debug, instead of
letting it auto-detect.

With clang 3.5.0 this auto-detection can fail, due to a discrepancy [1]
[2] in its debug information, when objects are produced with and without
-g.  When the auto-detection fails, gcc will compare objects with full
debug information during the stage comparisons, and this sometimes
causes those stage comparisons to fail unexpectedly.

[1] http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20141222/250134.html
[2] http://llvm.org/PR22046

Approved by:	gerald (maintainer)
2014-12-30 19:19:43 +00:00
Gerald Pfeifer
c31a9a5c91 Remove all traces of @dirrm from pkg-plist, including those parts that
are dynamically generated via the Makefile.
2014-10-20 02:50:46 +00:00
Baptiste Daroussin
e95ace05e4 Comment out info/dir files
indexinfo is taking care of generating it at package installation time

Reported by:	peter
2014-10-06 18:13:15 +00:00
Tijl Coosemans
7b08c84926 Add USES=libtool 2014-09-11 12:02:28 +00:00
Gerald Pfeifer
da7fe7d8f1 Also clean *.la files in LIBEXEC, and recursively so, here and for
TARGLIB.
2014-07-21 19:37:43 +00:00
Baptiste Daroussin
698f728a34 Fix build on system built WITHOUT_INFO
With hat:	portmgr
2014-06-25 08:58:09 +00:00
Baptiste Daroussin
a33191366c Convert GMAKE to MAKE_CMD
Please note that lots of invocation of MAKE_CMD here are wrong as they do not
properly respect MAKE_ENV and friends

With hat:	portmgr
2014-06-25 05:35:31 +00:00
Baptiste Daroussin
4a4ec28d37 Convert all :U to :tu and :L to :tl
Since FreeBSD 8.4 and FreeBSD 9.1 make(1) do support :tu and :tl as a
replacement for :U and :L (which has been marked as deprecated)

bmake which is the default on FreeBSD 10+ only support by default
:tu/:tl a hack has been added at the time to support :U and :L to ease
migration. This hack is now not necessary anymore

Note that this makes the ports tree incompatible with make(1) from
FreeBSD 8.3 or earlier

With hat:	portmgr
2014-05-05 09:45:36 +00:00
Gerald Pfeifer
b2bfd30660 Remove an (obsolete) CONFLICTS with a former state of lang/gcc.
Replace USE_BZIP2 by USES=tar:bzip2.

Extend full-regression-test by running contrib/test_summary.

No longer install rebuild-gcj-db46 (which requires bash among others)
and its man page.
2014-04-13 13:55:21 +00:00
Gerald Pfeifer
bc6d7b9197 No longer add -I${LOCALBASE}/include to CFLAGS.
Since we now configure with --with-gmp=${LOCALBASE} this is no longer
necessary, and due to bugs in binutils (which should not install ansidecl.h
into ${PREFIX}/include, fixed with revision 336642 [1]) and GCC (which
should search its own include directories with higher priority) could
lead to build failures.

Set the license to a combination of GPLv3 (for the compiler itself) and
GPLv3 with GCC Runtime Library Exception (for the runtime).

PR:		184327 [1]
2014-02-22 18:01:22 +00:00
Gerald Pfeifer
e8330bd911 Remove the man7 pages, which we are not packaging, from the staging
area to silence some warnings some are concerned about. [1]

No longer run ccache-update-links as part of post-install which, in
the world of staging, no longer is what it used to be.  Rely on the
existing @exec and @unexec in pkg-plist instead. [2]

Submitted by:	miwi [1]
Discussed with:	antoine [1][2]
2014-02-15 15:59:38 +00:00
Baptiste Daroussin
e04b632220 Fix properties on pkg-plist 2014-01-21 23:40:21 +00:00
Gerald Pfeifer
6073b55fd3 Revert revision 334619 from 2013-11-22 that worked around a problem with
the staging infrastructure and had us remove info/gcc46 ourselves. [1]

This has now been addressed in the general infrastructure and actually
causes warnings in some cases. [2]

PR:		184178 [1]
Reported by:	amdmi3 [2]
2013-12-07 10:01:55 +00:00
Gerald Pfeifer
52640bd401 Change PORTNAME for lang/gcc46 from gcc to gcc46 to match the actual
name of this port and avoid a package name collision with other GCC
ports.  This also allows us to remove LATEST_LINK.

And it finally allows for a simple and proper CONFLICTS between
lang/gcc and lang/gcc46.
2013-11-26 14:13:15 +00:00
Gerald Pfeifer
02997c0f68 Work around ports infrastructure breakage introduced with staging and
remove info/gcc46 ourselves.

Reported by:	QAT, amdmi3, mandree, bf, dbn
PR:		184178
2013-11-22 22:03:06 +00:00
Gerald Pfeifer
c5d9c8220e Remove a (long) obsolete dependency on bison. [1]
Migrate to the new LIB_DEPENDS standard.

STAGEify.

Reported by:	marino [1]
2013-10-28 00:26:28 +00:00
Gerald Pfeifer
3be3e90f93 Update to libmpc version 1.0.1 which brings the following fixes:
- Switched to automake 1.11.6, see CVE-2012-3386.
 - #14669: Fixed extraction of CC from gmp.h.
 - Fixed case of intermediate zero real or imaginary part in mpc_fma,
   found by hydra with GMP_CHECK_RANDOMIZE=1346362345.

This is on top of the following changes from version 1.0

 - Licence change towards LGPLv3+ for the code and GFDLv1.3+ (with no
   invariant sections) for the documentation.
 - 100% of all lines are covered by tests
 - Renamed functions
   . mpc_mul_2exp to mpc_mul_2ui
   . mpc_div_2exp to mpc_div_2ui
 - 0^0, which returned (NaN,NaN) previously, now returns (1,+0).
 - Removed compatibility with K&R compilers, which was untestable due
   to lack of such compilers.
 - New functions
   . mpc_log10
   . mpc_mul_2si, mpc_div_2si
 - Speed-ups
   . mpc_fma
 - Bug fixes
   . mpc_div and mpc_norm now return a value indicating the effective
     rounding direction, as the other functions.
   . mpc_mul, mpc_sqr and mpc_norm now return correct results even if
     there are over- or underflows during the computation.
   . mpc_asin, mpc_proj, mpc_sqr: Wrong result when input variable has
     infinite part and equals output variable is corrected.
   . mpc_fr_sub: Wrong return value for imaginary part is corrected.

Convert to the new LIB_DEPENDS standard and remove hard-coded
.so versions from a couple of dependent ports.

Bump PORTREVISIONS of all dependent ports.

PR:		183141
Approved by:	portmgr (bdrewery)
2013-10-26 00:52:33 +00:00
Baptiste Daroussin
888ab73a81 Add NO_STAGE all over the place in preparation for the staging support (cat: lang) 2013-09-20 19:53:09 +00:00
Bryan Drewery
c93dfc2e9f SSP support has been added to ports with WITH_SSP for i386 and amd64
on FreeBSD 10, and amd64 on earlier versions.

SSP_UNSAFE is added to disable in a port if it fails to build, but
this should only be used in rare circumstances such as kernel modules.
Otherwise, the port may just be failing due to lack of respecting
LDFLAGS.

On FreeBSD 10, this uses an ldscript in /usr/lib/libc.so to pull in
libssp_nonshared.a to address issues linking on i386 [1].

On earlier FreeBSD versions the WITH_SSP knob will add -lssp_nonshared
to LDFLAGS on i386. This is not needed on amd64. However, several hundred
ports do not currently respect LDFLAGS, so this support is disabled currently
as it causes build failures if a dependency is looking for the stack_chk
symbols.

Many thanks to jlh@ for this as he had many years of patience in getting
all of the necessary pieces [1][2] in.

[1] http://svnweb.freebsd.org/base/head/lib/libc/libc.ldscript?revision=251668&view=markup

PR:		ports/138228 [2]
Submitted by:	jlh (bsd.ssp.mk based on)
Reviewed by:	bapt
With hat:	portmgr
exp-runs done:	37 over a month on 91i386,91amd64,10i386,10amd64
2013-09-20 12:54:54 +00:00
Baptiste Daroussin
6adf864b81 Convert to new perl framework
Convert from USE_GMAKE to USES=gmake
2013-09-17 06:40:21 +00:00
John Marino
9518965c21 lang/gcc*: define CONFIGURE_TARGET genericly (8 ports)
Instead of hardcoding the compiler target as FreeBSD, use the OPSYS
variable to it.  This makes no practical difference for FreeBSD, but
it helps DragonFly get properly configured.

Approved by:	gerald
2013-09-12 10:20:45 +00:00
Gerald Pfeifer
6552b46cda Work around a bug in libcpp that pulls in the optional system iconv
if present instead of relying on the port we actually depend on.

The issue is that /usr/include/iconv.h has #include <stdbool.h> which
in turn, since both are included very late in the game, conflicts with
similar definintions by libcpp itself.

Interestingly enough, lang/gcc46 and lang/gcc48 did not fail under the
same test scenarios and libstdc++ does not seem to require adjustments,
so PR 161417 may not be relevant in full.

PR:		161417
2013-09-05 20:08:27 +00:00
Boris Samorodov
9f7e7e1326 Introduce ICONV_CONFIGURE_ARG variable defined at Uses/iconv.mk.
It's value is "--with-libiconv-prefix=/usr/local" for systems
before 100043 with ports libiconv and to use at systems post
100043 with base iconv it's value is "" (NULL).

Co-authors:	bapt, madpilot and bsam (me)
2013-09-04 20:01:05 +00:00
Gerald Pfeifer
bed8c78c4e Replace VERSIONSTRING by DISTVERSION.
Replace USE_GMAKE by USES=gmake.
2013-08-24 23:39:11 +00:00
Alex Kozlov
d4041784dc - Remove MAKE_JOBS_SAFE variable
Approved by:	portmgr (bdrewery)
2013-08-14 22:35:50 +00:00
Gerald Pfeifer
1c77b87bb3 When bootstrapping, which is not the default for this GCC port, use
bootstrap-lean instead of default/vanilla bootstrap to save on disk
space.
2013-06-02 19:13:51 +00:00
Gerald Pfeifer
00770c2bff Update to GCC 4.6.4, the final release and end of the GCC 4.6 branch.
(This requires an EPOCH bump due to how snapshots are labeled.)

Introduce a new option BOOTSTRAP that allows for doing a full
bootstrap of GCC, as opposed to just running a simple build.
Bootstrapping is actually the default upstream, we disable it
by default for the stable flavors of GCC since that is a huge
win in terms of build time of the port.  No change in default
behavior for this port.
2013-05-13 00:23:02 +00:00
Marcus von Appen
a3a0715f38 - Convert USE_ICONV=yes to USES=iconv
- Change USE_GNOME=pkgconfig|gnomehack to USES=pathfix|pkgconfig while here

Reviewed by:	zeising
2013-04-27 11:59:28 +00:00
Baptiste Daroussin
9250d94365 Convert USE_BISON to USES= bison
It brings bison as a build dependency in case it is set the following way:
USES= bison or USES= bison:build

it brings bison as a run dependency in case it is set the following way:
USES= bison:run

it brings bison both as a run and build dependency in case it the set the following way:
USES= bison:both

While here trim some headers
Convert some USE_GNOME= gnomehack to USES= pathfix
2013-03-08 11:32:11 +00:00
Gerald Pfeifer
2841ee31e4 Update to the 20130215 snapshot of GCC 4.6.4. 2013-02-16 16:22:44 +00:00
Gerald Pfeifer
50342b8b31 Use the new lang/gcc-ecj45 port when building the Java frontend
instead of including a pre-built version of the Eclipse Java Compiler
(ECJ) ourselves. [1]

Replace the use of DISTFILES by DISTNAME, since we are now down to
one in all cases.

On the way, update to the 20130125 of GCC 4.6.4.

PR:		175072 [1]
2013-01-26 14:23:59 +00:00
Gerald Pfeifer
8a9a692d46 Re-add ecj-4.5.jar to distinfo.
Reported by:	andy@neu.net
Feature safe:	yes
2012-12-01 01:43:54 +00:00
Gerald Pfeifer
ffb2b04055 Make binutils a build dependency as well (not just a run-time dependency).
Without this, the libiberty build fails locating ar.

Also update to the 20121123 snapshot of 4.6.4.

Feature safe:	yes
2012-12-01 01:03:05 +00:00
Gerald Pfeifer
8b8275c1a0 Given how stable the GCC 4.6 branch is these days, like with lang/gcc
just build, do not bootstrap, when building this port.  This speeds
up a full port/package test cycle by 31% on a 4-core system; a simple
build/install will benefit even more.

(This may impact compile time by this compiler a bit, depending on
how well the system compiler optimizes this codebase.  And we only
should do this for stable, established versions of GCC.)

On the way, update to the 20121102 snapshot of GCC 4.6.4.

Feature safe:	yes
2012-11-04 21:45:17 +00:00
Gerald Pfeifer
4f54c99b86 Update to the 20121026 snapshot of GCC 4.6.4. Bring a comment in line
with related ports.

Feature safe:	yes
2012-11-03 00:47:49 +00:00
Gerald Pfeifer
3b6cf85a1e Revamp the handling of different languages (frontends, run-times)
by GCC to allow for orthogonal setting them in the future. [1]

Print the list of languages being built as part of pre-everything
and shorten the output of operating system and version there.

Inspired by:	jkim [1]
2012-09-30 23:58:45 +00:00
Gerald Pfeifer
5129f999be Update to the 20120831 snapshot of GCC 4.6.4.
Remove now deprecated comments at the top of Makefile.
2012-09-01 19:16:37 +00:00
Gerald Pfeifer
c6d9a9155d Convert to the new options framework.
Remove ABI version numbers for all library dependencies.

Update to the 20120817 snapshot of GCC 4.6.4.
2012-08-22 00:41:37 +00:00
Gerald Pfeifer
73e1e72d69 Update to the 20120608 snapshot of GCC 4.6.4. 2012-06-10 21:22:54 +00:00
Gerald Pfeifer
58f4b725a9 Update to the 20120511 snapshot of GCC 4.6.4. 2012-05-12 12:18:02 +00:00
Gerald Pfeifer
a3cd7c16d1 Update to the 20120420 snapshot of GCC 4.6.4. 2012-04-22 11:08:05 +00:00
Gerald Pfeifer
5b6ebeb593 Update to the 20120413 snapshot of GCC 4.6.4. 2012-04-14 20:50:27 +00:00
Gerald Pfeifer
87828b1e8e Update to the 20120406 snapshot of GCC 4.6.4.
Feature safe:	yes
2012-04-07 10:29:09 +00:00
Gerald Pfeifer
9e4ad1bbe3 Update to the 20120330 snapshot of GCC 4.6.4.
Feature safe:	yes
2012-04-03 22:16:37 +00:00
Gerald Pfeifer
cb48fe94b5 Update to the 20120309 snapshot of GCC 4.6.4.
Increase CONFLICTS to also cover GCC 4.6.3 now, in anticipation of
a forthcoming update of lang/gcc to GCC 4.6.3.

Feature safe:	yes
2012-03-10 21:26:04 +00:00
Gerald Pfeifer
f8dde181c0 Update to the 20120302 snapshot of GCC 4.6.4, which nearly
coincides with the GCC 4.6.3 release.
2012-03-03 23:22:30 +00:00
Gerald Pfeifer
0295f339d4 Update to what is basically the first RC of GCC 4.6.3. 2012-02-26 22:48:41 +00:00
Gerald Pfeifer
2862fcd45a Update to the 20120217 snapshot of GCC 4.6.3. 2012-02-18 12:07:36 +00:00
Gerald Pfeifer
4bc63c6310 Update to the 20120203 snapshot of GCC 4.6.3. 2012-02-04 11:44:06 +00:00
Gerald Pfeifer
fb3f965faa Update to the 20120120 snapshot of GCC 4.6.3. 2012-01-22 23:20:27 +00:00