BIT. - Work with Bits

<< Click to Display Table of Contents >>

Navigation:  3. Script Language > BIT. - Work with Bits >

BIT. - Work with Bits

BIT.Set - Set Bit to 1

Previous Top Next


MiniRobotLanguage (MRL)

 

BIT.Set - Set Bit to 1

Check if bit is set

 

 

Intention

 

Check if a specified Bit is set or cleared. Technically Bit.Set is somehow equal to an OR.

But more easy to use with Single Bits.

 

The parameters P1 and P2 can be given as value or as "binary".

Please see details on v/b here ! Smart Package Robot 's BIT. - Operations

 

 

VAN.$$LEA=1

VAN.$$P01=(64+16+4)

VAN.$$P02=1

BIT.Show|v$$P01|$$ERA|$$LEA

BIT.Show|v$$P02|$$ERB|$$LEA

BIT.Set|$$P01|$$P02|$$P03|$$LEA

BIT.Show|v$$P03|$$ERC|$$LEA

MBX.$$P01 BitSet $$P02 is $$P03$crlf$Bin: $$ERA BitSet $$ERB -> $$ERC

ENR.

 

 

Bit_Set

 

 

 

Syntax

 

BIT.Set|[b/v]P1|[b/v]P2|[b/v]P3[|P4]

 

 

 

Parameter Explanation

 

P1 - Variable containing a value or binary number. For example take the Number "9". It can be an ASC-Code "9" or the numeric number "9".

    You can define this with a prefix of "v" for value and "b" for "binary". If the prefix is omitted, "v" is the default setting for P1.

 

P2 - Variable containing a value or binary number for the bit to set. Depending on P4 this number can be 1 to 8, 1 to 16 or 1 to 32. Unless "b" is prefixed the default type for P2 is "value".

 

P3  - Variable for result or "-". The result will always be numeric/value and can only be 1 or 0.

   If omitted the result is placed on the TOS. Also here you can specify [b/v] for the format of the result. If you do not specify anything the result is "value"-Format.

 

P4 - optional, can be 1,2 or 4. Number of Bytes that are used internally. The number of Bits is the number of Bytes times 8.

    1 - 8 Bits

    2 - 16 Bits

    4 - 32 Bits

   

    Do not use the "8" Option. See Limitations below.

 

 

Example

 

'*****************************************************

' EXAMPLE 1:

'*****************************************************

VAN.$$LEA=1

VAN.$$P01=(64+16+4)

VAN.$$P02=1

BIT.Show|v$$P01|$$ERA|$$LEA

BIT.Show|v$$P02|$$ERB|$$LEA

BIT.Set|$$P01|$$P02|$$P03|$$LEA

BIT.Show|v$$P03|$$ERC|$$LEA

MBX.$$P01 BitSet $$P02 is $$P03$crlf$Bin: $$ERA BitSet $$ERB -> $$ERC

ENR.

 

 

 

Remarks

-

 

 

Limitations:

 When using the "|8" Parameter, the lower 4 bits are possibly wrong. This is not a bug its due to the way variables are stored internally.

 Therefore we recommend to not use this option.

 

 

See also:

 

 

See also:

 

3.5 Hexadezimal, Decimal and Binary and more

VTH. - Variable to Hexadecimal

VDC. - Variable Decrement

CAL. - mathematical CALculation

VAR. - Variable Set Value/Clear

VAN. - Variable Numeric

! Smart Package Robot 's BIT. - Operations

BIT.16to8 - Split 1 Word into 2 Bytes

BIT.16to32 - concatenate 2 Words to 32 Bit DWord

BIT.32to16 - Split 1 DWord into 2 Words

BIT.8to16 - concatenate 2 Bytes to 16 Bit Word

BIT.AND - Use logical AND with Bits

BIT.Clear - Set Bit to 0

BIT.LShift - Shift Bits to Left, insert 0

BIT.NOT - Use logical NOT with Bits

BIT.OR - Use logical OR with Bits

BIT.RotateLeft - Rotate Bits Left

BIT.RotateRight - Rotate Bits Right

BIT.RShift - Shift Bits to Right, insert 0

BIT.Set - Set Bit to 1

BIT.Show - Show Bits in Binary-Numbers

BIT.Store - Set Bit to 1 or 0

BIT.ToBin - change Parameter to Binary-Format

BIT.Toggle - Switch Bit

BIT.ToVal - change Parameter to Value-Format

BIT.XOR - Use logical XOR with Bits

BIT.Get - check if Bit is set

    VDC. - Variable Decrement

    CAL. - mathematical CALculation

    VAR. - Variable Set Value/Clear

    VAN. - Variable Numeric