File: kvalueeditor.h

package info (click to toggle)
kdeutils 4%3A3.5.5-3etch1
  • links: PTS
  • area: main
  • in suites: etch
  • size: 21,152 kB
  • ctags: 16,106
  • sloc: cpp: 114,950; sh: 10,061; ansic: 3,182; perl: 2,835; python: 1,308; makefile: 931; xml: 303; lex: 302; yacc: 167
file content (75 lines) | stat: -rw-r--r-- 2,294 bytes parent folder | download | duplicates (3)
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
/***************************************************************************
                          kvalueeditor.h  -  description
                             -------------------
    begin                : Sa Dez 4 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_KVALUEEDITOR_H
#define KHE_KVALUEEDITOR_H


// lib specific
#include "keditor.h"

namespace KHE
{

class KValueColumn;


class KValueEditor: public KEditor
{
  protected:
    enum KValueEditAction
    { EnterValue, IncValue, DecValue, ValueAppend, ValueEdit, LeaveValue, CancelValue, ValueBackspace };

  public:
    KValueEditor( KValueColumn *VC, KBufferCursor *BC, KHexEdit *HE, KController *P );
    virtual ~KValueEditor();

  public: // KEditor API
    virtual bool handleKeyPress( QKeyEvent *KeyEvent );

  public:
    void reset();

  public:
    bool isInEditMode() const;

  protected:
    /** executes keyboard Action \a Action. This is normally called by a key event handler. */
    void doValueEditAction( KValueEditAction Action, int Input = -1 );

  public://protected:
    KValueColumn *ValueColumn;
    /** flag whether we are in editing mode */
    bool InEditMode:1;
    /** flag whether byte edit mode was reached by inserting */
    bool EditModeByInsert:1;
    /** */
    unsigned char EditValue;
    /** stores the old byte value */
    unsigned char OldValue;
    /** buffer with the  */
    QString ByteBuffer;
};

inline KValueEditor::~KValueEditor() {}

inline bool KValueEditor::isInEditMode() const { return InEditMode; }
inline void KValueEditor::reset() { InEditMode = false; }

}

#endif