From 19cd913e1c6fa7b0dfca54317b034914c32bd17b Mon Sep 17 00:00:00 2001 From: thierry Date: Sat, 7 Aug 2004 22:32:25 +0000 Subject: - Fix LyX build with gcc3.4; - take maintainership. PR: ports/70095 Submitted by: Andrew Thompson Obtained from: NetBSD. --- print/lyx16/Makefile | 2 +- .../patch-boost::boost::config::compiler::gcc.hpp | 97 ++++++++++++++++++++++ .../patch-boost::boost::format::feed_args.hpp | 13 +++ ...boost::boost::format::format_implementation.hpp | 13 +++ print/lyx16/files/patch-src::BoostFormat.h | 13 +++ ...src::frontends::controllers::ControlDialog.tmpl | 85 +++++++++++++++++++ .../files/patch-src::frontends::qt2::Qt2Base.h | 21 +++++ .../files/patch-src::frontends::xforms::FormBase.h | 21 +++++ 8 files changed, 264 insertions(+), 1 deletion(-) create mode 100644 print/lyx16/files/patch-boost::boost::config::compiler::gcc.hpp create mode 100644 print/lyx16/files/patch-boost::boost::format::feed_args.hpp create mode 100644 print/lyx16/files/patch-boost::boost::format::format_implementation.hpp create mode 100644 print/lyx16/files/patch-src::BoostFormat.h create mode 100644 print/lyx16/files/patch-src::frontends::controllers::ControlDialog.tmpl create mode 100644 print/lyx16/files/patch-src::frontends::qt2::Qt2Base.h create mode 100644 print/lyx16/files/patch-src::frontends::xforms::FormBase.h (limited to 'print/lyx16') diff --git a/print/lyx16/Makefile b/print/lyx16/Makefile index 8950dd7a0574..e444edebbe20 100644 --- a/print/lyx16/Makefile +++ b/print/lyx16/Makefile @@ -13,7 +13,7 @@ MASTER_SITES= ftp://ftp.lyx.org/pub/lyx/stable/ \ http://www-ftp.lip6.fr/ftp/pub/lyx/stable/ \ ftp://gd.tuwien.ac.at/publishing/tex/lyx/stable/ -MAINTAINER= ports@FreeBSD.org +MAINTAINER= andy@fud.org.nz COMMENT= Document processor interfaced with LaTeX (nearly WYSIWYG) BUILD_DEPENDS= gm4:${PORTSDIR}/devel/m4 \ diff --git a/print/lyx16/files/patch-boost::boost::config::compiler::gcc.hpp b/print/lyx16/files/patch-boost::boost::config::compiler::gcc.hpp new file mode 100644 index 000000000000..7c4814ea9941 --- /dev/null +++ b/print/lyx16/files/patch-boost::boost::config::compiler::gcc.hpp @@ -0,0 +1,97 @@ +$NetBSD$ + +--- ./boost/boost/config/compiler/gcc.hpp.orig 2003-05-26 08:27:34.000000000 -0600 ++++ ./boost/boost/config/compiler/gcc.hpp +@@ -1,7 +1,13 @@ +-// (C) Copyright Boost.org 2001. Permission to copy, use, modify, sell and +-// distribute this software is granted provided this copyright notice appears +-// in all copies. This software is provided "as is" without express or implied +-// warranty, and with no claim as to its suitability for any purpose. ++// (C) Copyright John Maddock 2001 - 2003. ++// (C) Copyright Darin Adler 2001 - 2002. ++// (C) Copyright Jens Maurer 2001 - 2002. ++// (C) Copyright Beman Dawes 2001 - 2003. ++// (C) Copyright Douglas Gregor 2002. ++// (C) Copyright David Abrahams 2002 - 2003. ++// (C) Copyright Synge Todo 2003. ++// Use, modification and distribution are subject to the ++// Boost Software License, Version 1.0. (See accompanying file ++// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) + + // See http://www.boost.org for most recent version. + +@@ -23,24 +29,53 @@ + # endif + # endif + ++# if __GNUC__ == 2 && __GNUC_MINOR__ < 96 ++# define BOOST_NO_SFINAE ++# endif ++ + # if __GNUC__ == 2 && __GNUC_MINOR__ <= 97 + # define BOOST_NO_MEMBER_TEMPLATE_FRIENDS + # define BOOST_NO_OPERATORS_IN_NAMESPACE + # endif + ++# if __GNUC__ < 3 ++# define BOOST_NO_USING_DECLARATION_OVERLOADS_FROM_TYPENAME_BASE ++# define BOOST_FUNCTION_SCOPE_USING_DECLARATION_BREAKS_ADL ++# endif ++ ++# ++# ++# ++ ++// ++// Bug specific to gcc 3.1 and 3.2: ++// ++#if (__GNUC__ == 3) && ((__GNUC_MINOR__ == 1) || (__GNUC_MINOR__ == 2)) ++# define BOOST_NO_EXPLICIT_FUNCTION_TEMPLATE_ARGUMENTS ++#endif ++ + // +-// Threading support: +-// Turn this on unconditionally here, it will get turned off again later +-// if no threading API is detected. ++// Threading support: Turn this on unconditionally here (except for ++// those platforms where we can know for sure). It will get turned off again ++// later if no threading API is detected. + // +-#define BOOST_HAS_THREADS ++#if !defined(__MINGW32__) && !defined(linux) && !defined(__linux) && !defined(__linux__) ++# define BOOST_HAS_THREADS ++#endif + + // + // gcc has "long long" + // + #define BOOST_HAS_LONG_LONG + +-#define BOOST_COMPILER "GNU C++ version " BOOST_STRINGIZE(__GNUC__) "." BOOST_STRINGIZE(__GNUC_MINOR__) ++// ++// gcc implements the named return value optimization since version 3.1 ++// ++#if __GNUC__ > 3 || ( __GNUC__ == 3 && __GNUC_MINOR__ >= 1 ) ++#define BOOST_HAS_NRVO ++#endif ++ ++#define BOOST_COMPILER "GNU C++ version " __VERSION__ + + // + // versions check: +@@ -49,11 +84,13 @@ + # error "Compiler not configured - please reconfigure" + #endif + // +-// last known and checked version is 3.2: +-#if (__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ > 3)) ++// last known and checked version is 3.4: ++#if (__GNUC__ > 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ > 4)) + # if defined(BOOST_ASSERT_CONFIG) + # error "Unknown compiler version - please run the configure tests and report the results" + # else + # warning "Unknown compiler version - please run the configure tests and report the results" + # endif + #endif ++ ++ diff --git a/print/lyx16/files/patch-boost::boost::format::feed_args.hpp b/print/lyx16/files/patch-boost::boost::format::feed_args.hpp new file mode 100644 index 000000000000..63e5aa397e06 --- /dev/null +++ b/print/lyx16/files/patch-boost::boost::format::feed_args.hpp @@ -0,0 +1,13 @@ +$NetBSD$ + +--- ./boost/boost/format/feed_args.hpp.orig 2002-11-20 10:20:54.000000000 -0700 ++++ ./boost/boost/format/feed_args.hpp +@@ -34,7 +34,7 @@ namespace { + + template inline + void empty_buf(BOOST_IO_STD basic_ostringstream & os) { +- static const std::basic_string emptyStr; // avoids 2 cases ( "" and L"" ) ++ const std::basic_string emptyStr; // avoids 2 cases ( "" and L"" ) + os.str(emptyStr); + } + diff --git a/print/lyx16/files/patch-boost::boost::format::format_implementation.hpp b/print/lyx16/files/patch-boost::boost::format::format_implementation.hpp new file mode 100644 index 000000000000..4c13f145afa1 --- /dev/null +++ b/print/lyx16/files/patch-boost::boost::format::format_implementation.hpp @@ -0,0 +1,13 @@ +$NetBSD$ + +--- ./boost/boost/format/format_implementation.hpp.orig 2002-11-21 11:33:01.000000000 -0700 ++++ ./boost/boost/format/format_implementation.hpp +@@ -151,7 +151,7 @@ basic_format& basic_format + { + if(argN<1 || argN > num_args_ || bound_.size()==0 || !bound_[argN-1] ) + { +- if( exceptions() & out_of_range_bit ) ++ if( exceptions() & io::out_of_range_bit ) + boost::throw_exception(io::out_of_range()); // arg not in range. + else return *this; + } diff --git a/print/lyx16/files/patch-src::BoostFormat.h b/print/lyx16/files/patch-src::BoostFormat.h new file mode 100644 index 000000000000..5926d34fad7f --- /dev/null +++ b/print/lyx16/files/patch-src::BoostFormat.h @@ -0,0 +1,13 @@ +$NetBSD$ + +--- ./src/BoostFormat.h.orig 2002-11-25 12:44:44.000000000 -0700 ++++ ./src/BoostFormat.h +@@ -15,7 +15,7 @@ namespace boost + { + + extern +-template basic_format; ++template class basic_format; + + extern template + std::ostream & diff --git a/print/lyx16/files/patch-src::frontends::controllers::ControlDialog.tmpl b/print/lyx16/files/patch-src::frontends::controllers::ControlDialog.tmpl new file mode 100644 index 000000000000..e805b47a3519 --- /dev/null +++ b/print/lyx16/files/patch-src::frontends::controllers::ControlDialog.tmpl @@ -0,0 +1,85 @@ +$NetBSD$ + +--- src/frontends/controllers/ControlDialog.tmpl.orig 2004-05-29 04:23:23.000000000 -0600 ++++ src/frontends/controllers/ControlDialog.tmpl +@@ -4,7 +4,7 @@ + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. + * +- * \author Angus Leeming ++ * \author Angus Leeming + * + * Full author contact details are available in file CREDITS + * +@@ -27,54 +27,56 @@ ControlDialog::ControlDialog(LyXVi + template + void ControlDialog::show() + { +- if (isBufferDependent() && !bufferIsAvailable()) ++ if (this->isBufferDependent() && !this->bufferIsAvailable()) + return; + +- connect(); ++ this->connect(); + + if (!dialog_built_) { +- view().build(); ++ this->view().build(); + dialog_built_ = true; + } + + setParams(); +- if (emergency_exit_) { ++ if (this->emergency_exit_) { + hide(); + return; + } + +- bc().readOnly(bufferIsReadonly()); +- view().show(); ++ this->bc().readOnly(this->bufferIsReadonly()); ++ this->view().show(); + + // The widgets may not be valid, so refresh the button controller +- bc().refresh(); ++ this->bc().refresh(); + } + ++ + template + void ControlDialog::update() + { +- if (isBufferDependent() && !bufferIsAvailable()) ++ if (this->isBufferDependent() && !this->bufferIsAvailable()) + return; + + setParams(); +- if (emergency_exit_) { ++ if (this->emergency_exit_) { + hide(); + return; + } + +- bc().readOnly(bufferIsReadonly()); +- view().update(); ++ this->bc().readOnly(this->bufferIsReadonly()); ++ this->view().update(); + + // The widgets may not be valid, so refresh the button controller +- bc().refresh(); ++ this->bc().refresh(); + } + ++ + template + void ControlDialog::hide() + { +- emergency_exit_ = false; ++ this->emergency_exit_ = false; + clearParams(); + +- disconnect(); +- view().hide(); ++ this->disconnect(); ++ this->view().hide(); + } diff --git a/print/lyx16/files/patch-src::frontends::qt2::Qt2Base.h b/print/lyx16/files/patch-src::frontends::qt2::Qt2Base.h new file mode 100644 index 000000000000..d8bdd5d2893a --- /dev/null +++ b/print/lyx16/files/patch-src::frontends::qt2::Qt2Base.h @@ -0,0 +1,21 @@ +$NetBSD$ + +--- ./src/frontends/qt2/Qt2Base.h.orig 2003-02-01 17:48:38.000000000 -0700 ++++ ./src/frontends/qt2/Qt2Base.h +@@ -174,14 +174,14 @@ Qt2CB::Qt2CB(QString c + template + Controller & Qt2CB::controller() + { +- return static_cast(getController()); ++ return static_cast(this->getController()); + } + + + template + Controller const & Qt2CB::controller() const + { +- return static_cast(getController()); ++ return static_cast(this->getController()); + } + + diff --git a/print/lyx16/files/patch-src::frontends::xforms::FormBase.h b/print/lyx16/files/patch-src::frontends::xforms::FormBase.h new file mode 100644 index 000000000000..ac64841f6101 --- /dev/null +++ b/print/lyx16/files/patch-src::frontends::xforms::FormBase.h @@ -0,0 +1,21 @@ +$NetBSD$ + +--- src/frontends/xforms/FormBase.h.orig 2003-02-01 17:48:38.000000000 -0700 ++++ src/frontends/xforms/FormBase.h +@@ -188,14 +188,14 @@ FormCB::FormCB(string + template + Controller & FormCB::controller() + { +- return static_cast(getController()); ++ return static_cast(this->getController()); + } + + + template + Controller const & FormCB::controller() const + { +- return static_cast(getController()); ++ return static_cast(this->getController()); + } + + -- cgit