mirror of
https://github.com/boostorg/thread.git
synced 2026-01-23 18:12:12 +00:00
https://svn.boost.org/svn/boost/trunk ................ r42455 | johnmaddock | 2008-01-04 08:54:35 -0800 (Fri, 04 Jan 2008) | 1 line Fix typos. ................ r42456 | eric_niebler | 2008-01-04 09:14:53 -0800 (Fri, 04 Jan 2008) | 1 line mark up borland and sun accumulators failures ................ r42459 | andreas_huber69 | 2008-01-04 10:23:18 -0800 (Fri, 04 Jan 2008) | 1 line This should fix template parameter shadowing errors for gcc and Intel compilers. ................ r42462 | bgubenko | 2008-01-04 15:55:43 -0800 (Fri, 04 Jan 2008) | 1 line mark Accumulators tests for gcc 4.2.1 affected by GCC Bugzilla Bug 33580 ................ r42471 | turkanis | 2008-01-04 20:51:49 -0800 (Fri, 04 Jan 2008) | 1 line merged changes from iostreams_dev, revisions 42441-42469; added 'std::' for Intel on Linux/Darwin; added STDCXX workaround for codecvt; fixed docs for invert.hpp ................ r42473 | turkanis | 2008-01-04 23:35:44 -0800 (Fri, 04 Jan 2008) | 1 line new iostreams expected failures: stream_offset_64bit_test.cpp on Borland, and wide stream tests on gcc-3.4.2_hpux_pa_risc ................ r42475 | andreas_huber69 | 2008-01-05 04:42:02 -0800 (Sat, 05 Jan 2008) | 1 line Added defaults for in_state_reaction template parameters and updated tests accordingly. ................ r42476 | bemandawes | 2008-01-05 06:41:55 -0800 (Sat, 05 Jan 2008) | 1 line Disable Microsoft "secure" overloads in Dinkumware libraries since they cause compile errors with Intel versions 9 and 10 ................ r42478 | jurko | 2008-01-05 07:19:53 -0800 (Sat, 05 Jan 2008) | 1 line Typo corrections. Minor stylistic changes. ................ r42479 | jurko | 2008-01-05 08:53:03 -0800 (Sat, 05 Jan 2008) | 1 line Updated Boost.Jam command line option texts. Minor stylistic changes. ................ r42480 | jurko | 2008-01-05 08:55:36 -0800 (Sat, 05 Jan 2008) | 1 line Typo corrections. Minor stylistic changes. ................ r42481 | jurko | 2008-01-05 08:56:42 -0800 (Sat, 05 Jan 2008) | 1 line Typo correction. Corrected an invalid command-line option name. ................ r42482 | jurko | 2008-01-05 08:57:17 -0800 (Sat, 05 Jan 2008) | 1 line Corrected an invalid command-line option name reference. ................ r42483 | jurko | 2008-01-05 08:58:01 -0800 (Sat, 05 Jan 2008) | 1 line Corrected an out-of-date comment listing all command-line options. ................ r42484 | jurko | 2008-01-05 09:11:50 -0800 (Sat, 05 Jan 2008) | 1 line Corrected the used file suffix for the VERBATIM file type. Now the documentation is in sync with the 'customization' example. This also closes the Trac ticket 134. Minor stylistic changes. ................ r42485 | jurko | 2008-01-05 09:46:45 -0800 (Sat, 05 Jan 2008) | 1 line Stylistic comment changes & typo corrections. ................ r42486 | jurko | 2008-01-05 09:52:31 -0800 (Sat, 05 Jan 2008) | 1 line Stylistic comment changes & typo corrections in several files. Corrected an incorrect error message in boost-build/build/project.jam displayed when a --build-dir command-line option and a non top-level project build-dir attribute are specified. ................ r42487 | jurko | 2008-01-05 09:54:02 -0800 (Sat, 05 Jan 2008) | 1 line Cleaned up some import rule calls. ................ r42488 | jurko | 2008-01-05 10:02:23 -0800 (Sat, 05 Jan 2008) | 1 line Documentation wording cleaned up a bit. ................ r42489 | jurko | 2008-01-05 10:13:10 -0800 (Sat, 05 Jan 2008) | 1 line Removed or simplified some import calls. Comment updates. Minor stylistic changes. ................ r42490 | jurko | 2008-01-05 10:14:20 -0800 (Sat, 05 Jan 2008) | 2 lines Simplified the used make rules. Removed some dead code. Minor stylistic changes. ................ r42492 | jurko | 2008-01-05 10:29:36 -0800 (Sat, 05 Jan 2008) | 1 line Removed trailing spaces and some empty lines. ................ r42494 | jurko | 2008-01-05 12:02:24 -0800 (Sat, 05 Jan 2008) | 1 line Minor stylistic changes such as: comment typo corrections, wrapping lines to 80 characters, indentations, removing trailing spaces, etc. ................ r42495 | jurko | 2008-01-05 12:06:15 -0800 (Sat, 05 Jan 2008) | 2 lines Cleaned up where the stage module is imported in tools/builtin.jam. Added a missing import in tools/stage.jam that causes errors with the previous fix. Minor stylistic changes in tools/stage.jam. ................ r42496 | jurko | 2008-01-05 12:14:48 -0800 (Sat, 05 Jan 2008) | 1 line Comment cleanup. ................ r42497 | jurko | 2008-01-05 12:37:44 -0800 (Sat, 05 Jan 2008) | 1 line Minor stylistic changes - cleaned up import calls, wrapped much text at 80 characters updated comments, typo corrections, removed trailing spaces, etc. ................ r42498 | jurko | 2008-01-05 12:48:50 -0800 (Sat, 05 Jan 2008) | 1 line Renamed some Jamfile and project-root.jam references to Jamfile.jam and Jamroot.jam respectively. ................ r42499 | jurko | 2008-01-05 13:37:15 -0800 (Sat, 05 Jan 2008) | 1 line Test code cleaned up a bit. No functional changes. ................ r42502 | hkaiser | 2008-01-05 14:44:28 -0800 (Sat, 05 Jan 2008) | 1 line Wave: updated copyright messages to include the year 2008 (merged from release branch). ................ r42504 | jurko | 2008-01-05 15:18:17 -0800 (Sat, 05 Jan 2008) | 1 line Refactored the test into two separate test functions. Made the 'directory names with dots' test use the expect_output_line() tool instead of a manual find, causing a better diagnostic to be displayed in case of a failure. Made one of the test Jam scripts more compact. Made the test use the Jamroot.jam file instead of project-root.jam. ................ r42505 | bgubenko | 2008-01-05 15:35:05 -0800 (Sat, 05 Jan 2008) | 1 line mark up accumulators library test weighted_kurtosis for acc toolset ................ r42506 | jurko | 2008-01-05 16:25:48 -0800 (Sat, 05 Jan 2008) | 1 line No functional changes but only stylistic changes such as: comment typo corrections, wrapping lines to 80 characters, indentations, removing trailing spaces, removing empty lines, made tests use Jamfile.jam and Jamroot.jam Boost Build script names, removed unnecessary module imports, etc. ................ r42507 | jurko | 2008-01-05 16:53:09 -0800 (Sat, 05 Jan 2008) | 1 line No functional changes but only stylistic changes such as: comment typo corrections, wrapping lines to 80 characters, indentations, removing trailing spaces, removing empty lines, removed unnecessary module imports, etc. ................ r42508 | jurko | 2008-01-05 22:15:39 -0800 (Sat, 05 Jan 2008) | 5 lines Refactored build-system.jam. Added many detailed comments. Test configuration module now gets loaded the same as all other configuration modules. In addition to being able to specify which user configuration to load, user may now also prevent loading the user configuration by specifying an empty file name for it. ................ r42509 | jurko | 2008-01-05 22:50:56 -0800 (Sat, 05 Jan 2008) | 1 line Added a --test-config command-line option for specifying where the test configuration file should be loaded from instead of always being looked up in Boost Build's test folder. This allows non-test builds to not use test config when it exists on the system and different tests to use different test configurations when needed. ................ r42510 | jurko | 2008-01-05 22:58:24 -0800 (Sat, 05 Jan 2008) | 1 line Specifying that a build uses test configuration no longer prevents toolset auto-configuration and therefore no longer causes --toolset options to be ignored. ................ r42511 | jurko | 2008-01-05 23:13:28 -0800 (Sat, 05 Jan 2008) | 1 line Minor stylistic comment changes. ................ r42512 | jurko | 2008-01-05 23:17:08 -0800 (Sat, 05 Jan 2008) | 1 line Added support for choosing the toolset and toolset version to be used 'by default' by Boost Build. Allows testing of default toolset functionality. ................ r42513 | jurko | 2008-01-05 23:26:46 -0800 (Sat, 05 Jan 2008) | 1 line Upgraded the tool for testing that a certain line exists in the given output support so that it now also knows how to test that a certain line does not exist in the given output. ................ r42514 | jurko | 2008-01-05 23:28:47 -0800 (Sat, 05 Jan 2008) | 1 line Added the --ignore-site-config option telling Boost.Build not to load the site configuration file. ................ r42516 | jurko | 2008-01-06 00:16:34 -0800 (Sun, 06 Jan 2008) | 1 line Stylistic changes: typo corrections, comment alignments, output string updates, no functional changes, etc. ................ r42527 | andreas_huber69 | 2008-01-06 05:49:31 -0800 (Sun, 06 Jan 2008) | 1 line Various doc updates. ................ r42528 | danieljames | 2008-01-06 08:47:16 -0800 (Sun, 06 Jan 2008) | 2 lines Add Boost.Unordered and add to the documentation. Not fully integrated yet. ................ r42529 | danieljames | 2008-01-06 08:48:36 -0800 (Sun, 06 Jan 2008) | 1 line Add more libraries that use Boost.Hash to its intro. ................ r42530 | danieljames | 2008-01-06 08:49:11 -0800 (Sun, 06 Jan 2008) | 1 line Add Boost.Unordered to Boost.Hash's intro. ................ r42531 | danieljames | 2008-01-06 08:59:18 -0800 (Sun, 06 Jan 2008) | 1 line Combine the 'container' and 'unordered' tests. ................ r42532 | danieljames | 2008-01-06 08:59:49 -0800 (Sun, 06 Jan 2008) | 1 line Give the unordered exception test suite its own name. ................ r42533 | danieljames | 2008-01-06 09:13:15 -0800 (Sun, 06 Jan 2008) | 1 line Add the contents of compile_tests.cpp to set_compile.cpp and map_compile.cpp ................ r42534 | danieljames | 2008-01-06 09:16:51 -0800 (Sun, 06 Jan 2008) | 1 line Rename the test-suites to match other libraries' style. ................ r42535 | danieljames | 2008-01-06 09:23:16 -0800 (Sun, 06 Jan 2008) | 2 lines Add forwarding html files for Boost.Unordered. ................ r42536 | danieljames | 2008-01-06 09:40:32 -0800 (Sun, 06 Jan 2008) | 1 line Add Boost.Unordered to the regression tests. ................ r42537 | eric_niebler | 2008-01-06 09:44:06 -0800 (Sun, 06 Jan 2008) | 1 line add myself as maintainer of accumulators ................ r42538 | danieljames | 2008-01-06 09:45:18 -0800 (Sun, 06 Jan 2008) | 2 lines Add library identification. ................ r42539 | danieljames | 2008-01-06 09:48:11 -0800 (Sun, 06 Jan 2008) | 2 lines Add the unordered library to the maintainers list. ................ r42540 | danieljames | 2008-01-06 09:56:06 -0800 (Sun, 06 Jan 2008) | 2 lines Add unordered to the library list. ................ r42544 | turkanis | 2008-01-06 10:32:05 -0800 (Sun, 06 Jan 2008) | 18 lines copy.hpp: fix for Visual Age: std::min was passed arguments of different types; replaced std:: min with conditional detail/streambuf/indirect_streambuf.hpp: removed trailing comma in enum definition test/combine_test.cpp: test/symmetric_filter_test.cpp: test/compose_test.cpp: test/close_test.cpp: test/invert_test.cpp: test/tee_test.cpp: test/restrict_test.cpp: test/Jamfile.v2: moved tests for close() into the test files for various adapters ................ r42546 | jurko | 2008-01-06 12:06:33 -0800 (Sun, 06 Jan 2008) | 1 line Corrected a bug with the customized default toolset being read from the toolset module but defined in the build-system module. Effect was that customized default toolsets were getting ignored. ................ r42547 | jurko | 2008-01-06 12:37:55 -0800 (Sun, 06 Jan 2008) | 1 line Simple code cleanup. Typo corrections. ................ r42548 | jurko | 2008-01-06 12:43:25 -0800 (Sun, 06 Jan 2008) | 1 line Added support for tests configuring whether they want their Boost Build to ignore toolset requirements instead of always ignoring them. Minor stylistic changes. ................ r42549 | jurko | 2008-01-06 12:56:20 -0800 (Sun, 06 Jan 2008) | 1 line Added new tests related to Boost Build's default toolset handling. They test that the correct default toolset gets use and that when it gets used that has no different status than any other explicitly specified toolset. ................ r42563 | turkanis | 2008-01-06 17:26:52 -0800 (Sun, 06 Jan 2008) | 1 line marked restrict_test.cpp as failing on vacpp and stream_offset_64bit_test as failing on sun (iostreams) ................ r42564 | turkanis | 2008-01-06 17:32:29 -0800 (Sun, 06 Jan 2008) | 1 line alphabetized the iostreams failures ................ r42565 | turkanis | 2008-01-06 21:20:32 -0800 (Sun, 06 Jan 2008) | 5 lines merged changes from branches/iostreams_dev, revisions 42544-42544 - added "slice" as an alias for "restrict", for platforms on which "restrict" is a keyword - attempted to configure file_descriptor for __IBMCPP__ - added better error output to stream_offset_64bit_test.cpp ................ r42566 | jurko | 2008-01-07 09:00:59 -0800 (Mon, 07 Jan 2008) | 1 line Corrected explicitly specified user-config file handling. Was not looking for the specified file in the regular path instead of the current folder and did not work with absolute paths. ................ r42567 | jurko | 2008-01-07 10:15:13 -0800 (Mon, 07 Jan 2008) | 1 line Code cleanup. Converted to using True/False instead of 1/0. Changed to obey documented coding conventions regarding whitespace and function parameters. Renamed private member functions to use the __ name prefix. ................ r42568 | jurko | 2008-01-07 10:38:28 -0800 (Mon, 07 Jan 2008) | 1 line Added a new configuration test making sure that the bug with not being able to process absolute user-config configuration file references never rears its ugly head again. ................ r42570 | eric_niebler | 2008-01-07 11:06:31 -0800 (Mon, 07 Jan 2008) | 1 line s/order/tail/ ................ r42571 | eric_niebler | 2008-01-07 11:08:16 -0800 (Mon, 07 Jan 2008) | 1 line add missing includes, fix signed/unsigned warnings, clean-up trailing whitespace, fixes #1552 ................ r42572 | danieljames | 2008-01-07 11:40:32 -0800 (Mon, 07 Jan 2008) | 1 line Rename the exception tests so that they don't clash with the normal tests. ................ r42573 | danieljames | 2008-01-07 11:41:05 -0800 (Mon, 07 Jan 2008) | 1 line Remove some development code. ................ r42575 | danieljames | 2008-01-07 11:44:13 -0800 (Mon, 07 Jan 2008) | 3 lines Add missing 'use namespace std'. Which I should have done when I was told about them before. Sorry. ................ r42576 | danieljames | 2008-01-07 11:46:27 -0800 (Mon, 07 Jan 2008) | 1 line Add support for multiple copyrights in the library info. ................ r42578 | danieljames | 2008-01-07 11:51:02 -0800 (Mon, 07 Jan 2008) | 1 line Reneame the set and map compile tests so they'll be adjacent in the test results. ................ r42580 | danieljames | 2008-01-07 12:06:15 -0800 (Mon, 07 Jan 2008) | 1 line Avoid some uses of an invalid pointer. ................ r42581 | danieljames | 2008-01-07 12:07:12 -0800 (Mon, 07 Jan 2008) | 1 line Use the default location for the reference documentation. ................ r42587 | danieljames | 2008-01-07 13:05:42 -0800 (Mon, 07 Jan 2008) | 5 lines Fix a bug which was causing the memory area stuff to fail. I should probably try to be less clever and use memory area's lower bounds as the key, and do the extra work required to get that working. ................ r42588 | danieljames | 2008-01-07 13:07:43 -0800 (Mon, 07 Jan 2008) | 1 line Fix an off by one error. ................ r42591 | danieljames | 2008-01-07 13:47:24 -0800 (Mon, 07 Jan 2008) | 1 line Merge in spell check. ................ r42596 | turkanis | 2008-01-07 15:13:26 -0800 (Mon, 07 Jan 2008) | 5 lines merged changes from branches/iostreams_dev, revisions 42565-42595: - Simplified implementation with the help to the C-runtime function _get_osfhandle so that on Windows only a single HANDLE is stored and the POSIX-style implementation is never needed; added the handle_type on POSIX systems (typedef for int) and a function returning the underlying handle as an instance of handle_type - fixed the bug described in ticket Ticket #1551 (stream_buffer::seekpos ignores openmode parameter) - fixed test/operation_sequence_test.cpp file description ................ r42598 | grafik | 2008-01-07 18:49:25 -0800 (Mon, 07 Jan 2008) | 1 line Mostly fix bad path calc for direct html from doxygen doc generation. (fixes #1562) ................ r42600 | turkanis | 2008-01-07 19:49:23 -0800 (Mon, 07 Jan 2008) | 1 line merged changes from branches/iostreams_dev revisions 42595-42599; applied Dinkumware implementation of positioning functions to IBM Visual Age; simplified and corrected implementation ................ r42602 | turkanis | 2008-01-07 20:20:38 -0800 (Mon, 07 Jan 2008) | 1 line removed unneeded headers, one of which (restrict.hpp) causes failures on IBM Visual Age ................ r42603 | turkanis | 2008-01-07 20:52:54 -0800 (Mon, 07 Jan 2008) | 1 line removed spurious '.cpp' extension from test names (iostreams) ................ r42612 | danieljames | 2008-01-08 05:59:01 -0800 (Tue, 08 Jan 2008) | 3 lines Merge in latest unordered developments (revisions 42607-42611). ................ r42613 | jurko | 2008-01-08 06:40:24 -0800 (Tue, 08 Jan 2008) | 1 line Added a new test making sure properties conditioned on multiple different feature values are handled correctly. This especially includes testing the case when one of those features is <toolset> and the value given for it includes a toolset version. ................ r42614 | jurko | 2008-01-08 07:21:15 -0800 (Tue, 08 Jan 2008) | 1 line Made some debugging messages more consistent. ................ r42615 | eric_niebler | 2008-01-08 09:42:20 -0800 (Tue, 08 Jan 2008) | 1 line support for LaTeX formulas in Doxygen comments ................ r42616 | eric_niebler | 2008-01-08 09:43:34 -0800 (Tue, 08 Jan 2008) | 1 line automatically generate png files from LaTeX formulas using doxygen ................ r42617 | jurko | 2008-01-08 09:51:30 -0800 (Tue, 08 Jan 2008) | 1 line Comment correction. ................ r42619 | danieljames | 2008-01-08 10:15:01 -0800 (Tue, 08 Jan 2008) | 1 line Merge: Another missing 'using namespace std' ................ r42620 | eric_niebler | 2008-01-08 10:43:43 -0800 (Tue, 08 Jan 2008) | 1 line fix signed/unsigned warnings, clean up trailing whitespace ................ r42624 | eric_niebler | 2008-01-08 13:40:52 -0800 (Tue, 08 Jan 2008) | 1 line disable iterator debugging for all msvc versions ................ r42625 | turkanis | 2008-01-08 14:25:01 -0800 (Tue, 08 Jan 2008) | 1 line merged changes from branches/iostreams_dev, revisions 42602-42624: adding missing included to fix #1550; fix for positioning on IBM; fix for file_descriptor on POSIX; restructed the version range for the Borland workaround in large_file_test.cpp ................ r42626 | jurko | 2008-01-08 17:09:26 -0800 (Tue, 08 Jan 2008) | 1 line Minor stylistic code indentation changes. ................ r42627 | jurko | 2008-01-08 17:11:03 -0800 (Tue, 08 Jan 2008) | 1 line Tried trailing spaces. Minor comment typo corrections. ................ r42628 | jurko | 2008-01-08 17:18:38 -0800 (Tue, 08 Jan 2008) | 1 line Remove trailing spaces. Removed an empty line. ................ r42629 | jurko | 2008-01-08 20:05:29 -0800 (Tue, 08 Jan 2008) | 8 lines Updated the __ACTION_RULE__ to not return its action command output as a single string but instead split it into a list of output lines. This allows Jam code using this output to work correctly independently of what newline character combinations are in use. This was causing problems with Boost Build unit tests which can now be updated to pass. Consequences & checks: * Final __ACTION_RULE__ rule parameter has changed from output ? to output-lines *. * Updated corresponding Jam documentation. * Updated the all related Boost Build code. * No code on the Boost trunk uses this rule except for Boost Build itself. ................ r42630 | jurko | 2008-01-08 20:15:35 -0800 (Tue, 08 Jan 2008) | 1 line Fixed a failing test by making it access action output using the __ACTION_RULE__ rule so it would not be affected by the level of debug output given by Boost Build/Jam. ................ r42631 | jurko | 2008-01-08 20:30:25 -0800 (Tue, 08 Jan 2008) | 1 line Fixed a failing test by making it access its action results using the __ACTION_RULE__ rule. Now it works with the default debug level settings (i.e. no action output displayed). ................ r42632 | grafik | 2008-01-08 20:31:58 -0800 (Tue, 08 Jan 2008) | 1 line Revert various changes that break backward compatibility, and also some minor edits. ................ r42633 | grafik | 2008-01-08 20:34:12 -0800 (Tue, 08 Jan 2008) | 1 line Revert various changes that break backward compatibility, and also some minor edits. ................ r42637 | jurko | 2008-01-09 06:36:37 -0800 (Wed, 09 Jan 2008) | 1 line Updated the test so it passes on Windows. Had to change it to enable action output logging and compensate for the fact that now action names are sent to the output as well. Minor stylistic changes. ................ r42639 | jurko | 2008-01-09 09:03:45 -0800 (Wed, 09 Jan 2008) | 1 line Updated the test so it passes on Windows. Had to change it to enable action output logging and compensate for the fact that now action names are sent to the output as well. Minor stylistic changes. ................ r42641 | eric_niebler | 2008-01-09 12:21:51 -0800 (Wed, 09 Jan 2008) | 1 line copy the png files to where fop will look for them when building pdf ................ r42642 | eric_niebler | 2008-01-09 12:33:05 -0800 (Wed, 09 Jan 2008) | 1 line fix more signed/unsigned warnings ................ r42644 | turkanis | 2008-01-09 15:13:57 -0800 (Wed, 09 Jan 2008) | 1 line marked stream_offset_64bit_test as an expected failure on vacpp (iostreams) ................ r42645 | turkanis | 2008-01-09 15:16:17 -0800 (Wed, 09 Jan 2008) | 1 line replaced 2 occurrences of the identifier 'restrict' with BOOST_IOSTREAMS_RESTRICT ................ r42646 | turkanis | 2008-01-09 19:27:51 -0800 (Wed, 09 Jan 2008) | 1 line added expected failures for Sun and IBM; removed a Borland intermittent failure; removed some obsolete toolsets (iostreams) ................ r42647 | troyer | 2008-01-10 01:49:16 -0800 (Thu, 10 Jan 2008) | 1 line Optimizations for Boost.MPI ................ r42648 | troyer | 2008-01-10 03:54:36 -0800 (Thu, 10 Jan 2008) | 1 line Undid backward-compatibility breaking change in pair serialization ................ r42651 | johnmaddock | 2008-01-10 04:10:37 -0800 (Thu, 10 Jan 2008) | 1 line Apply patch from Issue #1187. ................ r42657 | anthonyw | 2008-01-10 06:19:36 -0800 (Thu, 10 Jan 2008) | 1 line removed references to NULL ................ r42658 | turkanis | 2008-01-10 10:50:19 -0800 (Thu, 10 Jan 2008) | 1 line marked up two moe expected failures for sun-5.7-5.8 (iostreams) ................ r42664 | bgubenko | 2008-01-10 13:13:42 -0800 (Thu, 10 Jan 2008) | 1 line marked iostreams library compose_test for gcc-3.4.6_linux_ia64 : linking exceeds 10 min. limit ................ r42665 | danieljames | 2008-01-10 14:25:35 -0800 (Thu, 10 Jan 2008) | 2 lines Initialise svnmerge for merging changes for unordered. ................ r42666 | danieljames | 2008-01-10 14:30:46 -0800 (Thu, 10 Jan 2008) | 6 lines Merge latest unordered developments: Make simple_test test a little more. Use doubles for calculating max load factor. Some workarounds, mostly for Borland and running the tests. ................ r42670 | turkanis | 2008-01-10 16:02:36 -0800 (Thu, 10 Jan 2008) | 1 line merged changes from branches/iostreams_dev, revisions 42645=42660; fix for Intel-darwin; removed dependence of file_descriptor_test and mapped_file_test on library boost_iostreams ................ r42672 | turkanis | 2008-01-10 17:35:46 -0800 (Thu, 10 Jan 2008) | 1 line force static runtime-link for intel-darwin ................ r42674 | johnmaddock | 2008-01-11 01:55:43 -0800 (Fri, 11 Jan 2008) | 1 line Fix bugs reported by Will Drewry: certain invalid regexes can cause the library to access invalid memory, changed to ensure that the correct exception is thrown long before this happens. ................ r42676 | jurko | 2008-01-11 05:44:51 -0800 (Fri, 11 Jan 2008) | 1 line Removed the manual boost-build.jam file creation since that file already exists in the SVN repository and this only overwrote it with the same content minus the copyright notice. Removed a reference to the no longer existing boost_build_v2.html file. ................ r42677 | johnmaddock | 2008-01-11 05:48:57 -0800 (Fri, 11 Jan 2008) | 1 line Update for Intel-10.1. ................ r42684 | turkanis | 2008-01-11 11:12:22 -0800 (Fri, 11 Jan 2008) | 1 line another attempt to fix linking for compression tests on intel-darwin ................ r42688 | turkanis | 2008-01-11 14:58:21 -0800 (Fri, 11 Jan 2008) | 1 line merged changes from iostreams_dev; fixes for IBM and more documentation ................ r42689 | turkanis | 2008-01-11 18:45:55 -0800 (Fri, 11 Jan 2008) | 1 line more detailed note for vacpp (iostreams) ................ r42691 | eric_niebler | 2008-01-11 22:43:28 -0800 (Fri, 11 Jan 2008) | 1 line new style transforms a-la proto v3 ................ r42693 | nesotto | 2008-01-12 04:38:57 -0800 (Sat, 12 Jan 2008) | 1 line doc fixes ................ r42698 | danieljames | 2008-01-12 06:43:40 -0800 (Sat, 12 Jan 2008) | 9 lines Merge the latest unordered changes. These are concerned with getting the tests working on more compilers. The biggest change is that the exception tests have been changed to use a very simple exception testing mechanism on top of lightweight_test. This was because Boost.Test exception testing isn't working on several platforms. I'm trying to set this up so that I can use Boost.Test on compilers which it completely supports, and lightweight test on others. Boost.Test tests more than my simple exception testing code ever will so it's worth using where I can. ................ r42700 | eric_niebler | 2008-01-12 09:09:17 -0800 (Sat, 12 Jan 2008) | 1 line missing includes ................ r42701 | eric_niebler | 2008-01-12 09:40:40 -0800 (Sat, 12 Jan 2008) | 1 line more msvc-7.1-friendly default_context implementation, more missing headers ................ r42706 | turkanis | 2008-01-12 12:19:42 -0800 (Sat, 12 Jan 2008) | 1 line corrected use of feature detection macros for AIX; simplified implementation slightly; updated docs ................ r42707 | turkanis | 2008-01-12 12:20:35 -0800 (Sat, 12 Jan 2008) | 1 line removed intel-darwin sepcific code, since it didn't work ................ r42708 | eric_niebler | 2008-01-12 13:19:45 -0800 (Sat, 12 Jan 2008) | 1 line port toy_spirit example to proto v3 ................ r42713 | turkanis | 2008-01-12 23:17:07 -0800 (Sat, 12 Jan 2008) | 1 line improved docs ................ r42715 | nesotto | 2008-01-13 03:37:41 -0800 (Sun, 13 Jan 2008) | 1 line fixed #if to #ifdef ................ r42722 | bgubenko | 2008-01-13 07:52:12 -0800 (Sun, 13 Jan 2008) | 1 line better note for iostreams library test compose_test on gcc-3.4.6_linux_ia64 ................ r42723 | bgubenko | 2008-01-13 08:12:37 -0800 (Sun, 13 Jan 2008) | 1 line marked up random library test random_test for gcc-3.4.6_linux_ia64 ................ r42724 | danieljames | 2008-01-13 08:19:26 -0800 (Sun, 13 Jan 2008) | 3 lines Merge in latest changes to Boost.Unordered. Some compiler workarounds and starting to clean up the tests a little. ................ r42729 | eric_niebler | 2008-01-13 11:39:54 -0800 (Sun, 13 Jan 2008) | 1 line work around msvc-7.1 bug ................ r42741 | eric_niebler | 2008-01-13 13:56:56 -0800 (Sun, 13 Jan 2008) | 1 line boost template instantiation depth on darwin ................ r42745 | johnmaddock | 2008-01-14 01:46:12 -0800 (Mon, 14 Jan 2008) | 1 line Ooops, fix broken escape sequence. ................ r42747 | johnmaddock | 2008-01-14 01:58:36 -0800 (Mon, 14 Jan 2008) | 1 line Fix documentation typos. ................ r42750 | chris_kohlhoff | 2008-01-14 05:13:35 -0800 (Mon, 14 Jan 2008) | 2 lines Fix concept name in comment. ................ r42751 | johnmaddock | 2008-01-14 05:17:09 -0800 (Mon, 14 Jan 2008) | 1 line Patch regex concept checks and TR1 library to work with VC9 + MS TR1 feature pack. ................ r42752 | chris_kohlhoff | 2008-01-14 05:20:06 -0800 (Mon, 14 Jan 2008) | 2 lines Add missing broken pipe error. ................ r42753 | chris_kohlhoff | 2008-01-14 05:21:37 -0800 (Mon, 14 Jan 2008) | 3 lines Don't include sys/time.h when compiling with aCC, as that header does not supply pselect(), which is needed for HP-UX/aCC to work correctly. ................ r42754 | chris_kohlhoff | 2008-01-14 05:22:21 -0800 (Mon, 14 Jan 2008) | 2 lines Disable noisy and incorrect /Wp64 warnings generated by MSVC. ................ r42755 | chris_kohlhoff | 2008-01-14 05:24:28 -0800 (Mon, 14 Jan 2008) | 3 lines Don't call epoll_wait/kevent if there are no old operations (where old means added prior to the last epoll_wait/kevent call) needing to be demultiplexed. ................ r42756 | chris_kohlhoff | 2008-01-14 05:25:24 -0800 (Mon, 14 Jan 2008) | 2 lines Silence some integer truncation warnings. ................ r42758 | chris_kohlhoff | 2008-01-14 05:27:52 -0800 (Mon, 14 Jan 2008) | 8 lines Silence some integer truncation warnings. Only perform the windows-bug workaround where we use a short timeout with GetQueuedCompletionStatus from one thread, i.e. the timer thread. Keep track of the number of OVERLAPPED-derived operations to ensure that they all get cleaned up when the io_service is destroyed. ................ r42759 | chris_kohlhoff | 2008-01-14 05:29:08 -0800 (Mon, 14 Jan 2008) | 5 lines Check for truncation when converting buffer size from size_t to openssl's int argument. Try to fix possible thread-safety issues in SSL wrapper. ................ r42766 | eric_niebler | 2008-01-14 08:49:32 -0800 (Mon, 14 Jan 2008) | 1 line register mpl::bool_ with typeof ................ r42767 | dgregor | 2008-01-14 09:01:26 -0800 (Mon, 14 Jan 2008) | 1 line Improved suggestion for dealing with Qt MOC, from Niels Dekker ................ r42771 | niels_dekker | 2008-01-14 10:17:30 -0800 (Mon, 14 Jan 2008) | 1 line Documented value_init workaround to compiler issues, added new introduction, updated to 2003 edition of C++ Standard -- reviewed by Fernando Cacciola ................ r42773 | guwi17 | 2008-01-14 11:04:43 -0800 (Mon, 14 Jan 2008) | 2 lines - fixed typo ................ r42776 | eric_niebler | 2008-01-14 12:26:58 -0800 (Mon, 14 Jan 2008) | 1 line add skip(), for specifying a skip regex ................ r42778 | turkanis | 2008-01-14 12:47:17 -0800 (Mon, 14 Jan 2008) | 1 line overhaul of dual_use filters: close() is now called just once; suppressed Borland/Dinkumware warnings in mapped_file.hpp ................ r42779 | niels_dekker | 2008-01-14 13:46:20 -0800 (Mon, 14 Jan 2008) | 1 line Minor "beautifications" of value_init documentation, inc. placing references in order of appearance ................ r42780 | lbourdev | 2008-01-14 14:06:07 -0800 (Mon, 14 Jan 2008) | 3 lines Changed size_t to std::size_t ................ r42781 | lbourdev | 2008-01-14 15:25:10 -0800 (Mon, 14 Jan 2008) | 3 lines GIL: Changing size_t to std::size_t ................ r42788 | eric_niebler | 2008-01-14 22:46:39 -0800 (Mon, 14 Jan 2008) | 1 line code clean-up, begin updating the transform section in proto's docs ................ r42789 | eric_niebler | 2008-01-14 23:46:51 -0800 (Mon, 14 Jan 2008) | 1 line try disabling iterator debugging for intel-win toolset ................ r42797 | t_schwinger | 2008-01-15 11:46:10 -0800 (Tue, 15 Jan 2008) | 3 lines adds missing #include ................ r42798 | niels_dekker | 2008-01-15 11:53:28 -0800 (Tue, 15 Jan 2008) | 1 line value_init doc + test: Added revision date. ................ r42801 | jurko | 2008-01-15 13:13:52 -0800 (Tue, 15 Jan 2008) | 1 line Minor stylistic comment changes. Removed trailing spaces. ................ r42804 | eric_niebler | 2008-01-15 14:06:51 -0800 (Tue, 15 Jan 2008) | 1 line document call<>, make<> and bind<> ................ r42807 | turkanis | 2008-01-15 14:54:40 -0800 (Tue, 15 Jan 2008) | 1 line rewrote treatment of result_of in terms of a new (hopefully temporary) config macro BOOST_IOSTREAMS_NO_RESULT_OF; fixed docs ................ r42811 | turkanis | 2008-01-15 17:14:04 -0800 (Tue, 15 Jan 2008) | 1 line reverted last change except for doc fixes; regression was result of test runner's local patch ................ r42813 | turkanis | 2008-01-15 17:16:36 -0800 (Tue, 15 Jan 2008) | 1 line botched last commit ................ r42814 | djenkins | 2008-01-15 22:39:34 -0800 (Tue, 15 Jan 2008) | 1 line missing include ................ r42815 | niels_dekker | 2008-01-16 01:35:12 -0800 (Wed, 16 Jan 2008) | 1 line Added convenience class initialized_value, as announced at http://article.gmane.org/gmane.comp.lib.boost.devel/169833 ................ r42816 | niels_dekker | 2008-01-16 01:37:25 -0800 (Wed, 16 Jan 2008) | 1 line Added test and documentation for convenience class initialized_value, that was added with changeset [42815] ................ r42817 | chris_kohlhoff | 2008-01-16 05:46:01 -0800 (Wed, 16 Jan 2008) | 2 lines Set the openssl callback function for getting a thread ID. ................ r42818 | anthonyw | 2008-01-16 07:23:36 -0800 (Wed, 16 Jan 2008) | 1 line Provide tss_cleanup_implemented as a dummy function on Windows CE to allow tests to run ................ r42821 | t_schwinger | 2008-01-16 11:16:37 -0800 (Wed, 16 Jan 2008) | 3 lines works around MSVC7.1 problems (hopefully) ................ r42822 | t_schwinger | 2008-01-16 11:17:09 -0800 (Wed, 16 Jan 2008) | 3 lines attempts to fix Borland regressions ................ r42823 | eric_niebler | 2008-01-16 11:24:33 -0800 (Wed, 16 Jan 2008) | 1 line document when<> and is_callable<> ................ r42825 | turkanis | 2008-01-16 12:46:56 -0800 (Wed, 16 Jan 2008) | 1 line replaced __IBMCPP__ with _AIX ................ r42827 | turkanis | 2008-01-16 16:50:14 -0800 (Wed, 16 Jan 2008) | 1 line added pgi to toolsets expected to fail seekawble_file_test (iostreams) ................ r42836 | eric_niebler | 2008-01-17 14:47:54 -0800 (Thu, 17 Jan 2008) | 1 line stl_iterator does better error handling ................ r42837 | jurko | 2008-01-17 17:14:17 -0800 (Thu, 17 Jan 2008) | 1 line Stylistic changes. Removed trailing spaces. Removed empty lines. Corrected comment typos and wording. ................ r42839 | eric_niebler | 2008-01-17 23:56:31 -0800 (Thu, 17 Jan 2008) | 1 line tweaks for better doxygen-ated output ................ r42840 | eric_niebler | 2008-01-17 23:56:59 -0800 (Thu, 17 Jan 2008) | 1 line updated reference section ................ r42841 | eric_niebler | 2008-01-17 23:58:48 -0800 (Thu, 17 Jan 2008) | 1 line add back reference section, document user-defined transforms ................ r42843 | t_schwinger | 2008-01-18 06:37:41 -0800 (Fri, 18 Jan 2008) | 3 lines makes member object support work with BCC ................ r42851 | johnmaddock | 2008-01-18 08:56:57 -0800 (Fri, 18 Jan 2008) | 1 line Add needed <iostream> include. ................ r42852 | johnmaddock | 2008-01-18 09:05:35 -0800 (Fri, 18 Jan 2008) | 1 line We don't have a tr1::hash functor if the std lib is the Apache version. ................ r42853 | hkaiser | 2008-01-18 09:56:53 -0800 (Fri, 18 Jan 2008) | 1 line Wave: removed T_DEFINED token id from the library. ................ r42855 | johnmaddock | 2008-01-18 10:18:17 -0800 (Fri, 18 Jan 2008) | 1 line Needs to #include <cstring> in order to use std::memset. ................ r42856 | danieljames | 2008-01-18 11:35:55 -0800 (Fri, 18 Jan 2008) | 2 lines Merge in some changes to the unordered tests. ................ r42857 | t_schwinger | 2008-01-18 12:05:56 -0800 (Fri, 18 Jan 2008) | 3 lines simplifies function_types markup ................ r42858 | t_schwinger | 2008-01-18 12:52:06 -0800 (Fri, 18 Jan 2008) | 3 lines attempts to fix BCB 5.9 regression in synthesis/mem_func_ptr_cv_ptr_to_this test ................ r42859 | t_schwinger | 2008-01-18 13:06:44 -0800 (Fri, 18 Jan 2008) | 3 lines attempts to fix pathscale failure ................ r42868 | niels_dekker | 2008-01-19 12:21:18 -0800 (Sat, 19 Jan 2008) | 1 line value_init_test now works around Borland 5.82 bug ("Error E2015: Ambiguity..." when using initialized_value), that is fixed with a newer compiler version ................ r42869 | niels_dekker | 2008-01-19 12:52:04 -0800 (Sat, 19 Jan 2008) | 1 line Removed local named variable from value_initialized::operator=, as Fernando Cacciola suggested me to avoid unnecessary named variables. ................ r42873 | bemandawes | 2008-01-19 18:01:35 -0800 (Sat, 19 Jan 2008) | 1 line Remove extraneous defines since they are inherited from library build Jamfile ................ r42877 | johnmaddock | 2008-01-20 01:42:35 -0800 (Sun, 20 Jan 2008) | 1 line Add include of <eh.h> for msvc. ................ r42878 | igaztanaga | 2008-01-20 03:54:47 -0800 (Sun, 20 Jan 2008) | 5 lines Updated Interprocess and Intrusive: -> Added linear slist to intrusive -> Updated all allocators to version 2 allocators in Interprocess -> Optimized rbtree_best_fit size overhead to 1 std:size_t. ................ r42881 | danieljames | 2008-01-20 09:37:21 -0800 (Sun, 20 Jan 2008) | 1 line Include <new> to get std::bad_alloc. ................ r42882 | danieljames | 2008-01-20 10:55:57 -0800 (Sun, 20 Jan 2008) | 22 lines Merged revisions 42856-42881 via svnmerge from https://svn.boost.org/svn/boost/branches/unordered/trunk ........ r42880 | danieljames | 2008-01-20 16:10:43 +0000 (Sun, 20 Jan 2008) | 17 lines Simplify the tests a little: Add a parameter to random_values to control what sort of values it generates. This means that instead of using equivalent_object to test collisions (which was a total hack) we now just need another parameter. This requires some meta programming to act differently for maps and sets. Because of this pairs no longer need to be generated so remove the code for doing that (which doesn't work on some compilers). Remove the generator object, just call generate directly. Remove some of the tests using int containers, they didn't really add to anthing other than the compile time (some tests are timing out). ........ ................ r42884 | jurko | 2008-01-20 12:18:50 -0800 (Sun, 20 Jan 2008) | 5 lines Minor stylistic changes: * Removed trailing spaces. * Added a comment for code discovering the user's home-directories. * Removed a stale regex import. * Removed an old corpse 'identity' rule found inside the __test__ rule. ................ r42890 | johnmaddock | 2008-01-21 01:41:17 -0800 (Mon, 21 Jan 2008) | 1 line Only disable wide character support for HP aCC: for gcc the logic is already taken care of in libstdcpp3.hpp. ................ r42897 | hkaiser | 2008-01-21 08:13:31 -0800 (Mon, 21 Jan 2008) | 1 line Removed a duplicate entry. ................ r42898 | rogeeff | 2008-01-21 09:02:53 -0800 (Mon, 21 Jan 2008) | 1 line changed output of booleans ................ r42899 | johnmaddock | 2008-01-21 10:11:09 -0800 (Mon, 21 Jan 2008) | 1 line Updated type traits library so that everything compiles with -Wall -pedantic with GCC. ................ r42904 | davedeakins | 2008-01-21 11:38:44 -0800 (Mon, 21 Jan 2008) | 1 line Don't include <eh.h> for WinCE (since WinCE does not have this header) ................ r42906 | eric_niebler | 2008-01-21 12:39:35 -0800 (Mon, 21 Jan 2008) | 1 line minor clean-up ................ r42909 | rogeeff | 2008-01-21 19:41:23 -0800 (Mon, 21 Jan 2008) | 1 line missing header ................ r42911 | igaztanaga | 2008-01-22 08:49:22 -0800 (Tue, 22 Jan 2008) | 1 line Refactor some allocation code and fix instantiation problem in 64 bit platforms ................ r42916 | eric_niebler | 2008-01-22 12:42:18 -0800 (Tue, 22 Jan 2008) | 1 line add concepts section to proto reference ................ r42917 | hljin | 2008-01-22 14:10:48 -0800 (Tue, 22 Jan 2008) | 1 line GIL: fixed the problem with std::hex by adding #include <ios> ................ r42918 | eric_niebler | 2008-01-22 18:23:15 -0800 (Tue, 22 Jan 2008) | 1 line proto works with boost 1.34.1 ................ r42929 | johnmaddock | 2008-01-23 08:08:44 -0800 (Wed, 23 Jan 2008) | 1 line Applies fix for issue #1598: added missing #include. ................ r42931 | igaztanaga | 2008-01-23 11:34:39 -0800 (Wed, 23 Jan 2008) | 1 line Ticket #1593: [interprocess] 'streamoff' : is not a member of 'std' ................ r42934 | andreas_huber69 | 2008-01-23 13:46:58 -0800 (Wed, 23 Jan 2008) | 1 line Fixes #1594 ................ r42935 | eric_niebler | 2008-01-23 13:57:47 -0800 (Wed, 23 Jan 2008) | 1 line fix dependency issue in Jamfile ................ r42938 | jano_gaspar | 2008-01-23 15:04:57 -0800 (Wed, 23 Jan 2008) | 1 line circular_buffer: updated documentation ................ r42939 | eric_niebler | 2008-01-23 15:25:24 -0800 (Wed, 23 Jan 2008) | 1 line fix quickbook scanner to recognize the [import ...] block ................ r42943 | danieljames | 2008-01-23 15:39:59 -0800 (Wed, 23 Jan 2008) | 60 lines Merged revisions 42882-42941 via svnmerge from https://svn.boost.org/svn/boost/branches/unordered/trunk ................ r42887 | danieljames | 2008-01-20 21:32:04 +0000 (Sun, 20 Jan 2008) | 10 lines Merged revisions 42590-42664,42667-42697,42699-42723,42725-42855,42857-42881 via svnmerge from https://svn.boost.org/svn/boost/trunk ........ r42881 | danieljames | 2008-01-20 17:37:21 +0000 (Sun, 20 Jan 2008) | 1 line Include <new> to get std::bad_alloc. ........ ................ r42892 | danieljames | 2008-01-21 13:03:16 +0000 (Mon, 21 Jan 2008) | 1 line On some compilers the Rogue Wave/Apache stdcxx library doesn't have the normal std::distance, but instead has a variant that takes the result as the third parameter so it doesn't have to work out the type from the iterator. ................ r42893 | danieljames | 2008-01-21 13:07:58 +0000 (Mon, 21 Jan 2008) | 1 line Fix a typo in the last commit. ................ r42895 | danieljames | 2008-01-21 13:33:29 +0000 (Mon, 21 Jan 2008) | 1 line Remove tabs from the last checkin. ................ r42896 | danieljames | 2008-01-21 15:51:40 +0000 (Mon, 21 Jan 2008) | 1 line Use Boost config to tell when we have a std::distance function. Also, no need for a macro. ................ r42908 | danieljames | 2008-01-21 21:37:04 +0000 (Mon, 21 Jan 2008) | 1 line Use boost::long_long_type and boost::ulong_long_type. ................ r42921 | danieljames | 2008-01-23 11:43:35 +0000 (Wed, 23 Jan 2008) | 1 line Remove some tabs. ................ r42922 | danieljames | 2008-01-23 11:46:28 +0000 (Wed, 23 Jan 2008) | 2 lines Add missing include. Refs #1596 ................ r42923 | danieljames | 2008-01-23 11:52:47 +0000 (Wed, 23 Jan 2008) | 2 lines Always use void const* for the second parameter of allocate. Refs #1596. ................ r42936 | danieljames | 2008-01-23 22:22:16 +0000 (Wed, 23 Jan 2008) | 1 line Use Boost style library name in the documentation. ................ r42937 | danieljames | 2008-01-23 22:22:32 +0000 (Wed, 23 Jan 2008) | 1 line More tabs. ................ r42941 | danieljames | 2008-01-23 23:35:01 +0000 (Wed, 23 Jan 2008) | 1 line Fix all the allocators. ................ ................ r42948 | turkanis | 2008-01-23 22:50:32 -0800 (Wed, 23 Jan 2008) | 1 line merged changes from iostreams_dev, revisions 42825-42947 ................ r42950 | t_schwinger | 2008-01-24 10:56:27 -0800 (Thu, 24 Jan 2008) | 3 lines correctsbroken compiler support for MPL ................ r42951 | eric_niebler | 2008-01-24 13:06:23 -0800 (Thu, 24 Jan 2008) | 1 line peeker optimization looks inside independent sub-expressions ................ r42952 | nesotto | 2008-01-24 14:22:35 -0800 (Thu, 24 Jan 2008) | 1 line test of output iterators ................ r42953 | nesotto | 2008-01-24 14:26:36 -0800 (Thu, 24 Jan 2008) | 1 line output iterator test ................ r42954 | nesotto | 2008-01-24 14:27:27 -0800 (Thu, 24 Jan 2008) | 1 line output iterators for ptr_containers ................ r42957 | t_schwinger | 2008-01-24 16:26:16 -0800 (Thu, 24 Jan 2008) | 3 lines simplifies preprocessing code ................ r42958 | t_schwinger | 2008-01-24 16:28:15 -0800 (Thu, 24 Jan 2008) | 3 lines touched ................ r42960 | noel_belcourt | 2008-01-24 20:41:16 -0800 (Thu, 24 Jan 2008) | 6 lines Changed the -soname and -shared options in intel-darwin.jam to use -dynamiclib and -install_name, as done in darwin.jam. Apparently the Intel compilers on the Mac support the same options as gcc for setting the internal dynamic library name. ................ r42963 | nesotto | 2008-01-24 23:52:14 -0800 (Thu, 24 Jan 2008) | 1 line renaming ... ................ r42964 | nesotto | 2008-01-24 23:52:56 -0800 (Thu, 24 Jan 2008) | 1 line renaming ................ r42965 | nesotto | 2008-01-24 23:54:28 -0800 (Thu, 24 Jan 2008) | 1 line renaming ................ r42970 | turkanis | 2008-01-25 09:56:25 -0800 (Fri, 25 Jan 2008) | 1 line merged changes from iostreams_dev, revisions 42947-42962: fixed tickets 1003, 1139, 1140, 1149 ................ r42971 | noel_belcourt | 2008-01-25 11:52:47 -0800 (Fri, 25 Jan 2008) | 2 lines Fixed a typo to yesterdays patch. ................ r42972 | dgregor | 2008-01-25 13:07:14 -0800 (Fri, 25 Jan 2008) | 2 lines Include <ios> to get std::boolalpha. Fixes #1586 ................ r42974 | igaztanaga | 2008-01-25 15:07:51 -0800 (Fri, 25 Jan 2008) | 4 lines 1)Fixed gcc release mode warnings. 2)Replaced throw with BOOST_RETHROW when BOOST_TRY is used. 3)Fixed issues with singly linked lists ................ r42976 | hkaiser | 2008-01-25 17:24:21 -0800 (Fri, 25 Jan 2008) | 2 lines Wave: Fixed a problem in flex_string::compare() (#include_next was non-functional). ................ r42977 | hkaiser | 2008-01-25 17:36:20 -0800 (Fri, 25 Jan 2008) | 1 line Wave: Added new testcase. ................ r42980 | hkaiser | 2008-01-25 17:44:32 -0800 (Fri, 25 Jan 2008) | 1 line Wave: Tweaked new testcase. ................ r42982 | igaztanaga | 2008-01-26 03:52:25 -0800 (Sat, 26 Jan 2008) | 1 line Refactored common slist functions in a single class ................ r42984 | noel_belcourt | 2008-01-26 10:35:59 -0800 (Sat, 26 Jan 2008) | 7 lines Fixes #416 Fixed spelling of Jack Edmonds name and renamed files where necessary. Updated the documentation as well. Tested changes by building/running tests in libs/graph/test. ................ r42985 | noel_belcourt | 2008-01-26 10:51:28 -0800 (Sat, 26 Jan 2008) | 5 lines Fixes #640 Corrected the mpl push_front html documentation. ................ r42986 | eric_niebler | 2008-01-26 11:38:44 -0800 (Sat, 26 Jan 2008) | 1 line optimize repeated searches with patterns that have leading repeats ................ r42987 | t_schwinger | 2008-01-26 13:50:14 -0800 (Sat, 26 Jan 2008) | 3 lines attempts to allow some preprocessing with VACPP (IBM) ................ r42988 | noel_belcourt | 2008-01-26 14:21:57 -0800 (Sat, 26 Jan 2008) | 5 lines Fixes #1539 Fixed typo in the random documentation. ................ r42989 | noel_belcourt | 2008-01-26 15:06:24 -0800 (Sat, 26 Jan 2008) | 6 lines Fixes #965 Patched the XML and will check to ensure the html page reflects this change. ................ r42990 | eric_niebler | 2008-01-26 21:56:46 -0800 (Sat, 26 Jan 2008) | 1 line updated vcproj ................ r42991 | eric_niebler | 2008-01-26 21:57:08 -0800 (Sat, 26 Jan 2008) | 1 line fix typo ................ r42992 | johnmaddock | 2008-01-27 10:43:35 -0800 (Sun, 27 Jan 2008) | 1 line Extended leading repeat optimization to more cases. ................ r42997 | vladimir_prus | 2008-01-28 09:59:27 -0800 (Mon, 28 Jan 2008) | 1 line Correct speliing of --build-dir in --help output ................ r43000 | eric_niebler | 2008-01-28 12:03:41 -0800 (Mon, 28 Jan 2008) | 1 line update acknowledgement of john maddock ................ r43001 | bgubenko | 2008-01-28 13:27:13 -0800 (Mon, 28 Jan 2008) | 1 line marked 2 asio library tests for gcc-4.2.1_hpux_ia64 (HP-UX 11.23 with gcc) ................ r43002 | eric_niebler | 2008-01-28 14:55:30 -0800 (Mon, 28 Jan 2008) | 1 line doc more concepts, misc clean-up ................ r43003 | eric_niebler | 2008-01-28 14:56:46 -0800 (Mon, 28 Jan 2008) | 1 line proto doxygen comments, misc clean-up ................ r43006 | eric_niebler | 2008-01-28 18:20:45 -0800 (Mon, 28 Jan 2008) | 1 line more proto doxygen comments, update copyright ................ r43007 | vladimir_prus | 2008-01-28 22:28:09 -0800 (Mon, 28 Jan 2008) | 1 line Retain top-level boost-build.jam ................ r43008 | vladimir_prus | 2008-01-28 22:40:06 -0800 (Mon, 28 Jan 2008) | 4 lines Disable relinking when <target-os> is either windows or cygwin. Fixes #1062. ................ r43009 | eric_niebler | 2008-01-28 23:03:03 -0800 (Mon, 28 Jan 2008) | 1 line add tests for deep_copy, make_expr, unpack_expr; fix bugs; update more copyrights ................ r43012 | djenkins | 2008-01-29 08:41:12 -0800 (Tue, 29 Jan 2008) | 1 line fix typo ................ r43013 | djenkins | 2008-01-29 08:43:51 -0800 (Tue, 29 Jan 2008) | 1 line update copyright and misc cleanup ................ r43014 | bgubenko | 2008-01-29 09:47:01 -0800 (Tue, 29 Jan 2008) | 1 line marked interprocess library unusable on gcc-4.2.1_hpux_ia64 (until it is ported to HP-UX platform) ................ r43016 | eric_niebler | 2008-01-29 13:02:52 -0800 (Tue, 29 Jan 2008) | 1 line make_expr and unpack_expr improvements, fix scary transform::arg_c bug ................ r43018 | djenkins | 2008-01-29 19:39:02 -0800 (Tue, 29 Jan 2008) | 1 line use skip directive to simplify example ................ r43023 | eric_niebler | 2008-01-30 14:10:13 -0800 (Wed, 30 Jan 2008) | 1 line finally, a make_expr() I can live with ................ r43024 | eric_niebler | 2008-01-30 14:26:34 -0800 (Wed, 30 Jan 2008) | 1 line regenerated boostbook reference ................ r43025 | niels_dekker | 2008-01-30 14:42:23 -0800 (Wed, 30 Jan 2008) | 1 line value_init: Removed aligned_storage::address() calls, to improve TR1 compatibility, as confirmed by John Maddock. Added internal helper function, wrapper_address(), as discussed with Fernando. ................ r43026 | eric_niebler | 2008-01-30 15:03:36 -0800 (Wed, 30 Jan 2008) | 1 line minor tweak to make_expr result_of return type calculation ................ r43031 | eric_niebler | 2008-01-30 23:36:28 -0800 (Wed, 30 Jan 2008) | 1 line simplify make_expr.hpp, user docs for make_expr() ................ r43035 | eric_niebler | 2008-01-31 10:44:17 -0800 (Thu, 31 Jan 2008) | 1 line minor tweak to fusion value_of and value_at for expressions, for better interop with proto::unpack_expr ................ r43037 | vladimir_prus | 2008-01-31 11:47:12 -0800 (Thu, 31 Jan 2008) | 1 line Build in MT mode (as long as wave links to boost.thread) ................ r43038 | hkaiser | 2008-01-31 12:57:47 -0800 (Thu, 31 Jan 2008) | 1 line Wave: fixed expanding_function_like_macro() ................ r43040 | eric_niebler | 2008-01-31 13:12:44 -0800 (Thu, 31 Jan 2008) | 1 line finish documentation for expression construction utilities ................ r43041 | hkaiser | 2008-01-31 14:33:43 -0800 (Thu, 31 Jan 2008) | 1 line Wave: Added additional configuration possibility to allow control threading support. ................ r43042 | hkaiser | 2008-01-31 14:48:56 -0800 (Thu, 31 Jan 2008) | 1 line Wave: Added additional configuration possibility to allow control threading support. Updated the documentation. ................ r43043 | jurko | 2008-01-31 16:27:31 -0800 (Thu, 31 Jan 2008) | 1 line Reverted changes made in rev 43038 which seem to have been committed by mistake and include some user specific settings in it local to the comitter's environment while this file is intended to be used as generic template for actual user-config.jam files and do nothing in case user does not specify his own settings there. ................ r43044 | jurko | 2008-01-31 16:44:23 -0800 (Thu, 31 Jan 2008) | 1 line Minor stylistic spacing changes. Remove trailing spaces. ................ r43045 | jurko | 2008-01-31 16:46:50 -0800 (Thu, 31 Jan 2008) | 1 line Corrected outputting native Windows paths so that it works correctly for absolute paths without the drive letter being explicitly specified, e.g. \aaa\bbb or /aaa/bbb. ................ r43046 | jurko | 2008-01-31 17:49:16 -0800 (Thu, 31 Jan 2008) | 1 line Added the missing end-of-line character when outputting DEBUG_SEARCH debug messages from file_build1(). This cleans up the -d+6 bjam output a lot. ................ r43050 | eric_niebler | 2008-02-01 12:30:29 -0800 (Fri, 01 Feb 2008) | 1 line add future group example ................ r43052 | noel_belcourt | 2008-02-01 18:41:23 -0800 (Fri, 01 Feb 2008) | 4 lines Fix a typo in pgi.jam that prevented shared libraries from being built correctly. ................ r43054 | chris_kohlhoff | 2008-02-02 03:37:45 -0800 (Sat, 02 Feb 2008) | 4 lines Ensure that the workaround for the MSVC secure iterator problem is only used when compiling with MSVC. The workaround causes g++'s library debug mode to report errors due to the assignment from a singular iterator. ................ r43055 | chris_kohlhoff | 2008-02-02 03:39:17 -0800 (Sat, 02 Feb 2008) | 2 lines Fix "possible loss of data" warning when building for Windows 2000 targets. ................ r43056 | chris_kohlhoff | 2008-02-02 04:02:23 -0800 (Sat, 02 Feb 2008) | 3 lines The latest Windows SDKs don't support IPv6 when building for Windows 2000, so we need to use the SDK emulation in that case. ................ r43057 | eric_niebler | 2008-02-02 04:27:16 -0800 (Sat, 02 Feb 2008) | 1 line port test to boost version 1.34.1 ................ r43061 | turkanis | 2008-02-02 14:10:46 -0800 (Sat, 02 Feb 2008) | 1 line merged changes from iostreams_dev, revisions 42962-43059: updated copyright notices ................ r43080 | eric_niebler | 2008-02-03 10:40:03 -0800 (Sun, 03 Feb 2008) | 1 line fix bug found by L. Evans re: fusion and stateful function objects ................ r43083 | johnmaddock | 2008-02-04 01:13:36 -0800 (Mon, 04 Feb 2008) | 1 line Added missing file. ................ r43085 | johnmaddock | 2008-02-04 01:17:35 -0800 (Mon, 04 Feb 2008) | 1 line Removed dead file. ................ r43087 | johnmaddock | 2008-02-04 01:20:46 -0800 (Mon, 04 Feb 2008) | 1 line Removed dead files. ................ r43089 | johnmaddock | 2008-02-04 01:23:28 -0800 (Mon, 04 Feb 2008) | 1 line Removed dead files. ................ r43094 | anthonyw | 2008-02-04 05:16:32 -0800 (Mon, 04 Feb 2008) | 1 line added test for duration overloads of timed_lock, and added missing implementation to win32 version ................ r43101 | hkaiser | 2008-02-04 11:21:46 -0800 (Mon, 04 Feb 2008) | 1 line Wave: trying to fix stdcxx_gcc regression. ................ r43103 | matias | 2008-02-04 13:01:06 -0800 (Mon, 04 Feb 2008) | 1 line hooking --> additional information in html docs ................ r43106 | eric_niebler | 2008-02-04 18:09:51 -0800 (Mon, 04 Feb 2008) | 1 line fleshing out evaluation.qbk, document transforms of if_, not_, and_ and or_ ................ r43107 | eric_niebler | 2008-02-04 21:33:12 -0800 (Mon, 04 Feb 2008) | 1 line eliminate warnings under msvc's -W4 ................ r43111 | eric_niebler | 2008-02-04 22:03:01 -0800 (Mon, 04 Feb 2008) | 1 line fix typo ................ r43112 | marshall | 2008-02-05 08:07:19 -0800 (Tue, 05 Feb 2008) | 1 line Fix typo (bug #1434) ................ r43113 | marshall | 2008-02-05 08:15:35 -0800 (Tue, 05 Feb 2008) | 1 line Applied patch (fixes bug #1307) ................ r43117 | dgregor | 2008-02-05 12:51:23 -0800 (Tue, 05 Feb 2008) | 1 line Fix add_vertex and add_vertices when the CSR graph has vertex properties ................ r43118 | danieljames | 2008-02-05 12:57:02 -0800 (Tue, 05 Feb 2008) | 13 lines Merged revisions 42942-43116 via svnmerge from https://svn.boost.org/svn/boost/branches/unordered/trunk ........ r42975 | danieljames | 2008-01-26 00:29:32 +0000 (Sat, 26 Jan 2008) | 1 line Typedef some types before using them, to make life easier for Borland. ........ r43116 | danieljames | 2008-02-05 20:47:44 +0000 (Tue, 05 Feb 2008) | 1 line Some compilers and libraries combinations have problems with deques of non-assingable types. Using a list instead. ........ ................ r43120 | eric_niebler | 2008-02-05 13:07:31 -0800 (Tue, 05 Feb 2008) | 1 line add missing #include ................ r43121 | bemandawes | 2008-02-05 18:01:46 -0800 (Tue, 05 Feb 2008) | 1 line Add circular_buffer to the alphabetic list ................ r43125 | t_schwinger | 2008-02-06 05:00:08 -0800 (Wed, 06 Feb 2008) | 3 lines attempts to make synthesis metafunctions work with sun compiler ................ r43129 | danieljames | 2008-02-06 11:02:38 -0800 (Wed, 06 Feb 2008) | 2 lines In the boostbook navbar, link FAQ and people to the website. ................ r43130 | eric_niebler | 2008-02-06 11:57:51 -0800 (Wed, 06 Feb 2008) | 1 line untabify ................ r43132 | nesotto | 2008-02-06 14:46:19 -0800 (Wed, 06 Feb 2008) | 1 line cleanup to pass inspection report ................ r43133 | nesotto | 2008-02-06 14:46:31 -0800 (Wed, 06 Feb 2008) | 1 line cleanup to pass inspection report ................ r43134 | eric_niebler | 2008-02-06 14:57:57 -0800 (Wed, 06 Feb 2008) | 1 line add handy get() accessors on literal<> wrapper ................ r43135 | nesotto | 2008-02-06 15:12:21 -0800 (Wed, 06 Feb 2008) | 1 line cleanup to pass inspection tool ................ r43136 | eric_niebler | 2008-02-06 16:05:01 -0800 (Wed, 06 Feb 2008) | 1 line reasonably complete user docs for expression evaluation ................ r43138 | eric_niebler | 2008-02-07 00:06:29 -0800 (Thu, 07 Feb 2008) | 1 line tweaks for doxygen 1.5.4, document matches<> ................ r43141 | johnmaddock | 2008-02-07 01:55:41 -0800 (Thu, 07 Feb 2008) | 1 line Fix last checked version. ................ r43143 | johnmaddock | 2008-02-07 02:03:16 -0800 (Thu, 07 Feb 2008) | 1 line Remove tabs. ................ r43145 | johnmaddock | 2008-02-07 02:13:31 -0800 (Thu, 07 Feb 2008) | 1 line Fix min/max usage violation. ................ r43147 | vladimir_prus | 2008-02-07 02:17:03 -0800 (Thu, 07 Feb 2008) | 2 lines Attempt to unbreak <library-file> ................ r43148 | johnmaddock | 2008-02-07 02:24:29 -0800 (Thu, 07 Feb 2008) | 1 line Added comment to suppress inspect warning. ................ r43150 | johnmaddock | 2008-02-07 02:29:59 -0800 (Thu, 07 Feb 2008) | 1 line Added fix for inspection report. ................ r43152 | vladimir_prus | 2008-02-07 03:04:30 -0800 (Thu, 07 Feb 2008) | 4 lines Fix <framework> with no path. Patch from Jon Olsson. ................ r43154 | bemandawes | 2008-02-07 05:22:34 -0800 (Thu, 07 Feb 2008) | 1 line Remove obsolete CVS scripts, add 1.35.0 SVN scripts, beginning of docs page ................ r43155 | nesotto | 2008-02-07 06:41:04 -0800 (Thu, 07 Feb 2008) | 6 lines iterator_range disables msvc warning 4996 <http://svn.boost.org/trac/boost/ticket/1565> [range] sub_range assignment issue <http://svn.boost.org/trac/boost/ticket/1284> ................ r43156 | nesotto | 2008-02-07 06:46:19 -0800 (Thu, 07 Feb 2008) | 1 line test ................ r43157 | joaquin | 2008-02-07 08:29:27 -0800 (Thu, 07 Feb 2008) | 1 line updated according to latest regression tests results, fixed a broken link, typo ................ r43159 | turkanis | 2008-02-07 09:07:28 -0800 (Thu, 07 Feb 2008) | 1 line added missing 'self.' qualification ................ r43165 | dgregor | 2008-02-07 13:08:09 -0800 (Thu, 07 Feb 2008) | 1 line Support for non-blocking MPI operations in Python, from Andreas Kloeckner ................ r43166 | dgregor | 2008-02-07 13:09:38 -0800 (Thu, 07 Feb 2008) | 1 line Note addition of nonblocking operations to the Python interface ................ r43171 | nesotto | 2008-02-08 01:58:35 -0800 (Fri, 08 Feb 2008) | 1 line silence of warnings for unused arguments ................ r43175 | nesotto | 2008-02-08 07:25:01 -0800 (Fri, 08 Feb 2008) | 1 line missing ) fixed ................ r43176 | noel_belcourt | 2008-02-08 08:32:35 -0800 (Fri, 08 Feb 2008) | 14 lines Force PPC Darwin to use fork instead of vfork. This change requires both the parent and child process to explicitly set the process group id. Vfork guarantees the child process runs to the exec before it releases the parent process. Now that we use fork instead of vfork, it's possible for the parent to wait on the child process without having the child setpgid on itself. This eliminates spurious hangs on ppc darwin caused by either a race condition between vfork and execvp, or a bug in the vfork implementation. Added a test to ensure we don't try to read from the stderr pipe descriptor if the descriptor's not valid. ................ r43177 | eric_niebler | 2008-02-08 09:11:57 -0800 (Fri, 08 Feb 2008) | 1 line reserve some c_type bits for dinkumware on windows, fixes #1625 ................ r43179 | noel_belcourt | 2008-02-08 09:53:50 -0800 (Fri, 08 Feb 2008) | 13 lines I've added the -single_module option to the intel-darwin.link.dll action to fix this linker error when linking dylibs: ld: common symbols not allowed with MH_DYLIB output format with the -multi_module option boost/bin.v2/libs/system/build/intel-darwin-9.1/debug/macosx-version-10.4/error_code.o definition of common __ZGVZNK5boost6system14error_category7messageEiE1s (size 16) boost/bin.v2/libs/system/build/intel-darwin-9.1/debug/macosx-version-10.4/error_code.o definition of common __ZZNK5boost6system14error_category7messageEiE1s (size 16) though I would note that the common symbols problem occurs in a number of other libraries (test, graph, spirit, ...) as well. ................ r43188 | danieljames | 2008-02-09 04:29:02 -0800 (Sat, 09 Feb 2008) | 2 lines Fix a link in the intrusive redirect. ................ r43189 | danieljames | 2008-02-09 04:37:00 -0800 (Sat, 09 Feb 2008) | 1 line Fix another redirect link. ................ r43190 | danieljames | 2008-02-09 04:38:19 -0800 (Sat, 09 Feb 2008) | 1 line Update link to Jamfile, to link to the version 2 jamfile. ................ r43191 | danieljames | 2008-02-09 04:39:06 -0800 (Sat, 09 Feb 2008) | 1 line Fix a link. ................ r43192 | danieljames | 2008-02-09 04:45:32 -0800 (Sat, 09 Feb 2008) | 2 lines Add a forwarding header for hash/custom.html as Boost.Bimap links to it. ................ r43193 | danieljames | 2008-02-09 05:02:45 -0800 (Sat, 09 Feb 2008) | 1 line Fix the link to the license. ................ r43199 | eric_niebler | 2008-02-09 12:32:27 -0800 (Sat, 09 Feb 2008) | 1 line more doxygen comments, const-correctness tweak for fusion::at() on proto expression ................ r43200 | eric_niebler | 2008-02-09 12:34:33 -0800 (Sat, 09 Feb 2008) | 1 line document how to access children of proto expressions ................ r43204 | eric_niebler | 2008-02-09 22:57:24 -0800 (Sat, 09 Feb 2008) | 1 line fix oops in proto fusion interface ................ r43205 | eric_niebler | 2008-02-09 23:02:54 -0800 (Sat, 09 Feb 2008) | 1 line suppress msvc warning ................ r43206 | danieljames | 2008-02-10 01:55:03 -0800 (Sun, 10 Feb 2008) | 1 line Fix some broken links. ................ r43207 | vladimir_prus | 2008-02-10 05:13:41 -0800 (Sun, 10 Feb 2008) | 4 lines Tolerate argc being zero. Patch from C. K. Jester-Young. ................ r43209 | danieljames | 2008-02-10 06:56:22 -0800 (Sun, 10 Feb 2008) | 1 line Link to people pages on the website, as they've been removed from the download. ................ r43210 | danieljames | 2008-02-10 07:02:17 -0800 (Sun, 10 Feb 2008) | 1 line Point links to the pages that used to be in 'more' to the site. ................ r43212 | danieljames | 2008-02-10 08:10:16 -0800 (Sun, 10 Feb 2008) | 1 line Fix links on the home page as well. ................ r43213 | danieljames | 2008-02-10 08:21:22 -0800 (Sun, 10 Feb 2008) | 1 line Generated documentation which is no longer generated. ................ r43220 | eric_niebler | 2008-02-10 19:48:41 -0800 (Sun, 10 Feb 2008) | 1 line include config.hpp and workaround.hpp before uses of BOOST_WORKAROUND and BOOST_MSVC ................ r43221 | chris_kohlhoff | 2008-02-11 05:59:44 -0800 (Mon, 11 Feb 2008) | 2 lines Need to define _XOPEN_SOURCE_EXTENDED when compiling for HP-UX. ................ r43226 | djenkins | 2008-02-11 12:49:19 -0800 (Mon, 11 Feb 2008) | 1 line cleanup using local<> and skip() ................ r43239 | turkanis | 2008-02-12 21:43:39 -0800 (Tue, 12 Feb 2008) | 1 line fixed return value of read(), to correctly handle eof ................ r43240 | turkanis | 2008-02-12 21:47:44 -0800 (Tue, 12 Feb 2008) | 1 line merged changes from iostreams_dev, revisions 43059-43238: better debug output for mapped file; fixed large_file_test.cpp under UNICODE on Windows ................ r43241 | turkanis | 2008-02-13 11:38:52 -0800 (Wed, 13 Feb 2008) | 1 line added markup for stdcxx failures (iostreams) ................ r43243 | turkanis | 2008-02-13 11:42:10 -0800 (Wed, 13 Feb 2008) | 1 line switched from <wchar.h> to <cwchar>, for stdcxx (which is conforming in this case) ................ r43246 | matias | 2008-02-14 09:33:12 -0800 (Thu, 14 Feb 2008) | 1 line remove local admonitions ................ r43247 | matias | 2008-02-14 09:43:52 -0800 (Thu, 14 Feb 2008) | 1 line optional docs fixes ................ r43248 | matias | 2008-02-14 09:44:21 -0800 (Thu, 14 Feb 2008) | 1 line redirect optional docs to new version ................ r43251 | matias | 2008-02-14 10:08:16 -0800 (Thu, 14 Feb 2008) | 1 line conversion docs fixes ................ r43252 | matias | 2008-02-14 10:09:34 -0800 (Thu, 14 Feb 2008) | 1 line redirect to new conversion docs ................ r43253 | matias | 2008-02-14 10:19:34 -0800 (Thu, 14 Feb 2008) | 1 line redirect optional and numeric/conversion docs to new version ................ r43254 | matias | 2008-02-14 11:03:55 -0800 (Thu, 14 Feb 2008) | 1 line bimap doc fixes ................ r43255 | matias | 2008-02-14 11:05:04 -0800 (Thu, 14 Feb 2008) | 1 line fix tabs in files ................ r43256 | matias | 2008-02-14 11:22:15 -0800 (Thu, 14 Feb 2008) | 1 line fix tabs in files ................ r43260 | matias | 2008-02-14 13:24:11 -0800 (Thu, 14 Feb 2008) | 1 line add missing images ................ r43262 | hkaiser | 2008-02-14 14:01:54 -0800 (Thu, 14 Feb 2008) | 1 line Fixed a whitespace insertion glitch, where whitespace got inserted unconditionally between two operators even if one of these was a comma. ................ r43264 | hkaiser | 2008-02-14 15:52:33 -0800 (Thu, 14 Feb 2008) | 1 line Wave: More fixes to whitespace insertion engine. ................ r43266 | hkaiser | 2008-02-15 06:35:36 -0800 (Fri, 15 Feb 2008) | 1 line Wave: More fixes to whitespace insertion engine. ................ r43269 | pdimov | 2008-02-15 10:40:36 -0800 (Fri, 15 Feb 2008) | 1 line Added support for &&, || ................ r43272 | andreas_huber69 | 2008-02-16 02:13:08 -0800 (Sat, 16 Feb 2008) | 1 line Updated statechart markup ................ r43274 | andreas_huber69 | 2008-02-16 02:19:49 -0800 (Sat, 16 Feb 2008) | 2 lines Silenced GCC 4.0.1 warning (patch supplied by Euan) <http://thread.gmane.org/gmane.comp.lib.boost.devel/171071> ................ r43280 | jurko | 2008-02-16 08:50:42 -0800 (Sat, 16 Feb 2008) | 1 line Corrected comments related to the allowed linker & linker-type values. Minor stylistic changes. ................ r43281 | jurko | 2008-02-16 08:53:33 -0800 (Sat, 16 Feb 2008) | 1 line Added support for compiling C++ programs without RTTI support using the gcc toolset. ................ r43282 | jurko | 2008-02-16 09:03:54 -0800 (Sat, 16 Feb 2008) | 1 line Made the msvc toolset always explicitly enable or disable rtti support based on the <rtti> feature value instead of only setting it if <rtti>on and depending on it being disabled by default. The original behaviour did not work well with msvc 8.0 for which there was not way to disable rtti support as that compiler enables rtti support by default. ................ r43283 | bemandawes | 2008-02-16 18:01:32 -0800 (Sat, 16 Feb 2008) | 1 line Show output of example program ................ r43290 | hkaiser | 2008-02-17 08:45:08 -0800 (Sun, 17 Feb 2008) | 1 line Wave: Extended a workaround to newest Intel compiler version (Linux V10.1) ................ r43292 | nesotto | 2008-02-17 08:49:38 -0800 (Sun, 17 Feb 2008) | 1 line support for comparinson operators ................ r43293 | nesotto | 2008-02-17 08:50:02 -0800 (Sun, 17 Feb 2008) | 1 line support for comparison operators ................ r43294 | hkaiser | 2008-02-17 09:00:20 -0800 (Sun, 17 Feb 2008) | 1 line Wave: Fixed test cases to reflect recent changes to whitespace insertion. ................ r43296 | eric_niebler | 2008-02-17 12:53:18 -0800 (Sun, 17 Feb 2008) | 1 line proto documentation improvements ................ r43299 | turkanis | 2008-02-17 21:48:13 -0800 (Sun, 17 Feb 2008) | 1 line merged changes from iostreams_dev, revisions 43243-43298: overhaul of category_of and close(): stringstream is now dual_seekable; standard file streams and string streams are closable; public Boost.Iostreams streams and streambufs are closable; close() pops filtering streams and streambufs ................ r43300 | eric_niebler | 2008-02-17 22:16:27 -0800 (Sun, 17 Feb 2008) | 1 line remove dependence on boost.lambda, make numeric function objects work with std binders ................ r43301 | chris_kohlhoff | 2008-02-18 05:31:26 -0800 (Mon, 18 Feb 2008) | 2 lines Fix printing of error messages. ................ r43302 | chris_kohlhoff | 2008-02-18 05:33:23 -0800 (Mon, 18 Feb 2008) | 2 lines Only define _XOPEN_SOURCE_EXTENDED when building with gcc on HP-UX. ................ r43303 | chris_kohlhoff | 2008-02-18 05:35:15 -0800 (Mon, 18 Feb 2008) | 3 lines Add missing #include of socket_types.hpp needed for the SSL unit tests to compile successfully on Windows. ................ r43306 | eric_niebler | 2008-02-18 10:29:29 -0800 (Mon, 18 Feb 2008) | 1 line remove post_construct docs, fix link to boost.parameter library ................ r43308 | niels_dekker | 2008-02-18 14:11:19 -0800 (Mon, 18 Feb 2008) | 1 line Fixed the assignment of value_initialized<T> for T being a C-style array. (The previous version would trigger a compile error in this case.) ................ r43309 | niels_dekker | 2008-02-18 14:13:21 -0800 (Mon, 18 Feb 2008) | 1 line Tested the assignment of value_initialized<T>, for T being a C-style array. Related to the fix of changeset [43308] ................ r43310 | eric_niebler | 2008-02-18 15:03:23 -0800 (Mon, 18 Feb 2008) | 1 line some doxygen comments for proto/traits.hpp ................ r43311 | eric_niebler | 2008-02-18 21:56:52 -0800 (Mon, 18 Feb 2008) | 1 line more proto documentation tweaks, remove unnecessary result_of::arg_c instantiation ................ r43312 | eric_niebler | 2008-02-18 23:14:37 -0800 (Mon, 18 Feb 2008) | 1 line fix droppable accumulators ................ r43314 | eric_niebler | 2008-02-18 23:33:30 -0800 (Mon, 18 Feb 2008) | 1 line darn, back out bad droppable changes ................ r43316 | pdimov | 2008-02-19 05:18:58 -0800 (Tue, 19 Feb 2008) | 1 line Fixes #1590. ................ r43317 | pdimov | 2008-02-19 06:01:13 -0800 (Tue, 19 Feb 2008) | 1 line Fixes #1444. ................ r43318 | pdimov | 2008-02-19 06:26:36 -0800 (Tue, 19 Feb 2008) | 1 line Fix #398, as long as the macros BOOST_NO_STD_TYPEINFO and BOOST_NO_IOSTREAM are defined. I don't know how Boost.Config needs to be changed to autodetect eVC4 and set these on its own. ................ r43319 | pdimov | 2008-02-19 06:51:10 -0800 (Tue, 19 Feb 2008) | 1 line Fix #1641. ................ r43320 | pdimov | 2008-02-19 06:59:28 -0800 (Tue, 19 Feb 2008) | 1 line Fix #1646. ................ r43321 | pdimov | 2008-02-19 07:09:10 -0800 (Tue, 19 Feb 2008) | 1 line Fix #1642. ................ r43322 | nesotto | 2008-02-19 07:10:05 -0800 (Tue, 19 Feb 2008) | 1 line fixed problem with operator()() when the value_type was abstract. ................ r43323 | pdimov | 2008-02-19 07:40:58 -0800 (Tue, 19 Feb 2008) | 1 line Fix #1643. ................ r43325 | turkanis | 2008-02-19 11:34:07 -0800 (Tue, 19 Feb 2008) | 1 line stringstreams are no longer closable; the semantics of close() for these devices was illconsidered ................ r43328 | turkanis | 2008-02-19 16:09:06 -0800 (Tue, 19 Feb 2008) | 1 line menu fix from iostreams_dev ................ r43329 | turkanis | 2008-02-19 19:20:17 -0800 (Tue, 19 Feb 2008) | 1 line markup for pgi-7.0 (iostreams) ................ r43330 | bemandawes | 2008-02-20 05:46:49 -0800 (Wed, 20 Feb 2008) | 1 line Add .z7 archive generation ................ r43332 | grafik | 2008-02-20 09:32:09 -0800 (Wed, 20 Feb 2008) | 1 line New readme page for now standalone release. ................ r43334 | grafik | 2008-02-20 11:15:16 -0800 (Wed, 20 Feb 2008) | 1 line Fix link to getting started docs. ................ r43335 | grafik | 2008-02-20 14:50:03 -0800 (Wed, 20 Feb 2008) | 1 line Add the <python.interpreter> to all requirements to allow other toolsets to use the currently configured python instead of relying on python being in the path. ................ r43336 | grafik | 2008-02-20 15:01:43 -0800 (Wed, 20 Feb 2008) | 1 line Use the configured python interpreter instead of assuming it's in the path. ................ r43337 | grafik | 2008-02-20 15:03:28 -0800 (Wed, 20 Feb 2008) | 1 line Add missing, and assumed, white background for screen rendering. ................ r43338 | grafik | 2008-02-20 15:26:58 -0800 (Wed, 20 Feb 2008) | 1 line Doc cleanups. ................ r43344 | eric_niebler | 2008-02-20 23:18:24 -0800 (Wed, 20 Feb 2008) | 1 line More Proto documentation ................ r43346 | johnmaddock | 2008-02-21 02:37:59 -0800 (Thu, 21 Feb 2008) | 3 lines Fix typo in example. Added links to PDF versions of the docs. Regenerated all the docs to fix people links. ................ r43347 | johnmaddock | 2008-02-21 03:53:59 -0800 (Thu, 21 Feb 2008) | 1 line Update main overview page. ................ r43349 | bemandawes | 2008-02-21 04:46:11 -0800 (Thu, 21 Feb 2008) | 1 line Fix typo; .z7 should be .7z ................ r43351 | johnmaddock | 2008-02-21 04:58:15 -0800 (Thu, 21 Feb 2008) | 1 line Added link to PDF docs, and regenerated. ................ r43354 | johnmaddock | 2008-02-21 05:51:18 -0800 (Thu, 21 Feb 2008) | 1 line Added link to PDF docs, and regenerated. ................ r43357 | johnmaddock | 2008-02-21 08:49:59 -0800 (Thu, 21 Feb 2008) | 1 line Added link to PDF docs. ................ r43359 | johnmaddock | 2008-02-21 09:01:26 -0800 (Thu, 21 Feb 2008) | 1 line Regenerated docs to fix links. ................ r43361 | bemandawes | 2008-02-21 12:11:32 -0800 (Thu, 21 Feb 2008) | 1 line Fix still another typo ................ r43362 | eric_niebler | 2008-02-21 12:12:02 -0800 (Thu, 21 Feb 2008) | 1 line doxygen comments for proto::when<> ................ r43363 | eric_niebler | 2008-02-21 16:42:12 -0800 (Thu, 21 Feb 2008) | 1 line fix crash when actions are in keep() expressions ................ r43364 | eric_niebler | 2008-02-21 18:01:46 -0800 (Thu, 21 Feb 2008) | 1 line doxygen comments ................ r43365 | grafik | 2008-02-21 21:26:39 -0800 (Thu, 21 Feb 2008) | 1 line Rename readme.html to index.html, and add forwarding index.htm for backward compatibility. ................ r43368 | danieljames | 2008-02-22 01:21:22 -0800 (Fri, 22 Feb 2008) | 2 lines Update the index.html link in the navbar. ................ r43371 | grafik | 2008-02-22 08:25:21 -0800 (Fri, 22 Feb 2008) | 1 line Remove obsolete getting started files. They where replaced by more/getting_started/*. ................ r43377 | chris_kohlhoff | 2008-02-22 14:43:54 -0800 (Fri, 22 Feb 2008) | 2 lines Use the correct vector of timer queues when dispatching timers. ................ r43390 | turkanis | 2008-02-22 16:05:49 -0800 (Fri, 22 Feb 2008) | 2 lines Ported change from iostreams_dev ................ r43391 | turkanis | 2008-02-22 16:06:24 -0800 (Fri, 22 Feb 2008) | 2 lines Ported changes from iostreams_dev ................ r43392 | turkanis | 2008-02-22 16:07:13 -0800 (Fri, 22 Feb 2008) | 1 line merged changes from iostreams_dev, revisions 43327-43389 ................ r43393 | turkanis | 2008-02-22 16:11:07 -0800 (Fri, 22 Feb 2008) | 1 line merged changes from iostreams_dev ................ r43395 | turkanis | 2008-02-22 22:07:59 -0800 (Fri, 22 Feb 2008) | 1 line updated to test close() on filtering streambufs ................ r43399 | turkanis | 2008-02-22 23:44:58 -0800 (Fri, 22 Feb 2008) | 1 line merged changes from iostreams_dev ................ r43402 | bemandawes | 2008-02-23 06:04:02 -0800 (Sat, 23 Feb 2008) | 1 line Give the 1st and 2nd level index.html files a common look-and-feel. ................ r43405 | vladimir_prus | 2008-02-24 04:59:04 -0800 (Sun, 24 Feb 2008) | 3 lines Recognize that fact, for that for intel-win, <runtime-debuggin> matters and should be added to the library name. ................ r43409 | bemandawes | 2008-02-24 16:53:26 -0800 (Sun, 24 Feb 2008) | 1 line Fix html boo boo ................ r43410 | schoepflin | 2008-02-25 00:37:10 -0800 (Mon, 25 Feb 2008) | 1 line Added missing template keyword. ................ r43411 | t_schwinger | 2008-02-25 03:45:51 -0800 (Mon, 25 Feb 2008) | 3 lines removes unnecessary escaping ................ r43412 | t_schwinger | 2008-02-25 03:47:59 -0800 (Mon, 25 Feb 2008) | 3 lines removes unnecessary comment ................ r43416 | hkaiser | 2008-02-26 11:25:05 -0800 (Tue, 26 Feb 2008) | 1 line Wave: Fixed expanding_function_like_macro preprocessing hook. ................ r43417 | danieljames | 2008-02-26 14:04:55 -0800 (Tue, 26 Feb 2008) | 2 lines Fix a link to Boost.Bimap. ................ r43418 | danieljames | 2008-02-26 14:07:25 -0800 (Tue, 26 Feb 2008) | 2 lines Change another link that's no longer in the repository to link to the website. ................ r43419 | hkaiser | 2008-02-26 14:36:36 -0800 (Tue, 26 Feb 2008) | 1 line Fixed a compilation problem on pathscale ................ r43421 | eric_niebler | 2008-02-27 10:48:22 -0800 (Wed, 27 Feb 2008) | 1 line partially revert breaking change to independent sub-expressions until I can make a proper fix ................ r43422 | danieljames | 2008-02-27 10:51:14 -0800 (Wed, 27 Feb 2008) | 1 line Fix broken copyright urls. Fixes #1573. ................ r43423 | danieljames | 2008-02-27 11:22:01 -0800 (Wed, 27 Feb 2008) | 1 line Fix incorrect links to copyright of the form 'http:#www.boost.org ................ r43424 | eric_niebler | 2008-02-27 11:39:43 -0800 (Wed, 27 Feb 2008) | 1 line fix bug in use_simple_repeat calculation ................ r43428 | eric_niebler | 2008-02-27 16:03:15 -0800 (Wed, 27 Feb 2008) | 1 line add test case for use_simple_repeat fix ................ r43433 | eric_niebler | 2008-02-28 14:47:12 -0800 (Thu, 28 Feb 2008) | 1 line fix oops ................ r43434 | johnmaddock | 2008-02-29 01:49:42 -0800 (Fri, 29 Feb 2008) | 1 line Apply fixes to issue #1658 which fixes some broken URL's. ................ r43435 | johnmaddock | 2008-02-29 01:58:30 -0800 (Fri, 29 Feb 2008) | 1 line Fix broken link as per report #1658. ................ r43437 | chris_kohlhoff | 2008-02-29 04:57:57 -0800 (Fri, 29 Feb 2008) | 2 lines Add missing tie(). ................ r43438 | schoepflin | 2008-02-29 07:13:41 -0800 (Fri, 29 Feb 2008) | 2 lines Added expected failure markup for the test weighted_tail_variate_means on Tru64/CXX. ................ r43441 | eric_niebler | 2008-03-01 11:32:56 -0800 (Sat, 01 Mar 2008) | 1 line add map_assign example ................ r43458 | turkanis | 2008-03-02 22:20:14 -0800 (Sun, 02 Mar 2008) | 1 line merged changes from iostreams_dev, revisions 43399-43457 ................ r43461 | anthonyw | 2008-03-03 00:44:42 -0800 (Mon, 03 Mar 2008) | 1 line Test and fix for issue #1665 ................ r43464 | anthonyw | 2008-03-03 02:52:44 -0800 (Mon, 03 Mar 2008) | 1 line thread constructor now accepts up to three additional arguments to pass to thread function ................ r43467 | danieljames | 2008-03-03 04:10:35 -0800 (Mon, 03 Mar 2008) | 2 lines Tell subversion that date_time.doc is a text file, not a word document. ................ r43468 | danieljames | 2008-03-03 04:11:25 -0800 (Mon, 03 Mar 2008) | 1 line Fix license link in date_time.doc ................ r43469 | chris_kohlhoff | 2008-03-03 05:21:05 -0800 (Mon, 03 Mar 2008) | 4 lines Disable use of CancelIo by default, due to the possibility of silent failure on some system configurations. Swallow error returned by CancelIoEx if there are no operations to be cancelled. ................ r43470 | chris_kohlhoff | 2008-03-03 05:27:06 -0800 (Mon, 03 Mar 2008) | 2 lines Add missing 'boost_' prefix to helper namespace. ................ r43471 | chris_kohlhoff | 2008-03-03 05:36:35 -0800 (Mon, 03 Mar 2008) | 2 lines Regenerate documentation. ................ r43472 | chris_kohlhoff | 2008-03-03 06:05:35 -0800 (Mon, 03 Mar 2008) | 1 line Update copyright notices. ................ r43473 | chris_kohlhoff | 2008-03-03 06:13:01 -0800 (Mon, 03 Mar 2008) | 2 lines Update copyright notices. ................ r43476 | eric_niebler | 2008-03-03 11:44:54 -0800 (Mon, 03 Mar 2008) | 1 line add Map Assign example to documentation ................ r43478 | eric_niebler | 2008-03-03 11:47:47 -0800 (Mon, 03 Mar 2008) | 1 line second attempt at fixing actions in independent expressions ................ r43484 | eric_niebler | 2008-03-03 15:48:17 -0800 (Mon, 03 Mar 2008) | 1 line handle static regexes with actions nested in dynamic independent subexpressions ................ r43485 | emildotchevski | 2008-03-03 17:41:17 -0800 (Mon, 03 Mar 2008) | 1 line boost exception ................ r43496 | eric_niebler | 2008-03-04 10:51:07 -0800 (Tue, 04 Mar 2008) | 1 line rename numeric::empty to numeric::default_, fixes #1650 ................ r43501 | eric_niebler | 2008-03-04 11:31:57 -0800 (Tue, 04 Mar 2008) | 1 line eliminate msvc level 4 warnings, fixes #1631 ................ r43502 | eric_niebler | 2008-03-04 11:42:36 -0800 (Tue, 04 Mar 2008) | 1 line add Dave Jenkin's evil static/dynamic actions in keep test case ................ r43503 | eric_niebler | 2008-03-04 13:09:47 -0800 (Tue, 04 Mar 2008) | 1 line work around msvc bug 331418, fixes #1652 ................ r43506 | eric_niebler | 2008-03-04 15:01:17 -0800 (Tue, 04 Mar 2008) | 1 line fix bad interaction between boyer-moore optimization and partial match feature, fixes #1564 ................ r43508 | eric_niebler | 2008-03-04 22:32:39 -0800 (Tue, 04 Mar 2008) | 1 line add BOOST_REVERSE_FOREACH, fixes #1071 ................ r43509 | eric_niebler | 2008-03-04 23:12:03 -0800 (Tue, 04 Mar 2008) | 1 line fix bug iterating over abstract base ................ [SVN r43519]
2306 lines
88 KiB
XML
2306 lines
88 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<!DOCTYPE library PUBLIC "-//Boost//DTD BoostBook XML V1.0//EN"
|
|
"http://www.boost.org/tools/boostbook/dtd/boostbook.dtd" [
|
|
<!ENTITY % thread.entities SYSTEM "entities.xml">
|
|
%thread.entities;
|
|
]>
|
|
<!-- Copyright (c) 2002-2003 William E. Kempf, Michael Glassford
|
|
Subject to the Boost Software License, Version 1.0.
|
|
(See accompanying file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt)
|
|
-->
|
|
<section id="thread.concepts" last-revision="$Date$">
|
|
<title>Concepts</title>
|
|
|
|
<para>&Boost.Thread; currently supports two types of mutex concepts:
|
|
ordinary <link linkend="thread.concepts.mutexes">Mutexes</link>,
|
|
which allow only one thread at a time to access a resource, and
|
|
<link linkend="thread.concepts.read-write-mutexes">Read/Write Mutexes</link>,
|
|
which allow only one thread at a time to access a resource when it is
|
|
being modified (the "Write" part of Read/Write), but allows multiple threads
|
|
to access a resource when it is only being referenced (the "Read" part of
|
|
Read/Write).</para>
|
|
<note> Unfortunately it turned out that the current implementation of Read/Write Mutex has
|
|
some serious problems. So it was decided not to put this implementation into
|
|
release grade code. Also discussions on the mailing list led to the
|
|
conclusion that the current concepts need to be rethought. In particular
|
|
the schedulings <link linkend="thread.concepts.read-write-scheduling-policies.inter-class">
|
|
Inter-Class Scheduling Policies</link> are deemed unnecessary.
|
|
There seems to be common belief that a fair scheme suffices.
|
|
The following documentation has been retained however, to give
|
|
readers of this document the opportunity to study the original design.
|
|
</note>
|
|
|
|
<section id="thread.concepts.mutexes">
|
|
<title>Mutexes</title>
|
|
|
|
<note>Certain changes to the mutexes and lock concepts are
|
|
currently under discussion. In particular, the combination of
|
|
the multiple lock concepts into a single lock concept
|
|
is likely, and the combination of the multiple mutex
|
|
concepts into a single mutex concept is also possible.</note>
|
|
|
|
<para>A mutex (short for mutual-exclusion) object is used to serialize
|
|
access to a resource shared between multiple threads. The
|
|
<link linkend="thread.concepts.Mutex">Mutex</link> concept, with
|
|
<link linkend="thread.concepts.TryMutex">TryMutex</link> and
|
|
<link linkend="thread.concepts.TimedMutex">TimedMutex</link> refinements,
|
|
formalize the requirements. A model that implements Mutex and its
|
|
refinements has two states: <emphasis role="bold">locked</emphasis> and
|
|
<emphasis role="bold">unlocked</emphasis>. Before using a shared resource, a
|
|
thread locks a &Boost.Thread; mutex object
|
|
(an object whose type is a model of
|
|
<link linkend="thread.concepts.Mutex">Mutex</link> or one of it's
|
|
refinements), ensuring
|
|
<link linkend="thread.glossary.thread-safe">thread-safe</link> access to
|
|
the shared resource. When use of the shared resource is complete, the thread
|
|
unlocks the mutex object, allowing another thread to acquire the lock and
|
|
use the shared resource.</para>
|
|
<para>Traditional C thread APIs, like POSIX threads or the Windows thread
|
|
APIs, expose functions to lock and unlock a mutex object. This is dangerous
|
|
since it's easy to forget to unlock a locked mutex. When the flow of control
|
|
is complex, with multiple return points, the likelihood of forgetting to
|
|
unlock a mutex object becomes even greater. When exceptions are thrown,
|
|
it becomes nearly impossible to ensure that the mutex object is unlocked
|
|
properly when using these traditional API's. The result is
|
|
<link linkend="thread.glossary.deadlock">deadlock</link>.</para>
|
|
<para>Many C++ threading libraries use a pattern known as <emphasis>Scoped
|
|
Locking</emphasis> &cite.SchmidtStalRohnertBuschmann; to free the programmer from
|
|
the need to explicitly lock and unlock mutex objects. With this pattern, a
|
|
<link linkend="thread.concepts.lock-concepts">Lock</link> concept is employed where
|
|
the lock object's constructor locks the associated mutex object and the
|
|
destructor automatically does the unlocking. The
|
|
&Boost.Thread; library takes this pattern to
|
|
the extreme in that Lock concepts are the only way to lock and unlock a
|
|
mutex object: lock and unlock functions are not exposed by any
|
|
&Boost.Thread; mutex objects. This helps to
|
|
ensure safe usage patterns, especially when code throws exceptions.</para>
|
|
|
|
<section id="thread.concepts.locking-strategies">
|
|
<title>Locking Strategies</title>
|
|
|
|
<para>Every mutex object follows one of several locking strategies. These
|
|
strategies define the semantics for the locking operation when the calling
|
|
thread already owns a lock on the mutex object.</para>
|
|
|
|
<section id="thread.concepts.recursive-locking-strategy">
|
|
<title>Recursive Locking Strategy</title>
|
|
|
|
<para>With a recursive locking strategy, when a thread attempts to acquire
|
|
a lock on the mutex object for which it already owns a lock, the operation
|
|
is successful. Note the distinction between a thread, which may have
|
|
multiple locks outstanding on a recursive mutex object, and a lock object,
|
|
which even for a recursive mutex object cannot have any of its lock
|
|
functions called multiple times without first calling unlock.</para>
|
|
|
|
<para>Internally a lock count is maintained and the owning thread must
|
|
unlock the mutex object the same number of times that it locked it before
|
|
the mutex object's state returns to unlocked. Since mutex objects in
|
|
&Boost.Thread; expose locking
|
|
functionality only through lock concepts, a thread will always unlock a
|
|
mutex object the same number of times that it locked it. This helps to
|
|
eliminate a whole set of errors typically found in traditional C style
|
|
thread APIs.</para>
|
|
|
|
<para>Classes <classname>boost::recursive_mutex</classname>,
|
|
<classname>boost::recursive_try_mutex</classname> and
|
|
<classname>boost::recursive_timed_mutex</classname> use this locking
|
|
strategy.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.checked-locking-strategy">
|
|
<title>Checked Locking Strategy</title>
|
|
|
|
<para>With a checked locking strategy, when a thread attempts to acquire a
|
|
lock on the mutex object for which the thread already owns a lock, the
|
|
operation will fail with some sort of error indication. Further, attempts
|
|
by a thread to unlock a mutex object that was not locked by the thread
|
|
will also return some sort of error indication. In
|
|
&Boost.Thread;, an exception of type
|
|
<classname>boost::lock_error</classname>
|
|
would be thrown in these cases.</para>
|
|
|
|
<para>&Boost.Thread; does not currently
|
|
provide any mutex objects that use this strategy.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.unchecked-locking-strategy">
|
|
<title>Unchecked Locking Strategy</title>
|
|
|
|
<para>With an unchecked locking strategy, when a thread attempts to acquire
|
|
a lock on a mutex object for which the thread already owns a lock the
|
|
operation will
|
|
<link linkend="thread.glossary.deadlock">deadlock</link>. In general
|
|
this locking strategy is less safe than a checked or recursive strategy,
|
|
but it's also a faster strategy and so is employed by many libraries.</para>
|
|
|
|
<para>&Boost.Thread; does not currently
|
|
provide any mutex objects that use this strategy.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.unspecified-locking-strategy">
|
|
<title>Unspecified Locking Strategy</title>
|
|
|
|
<para>With an unspecified locking strategy, when a thread attempts to
|
|
acquire a lock on a mutex object for which the thread already owns a lock
|
|
the operation results in
|
|
<link linkend="thread.glossary.undefined-behavior">undefined behavior</link>.
|
|
</para>
|
|
|
|
<para>In general a mutex object with an unspecified locking strategy is
|
|
unsafe, and it requires programmer discipline to use the mutex object
|
|
properly. However, this strategy allows an implementation to be as fast as
|
|
possible with no restrictions on its implementation. This is especially
|
|
true for portable implementations that wrap the native threading support
|
|
of a platform. For this reason, the classes
|
|
<classname>boost::mutex</classname>,
|
|
<classname>boost::try_mutex</classname> and
|
|
<classname>boost::timed_mutex</classname> use this locking strategy
|
|
despite the lack of safety.</para>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.sheduling-policies">
|
|
<title>Scheduling Policies</title>
|
|
|
|
<para>Every mutex object follows one of several scheduling policies. These
|
|
policies define the semantics when the mutex object is unlocked and there is
|
|
more than one thread waiting to acquire a lock. In other words, the policy
|
|
defines which waiting thread shall acquire the lock.</para>
|
|
|
|
<section id="thread.concepts.FIFO-scheduling-policy">
|
|
<title>FIFO Scheduling Policy</title>
|
|
|
|
<para>With a FIFO ("First In First Out") scheduling policy, threads waiting
|
|
for the lock will acquire it in a first-come-first-served order.
|
|
This can help prevent a high priority thread from starving lower priority
|
|
threads that are also waiting on the mutex object's lock.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.priority-driven-scheduling-policy">
|
|
<title>Priority Driven Policy</title>
|
|
|
|
<para>With a Priority Driven scheduling policy, the thread with the
|
|
highest priority acquires the lock. Note that this means that low-priority
|
|
threads may never acquire the lock if the mutex object has high contention
|
|
and there is always at least one high-priority thread waiting. This is
|
|
known as thread starvation. When multiple threads of the same priority are
|
|
waiting on the mutex object's lock one of the other scheduling priorities
|
|
will determine which thread shall acquire the lock.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.unspecified-scheduling-policy">
|
|
<title>Unspecified Policy</title>
|
|
|
|
<para>The mutex object does not specify a scheduling policy. In order to
|
|
ensure portability, all &Boost.Thread;
|
|
mutex objects use an unspecified scheduling policy.</para>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.mutex-concepts">
|
|
<title>Mutex Concepts</title>
|
|
|
|
<section id="thread.concepts.Mutex">
|
|
<title>Mutex Concept</title>
|
|
|
|
<para>A Mutex object has two states: locked and unlocked. Mutex object
|
|
state can only be determined by a lock object meeting the
|
|
appropriate lock concept requirements
|
|
and constructed for the Mutex object.</para>
|
|
|
|
<para>A Mutex is
|
|
<ulink url="../../libs/utility/utility.htm#Class%20noncopyable">
|
|
NonCopyable</ulink>.</para>
|
|
<para>For a Mutex type <code>M</code>
|
|
and an object <code>m</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>Mutex Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>M m;</entry>
|
|
<entry><para>Constructs a mutex object m.</para>
|
|
<para>Postcondition: m is unlocked.</para></entry>
|
|
</row>
|
|
<row>
|
|
<entry>(&m)->~M();</entry>
|
|
<entry>Precondition: m is unlocked. Destroys a mutex object
|
|
m.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>M::scoped_lock</entry>
|
|
<entry>A model of
|
|
<link linkend="thread.concepts.ScopedLock">ScopedLock</link>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TryMutex">
|
|
<title>TryMutex Concept</title>
|
|
|
|
<para>A TryMutex is a refinement of
|
|
<link linkend="thread.concepts.Mutex">Mutex</link>.
|
|
For a TryMutex type <code>M</code>
|
|
and an object <code>m</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TryMutex Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>M::scoped_try_lock</entry>
|
|
<entry>A model of
|
|
<link linkend="thread.concepts.ScopedTryLock">ScopedTryLock</link>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TimedMutex">
|
|
<title>TimedMutex Concept</title>
|
|
|
|
<para>A TimedMutex is a refinement of
|
|
<link linkend="thread.concepts.TryMutex">TryMutex</link>.
|
|
For a TimedMutex type <code>M</code>
|
|
and an object <code>m</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TimedMutex Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>M::scoped_timed_lock</entry>
|
|
<entry>A model of
|
|
<link
|
|
linkend="thread.concepts.ScopedTimedLock">ScopedTimedLock</link>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.mutex-models">
|
|
<title>Mutex Models</title>
|
|
|
|
<para>&Boost.Thread; currently supplies six models of
|
|
<link linkend="thread.concepts.Mutex">Mutex</link>
|
|
and its refinements.</para>
|
|
|
|
<table>
|
|
<title>Mutex Models</title>
|
|
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Concept</entry>
|
|
<entry>Refines</entry>
|
|
<entry>Models</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.Mutex">Mutex</link></entry>
|
|
<entry></entry>
|
|
<entry>
|
|
<para><classname>boost::mutex</classname></para>
|
|
<para><classname>boost::recursive_mutex</classname></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TryMutex">TryMutex</link></entry>
|
|
<entry><link linkend="thread.concepts.Mutex">Mutex</link></entry>
|
|
<entry>
|
|
<para><classname>boost::try_mutex</classname></para>
|
|
<para><classname>boost::recursive_try_mutex</classname></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TimedMutex">TimedMutex</link></entry>
|
|
<entry><link linkend="thread.concepts.TryMutex">TryMutex</link></entry>
|
|
<entry>
|
|
<para><classname>boost::timed_mutex</classname></para>
|
|
<para><classname>boost::recursive_timed_mutex</classname></para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.lock-concepts">
|
|
<title>Lock Concepts</title>
|
|
|
|
<para>A lock object provides a safe means for locking and unlocking a mutex
|
|
object (an object whose type is a model of <link
|
|
linkend="thread.concepts.Mutex">Mutex</link> or one of its refinements). In
|
|
other words they are an implementation of the <emphasis>Scoped
|
|
Locking</emphasis> &cite.SchmidtStalRohnertBuschmann; pattern. The <link
|
|
linkend="thread.concepts.ScopedLock">ScopedLock</link>,
|
|
<link linkend="thread.concepts.ScopedTryLock">ScopedTryLock</link>, and
|
|
<link linkend="thread.concepts.ScopedTimedLock">ScopedTimedLock</link>
|
|
concepts formalize the requirements.</para>
|
|
<para>Lock objects are constructed with a reference to a mutex object and
|
|
typically acquire ownership of the mutex object by setting its state to
|
|
locked. They also ensure ownership is relinquished in the destructor. Lock
|
|
objects also expose functions to query the lock status and to manually lock
|
|
and unlock the mutex object.</para>
|
|
<para>Lock objects are meant to be short lived, expected to be used at block
|
|
scope only. The lock objects are not <link
|
|
linkend="thread.glossary.thread-safe">thread-safe</link>. Lock objects must
|
|
maintain state to indicate whether or not they've been locked and this state
|
|
is not protected by any synchronization concepts. For this reason a lock
|
|
object should never be shared between multiple threads.</para>
|
|
|
|
<section id="thread.concepts.Lock">
|
|
<title>Lock Concept</title>
|
|
|
|
<para>For a Lock type <code>L</code>
|
|
and an object <code>lk</code>
|
|
and const object <code>clk</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>Lock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>(&lk)->~L();</code></entry>
|
|
<entry><code>if (locked()) unlock();</code></entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>(&clk)->operator const void*()</code></entry>
|
|
<entry>Returns type void*, non-zero if the associated mutex
|
|
object has been locked by <code>clk</code>, otherwise 0.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>clk.locked()</code></entry>
|
|
<entry>Returns a <code>bool</code>, <code>(&clk)->operator
|
|
const void*() != 0</code></entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.lock()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>locked()</code>.</para>
|
|
|
|
<para>If the associated mutex object is
|
|
already locked by some other thread, places the current thread in the
|
|
<link linkend="thread.glossary.thread-state">Blocked</link> state until
|
|
the associated mutex is unlocked, after which the current thread
|
|
is placed in the <link
|
|
linkend="thread.glossary.thread-state">Ready</link> state,
|
|
eventually to be returned to the <link
|
|
linkend="thread.glossary.thread-state">Running</link> state. If
|
|
the associated mutex object is already locked by the same thread
|
|
the behavior is dependent on the <link
|
|
linkend="thread.concepts.locking-strategies">locking
|
|
strategy</link> of the associated mutex object.</para>
|
|
|
|
<para>Postcondition: <code>locked() == true</code></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.unlock()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>!locked()</code>.</para>
|
|
|
|
<para>Unlocks the associated mutex.</para>
|
|
|
|
<para>Postcondition: <code>!locked()</code></para></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.ScopedLock">
|
|
<title>ScopedLock Concept</title>
|
|
|
|
<para>A ScopedLock is a refinement of <link
|
|
linkend="thread.concepts.Lock">Lock</link>.
|
|
For a ScopedLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>m</code> of a type meeting the
|
|
<link linkend="thread.concepts.Mutex">Mutex</link> requirements,
|
|
and an object <code>b</code> of type <code>bool</code>,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ScopedLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>L lk(m);</code></entry>
|
|
<entry>Constructs an object <code>lk</code>, and associates mutex
|
|
object <code>m</code> with it, then calls
|
|
<code>lock()</code></entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>L lk(m,b);</code></entry>
|
|
<entry>Constructs an object <code>lk</code>, and associates mutex
|
|
object <code>m</code> with it, then if <code>b</code>, calls
|
|
<code>lock()</code></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TryLock">
|
|
<title>TryLock Concept</title>
|
|
|
|
<para>A TryLock is a refinement of <link
|
|
linkend="thread.concepts.Lock">Lock</link>.
|
|
For a TryLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TryLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>lk.try_lock()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if locked().</para>
|
|
|
|
<para>Makes a
|
|
non-blocking attempt to lock the associated mutex object,
|
|
returning <code>true</code> if the lock attempt is successful,
|
|
otherwise <code>false</code>. If the associated mutex object is
|
|
already locked by the same thread the behavior is dependent on the
|
|
<link linkend="thread.concepts.locking-strategies">locking
|
|
strategy</link> of the associated mutex object.</para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.ScopedTryLock">
|
|
<title>ScopedTryLock Concept</title>
|
|
|
|
<para>A ScopedTryLock is a refinement of <link
|
|
linkend="thread.concepts.TryLock">TryLock</link>.
|
|
For a ScopedTryLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>m</code> of a type meeting the
|
|
<link linkend="thread.concepts.TryMutex">TryMutex</link> requirements,
|
|
and an object <code>b</code> of type <code>bool</code>,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ScopedTryLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>L lk(m);</code></entry>
|
|
<entry>Constructs an object <code>lk</code>, and associates mutex
|
|
object <code>m</code> with it, then calls
|
|
<code>try_lock()</code></entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>L lk(m,b);</code></entry>
|
|
<entry>Constructs an object <code>lk</code>, and associates mutex
|
|
object <code>m</code> with it, then if <code>b</code>, calls
|
|
<code>lock()</code></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TimedLock">
|
|
<title>TimedLock Concept</title>
|
|
|
|
<para>A TimedLock is a refinement of <link
|
|
linkend="thread.concepts.TryLock">TryLock</link>.
|
|
For a TimedLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>t</code> of type <classname>boost::xtime</classname>,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TimedLock Expressions</title>
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>lk.timed_lock(t)</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if locked().</para>
|
|
|
|
<para>Makes a blocking attempt
|
|
to lock the associated mutex object, and returns <code>true</code>
|
|
if successful within the specified time <code>t</code>, otherwise
|
|
<code>false</code>. If the associated mutex object is already
|
|
locked by the same thread the behavior is dependent on the <link
|
|
linkend="thread.concepts.locking-strategies">locking
|
|
strategy</link> of the associated mutex object.</para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.ScopedTimedLock">
|
|
<title>ScopedTimedLock Concept</title>
|
|
|
|
<para>A ScopedTimedLock is a refinement of <link
|
|
linkend="thread.concepts.TimedLock">TimedLock</link>.
|
|
For a ScopedTimedLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>m</code> of a type meeting the
|
|
<link linkend="thread.concepts.TimedMutex">TimedMutex</link> requirements,
|
|
and an object <code>b</code> of type <code>bool</code>,
|
|
and an object <code>t</code> of type <classname>boost::xtime</classname>,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ScopedTimedLock Expressions</title>
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>L lk(m,t);</code></entry>
|
|
<entry>Constructs an object <code>lk</code>, and associates mutex
|
|
object <code>m</code> with it, then calls
|
|
<code>timed_lock(t)</code></entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>L lk(m,b);</code></entry>
|
|
<entry>Constructs an object <code>lk</code>, and associates mutex
|
|
object <code>m</code> with it, then if <code>b</code>, calls
|
|
<code>lock()</code></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.lock-models">
|
|
<title>Lock Models</title>
|
|
|
|
<para>&Boost.Thread; currently supplies twelve models of
|
|
<link linkend="thread.concepts.Lock">Lock</link>
|
|
and its refinements.</para>
|
|
|
|
<table>
|
|
<title>Lock Models</title>
|
|
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Concept</entry>
|
|
<entry>Refines</entry>
|
|
<entry>Models</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.Lock">Lock</link></entry>
|
|
<entry></entry>
|
|
<entry></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ScopedLock">ScopedLock</link></entry>
|
|
<entry><link linkend="thread.concepts.Lock">Lock</link></entry>
|
|
<entry>
|
|
<para><classname>boost::mutex::scoped_lock</classname></para>
|
|
<para><classname>boost::recursive_mutex::scoped_lock</classname></para>
|
|
|
|
<para><classname>boost::try_mutex::scoped_lock</classname></para>
|
|
<para><classname>boost::recursive_try_mutex::scoped_lock</classname></para>
|
|
|
|
<para><classname>boost::timed_mutex::scoped_lock</classname></para>
|
|
<para><classname>boost::recursive_timed_mutex::scoped_lock</classname></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TryLock">TryLock</link></entry>
|
|
<entry><link linkend="thread.concepts.Lock">Lock</link></entry>
|
|
<entry></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ScopedTryLock">ScopedTryLock</link></entry>
|
|
<entry><link linkend="thread.concepts.TryLock">TryLock</link></entry>
|
|
<entry>
|
|
<para><classname>boost::try_mutex::scoped_try_lock</classname></para>
|
|
<para><classname>boost::recursive_try_mutex::scoped_try_lock</classname></para>
|
|
|
|
<para><classname>boost::timed_mutex::scoped_try_lock</classname></para>
|
|
<para><classname>boost::recursive_timed_mutex::scoped_try_lock</classname></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TimedLock">TimedLock</link></entry>
|
|
<entry><link linkend="thread.concepts.TryLock">TryLock</link></entry>
|
|
<entry></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ScopedTimedLock">ScopedTimedLock</link></entry>
|
|
<entry><link linkend="thread.concepts.TimedLock">TimedLock</link></entry>
|
|
<entry>
|
|
<para><classname>boost::timed_mutex::scoped_timed_lock</classname></para>
|
|
<para><classname>boost::recursive_timed_mutex::scoped_timed_lock</classname></para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-mutexes">
|
|
<title>Read/Write Mutexes</title>
|
|
<note> Unfortunately it turned out that the current implementation has
|
|
some serious problems. So it was decided not to put this implementation into
|
|
release grade code. Also discussions on the mailing list led to the
|
|
conclusion that the current concepts need to be rethought. In particular
|
|
the schedulings <link linkend="thread.concepts.read-write-scheduling-policies.inter-class">
|
|
Inter-Class Scheduling Policies</link> are deemed unnecessary.
|
|
There seems to be common belief that a fair scheme suffices.
|
|
The following documentation has been retained however, to give
|
|
readers of this document the opportunity to study the original design.
|
|
</note>
|
|
|
|
<para>A read/write mutex (short for reader/writer mutual-exclusion) object
|
|
is used to serialize access to a resource shared between multiple
|
|
threads, where multiple "readers" can share simultaneous access, but
|
|
"writers" require exclusive access. The
|
|
<link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link> concept, with
|
|
<link linkend="thread.concepts.TryReadWriteMutex">TryReadWriteMutex</link> and
|
|
<link linkend="thread.concepts.TimedReadWriteMutex"> TimedReadWriteMutex</link>
|
|
refinements formalize the requirements. A model that implements
|
|
ReadWriteMutex and its refinements has three states:
|
|
<emphasis role="bold">read-locked</emphasis>,
|
|
<emphasis role="bold">write-locked</emphasis>, and
|
|
<emphasis role="bold">unlocked</emphasis>.
|
|
Before reading from a shared resource, a thread
|
|
<emphasis role="bold">read-locks</emphasis>
|
|
a &Boost.Thread; read/write mutex object
|
|
(an object whose type is a model of
|
|
<link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link>
|
|
or one of it's refinements), ensuring
|
|
<link linkend="thread.glossary.thread-safe">thread-safe</link>
|
|
access for reading from the shared resource. Before writing
|
|
to a shared resource, a thread
|
|
<emphasis role="bold">write-locks</emphasis> a &Boost.Thread;
|
|
read/write mutex object
|
|
(an object whose type is a model of
|
|
<link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link>
|
|
or one of it's refinements), ensuring
|
|
<link linkend="thread.glossary.thread-safe">thread-safe</link>
|
|
access for altering the shared resource. When use of the shared
|
|
resource is complete, the thread unlocks the mutex object,
|
|
allowing another thread to acquire the lock and use the shared
|
|
resource.</para>
|
|
|
|
<para>Traditional C thread APIs that provide read/write mutex
|
|
primitives (like POSIX threads) expose functions to lock and unlock a
|
|
mutex object. This is dangerous since it's easy to forget to unlock a
|
|
locked mutex. When the flow of control is complex, with multiple
|
|
return points, the likelihood of forgetting to unlock a mutex object
|
|
becomes even greater. When exceptions are thrown, it becomes nearly
|
|
impossible to ensure that the mutex object is unlocked
|
|
properly when using these traditional API's. The result is
|
|
<link linkend="thread.glossary.deadlock">deadlock</link>.</para>
|
|
|
|
<para>Many C++ threading libraries use a pattern known as <emphasis>Scoped
|
|
Locking</emphasis> &cite.SchmidtStalRohnertBuschmann; to free the
|
|
programmer from the need to explicitly lock and unlock
|
|
read/write mutex objects. With this pattern, a
|
|
<link linkend="thread.concepts.read-write-lock-concepts">Read/Write Lock</link>
|
|
concept is employed where the lock object's constructor locks
|
|
the associated read/write mutex object
|
|
and the destructor automatically does the unlocking. The
|
|
&Boost.Thread; library takes this pattern to
|
|
the extreme in that
|
|
<link linkend="thread.concepts.read-write-lock-concepts">Read/Write Lock</link>
|
|
concepts are the only way to lock and unlock a read/write mutex
|
|
object: lock and unlock functions are not exposed by any
|
|
&Boost.Thread; read/write mutex objects. This helps to
|
|
ensure safe usage patterns, especially when code throws exceptions.</para>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies">
|
|
<title>Locking Strategies</title>
|
|
|
|
<para>Every read/write mutex object follows one of several locking
|
|
strategies. These strategies define the semantics for the locking
|
|
operation when the calling thread already owns a lock on the
|
|
read/write mutex object.</para>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies.recursive">
|
|
<title>Recursive Locking Strategy</title>
|
|
|
|
<para>With a recursive locking strategy, when a thread attempts
|
|
to acquire a lock on a read/write mutex object
|
|
for which it already owns a lock, the operation is successful,
|
|
except in the case where a thread holding a read-lock
|
|
attempts to obtain a write lock, in which case a
|
|
<classname>boost::lock_error</classname> exception will
|
|
be thrown. Note the distinction between a thread, which may have
|
|
multiple locks outstanding on a recursive read/write mutex object,
|
|
and a lock object, which even for a recursive read/write mutex
|
|
object cannot have any of its lock functions called multiple
|
|
times without first calling unlock.</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Lock Type Held</entry>
|
|
<entry>Lock Type Requested</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>If this thread is the only holder of the read-lock,
|
|
grants the write lock immediately. Otherwise throws a
|
|
<classname>boost::lock_error</classname> exception.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grants the (additional) read-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry> Grant the write-lock immediately</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
|
|
<para>Internally a lock count is maintained and the owning
|
|
thread must unlock the mutex object the same number of times
|
|
that it locked it before the mutex object's state returns
|
|
to unlocked. Since mutex objects in &Boost.Thread; expose
|
|
locking functionality only through lock concepts, a thread
|
|
will always unlock a mutex object the same number of times
|
|
that it locked it. This helps to eliminate a whole set of
|
|
errors typically found in traditional C style thread APIs.
|
|
</para>
|
|
|
|
<para>&Boost.Thread; does not currently provide any read/write mutex objects
|
|
that use this strategy. A successful implementation of this locking strategy
|
|
may require
|
|
<link linkend="thread.concepts.read-write-locking-strategies.thread-identification">thread identification</link>.
|
|
</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies.checked">
|
|
<title>Checked Locking Strategy</title>
|
|
|
|
<para>With a checked locking strategy, when a thread attempts
|
|
to acquire a lock on the mutex object for which the thread
|
|
already owns a lock, the operation will fail with some sort of
|
|
error indication, except in the case of multiple read-lock
|
|
acquisition which is a normal operation for ANY ReadWriteMutex.
|
|
Further, attempts by a thread to unlock a mutex that was not
|
|
locked by the thread will also return some sort of error
|
|
indication. In &Boost.Thread;, an exception of type
|
|
<classname>boost::lock_error</classname> would be thrown in
|
|
these cases.</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Lock Type Held</entry>
|
|
<entry>Lock Type Requested</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Throw <classname>boost::lock_error</classname></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Throw <classname>boost::lock_error</classname></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry> Throw <classname>boost::lock_error</classname></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
|
|
<para>&Boost.Thread; does not currently provide any read/write mutex objects
|
|
that use this strategy. A successful implementation of this locking strategy
|
|
may require
|
|
<link linkend="thread.concepts.read-write-locking-strategies.thread-identification">thread identification</link>.
|
|
</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies.unchecked">
|
|
<title>Unchecked Locking Strategy</title>
|
|
|
|
<para>With an unchecked locking strategy, when a thread
|
|
attempts to acquire a lock on the read/write mutex object
|
|
for which the thread already owns a lock, the operation
|
|
will <link linkend="thread.glossary.deadlock">deadlock</link>.
|
|
In general this locking strategy is less safe than a checked
|
|
or recursive strategy, but it can be a faster strategy and so
|
|
is employed by many libraries.</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Lock Type Held</entry>
|
|
<entry>Lock Type Requested</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>write-lock</entry>
|
|
<entry><link linkend="thread.glossary.deadlock">Deadlock</link></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry><link linkend="thread.glossary.deadlock">Deadlock</link></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry><link linkend="thread.glossary.deadlock">Deadlock</link></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
|
|
<para>&Boost.Thread; does not currently provide any mutex
|
|
objects that use this strategy. For ReadWriteMutexes on
|
|
platforms that contain natively recursive synchronization
|
|
primitives, implementing a guaranteed-deadlock can actually
|
|
involve extra work, and would likely require
|
|
<link linkend="thread.concepts.read-write-locking-strategies.thread-identification">thread identification</link>.
|
|
</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies.unspecified">
|
|
<title>Unspecified Locking Strategy</title>
|
|
|
|
<para>With an unspecified locking strategy, when a thread
|
|
attempts to acquire a lock on a read/write mutex object for
|
|
which the thread already owns a lock, the operation results
|
|
in <link linkend="thread.glossary.undefined-behavior">undefined behavior</link>.
|
|
When a read/write mutex object has an unspecified locking
|
|
strategy the programmer must assume that the read/write mutex
|
|
object instead uses an unchecked strategy as the worse case,
|
|
although some platforms may exhibit a mix of unchecked and
|
|
recursive behavior.</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Lock Type Held</entry>
|
|
<entry>Lock Type Requested</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-lock</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>
|
|
<link linkend="thread.glossary.undefined-behavior">Undefined</link>, but generally <link linkend="thread.glossary.deadlock">deadlock</link>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry><link linkend="thread.glossary.undefined-behavior">Undefined</link>, but generally <link linkend="thread.glossary.deadlock">deadlock</link></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry><link linkend="thread.glossary.undefined-behavior">Undefined</link>, but generally <link linkend="thread.glossary.deadlock">deadlock</link></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
|
|
<para>In general a read/write mutex object with an unspecified
|
|
locking strategy is unsafe, and it requires programmer discipline
|
|
to use the read/write mutex object properly. However, this strategy
|
|
allows an implementation to be as fast as possible with no restrictions
|
|
on its implementation. This is especially true for portable implementations
|
|
that wrap the native threading support of a platform. For this reason, the
|
|
classes
|
|
<classname>read_write_mutex</classname>,
|
|
<classname>try_read_write_mutex</classname>, and
|
|
<classname>timed_read_write_mutex</classname>
|
|
use this locking strategy despite the lack of safety.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies.thread-identification">
|
|
<title>Thread Identification</title>
|
|
|
|
<para>ReadWriteMutexes can support specific Locking Strategies
|
|
(recursive and checked) which help to detect and protect against
|
|
self-deadlock. Self-deadlock can occur when a holder of a locked
|
|
ReadWriteMutex attempts to obtain another lock. Given an
|
|
implemention <emphasis>I</emphasis> which is susceptible to
|
|
self-deadlock but otherwise correct and efficient, a recursive or
|
|
checked implementation <emphasis>Ir</emphasis> or
|
|
<emphasis>Ic</emphasis> can use the same basic implementation,
|
|
but make special checks against self-deadlock by tracking the
|
|
identities of thread(s) currently holding locks. This approach
|
|
makes deadlock detection othrogonal to the basic ReadWriteMutex
|
|
implementaion.</para>
|
|
|
|
<para>Alternatively, a different basic implementation for
|
|
ReadWriteMutex concepts,
|
|
<emphasis>I'</emphasis> (I-Prime) may exist which uses recursive
|
|
or checked versions of synchronization primitives to produce
|
|
a recursive or checked ReadWriteMutex while still providing
|
|
flexibility in terms of Scheduling Policies. </para>
|
|
|
|
<para>Please refer to the &Boost.Thread;
|
|
<link linkend="thread.concepts.read-write-mutex-concepts">read/write mutex concept</link>
|
|
documentation for a discussion of locking strategies.
|
|
The read/write mutex supports only the
|
|
<link linkend="thread.concepts.read-write-locking-strategies.unspecified">unspecified</link>
|
|
locking strategy. ReadWriteMutexes are parameterized on a
|
|
Mutex type which they use to control write-locking
|
|
and access to internal state.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies.promotion">
|
|
<title>Lock Promotion</title>
|
|
|
|
<para>ReadWriteMutexes can support lock promotion, where a
|
|
mutex which is in the read-locked state transitions to a
|
|
write-locked state without releasing the lock. Lock
|
|
promotion can be tricky to implement; for instance,
|
|
extra care must be taken to ensure that only one thread holding a
|
|
read-lock can block awaiting promotion at any given time. If
|
|
more than one read-lock holder is allowed to enter a blocked
|
|
state while waiting to be promoted, deadlock will result since
|
|
both threads will be waiting for the other to release their read-lock.
|
|
</para>
|
|
|
|
<para>Currently, &Boost.Thread; supports lock promotion
|
|
through <code>promote()</code>, <code>try_promote()</code>,
|
|
and <code>timed_promote()</code> operations.</para>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-locking-strategies.demotion">
|
|
<title>Lock Demotion</title>
|
|
|
|
<para>ReadWriteMutexes can support lock demotion, where a
|
|
mutex which is in the write-locked state transitions to a
|
|
read-locked state without releasing the lock.
|
|
Since by definition only one thread at a time may hold
|
|
a write-lock, the problem with deadlock that can occur
|
|
during lock promotion is not a problem for lock
|
|
demotion.</para>
|
|
|
|
<para>Currently, &Boost.Thread; supports lock demotion
|
|
through <code>demote()</code>, <code>try_demote()</code>,
|
|
and <code>timed_demote()</code> operations.</para>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-scheduling-policies">
|
|
<title>Scheduling Policies</title>
|
|
|
|
<para>Every read/write mutex object follows one of several scheduling
|
|
policies. These policies define the semantics when the mutex object
|
|
is unlocked and there is more than one thread waiting to acquire a
|
|
lock. In other words, the policy defines which waiting thread shall
|
|
acquire the lock. For a read/write mutex, it is particularly important
|
|
to define the behavior when threads are requesting both read and
|
|
write access simultaneously. This will be referred to as "inter-class
|
|
scheduling" because it describes the scheduling between two
|
|
classes of threads (those waiting for a read lock and those
|
|
waiting for a write lock).</para>
|
|
|
|
<para>For some types of inter-class scheduling, an "intra-class"
|
|
scheduling policy can also be defined that will describe the order
|
|
in which waiting threads of the same class (i.e., those
|
|
waiting for the same type of lock) will acquire the thread.
|
|
</para>
|
|
|
|
<section id="thread.concepts.read-write-scheduling-policies.inter-class">
|
|
<title>Inter-Class Scheduling Policies</title>
|
|
|
|
<section id="thread.concepts.read-write-scheduling-policies.reader-priority">
|
|
<title>ReaderPriority</title>
|
|
|
|
<para>With ReaderPriority scheduling, any pending request for
|
|
a read-lock will have priority over a pending request for a
|
|
write-lock, irrespective of the current lock state of the
|
|
read/write mutex, and irrespective of the relative order
|
|
that the pending requests arrive.</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Current mutex state</entry>
|
|
<entry>Request Type</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the additional read-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Wait to acquire the lock until the thread
|
|
holding the write-lock releases its lock (or until
|
|
the specified time, if any). A
|
|
read-lock will be granted to all pending readers
|
|
before any other thread can acquire a write-lock.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Grant the write-lock immediately, if and
|
|
only if there are no pending read-lock requests.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry> Wait to acquire the lock until all
|
|
threads holding read-locks release their locks
|
|
<emphasis role="bold">AND</emphasis> no requests
|
|
for read-locks exist. If other write-lock
|
|
requests exist, the lock is granted in accordance
|
|
with the intra-class scheduling policy.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Wait to acquire the lock until the thread
|
|
holding the write-lock releases its lock
|
|
<emphasis role="bold">AND</emphasis> no requests
|
|
for read-locks exist. If other write-lock
|
|
requests exist, the lock is granted in accordance
|
|
with the intra-class scheduling policy.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>promote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>demote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-scheduling-policies.writer-priority">
|
|
<title>WriterPriority</title>
|
|
|
|
<para>With WriterPriority scheduling, any pending request
|
|
for a write-lock will have priority over a pending request
|
|
for a read-lock, irrespective of the current lock state
|
|
of the read/write mutex, and irrespective of the relative
|
|
order that the pending requests arrive.</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Current mutex state</entry>
|
|
<entry>Request Type</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the additional read-lock immediately,
|
|
<emphasis role="bold">IF</emphasis> no outstanding
|
|
requests for a write-lock exist; otherwise TODO.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry> Wait to acquire the lock until the
|
|
thread holding the write-lock
|
|
releases its lock. The read lock will be granted
|
|
once no other outstanding write-lock requests
|
|
exist.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Grant the write-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Wait to acquire the lock until all
|
|
threads holding read-locks release their locks.
|
|
If other write-lock requests exist, the lock
|
|
is granted in accordance with the intra-class
|
|
scheduling policy. This request will be granted
|
|
before any new read-lock requests are granted.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Wait to acquire the lock until the thread
|
|
holding the write-lock releases its lock. If
|
|
other write-lock requests exist, the lock is
|
|
granted in accordance with the intra-class
|
|
scheduling policy. This request will be granted
|
|
before any new read-lock requests are granted.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>promote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>demote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-scheduling-policies.alternating-many-reads">
|
|
<title>AlternatingPriority/ManyReads</title>
|
|
|
|
<para>With AlternatingPriority/ManyReads scheduling, reader
|
|
or writer starvation is avoided by alternatively granting read
|
|
or write access when pending requests exist for both types of
|
|
locks. Outstanding read-lock requests are treated as a group
|
|
when it is the "readers' turn"</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Current mutex state</entry>
|
|
<entry>Request Type</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the additional read-lock immediately,
|
|
<emphasis role="bold">IF</emphasis> no outstanding
|
|
requests for a write-lock exist. If outstanding
|
|
write-lock requests exist, this lock will not
|
|
be granted until at least one of the
|
|
write-locks is granted and released. If other
|
|
read-lock requests exist, all read-locks will be
|
|
granted as a group.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry> Wait to acquire the lock until the thread
|
|
holding the write-lock releases its lock. If other
|
|
outstanding write-lock requests exist, they will
|
|
have to wait until all current read-lock requests
|
|
are serviced.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Grant the write-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>
|
|
<para>Wait to acquire the lock until all threads
|
|
holding read-locks release their locks.</para>
|
|
|
|
<para>If other write-lock requests exist, this
|
|
lock will be granted to one of them in accordance
|
|
with the intra-class scheduling policy.</para>
|
|
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Wait to acquire the lock until the thread
|
|
holding the write-lock releases its lock. If
|
|
other outstanding read-lock requests exist, this
|
|
lock will not be granted until all of the
|
|
currently waiting read-locks are granted and
|
|
released. If other write-lock requests exist,
|
|
this lock will be granted in accordance with the
|
|
intra-class scheduling policy.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>promote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>demote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-scheduling-policies.alternating-single-read">
|
|
<title>AlternatingPriority/SingleRead</title>
|
|
|
|
<para>With AlternatingPriority/SingleRead scheduling, reader
|
|
or writer starvation is avoided by alternatively granting read
|
|
or write access when pending requests exist for both types of
|
|
locks. Outstanding read-lock requests are services one at a
|
|
time when it is the "readers' turn"</para>
|
|
|
|
<informaltable>
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Current mutex state</entry>
|
|
<entry>Request Type</entry>
|
|
<entry>Action</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the read-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>Grant the additional read-lock immediately,
|
|
<emphasis role="bold">IF</emphasis> no outstanding
|
|
requests for a write-lock exist. If outstanding
|
|
write-lock requests exist, this lock will not
|
|
be granted until at least one of the write-locks
|
|
is granted and released.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>read-lock</entry>
|
|
<entry>
|
|
<para>Wait to acquire the lock until the thread
|
|
holding the write-lock releases its lock.</para>
|
|
<para>If other outstanding write-lock requests
|
|
exist, exactly one read-lock request will be
|
|
granted before the next write-lock is granted.
|
|
</para>
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>unlocked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Grant the write-lock immediately.</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>
|
|
<para>Wait to acquire the lock until all
|
|
threads holding read-locks release their
|
|
locks.</para>
|
|
|
|
<para>If other write-lock requests exist,
|
|
this lock will be granted to one of them
|
|
in accordance with the intra-class
|
|
scheduling policy.</para></entry>
|
|
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>write-lock</entry>
|
|
<entry>Wait to acquire the lock until the
|
|
thread holding the write-lock releases its
|
|
lock. If other outstanding read-lock requests
|
|
exist, this lock can not be granted until
|
|
exactly one read-lock request is granted and
|
|
released. If other write-lock requests exist,
|
|
this lock will be granted in accordance with
|
|
the intra-class scheduling policy.
|
|
<para>TODO: try-lock, timed-lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>read-locked</entry>
|
|
<entry>promote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
<row>
|
|
<entry>write-locked</entry>
|
|
<entry>demote</entry>
|
|
<entry><para>TODO</para></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</informaltable>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-scheduling-policies.intra-class">
|
|
<title>Intra-Class Scheduling Policies</title>
|
|
|
|
<para>Please refer to
|
|
<xref linkend="thread.concepts.sheduling-policies" />
|
|
for a discussion of mutex scheduling policies, which are identical to
|
|
read/write mutex intra-class scheduling policies.</para>
|
|
|
|
<para>For threads waiting to obtain write-locks, the read/write mutex
|
|
supports only the
|
|
<link linkend="thread.concepts.unspecified-scheduling-policy">Unspecified</link>
|
|
intra-class scheduling policy. That is, given a set of threads
|
|
waiting for write-locks, the order, relative to one another, in
|
|
which they receive the write-lock is unspecified.</para>
|
|
|
|
<para>For threads waiting to obtain read-locks, the read/write mutex
|
|
supports only the
|
|
<link linkend="thread.concepts.unspecified-scheduling-policy">Unspecified</link>
|
|
intra-class scheduling policy. That is, given a set of threads
|
|
waiting for read-locks, the order, relative to one another, in
|
|
which they receive the read-lock is unspecified.</para>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-mutex-concepts">
|
|
<title>Mutex Concepts</title>
|
|
|
|
<section id="thread.concepts.ReadWriteMutex">
|
|
<title>ReadWriteMutex Concept</title>
|
|
|
|
<para>A ReadWriteMutex object has three states: read-locked,
|
|
write-locked, and unlocked. ReadWriteMutex object state can
|
|
only be determined by a lock object meeting the appropriate lock concept
|
|
requirements and constructed for the ReadWriteMutex object.</para>
|
|
|
|
<para>A ReadWriteMutex is
|
|
<ulink url="../../libs/utility/utility.htm#Class%20noncopyable">NonCopyable</ulink>.
|
|
</para>
|
|
|
|
<para>For a ReadWriteMutex type <code>M</code>,
|
|
and an object <code>m</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ReadWriteMutex Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>M m;</code></entry>
|
|
<entry>Constructs a read/write mutex object <code>m</code>.
|
|
Post-condition: <code>m</code> is unlocked.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>(&m)->~M();</code></entry>
|
|
<entry>Precondition: <code>m</code> is unlocked.
|
|
Destroys a read/write mutex object <code>m</code>.
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>M::scoped_read_write_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedReadWriteLock">ScopedReadWriteLock</link>
|
|
requirements. </entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>M::scoped_read_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedLock">ScopedLock</link>
|
|
requirements. </entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>M::scoped_write_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedLock">ScopedLock</link>
|
|
requirements. </entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TryReadWriteMutex">
|
|
<title>TryReadWriteMutex Concept</title>
|
|
|
|
<para>A TryReadWriteMutex is a refinement of
|
|
<link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link>.
|
|
For a TryReadWriteMutex type <code>M</code>
|
|
and an object <code>m</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TryReadWriteMutex Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>M::scoped_try_read_write_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedTryReadWriteLock">ScopedTryReadWriteLock</link>
|
|
requirements.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>M::scoped_try_read_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedTryLock">ScopedTryLock</link>
|
|
requirements.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>M::scoped_try_write_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedTryLock">ScopedTryLock</link>
|
|
requirements.</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TimedReadWriteMutex">
|
|
<title>TimedReadWriteMutex Concept</title>
|
|
|
|
<para>A TimedReadWriteMutex is a refinement of
|
|
<link linkend="thread.concepts.TryReadWriteMutex">TryReadWriteMutex</link>.
|
|
For a TimedReadWriteMutex type <code>M</code>
|
|
and an object <code>m</code> of that type
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TimedReadWriteMutex Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>M::scoped_timed_read_write_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedTimedReadWriteLock">ScopedTimedReadWriteLock</link>
|
|
requirements.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>M::scoped_timed_read_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedTimedLock">ScopedTimedLock</link>
|
|
requirements.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>M::scoped_timed_write_lock</code></entry>
|
|
<entry>A type meeting the
|
|
<link linkend="thread.concepts.ScopedTimedLock">ScopedTimedLock</link>
|
|
requirements.</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-mutex-models">
|
|
<title>Mutex Models</title>
|
|
|
|
<para>&Boost.Thread; currently supplies three models of
|
|
<link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link>
|
|
and its refinements.</para>
|
|
|
|
<table>
|
|
<title>Mutex Models</title>
|
|
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Concept</entry>
|
|
<entry>Refines</entry>
|
|
<entry>Models</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link></entry>
|
|
<entry></entry>
|
|
<entry><classname>boost::read_write_mutex</classname></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TryReadWriteMutex">TryReadWriteMutex</link></entry>
|
|
<entry><link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link></entry>
|
|
<entry><classname>boost::try_read_write_mutex</classname></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TimedReadWriteMutex">TimedReadWriteMutex</link></entry>
|
|
<entry><link linkend="thread.concepts.TryReadWriteMutex">TryReadWriteMutex</link></entry>
|
|
<entry><classname>boost::timed_read_write_mutex</classname></entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-lock-concepts">
|
|
<title>Lock Concepts</title>
|
|
|
|
<para>A read/write lock object provides a safe means for locking
|
|
and unlocking a read/write mutex object (an object whose type is
|
|
a model of
|
|
<link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link>
|
|
or one of its refinements). In other words they are an
|
|
implementation of the <emphasis>Scoped Locking</emphasis>
|
|
&cite.SchmidtStalRohnertBuschmann; pattern. The
|
|
<link linkend="thread.concepts.ScopedReadWriteLock">ScopedReadWriteLock</link>,
|
|
<link linkend="thread.concepts.ScopedTryReadWriteLock">ScopedTryReadWriteLock</link>, and
|
|
<link linkend="thread.concepts.ScopedTimedReadWriteLock">ScopedTimedReadWriteLock</link>
|
|
concepts formalize the requirements.</para>
|
|
|
|
<para>Read/write lock objects are constructed with a reference to a
|
|
read/write mutex object and typically acquire ownership of the
|
|
read/write mutex object by setting its state to locked. They also
|
|
ensure ownership is relinquished in the destructor. Lock objects
|
|
also expose functions to query the lock status and to manually lock
|
|
and unlock the read/write mutex object.</para>
|
|
|
|
<para>Read/write lock objects are meant to be short lived, expected
|
|
to be used at block scope only. The read/write lock objects are not
|
|
<link linkend="thread.glossary.thread-safe">thread-safe</link>.
|
|
Read/write lock objects must maintain state to indicate whether or
|
|
not they've been locked and this state is not protected by any
|
|
synchronization concepts. For this reason a read/write lock object
|
|
should never be shared between multiple threads.</para>
|
|
|
|
<section id="thread.concepts.ReadWriteLock">
|
|
<title>ReadWriteLock Concept</title>
|
|
|
|
<para>For a read/write lock type <code>L</code>
|
|
and an object <code>lk</code>
|
|
and const object <code>clk</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ReadWriteLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>(&lk)->~L();</code></entry>
|
|
<entry><code>if (locked()) unlock();</code></entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>(&clk)->operator const void*()</code></entry>
|
|
<entry>Returns type void*, non-zero if the associated read/write
|
|
mutex object has been either read-locked or write-locked by
|
|
<code>clk</code>, otherwise 0.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>clk.locked()</code></entry>
|
|
<entry>Returns a <code>bool</code>, <code>(&clk)->operator
|
|
const void*() != 0</code></entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>clk.state()</code></entry>
|
|
<entry>Returns an enumeration constant of type <code>read_write_lock_state</code>:
|
|
<code>read_write_lock_state::read_locked</code> if the associated read/write mutex object has been
|
|
read-locked by <code>clk</code>, <code>read_write_lock_state::write_locked</code> if it
|
|
has been write-locked by <code>clk</code>, and <code>read_write_lock_state::unlocked</code>
|
|
if has not been locked by <code>clk</code>.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>clk.read_locked()</code></entry>
|
|
<entry>Returns a <code>bool</code>, <code>(&clk)->state() == read_write_lock_state::read_locked</code>.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>clk.write_locked()</code></entry>
|
|
<entry>Returns a <code>bool</code>, <code>(&clk)->state() == read_write_lock_state::write_locked</code>.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.read_lock()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>locked()</code>.</para>
|
|
|
|
<para>If the associated read/write mutex
|
|
object is already read-locked by some other
|
|
thread, the effect depends on the
|
|
<link linkend="thread.concepts.read-write-scheduling-policies.inter-class">inter-class scheduling policy</link>
|
|
of the associated read/write mutex:
|
|
either immediately obtains an additional
|
|
read-lock on the associated read/write
|
|
mutex, or places the current thread in the
|
|
<link linkend="thread.glossary.thread-state">Blocked</link>
|
|
state until the associated read/write mutex
|
|
is unlocked, after which the current thread
|
|
is placed in the
|
|
<link linkend="thread.glossary.thread-state">Ready</link>
|
|
state, eventually to be returned to the
|
|
<link linkend="thread.glossary.thread-state">Running</link>
|
|
state.</para>
|
|
|
|
<para>If the associated read/write mutex
|
|
object is already write-locked by some other
|
|
thread, places the current thread in the
|
|
<link linkend="thread.glossary.thread-state">Blocked</link>
|
|
state until the associated read/write mutex
|
|
is unlocked, after which the current thread
|
|
is placed in the
|
|
<link linkend="thread.glossary.thread-state">Ready</link>
|
|
state, eventually to be returned to the
|
|
<link linkend="thread.glossary.thread-state">Running</link>
|
|
state.</para>
|
|
|
|
<para>If the associated read/write mutex
|
|
object is already locked by the same thread
|
|
the behavior is dependent on the
|
|
<link linkend="thread.concepts.read-write-locking-strategies">locking strategy</link>
|
|
of the associated read/write mutex object.
|
|
</para>
|
|
|
|
<para>Postcondition: <code>state() == read_write_lock_state::read_locked</code></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.write_lock()</code></entry>
|
|
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>locked()</code>.</para>
|
|
|
|
<para>If the associated read/write mutex
|
|
object is already locked by some other
|
|
thread, places the current thread in the
|
|
<link linkend="thread.glossary.thread-state">Blocked</link>
|
|
state until the associated read/write mutex
|
|
is unlocked, after which the current thread
|
|
is placed in the
|
|
<link linkend="thread.glossary.thread-state">Ready</link>
|
|
state, eventually to be returned to the
|
|
<link linkend="thread.glossary.thread-state">Running</link>
|
|
state.</para>
|
|
|
|
<para>If the associated read/write mutex
|
|
object is already locked by the same thread
|
|
the behavior is dependent on the
|
|
<link linkend="thread.concepts.read-write-locking-strategies">locking strategy</link>
|
|
of the associated read/write mutex object.
|
|
</para>
|
|
|
|
<para>Postcondition: <code>state() == read_write_lock_state::write_locked</code></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.demote()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>state() != read_write_lock_state::write_locked</code>.</para>
|
|
|
|
<para>Converts the lock held on the associated read/write mutex
|
|
object from a write-lock to a read-lock without releasing
|
|
the lock.</para>
|
|
|
|
<para>Postcondition: <code>state() == read_write_lock_state::read_locked</code></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.promote()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>state() != read_write_lock_state::read_locked</code>
|
|
or if the lock cannot be promoted because another lock
|
|
on the same mutex is already waiting to be promoted.</para>
|
|
|
|
<para>Makes a blocking attempt to convert the lock held on the associated
|
|
read/write mutex object from a read-lock to a write-lock without releasing
|
|
the lock.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.unlock()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>!locked()</code>.</para>
|
|
|
|
<para>Unlocks the associated read/write mutex.</para>
|
|
|
|
<para>Postcondition: <code>!locked()</code></para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.ScopedReadWriteLock">
|
|
<title>ScopedReadWriteLock Concept</title>
|
|
|
|
<para>A ScopedReadWriteLock is a refinement of
|
|
<link linkend="thread.concepts.ReadWriteLock">ReadWriteLock</link>.
|
|
For a ScopedReadWriteLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>m</code> of a type meeting the
|
|
<link linkend="thread.concepts.ReadWriteMutex">ReadWriteMutex</link> requirements,
|
|
and an object <code>s</code> of type <code>read_write_lock_state</code>,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ScopedReadWriteLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>L lk(m,s);</code></entry>
|
|
<entry>Constructs an object <code>lk</code> and associates read/write mutex
|
|
object <code>m</code> with it, then: if <code>s == read_write_lock_state::read_locked</code>, calls
|
|
<code>read_lock()</code>; if <code>s==read_write_lock_state::write_locked</code>,
|
|
calls <code>write_lock()</code>.</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TryReadWriteLock">
|
|
<title>TryReadWriteLock Expressions</title>
|
|
|
|
<para>A TryReadWriteLock is a refinement of
|
|
<link linkend="thread.concepts.ReadWriteLock">ReadWriteLock</link>.
|
|
For a TryReadWriteLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TryReadWriteLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>lk.try_read_lock()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if locked().</para>
|
|
|
|
<para>Makes a non-blocking attempt to read-lock the associated read/write
|
|
mutex object, returning <code>true</code> if the attempt is successful,
|
|
otherwise <code>false</code>. If the associated read/write mutex object is
|
|
already locked by the same thread the behavior is dependent on the
|
|
<link linkend="thread.concepts.locking-strategies">locking
|
|
strategy</link> of the associated read/write mutex object.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.try_write_lock()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if locked().</para>
|
|
|
|
<para>Makes a non-blocking attempt to write-lock the associated read/write
|
|
mutex object, returning <code>true</code> if the attempt is successful,
|
|
otherwise <code>false</code>. If the associated read/write mutex object is
|
|
already locked by the same thread the behavior is dependent on the
|
|
<link linkend="thread.concepts.locking-strategies">locking
|
|
strategy</link> of the associated read/write mutex object.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.try_demote()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>state() != read_write_lock_state::write_locked</code>.</para>
|
|
|
|
<para>Makes a non-blocking attempt to convert the lock held on the associated
|
|
read/write mutex object from a write-lock to a read-lock without releasing
|
|
the lock, returning <code>true</code> if the attempt is successful,
|
|
otherwise <code>false</code>.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.try_promote()</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>state() != read_write_lock_state::read_locked</code>.</para>
|
|
|
|
<para>Makes a non-blocking attempt to convert the lock held on the associated
|
|
read/write mutex object from a read-lock to a write-lock without releasing
|
|
the lock, returning <code>true</code> if the attempt is successful,
|
|
otherwise <code>false</code>.</para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.ScopedTryReadWriteLock">
|
|
<title>ScopedTryReadWriteLock Expressions</title>
|
|
|
|
<para>A ScopedTryReadWriteLock is a refinement of
|
|
<link linkend="thread.concepts.TryReadWriteLock">TryReadWriteLock</link>.
|
|
For a ScopedTryReadWriteLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>m</code> of a type meeting the
|
|
<link linkend="thread.concepts.TryMutex">TryReadWriteMutex</link> requirements,
|
|
and an object <code>s</code> of type <code>read_write_lock_state</code>,
|
|
and an object <code>b</code> of type <code>blocking_mode</code>,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ScopedTryReadWriteLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>L lk(m,s,b);</code></entry>
|
|
<entry>Constructs an object <code>lk</code> and associates read/write mutex
|
|
object <code>m</code> with it, then: if <code>s == read_write_lock_state::read_locked</code>, calls
|
|
<code>read_lock()</code> if <code>b</code>, otherwise <code>try_read_lock()</code>;
|
|
if <code>s==read_write_lock_state::write_locked</code>, calls <code>write_lock()</code> if <code>b</code>,
|
|
otherwise <code>try_write_lock</code>.</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.TimedReadWriteLock">
|
|
<title>TimedReadWriteLock Concept</title>
|
|
|
|
<para>A TimedReadWriteLock is a refinement of
|
|
<link linkend="thread.concepts.TryReadWriteLock">TryReadWriteLock</link>.
|
|
For a TimedReadWriteLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>t</code> of type <classname>boost::xtime</classname>,
|
|
the following expressions must be well-formed
|
|
and have the indicated effects.</para>
|
|
|
|
<table>
|
|
<title>TimedReadWriteLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>lk.timed_read_lock(t)</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if locked().</para>
|
|
|
|
<para>Makes a blocking attempt to read-lock the associated read/write mutex object,
|
|
and returns <code>true</code> if successful within the specified time <code>t</code>,
|
|
otherwise <code>false</code>. If the associated read/write mutex object is already
|
|
locked by the same thread the behavior is dependent on the <link
|
|
linkend="thread.concepts.locking-strategies">locking
|
|
strategy</link> of the associated read/write mutex object.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.timed_write_lock(t)</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if locked().</para>
|
|
|
|
<para>Makes a blocking attempt to write-lock the associated read/write mutex object,
|
|
and returns <code>true</code> if successful within the specified time <code>t</code>,
|
|
otherwise <code>false</code>. If the associated read/write mutex object is already
|
|
locked by the same thread the behavior is dependent on the <link
|
|
linkend="thread.concepts.locking-strategies">locking
|
|
strategy</link> of the associated read/write mutex object.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.timed_demote(t)</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>state() != read_write_lock_state::write_locked</code>.</para>
|
|
|
|
<para>Makes a blocking attempt to convert the lock held on the associated
|
|
read/write mutex object from a write-lock to a read-lock without releasing
|
|
the lock, returning <code>true</code> if the attempt is successful
|
|
in the specified time <code>t</code>, otherwise <code>false</code>.</para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>lk.timed_promote(t)</code></entry>
|
|
<entry>
|
|
<para>Throws <classname>boost::lock_error</classname>
|
|
if <code>state() != read_write_lock_state::read_locked</code>.</para>
|
|
|
|
<para>Makes a blocking attempt to convert the lock held on the associated
|
|
read/write mutex object from a read-lock to a write-lock without releasing
|
|
the lock, returning <code>true</code> if the attempt is successful
|
|
in the specified time <code>t</code>, otherwise <code>false</code>.</para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
|
|
<section id="thread.concepts.ScopedTimedReadWriteLock">
|
|
<title>ScopedTimedReadWriteLock Concept</title>
|
|
|
|
<para>A ScopedTimedReadWriteLock is a refinement of
|
|
<link linkend="thread.concepts.TimedReadWriteLock">TimedReadWriteLock</link>.
|
|
For a ScopedTimedReadWriteLock type <code>L</code>
|
|
and an object <code>lk</code> of that type,
|
|
and an object <code>m</code> of a type meeting the
|
|
<link linkend="thread.concepts.TimedReadWriteMutex">TimedReadWriteMutex</link> requirements,
|
|
and an object <code>s</code> of type <code>read_write_lock_state</code>,
|
|
and an object <code>t</code> of type <classname>boost::xtime</classname>,
|
|
and an object <code>b</code> of type <code>blocking_mode</code>,
|
|
the following expressions must be well-formed and have the
|
|
indicated effects.</para>
|
|
|
|
<table>
|
|
<title>ScopedTimedReadWriteLock Expressions</title>
|
|
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Expression</entry>
|
|
<entry>Effects</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><code>L lk(m,s,b);</code></entry>
|
|
<entry>Constructs an object <code>lk</code> and associates read/write mutex
|
|
object <code>m</code> with it, then: if <code>s == read_write_lock_state::read_locked</code>, calls
|
|
<code>read_lock()</code> if <code>b</code>, otherwise <code>try_read_lock()</code>;
|
|
if <code>s==read_write_lock_state::write_locked</code>, calls <code>write_lock()</code> if <code>b</code>,
|
|
otherwise <code>try_write_lock</code>.</entry>
|
|
</row>
|
|
<row>
|
|
<entry><code>L lk(m,s,t);</code></entry>
|
|
<entry>Constructs an object <code>lk</code> and associates read/write mutex
|
|
object <code>m</code> with it, then: if <code>s == read_write_lock_state::read_locked</code>, calls
|
|
<code>timed_read_lock(t)</code>; if <code>s==read_write_lock_state::write_locked</code>,
|
|
calls <code>timed_write_lock(t)</code>.</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="thread.concepts.read-write-lock-models">
|
|
<title>Lock Models</title>
|
|
|
|
<para>&Boost.Thread; currently supplies six models of
|
|
<link linkend="thread.concepts.ReadWriteLock">ReadWriteLock</link>
|
|
and its refinements.</para>
|
|
|
|
<table>
|
|
<title>Lock Models</title>
|
|
|
|
<tgroup cols="3">
|
|
<thead>
|
|
<row>
|
|
<entry>Concept</entry>
|
|
<entry>Refines</entry>
|
|
<entry>Models</entry>
|
|
</row>
|
|
</thead>
|
|
|
|
<tbody>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ReadWriteLock">ReadWriteLock</link></entry>
|
|
<entry></entry>
|
|
<entry></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ScopedReadWriteLock">ScopedReadWriteLock</link></entry>
|
|
<entry><link linkend="thread.concepts.ReadWriteLock">ReadWriteLock</link></entry>
|
|
<entry>
|
|
<para><classname>boost::read_write_mutex::scoped_read_write_lock</classname></para>
|
|
<para><classname>boost::try_read_write_mutex::scoped_read_write_lock</classname></para>
|
|
<para><classname>boost::timed_read_write_mutex::scoped_read_write_lock</classname></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TryReadWriteLock">TryReadWriteLock</link></entry>
|
|
<entry><link linkend="thread.concepts.ReadWriteLock">ReadWriteLock</link></entry>
|
|
<entry></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ScopedTryReadWriteLock">ScopedTryReadWriteLock</link></entry>
|
|
<entry><link linkend="thread.concepts.TryReadWriteLock">TryReadWriteLock</link></entry>
|
|
<entry>
|
|
<para><classname>boost::try_read_write_mutex::scoped_try_read_write_lock</classname></para>
|
|
<para><classname>boost::timed_read_write_mutex::scoped_try_read_write_lock</classname></para>
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.TimedReadWriteLock">TimedReadWriteLock</link></entry>
|
|
<entry><link linkend="thread.concepts.TryReadWriteLock">TryReadWriteLock</link></entry>
|
|
<entry></entry>
|
|
</row>
|
|
<row>
|
|
<entry><link linkend="thread.concepts.ScopedTimedReadWriteLock">ScopedTimedReadWriteLock</link></entry>
|
|
<entry><link linkend="thread.concepts.TimedReadWriteLock">TimedReadWriteLock</link></entry>
|
|
<entry>
|
|
<para><classname>boost::timed_read_write_mutex::scoped_timed_read_write_lock</classname></para>
|
|
</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</section>
|
|
</section>
|
|
</section>
|