blob: d0354fa5cd2925ff6ba98bb085459f3c076d8753 (
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
|
/***************************************************************************
kbinarybytecodec.h - 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. *
* *
***************************************************************************/
#ifndef KHE_KBINARYBYTECODEC_H
#define KHE_KBINARYBYTECODEC_H
// lib specific
#include "kbytecodec.h"
namespace KHE
{
/** class that is able to convert codings to and from binary
*
* the buffer will be always filled up to CodingWidth, if not using shortCodingFunction
* a closing '\0' will be always added
*
*@author Friedrich W. H. Kossebau
*/
class KBinaryByteCodec : public KByteCodec
{
public: // API to be implemented
/** */
virtual unsigned int encodingWidth() const { return 8; }
/** */
virtual unsigned char digitsFilledLimit() const { return 128; }
/** encodes the Char and writes the result to */
virtual void encode( QString &Digits, unsigned int Pos, const unsigned char Char ) const;
/** */
virtual void encodeShort( QString &Digits, unsigned int Pos, const unsigned char Char ) const;
/** */
virtual bool appendDigit( unsigned char *Byte, const unsigned char Digit ) const;
/** */
virtual void removeLastDigit( unsigned char *Byte ) const;
/** */
virtual bool isValidDigit( const unsigned char Digit ) const;
/** */
virtual bool turnToValue( unsigned char *Digit ) const;
};
}
#endif
|