File: Byte.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 (54 lines) | stat: -rw-r--r-- 2,246 bytes parent folder | download | duplicates (5)
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
(*
    Title:      Standard Basis Library: Byte Structure and signature
    Author:     David Matthews
    Copyright   David Matthews 1999, 2005, 2015

    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
    under the terms of that licence.
*)

signature BYTE =
sig
    val byteToChar : Word8.word -> char
    val charToByte : char -> Word8.word
    val bytesToString : Word8Vector.vector -> string
    val stringToBytes : string -> Word8Vector.vector
    val unpackStringVec : Word8VectorSlice.slice -> string
    val unpackString : Word8ArraySlice.slice -> string
    val packString : Word8Array.array * int * Substring.substring -> unit
end;

structure Byte: BYTE =
    struct
        (* Chars and Word8.word values are both tagged integers in the
           range 0..255. *)
        fun byteToChar (w: Word8.word): char = RunCall.unsafeCast w
        fun charToByte (c: char) : Word8.word = RunCall.unsafeCast c

        (* Conversion between Word8Vector.vector and string is just a cast. *)
        val bytesToString = LibrarySupport.w8vectorToString
        and stringToBytes = LibrarySupport.w8vectorFromString

        fun unpackStringVec slice : string = bytesToString(Word8VectorSlice.vector slice)
        fun unpackString slice : string = bytesToString(Word8ArraySlice.vector slice)

        fun packString(array: Word8Array.array, i, s: substring) =
        let
            val (str, offset, size) = Substring.base s
            val slice = Word8VectorSlice.slice(stringToBytes str, offset, SOME size)
        in
            Word8ArraySlice.copyVec{src=slice, dst=array, di=i}
        end
    end;