satengine/satserver/Engine/inc/TSatBitOP.h
author hgs
Fri, 15 Oct 2010 13:21:28 +0300
changeset 53 25b8d29b7c59
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2005 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Extracts a bits from byte row.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
#ifndef TSATBITOP_H
hgs
parents:
diff changeset
    21
#define TSATBITOP_H
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
//  INCLUDES
hgs
parents:
diff changeset
    24
#include <e32std.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// CLASS DECLARATION
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
/**
hgs
parents:
diff changeset
    29
*  Bit manipulations
hgs
parents:
diff changeset
    30
*
hgs
parents:
diff changeset
    31
*  @lib SatEngine.lib
hgs
parents:
diff changeset
    32
*  @since 2.6
hgs
parents:
diff changeset
    33
*/
hgs
parents:
diff changeset
    34
class TSatBitOP
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
    public: // New functions
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
        /**
hgs
parents:
diff changeset
    39
        * Extracts bits from byte row.
hgs
parents:
diff changeset
    40
        * Following assumptions is made about parameters:
hgs
parents:
diff changeset
    41
        *  aBitCount is 1 to 8.
hgs
parents:
diff changeset
    42
        * @param aBitIndex Index to bit, where extraction starts. Index of
hgs
parents:
diff changeset
    43
        * MSB from aBytes[0] is 0.
hgs
parents:
diff changeset
    44
        * @param aBitCount Number of extracted bits.
hgs
parents:
diff changeset
    45
        * @param aBytes Array of bytes where bits are extracted.
hgs
parents:
diff changeset
    46
        * @return Value of extracted bits.
hgs
parents:
diff changeset
    47
        */
hgs
parents:
diff changeset
    48
        static TUint8 ExtractBits(
hgs
parents:
diff changeset
    49
            TInt aBitIndex,
hgs
parents:
diff changeset
    50
            TUint8 aBitCount,
hgs
parents:
diff changeset
    51
            const TDesC8& aBytes );
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
        /**
hgs
parents:
diff changeset
    54
        * Creates a mask of ones, starting from aBitIndex
hgs
parents:
diff changeset
    55
        * to aBitIndex + aCount.
hgs
parents:
diff changeset
    56
        * if aMSB is 5 and aCount is 2 then the mask would be
hgs
parents:
diff changeset
    57
        * 0011 0000.
hgs
parents:
diff changeset
    58
        * @param aBitIndex. 0 means MSB and 7 is LSB.
hgs
parents:
diff changeset
    59
        * @param aCount 1 to 8.
hgs
parents:
diff changeset
    60
        * @return Mask.
hgs
parents:
diff changeset
    61
        */
hgs
parents:
diff changeset
    62
        static TUint8 CreateMask8Bit(
hgs
parents:
diff changeset
    63
            TUint8 aBitIndex,
hgs
parents:
diff changeset
    64
            TUint8 aCount );
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
        /**
hgs
parents:
diff changeset
    67
        * Creates a mask of ones, starting from aBitIndex to aBitIndex +
hgs
parents:
diff changeset
    68
        * aCount.
hgs
parents:
diff changeset
    69
        * @param aBitIndex 0 means MSB and 15 means LSB.
hgs
parents:
diff changeset
    70
        * @param aCount 1 to 16.
hgs
parents:
diff changeset
    71
        * @return Mask of ones.
hgs
parents:
diff changeset
    72
        */
hgs
parents:
diff changeset
    73
        static TUint16 CreateMask16Bit(
hgs
parents:
diff changeset
    74
            TUint8 aBitIndex,
hgs
parents:
diff changeset
    75
            TUint8 aCount );
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
    };
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
#endif      // TSATBITOP_H
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
// End of File