data:image/s3,"s3://crabby-images/6bf79/6bf799e4b7568a3f28ee28c9e24cd05cbf93b60e" alt=""
From: "Simon Bailey
" I've been using boost for about a year now. I upgraded from 27 to 28 and appreciated the backwards compatability. But I'm wondering if a slight modification to the directory structure is in order?
I have written a cross-platform class library. The library provides high-level business objects and comes bundled with boost 1.28.0 to provide support for threads, CRC, shared_ptr, and function (or whatever else the end user might want).
Currently, users need to add two directories to their #include search path: include/boost include/sb_library
Then, in their source code: #include
#include #include Two problems (albeit very minor ones!) 1. Boost has two levels of includes (due to it's history of course).
Two levels? There's only one, $BOOST_ROOT/boost. To avoid name clashes, many libraries are located in library specific directories off of this, as you see with
2. Each library bundled with boost means another #include search path needs to be added.
No, there's only one path added for all Boost libraries, $BOOST_ROOT/boost.
Proposed solution: 1. Create a single boost include directory instead of having the two nested ones that there are now.
What two nested ones?
2. Put all boost headers into a sub-directory of boost eg
, . (It's a small change for existing users to change their includes).
This is mostly how it is now... though many headers don't live in library specific subdirectories (which is probably how it should be).
3. Place all src, documentation etc. into a directory within boost called "private" or something.
Suggested directory structure:
--include // This is the only directory needed to be specified in the #include search path ----other_library1 ----other_library2 ----boost -------ptr -------thread -------private ----------documentation ----------src ----------thread
In other words, you will have
and but never .
This is just a variation on what's currently done, and I can't see how it buys you anything, and actually is a more confusing layout IMHO.
I think it's worth breaking the backwards compatability a little in order to bring the older boost headers in line with the directory structure of the newer ones like thread. I also think enabling a single include path for multiple libraries is useful.
Boost.Threads followed existing directory guidelines (as do all libraries). There's no difference between it and "older" libraries (note that Boost.Threads is not that new). William E. Kempf wekempf@cox.net