blob: d93182e2eb116a53cf5f360486dbfe11d68006e9 [file] [log] [blame]
.. Metafunctions/Bitwise Operations//shift_left
shift_left
==========
Synopsis
--------
.. parsed-literal::
template<
typename T
, typename Shift
>
struct shift_left
{
typedef |unspecified| type;
};
Description
-----------
Returns the result of bitwise *shift left* (``<<``) operation on ``T``.
Header
------
.. parsed-literal::
#include <boost/mpl/shift_left.hpp>
#include <boost/mpl/bitwise.hpp>
Model of
--------
|Numeric Metafunction|
Parameters
----------
+---------------+-------------------------------+---------------------------+
| Parameter | Requirement | Description |
+===============+===============================+===========================+
| ``T`` | |Integral Constant| | A value to shift. |
+---------------+-------------------------------+---------------------------+
| ``Shift`` | Unsigned |Integral Constant| | A shift distance. |
+---------------+-------------------------------+---------------------------+
|Note:| |numeric metafunction note| |-- end note|
Expression semantics
--------------------
For arbitrary |Integral Constant| ``c`` and unsigned |Integral Constant| ``shift``:
.. parsed-literal::
typedef shift_left<c,shift>::type r;
:Return type:
|Integral Constant|.
:Semantics:
Equivalent to
.. parsed-literal::
typedef integral_c<
c::value_type
, ( c::value << shift::value )
> r;
.. ..........................................................................
.. parsed-literal::
typedef shift_left<c,shift> r;
:Return type:
|Integral Constant|.
:Semantics:
Equivalent to
.. parsed-literal::
struct r : shift_left<c,shift>::type {};
Complexity
----------
Amortized constant time.
Example
-------
.. parsed-literal::
typedef integral_c<unsigned,0> u0;
typedef integral_c<unsigned,1> u1;
typedef integral_c<unsigned,2> u2;
typedef integral_c<unsigned,8> u8;
BOOST_MPL_ASSERT_RELATION( (shift_left<u0,u0>::value), ==, 0 );
BOOST_MPL_ASSERT_RELATION( (shift_left<u1,u0>::value), ==, 1 );
BOOST_MPL_ASSERT_RELATION( (shift_left<u1,u1>::value), ==, 2 );
BOOST_MPL_ASSERT_RELATION( (shift_left<u2,u1>::value), ==, 4 );
BOOST_MPL_ASSERT_RELATION( (shift_left<u8,u1>::value), ==, 16 );
See also
--------
|Bitwise Operations|, |Numeric Metafunction|, |numeric_cast|, |shift_right|, |bitand_|
.. copyright:: Copyright © 2001-2009 Aleksey Gurtovoy and David Abrahams
Distributed under the Boost Software License, Version 1.0. (See accompanying
file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)