File: StringChar.sml

package info (click to toggle)
polyml 5.7.1-5
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, sid
  • size: 40,616 kB
  • sloc: cpp: 44,142; ansic: 26,963; sh: 22,002; asm: 13,486; makefile: 602; exp: 525; python: 253; awk: 91
file content (57 lines) | stat: -rw-r--r-- 2,243 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
(*
    Title:      Rebuild the basis library: String and char.
    Copyright   David C.J. Matthews 2016

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    License version 2.1 as published by the Free Software Foundation.
    
    This library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    Lesser General Public License for more details.
    
    You should have received a copy of the GNU Lesser General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
*)

(* Char and String *)
useBasis "StringSignatures";

structure Char: CHAR =
struct
    open Char
    val maxOrd = FixedInt.toInt maxOrd
    val chr = chr o FixedInt.fromInt
    val ord = FixedInt.toInt o ord
end;

structure String: STRING =
struct
    open String
    val maxSize = FixedInt.toInt maxSize
    val size = FixedInt.toInt o size
    val sub = fn (s, i) => sub(s, FixedInt.fromInt i)
    val substring = fn (s, i, j) => substring(s, FixedInt.fromInt i, FixedInt.fromInt j)
    val extract = fn(s, i, j) => extract(s, FixedInt.fromInt i, Option.map FixedInt.fromInt j)
end;

structure Substring: SUBSTRING =
struct
    open Substring
    val base = fn s => let val (a, i, j) = base s in (a, FixedInt.toInt i, FixedInt.toInt j) end
    val size = FixedInt.toInt o size
    val sub = fn (s, i) => sub(s, FixedInt.fromInt i)
    val substring = fn (s, i, j) => substring(s, FixedInt.fromInt i, FixedInt.fromInt j)
    val extract = fn(s, i, j) => extract(s, FixedInt.fromInt i, Option.map FixedInt.fromInt j)
    val splitAt = fn (s, i) => splitAt(s, FixedInt.fromInt i)
    val slice = fn (s, i, j) => slice(s, FixedInt.fromInt i, Option.map FixedInt.fromInt j)
    val trimr = fn i => trimr(FixedInt.fromInt i)
    and triml = fn i => triml(FixedInt.fromInt i)
end;

val ord : char -> int = Char.ord 
val chr : int -> char = Char.chr 
val substring : string * int * int -> string = String.substring;
val size: string -> int = String.size;