diff options
| author | filliatr | 2004-10-28 16:13:12 +0000 |
|---|---|---|
| committer | filliatr | 2004-10-28 16:13:12 +0000 |
| commit | 938338cad536ee3e7a71064f140a05e3c9f8031e (patch) | |
| tree | a8bfd295d1d693e592d355e86f66e34e0b558dff | |
| parent | 2fa1a1264fcb7aac96692458abbadbacda95d1ad (diff) | |
qq bugs du highlight de CoqIDE
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@6267 85f007b7-540e-0410-9357-904b9bb8a0f7
| -rw-r--r-- | ide/highlight.mll | 47 |
1 files changed, 34 insertions, 13 deletions
diff --git a/ide/highlight.mll b/ide/highlight.mll index 2583c38284..ea40821466 100644 --- a/ide/highlight.mll +++ b/ide/highlight.mll @@ -18,6 +18,30 @@ let comment_start = ref 0 + let is_keyword = + let h = Hashtbl.create 97 in + List.iter (fun s -> Hashtbl.add h s ()) + [ "Add" ; "CoInductive" ; "Defined" ; + "End" ; "Export" ; "Extraction" ; "Hint" ; "Hints" ; + "Implicits" ; "Import" ; + "Infix" ; "Load" ; "match" ; "Module" ; + "Proof" ; "Qed" ; + "Record" ; "Require" ; "Save" ; "Scheme" ; + "Section" ; "Unset" ; + "Set" ; "Notation" + ]; + Hashtbl.mem h + + let is_declaration = + let h = Hashtbl.create 97 in + List.iter (fun s -> Hashtbl.add h s ()) + [ "Lemma" ; "Axiom" ; "CoFixpoint" ; "Definition" ; + "Fixpoint" ; "Hypothesis" ; + "Inductive" ; "Parameter" ; "Theorem" ; + "Variable" ; "Variables" + ]; + Hashtbl.mem h + } let space = @@ -28,25 +52,22 @@ let identchar = ['$' 'A'-'Z' 'a'-'z' '_' '\192'-'\214' '\216'-'\246' '\248'-'\255' '\'' '0'-'9'] let ident = firstchar identchar* -let keyword = - "Add" | "CoInductive" | "Defined" | - "End" | "Export" | "Extraction" | "Hint" | - "Implicits" | "Import" | - "Infix" | "Load" | "match" | "Module" | "Module Type" | - "Proof" | "Qed" | - "Record" | "Require" | "Save" | "Scheme" | - "Section" | "Unset" | - "Set" - let declaration = "Lemma" | "Axiom" | "CoFixpoint" | "Definition" | "Fixpoint" | "Hypothesis" | "Inductive" | "Parameter" | "Theorem" | - "Variable" | "Variables" + "Variable" | "Variables" | "Declare" space+ "Module" rule next_order = parse - | "(*" { comment_start := lexeme_start lexbuf; comment lexbuf } - | keyword { lexeme_start lexbuf,lexeme_end lexbuf, "kwd" } + | "(*" + { comment_start := lexeme_start lexbuf; comment lexbuf } + | "Module Type" + { lexeme_start lexbuf,lexeme_end lexbuf, "kwd" } + | ident as id + { if is_keyword id then + lexeme_start lexbuf,lexeme_end lexbuf, "kwd" + else + next_order lexbuf } | declaration space+ ident (space* ',' space* ident)* { lexeme_start lexbuf, lexeme_end lexbuf, "decl" } | _ { next_order lexbuf} |
