Ayé, cette fois c'est au poil pour les fonctionnalités, ça marche de partout !

Un petit screen :
Fichier joint : 
(snapshot9.png)
C'est très chargé en style et coloré, mais c'est pour montrer les différentes possibilités.
Voici ce que le lexer identifie, et qui est donc paramétrable séparément en couleur et style :
- style par défaut
- commentaires
- nombres décimaux
- nombres binaires
- nombres hexadécimaux
- chaines (doubles quotes)
- chaines (simples quotes)
- opérateurs mathématiques (plus la virgule, c'est toujours le séparateur des opérandes)
- les instructions processeur
- les instructions étendues (celles mixées pour le linker, genre 'jbsr' ou 'jra')
- les registres
- les directives
- les arguments de macro (\1, \2, ...)
- les labels
- les identifiants divers (macros, constantes, offsets, labels, ...)
- les déclarations de macro
Voilà, ça fait 15 styles bien distincts, qu'on peut mettre à son gout.

S'il en manquent qui vous viennent à l'idée, n'hésitez pas.
(et si un graphiste veux bien me donner des codes couleurs qui rendraient bien, alors là je lui roule une moche de gamelle

)
Et si certaines bonnes volontés ont encore la force d'apporter des critiques à mon code, je les en remercie d'avance. J'ai essayé de faire un mix de vos conseils : Des commentaires pas trop intrusifs (entre les lignes), des accolades discrètes mais efficaces, des commentaires de fonctions et des defines, sans toute fois tomber dans un code... aérien.

Merci encore à tous.

LexA68k.cxx
// Return values for GetOperatorType
#define NO_OPERATOR 0
#define OPERATOR_1CHAR 1
#define OPERATOR_2CHAR 2
/**
* IsIdentifierStart
*
* Return true if the given char is a valid identifier first char
*/
static inline bool IsIdentifierStart (const int ch)
{
return (isalpha(ch) || (ch == '_') || (ch == '\'));
}
/**
* IsIdentifierChar
*
* Return true if the given char is a valid identifier char
*/
static inline bool IsIdentifierChar (const int ch)
{
return (isalnum(ch) || (ch == '_') || (ch == '@') || (ch == ':') || (ch == '.'));
}
/**
* GetOperatorType
*
* Return:
* NO_OPERATOR if char is not an operator
* OPERATOR_1CHAR if the operator is one char long
* OPERATOR_2CHAR if the operator is two chars long
*/
static inline int GetOperatorType (const int ch1, const int ch2)
{
int OpType = NO_OPERATOR;
if ((ch1 == '+') || (ch1 == '-') || (ch1 == '*') || (ch1 == '/') || (ch1 == '#') ||
(ch1 == '(') || (ch1 == ')') || (ch1 == '~') || (ch1 == '&') || (ch1 == '|') || (ch1 == ','))
OpType = OPERATOR_1CHAR;
else if ((ch1 == ch2) && (ch1 == '<' || ch1 == '>'))
OpType = OPERATOR_2CHAR;
return OpType;
}
/**
* IsBin
*
* Return true if the given char is 0 or 1
*/
static inline bool IsBin (const int ch)
{
return (ch == '0') || (ch == '1');
}
/**
* ColouriseA68kDoc
*
* Main function, which colourise a 68k source
*/
static void ColouriseA68kDoc (unsigned int startPos, int length, int initStyle, WordList *keywordlists[], Accessor &styler)
{
// Get references to keywords lists
WordList &cpuInstruction = *keywordlists[0];
WordList ®isters = *keywordlists[1];
WordList &directive = *keywordlists[2];
WordList &extInstruction = *keywordlists[3];
// Instanciate a context for our source
StyleContext sc(startPos, length, initStyle, styler);
/************************************************************
*
* Parse the text
*
************************************************************/
for ( ; sc.More(); sc.Forward())
{
char Buffer[100];
int OpType;
// Reset style at beginning of line
if (sc.atLineStart)
sc.SetState(SCE_A68K_DEFAULT);
/************************************************************
*
* Handle current state if we are not in the "default style"
*
************************************************************/
if (sc.state != SCE_A68K_DEFAULT)
{
// Check if current style continue.
// If this case, we loop because there is nothing else to do
if ((sc.state == SCE_A68K_COMMENT) || // Comment
((sc.state == SCE_A68K_NUMBER_DEC) && isdigit(sc.ch)) || // Decimal number
((sc.state == SCE_A68K_NUMBER_BIN) && IsBin(sc.ch)) || // Binary number
((sc.state == SCE_A68K_NUMBER_HEX) && isxdigit(sc.ch)) || // Hexa number
((sc.state == SCE_A68K_MACRO_ARG) && isdigit(sc.ch)) || // Arg of macro
((sc.state == SCE_A68K_STRING1) && (sc.ch != '\'')) || // String single-quoted
((sc.state == SCE_A68K_STRING2) && (sc.ch != '\"')) || // String double-quoted
// Label. ' ' and '\t' are needed to handle macro declarations
((sc.state == SCE_A68K_LABEL) && (sc.ch != ':') && (sc.ch != ' ') && (sc.ch != '\t')) ||
((sc.state == SCE_A68K_IDENTIFIER) && (sc.ch < 0x80) && IsIdentifierChar(sc.ch))) { // Identifier
continue;
}
// Check if some states terminate at the current char:
// we must include that char in the current style context
else if (((sc.state == SCE_A68K_STRING1) && (sc.ch < 0x80) && (sc.ch == '\'')) || // String single-quoted
((sc.state == SCE_A68K_STRING2) && (sc.ch < 0x80) && (sc.ch == '\"')) || // String double-quoted
((sc.state == SCE_A68K_LABEL) && (sc.ch < 0x80) && (sc.ch == ':'))) { // Label
sc.ForwardSetState(SCE_A68K_DEFAULT);
}
// Check if we are in the case of a label which terminates without ':'
// It should be a macro declaration, not a label
else if ((sc.state == SCE_A68K_LABEL) && (sc.ch < 0x80) && ((sc.ch == ' ') || (sc.ch == '\t'))) {
sc.ChangeState(SCE_A68K_MACRO_DECLARATION);
}
// Check if we are at the end of a identifier
// In this case, colourise it if was a keyword.
else if ((sc.state == SCE_A68K_IDENTIFIER) && !IsIdentifierChar(sc.ch)) {
sc.GetCurrentLowered(Buffer, sizeof(Buffer)); // Buffer the string of the current context
if (cpuInstruction.InList(Buffer)) // And check if it belongs to a keyword list
sc.ChangeState(SCE_A68K_CPUINSTRUCTION);
else if (extInstruction.InList(Buffer))
sc.ChangeState(SCE_A68K_EXTINSTRUCTION);
else if (registers.InList(Buffer))
sc.ChangeState(SCE_A68K_REGISTER);
else if (directive.InList(Buffer))
sc.ChangeState(SCE_A68K_DIRECTIVE);
}
// All special contexts are now handled.Come back to default style
sc.SetState(SCE_A68K_DEFAULT);
}
/************************************************************
*
* Check if we must enter a new state
*
************************************************************/
// Label and macro identifiers start at the beginning of a line
// We set both as a label, but if it wasn't one (no ':' at the end),
// it will be changed as a macro identifier.
if (sc.atLineStart && (sc.ch < 0x80) && IsIdentifierStart(sc.ch)) {
sc.SetState(SCE_A68K_LABEL);
}
else if ((sc.ch < 0x80) && (sc.ch == ';')) { // Comment
sc.SetState(SCE_A68K_COMMENT);
}
else if ((sc.ch < 0x80) && isdigit(sc.ch)) { // Decimal numbers haven't prefix
sc.SetState(SCE_A68K_NUMBER_DEC);
}
else if ((sc.ch < 0x80) && (sc.ch == '%')) { // Binary numbers are prefixed with '%'
sc.SetState(SCE_A68K_NUMBER_BIN);
}
else if ((sc.ch < 0x80) && (sc.ch == '$')) { // Hexadecimal numbers are prefixed with '$'
sc.SetState(SCE_A68K_NUMBER_HEX);
}
else if ((sc.ch < 0x80) && (sc.ch == '\'')) { // String (single-quoted)
sc.SetState(SCE_A68K_STRING1);
}
else if ((sc.ch < 0x80) && (sc.ch == '\"')) { // String (double-quoted)
sc.SetState(SCE_A68K_STRING2);
}
else if ((sc.ch < 0x80) && (sc.ch == '\') && (isdigit(sc.chNext))) { // Replacement symbols in macro
sc.SetState(SCE_A68K_MACRO_ARG);
}
else if ((sc.ch < 0x80) && IsIdentifierStart(sc.ch)) { // An identifier: constant, label, etc...
sc.SetState(SCE_A68K_IDENTIFIER);
}
else {
if (sc.ch < 0x80) {
OpType = GetOperatorType(sc.ch, sc.chNext); // Check if current char is an operator
if (OpType != NO_OPERATOR) {
sc.SetState(SCE_A68K_OPERATOR);
if (OpType == OPERATOR_2CHAR) { // Check if the operator is 2 bytes long
sc.ForwardSetState(SCE_A68K_OPERATOR); // (>> or <<)
}
}
}
}
} // End of for()
sc.Complete();
}