merged from trunk

[SVN r18033]
This commit is contained in:
Dave Abrahams
2003-03-20 15:38:58 +00:00
parent d11fe4464a
commit fcc6f41a56

View File

@@ -20,16 +20,21 @@
// //
// (BOOST_MSVC) != 0 && (BOOST_MSVC) <= 1200 // (BOOST_MSVC) != 0 && (BOOST_MSVC) <= 1200
// //
// When used for workarounds on the latest known version of a // When used for workarounds that apply to the latest known version
// compiler, the following convention should be observed: // and all earlier versions of a compiler, the following convention
// should be observed:
// //
// #if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1301)) // #if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1301))
// //
// The version number in this case corresponds to the last version in // The version number in this case corresponds to the last version in
// which the workaround was known to have been required. It only has // which the workaround was known to have been required. When
// value as a comment unless BOOST_DETECT_OUTDATED_WORKAROUNDS is // BOOST_DETECT_OUTDATED_WORKAROUNDS is not the defined, the macro
// defined, in which case a compiler warning or error will be issued // BOOST_TESTED_AT(x) expands to "!= 0", which effectively activates
// when the compiler version exceeds the argument to BOOST_TESTED_AT // the workaround for any version of the compiler. When
// BOOST_DETECT_OUTDATED_WORKAROUNDS is defined, a compiler warning or
// error will be issued if the compiler version exceeds the argument
// to BOOST_TESTED_AT(). This can be used to locate workarounds which
// may be obsoleted by newer versions.
# ifndef BOOST_STRICT_CONFIG # ifndef BOOST_STRICT_CONFIG
@@ -41,16 +46,16 @@
// broken preprocessor in MWCW 8.3 and earlier. // broken preprocessor in MWCW 8.3 and earlier.
// //
// The basic mechanism works as follows: // The basic mechanism works as follows:
// (symbol test) + 1 => 2 if the test passes, 1 otherwise // (symbol test) + 1 => if (symbol test) then 2 else 1
// 1 % ((symbol test) + 1) => 1 if the test passes, 0 otherwise // 1 % ((symbol test) + 1) => if (symbol test) then 1 else 0
// //
// The complication with % is for cooperation with BOOST_TESTED_AT(). // The complication with % is for cooperation with BOOST_TESTED_AT().
// When "test" is BOOST_TESTED_AT(x) and // When "test" is BOOST_TESTED_AT(x) and
// BOOST_DETECT_OUTDATED_WORKAROUNDS is #defined, // BOOST_DETECT_OUTDATED_WORKAROUNDS is #defined,
// //
// symbol test => 1 if symbol <= x, -1 otherwise // symbol test => if (symbol <= x) then 1 else -1
// (symbol test) + 1 => 2 if symbol <= x, 0 otherwise // (symbol test) + 1 => if (symbol <= x) then 2 else 0
// 1 % ((symbol test) + 1) => 1 if symbol <= x, zero divide otherwise // 1 % ((symbol test) + 1) => if (symbol <= x) then 1 else divide-by-zero
// //
# ifdef BOOST_DETECT_OUTDATED_WORKAROUNDS # ifdef BOOST_DETECT_OUTDATED_WORKAROUNDS