File: 335_dynamic.sml

package info (click to toggle)
smlsharp 4.1.0-1.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 123,724 kB
  • sloc: ansic: 16,725; sh: 4,347; makefile: 2,191; java: 742; haskell: 493; ruby: 305; cpp: 284; pascal: 256; ml: 255; lisp: 141; asm: 97; sql: 74
file content (56 lines) | stat: -rw-r--r-- 1,284 bytes parent folder | download | duplicates (3)
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
datatype 'a template = TEMPLATE of 'a * unit ptr ref * unit ptr ref

fun import jstr =
    let
      val dyn = JSON.import jstr
      val hdf = ref (Pointer.NULL ()) : unit ptr ref
      val cs = ref (Pointer.NULL ()) : unit ptr ref
    in      
      TEMPLATE (dyn, hdf, cs)
    end

fun decompose temp =
    case temp of
        TEMPLATE (dyn, hdf, cs) => (dyn, hdf, cs)

fun compose tuple = TEMPLATE tuple

;

val template = import "{\"name\":null, \"age\":null}"

val typedTemplate =
    let
      val (dyn, hdf, cs) = decompose template
    in
      compose
        (_json dyn as {name : string option, age : int option} JSON.dyn,
         hdf, cs)
    end

val str = SOME "Hanako"
val dynamicStr = JSON.toDynamic str
val jsonStr = JSON.dynamicToJson dynamicStr
fun viewFunStr (x : JSON.json) = str

val num = SOME 100
val dynamicNum = JSON.toDynamic num
val jsonNum = JSON.dynamicToJson dynamicNum

(* 2016-11-14 osaka

このファイルをSML#の対話環境にコピーする(useで読み込ませない)と,
最後の行のJSON.dynamicToJsonでsegmentation fault.

*)

(* 2016-11-14 katsu

fixed by
changeset:   7688:e4acd795cebb
user:        UENO Katsuhiro
date:        Mon Nov 14 22:06:19 2016 +0900
files:       smlsharp/src/runtime/dump.c
description:
  bugfix
*)