|
Boost-Commit : |
Subject: [Boost-commit] svn:boost r62423 - sandbox/SOC/2010/bit_masks/lib/integer/doc
From: bbartmanboost_at_[hidden]
Date: 2010-06-04 07:26:01
Author: bbartman
Date: 2010-06-04 07:25:59 EDT (Fri, 04 Jun 2010)
New Revision: 62423
URL: http://svn.boost.org/trac/boost/changeset/62423
Log:
working on documentation for high_bits
Text files modified:
sandbox/SOC/2010/bit_masks/lib/integer/doc/high_bits.qbk | 30 +++++++++++++++++++++---------
sandbox/SOC/2010/bit_masks/lib/integer/doc/main.qbk | 1 +
2 files changed, 22 insertions(+), 9 deletions(-)
Modified: sandbox/SOC/2010/bit_masks/lib/integer/doc/high_bits.qbk
==============================================================================
--- sandbox/SOC/2010/bit_masks/lib/integer/doc/high_bits.qbk (original)
+++ sandbox/SOC/2010/bit_masks/lib/integer/doc/high_bits.qbk 2010-06-04 07:25:59 EDT (Fri, 04 Jun 2010)
@@ -1,29 +1,41 @@
[c++]
-[section:MASKNAME MASKNAME]
+[section:high_bits high_bits]
[h3 Description]
-
+THe template `high_bits` preforms bitwise operations on compile time then
+exposes the newly created mask via `value` and `operator T()`. What `high_bits`
+does is create a mask inside your integral type which sets all bits starting
+from the left most bit reaching out width bits to the right. For example,
+``
+// using high bits to create a mask starting from the left most bit with a width
+// of 15
+typedef high_bits<int, 15> bits;
+// bits::value will have the following value in binary.
+// 1111 1111 1111 1110 0000 0000 0000 0000
+``
[h3 Template Signature]
-`TYPENME` has the following template signature:
+`high_bits` has the following template signature:
``
-TEMPLATE SIGNATURE.
+template <typename T, unsigned int Width>
+struct high_bits;
``
[table
[[Parameter][Description]]
- [[][ ]]
- [[][ ]]
+ [[`T`][ Is an integral type which the mask is to be created over. ]]
+ [[`Width`][ This is the width of the mask in bits. ]]
]
[h3 Interface]
-`TYPENAME` Compile time interface. Assume that N is of type
-`N TYPE` the type supplied here is only for example.
+`high_bits` Compile time interface. Assume that N is of type
+`high_bits` the type supplied here is only for example.
[table
[[Operation][Description]]
[[`N::value`][Returns the `value` associated with `N`. ]]
[[`N::value_type`][Returns `T` which is the type associated with `value` inside `N`. ]]
[[`N::type`][ Returns the current types type. ]]
+ [[`N::width`][ Returns the integral value associated with the `width` template parameter. ]]
[[`operator T()`][ Run time support function. All this function does is
return the value associated with the type. With the c++0x feature constexper
this function will be made fasters and more effieient.]]
@@ -31,7 +43,7 @@
[h3 Examples]
-Examples and use cases related to the `TYPENAME` type.
+Examples and use cases related to the `high_bits` type.
Exaple:
Modified: sandbox/SOC/2010/bit_masks/lib/integer/doc/main.qbk
==============================================================================
--- sandbox/SOC/2010/bit_masks/lib/integer/doc/main.qbk (original)
+++ sandbox/SOC/2010/bit_masks/lib/integer/doc/main.qbk 2010-06-04 07:25:59 EDT (Fri, 04 Jun 2010)
@@ -62,4 +62,5 @@
[endsect]
[include:integral_mask integral_mask.qbk]
+[include:high_bits high_bits.qbk]
Boost-Commit list run by bdawes at acm.org, david.abrahams at rcn.com, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk