// -*- C++ -*-
-#ifndef _Trans_Manager_h_
-#define _Trans_Manager_h_
+#ifndef TRANS_MANAGER_H
+#define TRANS_MANAGER_H
#ifdef __GNUG__
#pragma interface
#include "tex-accent.h"
#include "trans_decl.h"
+#include "chset.h"
+#include "LString.h"
class LyXText;
-class LString;
-class CharacterSet;
class Trans;
-/// Translation State
+/// Translation state
class TransState {
public:
///
- virtual ~TransState();
+ virtual ~TransState() {}
///
- virtual LString normalkey(char,char*)=0;
+ virtual string const normalkey(char) = 0;
///
- virtual bool backspace()=0;
+ virtual bool backspace() = 0;
///
- virtual LString deadkey(char,KmodInfo)=0;
+ virtual string const deadkey(char, KmodInfo) = 0;
///
- static const char TOKEN_SEP;
+ static char const TOKEN_SEP;
};
class TransFSMData {
protected:
///
- virtual ~TransFSMData()
- {}
+ virtual ~TransFSMData() {}
///
char deadkey_;
///
///
KmodInfo deadkey2_info_;
///
- KmodException comb_info_;
+ Keyexc comb_info_;
///
- TransState* init_state_;
+ TransState * init_state_;
///
- TransState* deadkey_state_;
+ TransState * deadkey_state_;
///
- TransState* combined_state_;
+ TransState * combined_state_;
///
public:
///
TransFSMData();
///
- TransState* currentState;
+ TransState * currentState;
};
/// Init State
-class TransInitState:
- virtual public TransFSMData,
- public TransState {
+class TransInitState : virtual public TransFSMData, public TransState {
public:
- ///
- TransInitState();
- ///
- virtual LString normalkey(char,char*);
- ///
- virtual bool backspace() { return true; }
- ///
- virtual LString deadkey(char,KmodInfo);
+ ///
+ TransInitState();
+ ///
+ virtual string const normalkey(char);
+ ///
+ virtual bool backspace() { return true; }
+ ///
+ virtual string const deadkey(char, KmodInfo);
};
/// Deadkey State
-class TransDeadkeyState:
- virtual public TransFSMData,
- public TransState {
+class TransDeadkeyState : virtual public TransFSMData, public TransState {
public:
- ///
- TransDeadkeyState();
- ///
- virtual LString normalkey(char,char*);
- ///
- virtual bool backspace()
- {
- currentState=init_state_;
+ ///
+ TransDeadkeyState();
+ ///
+ virtual string const normalkey(char);
+ ///
+ virtual bool backspace() {
+ currentState = init_state_;
return false;
}
- ///
- virtual LString deadkey(char,KmodInfo);
+ ///
+ virtual string const deadkey(char, KmodInfo);
};
/// Combined State
-class TransCombinedState:
- virtual public TransFSMData,
- public TransState {
+class TransCombinedState : virtual public TransFSMData, public TransState {
public:
- ///
- TransCombinedState();
- ///
- virtual LString normalkey(char,char*);
- ///
- virtual bool backspace()
- {
+ ///
+ TransCombinedState();
+ ///
+ virtual string const normalkey(char);
+ ///
+ virtual bool backspace() {
// cancel the second deadkey
- deadkey2_=0;
- deadkey2_info_.accent=TEX_NOACCENT;
- currentState=deadkey_state_;
-
+ deadkey2_ = 0;
+ deadkey2_info_.accent = TEX_NOACCENT;
+ currentState = deadkey_state_;
+
return false;
}
- ///
- virtual LString deadkey(char,KmodInfo);
+ ///
+ virtual string const deadkey(char, KmodInfo);
};
///
-class TransFSM:
- virtual public TransFSMData,
- public TransInitState,
- public TransDeadkeyState,
- public TransCombinedState
-{
+class TransFSM : virtual public TransFSMData,
+ public TransInitState,
+ public TransDeadkeyState,
+ public TransCombinedState {
public:
///
TransFSM();
};
+
///
-class TransManager
-{
+class TransManager {
private:
///
TransFSM trans_fsm_;
///
- Trans* active_;
+ Trans * active_;
///
- Trans* t1_;
+ Trans * t1_;
///
- Trans* t2_;
+ Trans * t2_;
///
- static Trans* default_;
+ static Trans default_;
///
- CharacterSet* chset_;
+ CharacterSet chset_;
///
- void insert(LString,LyXText*);
+ void insert(string const &, LyXText *);
///
- void insertVerbatim(const LString&,LyXText*);
+ void insertVerbatim(string const &, LyXText *);
public:
///
TransManager();
///
virtual ~TransManager();
///
- int SetPrimary(LString const &);
+ int SetPrimary(string const &);
///
- int SetSecondary(LString const &);
+ int SetSecondary(string const &);
///
void EnablePrimary();
///
///
void DisableKeymap();
///
- bool setCharset(const char*);
+ bool setCharset(string const &);
///
- bool backspace()
- {
+ bool backspace() {
return trans_fsm_.currentState->backspace();
}
///
- void TranslateAndInsert(char,LyXText*);
+ void TranslateAndInsert(char, LyXText *);
///
- inline LString deadkey(char,KmodInfo);
+ string const deadkey(char, KmodInfo);
///
- inline LString normalkey(char,char*);
+ string const normalkey(char);
///
- void deadkey(char,tex_accent,LyXText*);
-
+ void deadkey(char, tex_accent, LyXText *);
};
-LString TransManager::normalkey(char c,char *t)
+inline
+string const TransManager::normalkey(char c)
{
- return trans_fsm_.currentState->normalkey(c,t);
+ return trans_fsm_.currentState->normalkey(c);
}
-LString TransManager::deadkey(char c,KmodInfo t)
+inline
+string const TransManager::deadkey(char c, KmodInfo t)
{
- return trans_fsm_.currentState->deadkey(c,t);
+ return trans_fsm_.currentState->deadkey(c, t);
}
-#endif
+#endif // TRANS_MANAGER_H