summaryrefslogtreecommitdiffstats
path: root/khexedit/lib/codecs/kbytecodec.cpp
blob: dc5137f852740d5259d08b65ce2b3973858ee8d9 (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
/***************************************************************************
                          kbytecodec.cpp  -  description
                             -------------------
    begin                : Mo Nov 29 2004
    copyright            : (C) 2004 by Friedrich W. H. Kossebau
    email                : [email protected]
 ***************************************************************************/

/***************************************************************************
 *                                                                         *
 *   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"
#include "koctalbytecodec.h"
#include "kdecimalbytecodec.h"
#include "khexadecimalbytecodec.h"

using namespace KHE;


KByteCodec *KByteCodec::createCodec( KCoding C )
{
  KByteCodec *Codec;
  switch( C )
  {
    case DecimalCoding: Codec = new KDecimalByteCodec(); break;
    case OctalCoding: Codec = new KOctalByteCodec(); break;
    case BinaryCoding: Codec = new KBinaryByteCodec(); break;
    case HexadecimalCoding:
    default:  Codec = new KHexadecimalByteCodec();
  }
  return Codec;
}

unsigned int KByteCodec::decode( unsigned char *Char, const QString &Digits, uint Pos ) const
{
  //kdDebug() << QString("KByteCodec::decode(%1,%2)").arg(Digits).arg(Pos) << endl;
  const uint P = Pos;

  // remove leading 0s
  while( Digits.at(Pos) == '0' ) { ++Pos; }

  unsigned char C = 0;
  unsigned int d = encodingWidth();
  do
  {
    if( !appendDigit(&C,Digits.at(Pos)) )
      break;

    ++Pos;
    --d;
  }
  while( d > 0 );

  *Char = C;
  return Pos - P;
}