Fix various compatibility problems with newer GCC. This is an amalgamation of these upstream commits: https://git.savannah.gnu.org/cgit/src-highlite.git/commit/?id=904949c9026cb772dc93fbe0947a252ef47127f4 https://git.savannah.gnu.org/cgit/src-highlite.git/commit/?id=ab9fe5cb9b85c5afab94f2a7f4b6d7d473c14ee9 diff --git a/lib/srchilite/fileutil.cc b/lib/srchilite/fileutil.cc index 59a6d64..963178c 100644 --- a/lib/srchilite/fileutil.cc +++ b/lib/srchilite/fileutil.cc @@ -48,7 +48,7 @@ void set_file_util_verbose(bool b) { // FIXME avoid using a global variable std::string start_path; -string readFile(const string &fileName) throw (IOException) { +string readFile(const string &fileName) { ifstream file(fileName.c_str()); if (!file.is_open()) { diff --git a/lib/srchilite/fileutil.h b/lib/srchilite/fileutil.h index 7335a9b..042eb56 100644 --- a/lib/srchilite/fileutil.h +++ b/lib/srchilite/fileutil.h @@ -27,7 +27,7 @@ extern std::string start_path; * @return the contents of the file * @throw IOException */ -string readFile(const string &fileName) throw (IOException); +string readFile(const string &fileName); //char *read_file(const string &fileName); diff --git a/lib/tests/stdboosterror.h b/lib/tests/stdboosterror.h index 568545b..d59bfa6 100644 --- a/lib/tests/stdboosterror.h +++ b/lib/tests/stdboosterror.h @@ -4,7 +4,7 @@ #include static boost::regex_error - std_boost_exception(boost::regex_error(boost::regex_constants::error_bad_pattern)); + std_boost_exception = boost::regex_error(boost::regex_constants::error_bad_pattern); /** * returns the string representing a standard exception (which diff --git a/lib/tests/test_wordtokenizer_main.cpp b/lib/tests/test_wordtokenizer_main.cpp index 40e23b1..11ba389 100644 --- a/lib/tests/test_wordtokenizer_main.cpp +++ b/lib/tests/test_wordtokenizer_main.cpp @@ -11,6 +11,14 @@ using namespace std; using namespace srchilite; +/* + * We have to use 'std' namespaces because 'WordTokenizer::WordTokenizerResults::value_type' + * is an std::pair in disguise. We have to place 'operator<<()' + * into the same namespace for ADL to work. Otherwise gcc-12 or clang-13 can't find the + * overload. + */ +namespace std { + static ostream &operator <<(ostream &os, const WordTokenizer::WordTokenizerResults::value_type &); ostream &operator <<(ostream &os, const WordTokenizer::WordTokenizerResults::value_type &token) { @@ -23,6 +31,8 @@ ostream &operator <<(ostream &os, const WordTokenizer::WordTokenizerResults::val return os; } +} + int main() { WordTokenizer::WordTokenizerResults tokens; f....* doc/htmlxref.cnf: Update from Texinfo. Add entries for "mes", "guix.ru", and "guix.zh_CN". Ludovic Courtès 2019-05-04doc: Update htmlxref.cnf....* doc/htmlxref.cnf (G): Switch to https. (geiser, guix.de, guix.es, hurd): New entries. Ludovic Courtès 2018-07-05doc: Update URL of the Emacs-Guix manual....* doc/htmlxref.cnf (EMACS_GUIX): Update URL. Ludovic Courtès 2018-07-05doc: Mention translations of the manual....* doc/guix.texi (Top): Add note about l10n. * doc/htmlxref.cnf: Add "guix.fr". Ludovic Courtès 2017-05-30doc: htmlxref: Fix link to Emacs-Guix manual....Reported-by: Ludovic Courtès <ludo@gnu.org> This fixes a regression introduced by commit 8ca0c88a894c685b624757e38ee7663534f03460. * doc/htmlxref.cnf (EMACS_GUIX): Fix the link to 'html_node'. Alex Kost 2017-05-04doc: Add references to Emacs-Guix manual....* doc/htmlxref.cnf: Add links to the real manual. * doc/contributing.texi (Formatting Code): Add reference to it. * doc/guix.texi (Package Management): Likewise. Alex Kost