lib_guide.htm 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. <html>
  2. <head>
  3. <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
  4. <title>Library Requirements and Guidelines</title>
  5. <meta name="GENERATOR" content="Microsoft FrontPage 4.0">
  6. <meta name="ProgId" content="FrontPage.Editor.Document">
  7. <meta name="Microsoft Border" content="none, default">
  8. </head>
  9. <body bgcolor="#FFFFFF" text="#000000">
  10. <table border="1" bgcolor="#007F7F" cellpadding="2">
  11. <tr>
  12. <td bgcolor="#FFFFFF"><img src="../c++boost.gif" alt="c++boost.gif (8819 bytes)" width="277" height="86"></td>
  13. <td><a href="../index.htm"><font face="Arial" color="#FFFFFF"><big>Home</big></font></a></td>
  14. <td><a href="../libs/libraries.htm"><font face="Arial" color="#FFFFFF"><big>Libraries</big></font></a></td>
  15. <td><a href="../people/people.htm"><font face="Arial" color="#FFFFFF"><big>People</big></font></a></td>
  16. <td><a href="faq.htm"><font face="Arial" color="#FFFFFF"><big>FAQ</big></font></a></td>
  17. <td><a href="index.htm"><font face="Arial" color="#FFFFFF"><big>More</big></font></a></td>
  18. </tr>
  19. </table>
  20. <h1 align="left">Boost Library Requirements and Guidelines</h1>
  21. <p align="left">This page describes requirements and guidelines for the content
  22. of a library submitted to Boost.</p>
  23. <p align="left">See the <a href="submission_process.htm">Boost Library
  24. Submission Process</a> page for a description of the process involved.</p>
  25. <h2 align="left">Requirements</h2>
  26. <p>To avoid the frustration and wasted time of a proposed library being
  27. rejected, it must meets these requirements:</p>
  28. <ul>
  29. <li>The license must meet the <a href="#License">license requirements</a>
  30. below. Restricted licenses like the GPL and LGPL are not acceptable. The
  31. copyright <a href="#Ownership">ownership</a> must be clear.<br>
  32. </li>
  33. <li>The library must be generally useful and not restricted to a narrow
  34. problem domain.<br>
  35. </li>
  36. <li>The library must meet the <a href="#Portability">portability requirements</a>
  37. below.&nbsp;<br>
  38. </li>
  39. <li>The library must come reasonably close to meeting the <a href="#Guidelines">Guidelines</a>
  40. below.<br>
  41. </li>
  42. <li>The author must be willing to participate in discussions on the mailing
  43. list, and to refine the library accordingly.</li>
  44. </ul>
  45. <p>There's no requirement that an author read the mailing list for a time before
  46. making a submission. It has been noted, however, that submissions which begin
  47. &quot;I just started to read this mailing list ...&quot; seem to fail, often
  48. embarrassingly.</p>
  49. <h3 align="left"><a name="License">License</a> requirements</h3>
  50. <ul>
  51. <li>Must be simple to read and understand.<br>
  52. </li>
  53. <li>Must grant permission to copy, use and modify the software for any use
  54. (commercial and non-commercial) for no fee.<br>
  55. </li>
  56. <li>Must require that the license appear on all copies of the software source
  57. code.<br>
  58. </li>
  59. <li>Must not require that the license appear with executables or other binary
  60. uses of the library.&nbsp;&nbsp; Must not require that the source code be
  61. available for execution or other binary uses of the library.<br>
  62. </li>
  63. <li>May restrict the use of the name and description of the library to the
  64. standard version found on the Boost web site.</li>
  65. </ul>
  66. <h3 align="left"><a name="Portability">Portability</a> requirements</h3>
  67. <ul>
  68. <li>
  69. <p align="left">A library's interface must portable and not restricted to a
  70. particular compiler or operating system.<br>
  71. </li>
  72. <li>
  73. <p align="left">A library's implementation must if possible be portable and
  74. not restricted to a particular compiler or operating system.&nbsp; If a
  75. portable implementation is not possible, non-portable constructions are
  76. acceptable if reasonably easy to port to other environments.<br>
  77. </li>
  78. <li>
  79. <p align="left">There is no requirement that a library run on all C++
  80. compilers.&nbsp;&nbsp;<br>
  81. </li>
  82. <li>
  83. <p align="left">There is no requirement that a library run on any particular
  84. C++ compiler.&nbsp; Boost contributors often try to ensure their libraries
  85. work with popular compilers.&nbsp; The boost/config.hpp <a href="../libs/config/index.htm">configuration
  86. header</a> is the preferred mechanism for working around compiler
  87. deficiencies.</li>
  88. </ul>
  89. <p align="left">Since there is no absolute way to prove portability, many boost
  90. submissions demonstrate practical portability by compiling and executing
  91. correctly with two different C++ compilers, often under different operating
  92. systems.&nbsp; Otherwise reviewers may disbelieve that porting is in fact
  93. practical.</p>
  94. <h3 align="left"><a name="Ownership">Ownership</a></h3>
  95. <p align="left">Are you sure you own the library you are thinking of
  96. submitting?&nbsp;&nbsp; &quot;How to Copyright Software&quot; by MJ Salone, Nolo
  97. Press, 1990 says:</p>
  98. <blockquote>
  99. <p align="left">Doing work on your own time that is very similar to
  100. programming you do for your employer on company time can raise nasty legal
  101. problems.&nbsp; In this situation, it's best to get a written release from
  102. your employer in advance.</p>
  103. </blockquote>
  104. <p align="left">Place a copyright notice in all the important files you submit.
  105. Boost.org won't accept libraries without clear copyright information.</p>
  106. <h2 align="left"><a name="Guidelines">Guidelines</a></h2>
  107. <p align="left">Please use these guidelines as a checklist for preparing the
  108. content a library submission.&nbsp; Not every guideline applies to every
  109. library, but a reasonable effort to comply is expected.</p>
  110. <h3>Design and Programming</h3>
  111. <ul>
  112. <li>Aim for ISO Standard C++. Than means making effective use of the standard
  113. features of the language, and avoiding non-standard compiler extensions. It
  114. also means using the C++ Standard Library where applicable.</li>
  115. </ul>
  116. <ul>
  117. <li>Headers should be good neighbors. See the <a href="header.htm">header
  118. policy</a>.</li>
  119. </ul>
  120. <ul>
  121. <li>Follow quality programming practices. See, for example, &quot;Effective
  122. C++&quot; 2nd Edition, and &quot;More Effective C++&quot;, both by Scott
  123. Meyers, published by Addison Wesley.</li>
  124. </ul>
  125. <ul>
  126. <li>Use the C++ Standard Library or other Boost libraries, but only when the
  127. benefits outweigh the costs.&nbsp; Do not use libraries other than the C++
  128. Standard Library or Boost. See <a href="library_reuse.htm">Library reuse</a>.</li>
  129. </ul>
  130. <ul>
  131. <li>Read <a href="imp_vars.htm">Implementation Variation</a> to see how to
  132. supply performance, platform, or other implementation variations.</li>
  133. </ul>
  134. <ul>
  135. <li>Use the lowercase/underscore <a href="#Naming">naming conventions</a> of
  136. the C++ standard library.&nbsp; Template parameter names begin with an
  137. uppercase letter. Macro (gasp!) names should be all uppercase and begin with
  138. BOOST_.</li>
  139. </ul>
  140. <ul>
  141. <li>Use exceptions to report errors where appropriate, and write code that is
  142. safe in the face of exceptions.</li>
  143. </ul>
  144. <ul>
  145. <li>Avoid exception-specifications. See <a href="#Exception-specification">exception-specification
  146. rationale</a>.</li>
  147. </ul>
  148. <ul>
  149. <li>Provide sample programs, confidence tests, or regression tests so
  150. potential users can see how to use your library and verify that it has
  151. compiled correctly.</li>
  152. </ul>
  153. <ul>
  154. <li>Although some boost members use proportional fonts, tabs, and unrestricted
  155. line lengths in their own code, boost's widely distributed source code
  156. should follow more conservative guidelines:
  157. <ul>
  158. <li>Use fixed-width fonts.&nbsp; See <a href="#code fonts">fonts rationale</a>.</li>
  159. <li>Use spaces rather than tabs.</li>
  160. <li>Limit line lengths to 80 characters.</li>
  161. </ul>
  162. </li>
  163. </ul>
  164. <ul>
  165. <li>Begin all source files with:
  166. <ul>
  167. <li>A comment line describing the contents of the file.</li>
  168. <li>Comments describing copyright and licensing.</li>
  169. <li>A comment line referencing the Boost home page in the form:<br>
  170. <code>// See http://www.boost.org for updates, documentation, and
  171. revision history.</code><br>
  172. [Including revision history in source files is no longer recommended;
  173. the publicly available CVS repository better serves that purpose.]</li>
  174. </ul>
  175. </li>
  176. </ul>
  177. <h3>Documentation</h3>
  178. <p>Even the simplest library needs some documentation; the amount should be
  179. proportional to the need.&nbsp; The documentation should assume the readers have
  180. a basic knowledge of C++, but are not necessarily experts.</p>
  181. <p>The format for documentation should be HTML, and should not require an
  182. advanced browser or server-side extensions.</p>
  183. <p>There is no single right way to do documentation. HTML documentation is often
  184. organized quite differently from traditional printed documents. Task-oriented
  185. styles differ from reference oriented styles. In the end, it comes down to the
  186. question: Is the documentation sufficient for the mythical &quot;average&quot;
  187. C++ programmer to use the library successfully?</p>
  188. <p>Appropriate topics for documentation often include:
  189. <ul>
  190. <li>General introduction to the library.</li>
  191. <li>Description of each class.</li>
  192. <li>Relationship between classes.</li>
  193. <li>For each function, as applicable, description, requirements
  194. (preconditions), effects, post-conditions, returns, and throws.</li>
  195. <li>Discussion of error detection and recovery strategy.</li>
  196. <li>How to use including description of typical uses.</li>
  197. <li>How to compile and link.</li>
  198. <li>How to test.</li>
  199. <li>Version or revision history.</li>
  200. <li>Rationale for design decisions.&nbsp; See <a href="#Rationale">Rationale
  201. rationale</a>.</li>
  202. <li>Acknowledgements.&nbsp; See <a href="#Acknowledgements">Acknowledgments
  203. rationale.</a></li>
  204. </ul>
  205. <h2>Rationale</h2>
  206. <p>Rationale for some of the requirements and guidelines follows.</p>
  207. <h3><a name="Exception-specification">Exception-specification</a> rationale</h3>
  208. <p>Exception specifications [ISO 15.4] are sometimes coded to indicate what
  209. exceptions may be thrown, or because the programmer hopes they will improved
  210. performance.&nbsp; But consider the follow member from a smart pointer:</p>
  211. <pre> T&amp; operator*() const throw() { return *ptr; }</pre>
  212. <p>This function calls no other functions; it only manipulates fundamental data
  213. types like pointers Therefore, no runtime behavior of the
  214. exception-specification can ever be invoked.&nbsp; The function is completely
  215. exposed to the compiler; indeed it is declared inline Therefore, a smart
  216. compiler can easily deduce that the functions are incapable of throwing
  217. exceptions, and make the same optimizations it would have made based on the
  218. empty exception-specification. A &quot;dumb&quot; compiler, however, may make
  219. all kinds of pessimizations.</p>
  220. <p>For example, some compilers turn off inlining if there is an
  221. exception-specification.&nbsp; Some compilers add try/catch blocks. Such
  222. pessimizations can be a performance disaster which makes the code unusable in
  223. practical applications.</p>
  224. <p>Although initially appealing, an exception-specification tends to have
  225. consequences that require <b>very</b> careful thought to understand. The biggest
  226. problem with exception-specifications is that programmers use them as though
  227. they have the effect the programmer would like, instead of the effect they
  228. actually have.</p>
  229. <p>A non-inline function is the one place a &quot;throws nothing&quot;
  230. exception-specification may have some benefit with some compilers.</p>
  231. <hr>
  232. <h3><a name="Naming">Naming</a> conventions rationale</h3>
  233. <p>The C++ standard committee's Library Working Group discussed this issue in
  234. detail, and over a long period of time. The discussion was repeated again in
  235. early boost postings. A short summary:</p>
  236. <ul>
  237. <li>Naming conventions are contentious, and although several are widely used,
  238. no one style predominates.<br>
  239. </li>
  240. <li>Given the intent to propose portions of boost for the next revision of the
  241. C++ standard library, boost decided to follow the standard library's
  242. conventions.<br>
  243. </li>
  244. <li>Once a library settles on a particular convention, a vast majority of
  245. stakeholders want that style to be consistently used.<br>
  246. </li>
  247. <li>There is a strong preference for clear and descriptive names, even if
  248. lengthy.</li>
  249. </ul>
  250. <hr>
  251. <h3>Source <a name="code fonts">code fonts</a> rationale</h3>
  252. <p>Dave Abrahams comments: An important purpose (I daresay the primary purpose)
  253. of source code is communication: the documentation of intent. This is a doubly
  254. important goal for boost, I think. Using a fixed-width font allows us to
  255. communicate with more people, in more ways (diagrams are possible) right there
  256. in the source. Code written for fixed-width fonts using spaces will read
  257. reasonably well when viewed with a variable-width font, and as far as I can tell
  258. every editor supporting variable-width fonts also supports fixed width. I don't
  259. think the converse is true.</p>
  260. <hr>
  261. <h3><a name="Rationale">Rationale</a> rationale</h3>
  262. <p>Rationale is defined as &quot;The fundamental reasons for something;
  263. basis.&quot; by the American Heritage Dictionary.</p>
  264. <p>Beman Dawes comments:&nbsp; Failure to supply contemporaneous rationale for
  265. design decisions is a major defect in many software projects. Lack of accurate
  266. rationale causes issues to revisited endlessly, causes maintenance bugs when a
  267. maintainer changes something without realizing it was done a certain way for
  268. some purpose, and shortens the useful lifetime of software.</p>
  269. <p>Rationale is fairly easy to provide at the time decisions are made, but very
  270. hard to accurately recover even a short time later.</p>
  271. <hr>
  272. <h3><a name="Acknowledgements">Acknowledgements</a> rationale</h3>
  273. <p>As a library matures, it almost always accumulates improvements suggested to
  274. the authors by other boost members.&nbsp; It is a part of the culture of
  275. boost.org to acknowledge such contributions, identifying the person making the
  276. suggestion.&nbsp; Major contributions are usually acknowledged in the
  277. documentation, while minor fixes are often mentioned in comments within the code
  278. itself.</p>
  279. <hr>
  280. <p>Revised <!--webbot bot="Timestamp" s-type="EDITED" s-format="%d %B, %Y" startspan -->10 November, 2000<!--webbot bot="Timestamp" endspan i-checksum="39349" --></p>
  281. </body>
  282. </html>
粤ICP备19079148号