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
|
/***************************************************************************
kdecimalbytecodec.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_KDECIMALBYTECODEC_H
#define KHE_KDECIMALBYTECODEC_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 KDecimalByteCodec : public KByteCodec
{
public: // API to be implemented
/** */
virtual unsigned int encodingWidth() const { return 3; }
/** */
virtual unsigned char digitsFilledLimit() const { return 26; }
/** 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
|