src/HOL/Import/mono_scan.ML
author krauss
Wed, 02 Feb 2011 08:47:45 +0100
changeset 41686 d8efc2490b8e
parent 41589 bbd861837ebc
permissions -rw-r--r--
made SML/NJ happy
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     1
(*  Title:      HOL/Import/mono_scan.ML
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     2
    Author:     Steven Obua, TU Muenchen
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     3
41589
bbd861837ebc tuned headers;
wenzelm
parents: 40627
diff changeset
     4
Monomorphic scanner combinators for monomorphic sequences.
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     5
*)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     6
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     7
signature MONO_SCANNER =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     8
sig
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
     9
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    10
    include MONO_SCANNER_SEQ
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    11
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    12
    exception SyntaxError
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    13
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    14
    type 'a scanner = seq -> 'a * seq
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    15
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    16
    val :--      : 'a scanner * ('a -> 'b scanner)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    17
                   -> ('a*'b) scanner
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    18
    val --       : 'a scanner * 'b scanner -> ('a * 'b) scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    19
    val >>       : 'a scanner * ('a -> 'b) -> 'b scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    20
    val --|      : 'a scanner * 'b scanner -> 'a scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    21
    val |--      : 'a scanner * 'b scanner -> 'b scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    22
    val ^^       : string scanner * string scanner
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    23
                   -> string scanner 
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    24
    val ||       : 'a scanner * 'a scanner -> 'a scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    25
    val one      : (item -> bool) -> item scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    26
    val anyone   : item scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    27
    val succeed  : 'a -> 'a scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    28
    val any      : (item -> bool) -> item list scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    29
    val any1     : (item -> bool) -> item list scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    30
    val optional : 'a scanner -> 'a -> 'a scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    31
    val option   : 'a scanner -> 'a option scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    32
    val repeat   : 'a scanner -> 'a list scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    33
    val repeat1  : 'a scanner -> 'a list scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    34
    val repeat_fixed : int -> 'a scanner -> 'a list scanner  
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    35
    val ahead    : 'a scanner -> 'a scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    36
    val unless   : 'a scanner -> 'b scanner -> 'b scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    37
    val !!       : (seq -> string) -> 'a scanner -> 'a scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    38
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    39
end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    40
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    41
signature STRING_SCANNER =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    42
sig
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    43
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    44
    include MONO_SCANNER  where type item = string
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    45
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    46
    val $$       : item -> item scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    47
    
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    48
    val scan_id : string scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    49
    val scan_nat : int scanner
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    50
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    51
    val this : item list -> item list scanner
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    52
    val this_string : string -> string scanner                                      
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    53
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    54
end    
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    55
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    56
functor MonoScanner (structure Seq : MONO_SCANNER_SEQ) : MONO_SCANNER =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    57
struct
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    58
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    59
infix 7 |-- --|
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    60
infix 5 :-- -- ^^
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    61
infix 3 >>
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    62
infix 0 ||
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    63
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    64
exception SyntaxError
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    65
exception Fail of string
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    66
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    67
type seq = Seq.seq
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    68
type item = Seq.item
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    69
type 'a scanner = seq -> 'a * seq
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    70
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    71
val pull = Seq.pull
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    72
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    73
fun (sc1 :-- sc2) toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    74
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    75
        val (x,toks2) = sc1 toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    76
        val (y,toks3) = sc2 x toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    77
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    78
        ((x,y),toks3)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    79
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    80
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    81
fun (sc1 -- sc2) toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    82
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    83
        val (x,toks2) = sc1 toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    84
        val (y,toks3) = sc2 toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    85
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    86
        ((x,y),toks3)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    87
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    88
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    89
fun (sc >> f) toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    90
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    91
        val (x,toks2) = sc toks
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    92
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    93
        (f x,toks2)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    94
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    95
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    96
fun (sc1 --| sc2) toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
    97
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    98
        val (x,toks2) = sc1 toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
    99
        val (_,toks3) = sc2 toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   100
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   101
        (x,toks3)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   102
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   103
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   104
fun (sc1 |-- sc2) toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   105
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   106
        val (_,toks2) = sc1 toks
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   107
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   108
        sc2 toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   109
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   110
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   111
fun (sc1 ^^ sc2) toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   112
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   113
        val (x,toks2) = sc1 toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   114
        val (y,toks3) = sc2 toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   115
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   116
        (x^y,toks3)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   117
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   118
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   119
fun (sc1 || sc2) toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   120
    (sc1 toks)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   121
    handle SyntaxError => sc2 toks
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   122
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   123
fun anyone toks = case pull toks of NONE => raise SyntaxError | SOME x => x
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   124
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   125
fun one p toks = case anyone toks of x as (t, toks) => if p t then x else raise SyntaxError
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   126
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   127
fun succeed e toks = (e,toks)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   128
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   129
fun any p toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   130
    case pull toks of
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   131
        NONE =>  ([],toks)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   132
      | SOME(x,toks2) => if p x
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   133
                         then
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   134
                             let
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   135
                                 val (xs,toks3) = any p toks2
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   136
                             in
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   137
                                 (x::xs,toks3)
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   138
                             end
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   139
                         else ([],toks)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   140
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   141
fun any1 p toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   142
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   143
        val (x,toks2) = one p toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   144
        val (xs,toks3) = any p toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   145
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   146
        (x::xs,toks3)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   147
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   148
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   149
fun optional sc def =  sc || succeed def
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   150
fun option sc = (sc >> SOME) || succeed NONE
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   151
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   152
(*
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   153
fun repeat sc =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   154
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   155
        fun R toks =
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   156
            let
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   157
                val (x,toks2) = sc toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   158
                val (xs,toks3) = R toks2
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   159
            in
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   160
                (x::xs,toks3)
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   161
            end
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   162
            handle SyntaxError => ([],toks)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   163
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   164
        R
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   165
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   166
*)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   167
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   168
(* A tail-recursive version of repeat.  It is (ever so) slightly slower
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   169
 * than the above, non-tail-recursive version (due to the garbage generation
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   170
 * associated with the reversal of the list).  However,  this version will be
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   171
 * able to process input where the former version must give up (due to stack
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   172
 * overflow).  The slowdown seems to be around the one percent mark.
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   173
 *)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   174
fun repeat sc =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   175
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   176
        fun R xs toks =
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   177
            case SOME (sc toks) handle SyntaxError => NONE of
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   178
                SOME (x,toks2) => R (x::xs) toks2
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   179
              | NONE => (List.rev xs,toks)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   180
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   181
        R []
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   182
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   183
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   184
fun repeat1 sc toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   185
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   186
        val (x,toks2) = sc toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   187
        val (xs,toks3) = repeat sc toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   188
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   189
        (x::xs,toks3)
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   190
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   191
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   192
fun repeat_fixed n sc =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   193
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   194
        fun R n xs toks =
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   195
            if (n <= 0) then (List.rev xs, toks)
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   196
            else case (sc toks) of (x, toks2) => R (n-1) (x::xs) toks2
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   197
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   198
        R n []
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   199
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   200
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   201
fun ahead (sc:'a->'b*'a) toks = (#1 (sc toks),toks)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   202
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   203
fun unless test sc toks =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   204
    let
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   205
        val test_failed = (test toks;false) handle SyntaxError => true
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   206
    in
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   207
        if test_failed
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   208
        then sc toks
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   209
        else raise SyntaxError
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   210
    end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   211
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   212
fun !! f sc toks = (sc toks
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 19093
diff changeset
   213
                    handle SyntaxError => raise Fail (f toks))
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   214
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   215
end
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   216
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   217
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   218
structure StringScanner : STRING_SCANNER =
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   219
struct
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   220
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   221
structure Scan = MonoScanner(structure Seq = StringScannerSeq)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   222
open Scan
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   223
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   224
fun $$ arg = one (fn x => x = arg)
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   225
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   226
val scan_id = one Symbol.is_letter ^^ (any Symbol.is_letdig >> implode);
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   227
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   228
val nat_of_list = the o Int.fromString o implode 
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   229
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   230
val scan_nat = repeat1 (one Symbol.is_digit) >> nat_of_list 
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   231
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   232
fun this [] = (fn toks => ([], toks))
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   233
  | this (xs' as (x::xs)) = one (fn y => x=y) -- this xs >> K xs'
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   234
40627
becf5d5187cc renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents: 32960
diff changeset
   235
fun this_string s = this (raw_explode s) >> K s
19093
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   236
6d584f9d2021 use monomorphic sequences / scanners
obua
parents:
diff changeset
   237
end