blob: d665a05b568127ab5f2d2c960c25518ace2aaf9e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
/***************************************************************************
kbinarybytecodec.cpp - description
-------------------
begin : Mo Nov 29 2004
copyright : (C) 2004 by Friedrich W. H. Kossebau
email : Friedrich.W.H@Kossebau.de
***************************************************************************/
/***************************************************************************
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License version 2 as published by the Free Software Foundation. *
* *
***************************************************************************/
// lib specific
#include "kbinarybytecodec.h"
using namespace KHE;
void KBinaryByteCodec::encode( QString &Digits, unsigned int Pos, const unsigned char Char ) const
{
for( unsigned char M=1<<7; M>0; M>>=1 )
Digits.at(Pos++) = (Char & M) ? '1' : '0';
}
void KBinaryByteCodec::encodeShort( QString &Digits, unsigned int Pos, unsigned char Char ) const
{
unsigned char M = 1<<7;
// find first set bit
for( ; M>0; M>>=1 )
if( Char & M )
break;
// now set the
for( ; M>0; M>>=1 )
Digits.at(Pos++) = (Char & M) ? '1' : '0';
}
bool KBinaryByteCodec::isValidDigit( unsigned char Digit ) const
{
return Digit == '0' || Digit == '1';
}
bool KBinaryByteCodec::turnToValue( unsigned char *Digit ) const
{
if( isValidDigit(*Digit) )
{
*Digit -= '0';
return true;
}
return false;
}
bool KBinaryByteCodec::appendDigit( unsigned char *Byte, unsigned char Digit ) const
{
if( turnToValue(&Digit) )
{
unsigned char B = *Byte;
if( B < 128 )
{
B <<= 1;
B += Digit;
*Byte = B;
return true;
}
}
return false;
}
void KBinaryByteCodec::removeLastDigit( unsigned char *Byte ) const
{
*Byte >>= 1;
}
|