src/Pure/ML-Systems/polyml-old-basis.ML
author wenzelm
Sun, 16 Sep 2007 15:36:57 +0200
changeset 24604 d5c5d2e13fbf
parent 24564 260a65fa2900
permissions -rw-r--r--
added structure Posix;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
23139
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/ML-Systems/polyml-old-basis.ML
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     2
    ID:         $Id$
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     3
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     4
Fixes for the old SML basis library (before Poly/ML 4.2.0).
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     5
*)
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     6
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     7
structure String =
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     8
struct
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
     9
  fun isSuffix s1 s2 =
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    10
    let val n1 = size s1 and n2 = size s2
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    11
    in if n1 = n2 then s1 = s2 else n1 <= n2 andalso String.substring (s2, n2 - n1, n1) = s1 end;
24564
260a65fa2900 added String.isSubstring;
wenzelm
parents: 23141
diff changeset
    12
  fun isSubstring s1 s2 =
260a65fa2900 added String.isSubstring;
wenzelm
parents: 23141
diff changeset
    13
    String.isPrefix s1 s2 orelse
260a65fa2900 added String.isSubstring;
wenzelm
parents: 23141
diff changeset
    14
      size s1 < size s2 andalso isSubstring s1 (String.extract (s2, 1, NONE)); 
23141
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    15
  open String;
23139
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    16
end;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    17
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    18
structure Substring =
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    19
struct
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    20
  open Substring;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    21
  val full = all;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    22
end;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    23
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    24
structure Posix =
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    25
struct
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    26
  open Posix;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    27
  structure IO =
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    28
  struct
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    29
    open IO;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    30
    val mkTextReader = mkReader;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    31
    val mkTextWriter = mkWriter;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    32
  end;
aa899bce7c3b TextIO.inputLine: use present SML B library version;
wenzelm
parents:
diff changeset
    33
end;
23141
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    34
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    35
structure TextIO =
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    36
struct
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    37
  open TextIO;
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    38
  fun inputLine is =
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    39
    let val s = TextIO.inputLine is
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    40
    in if s = "" then NONE else SOME s end;
1f6b6a7314cf emulate later version of TextIO.inputLine;
wenzelm
parents: 23139
diff changeset
    41
end;