Home My Page Projects Code Snippets Project Openings diderot
Summary Activity Tracker Tasks SCM

SCM Repository

[diderot] Annotation of /branches/vis15/src/compiler/cxx-util/cxx-names.sml
ViewVC logotype

Annotation of /branches/vis15/src/compiler/cxx-util/cxx-names.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3918 - (view) (download)

1 : jhr 3906 (* cxx-names.sml
2 : jhr 3810 *
3 :     * This code is part of the Diderot Project (http://diderot-language.cs.uchicago.edu)
4 :     *
5 :     * COPYRIGHT (c) 2016 The University of Chicago
6 :     * All rights reserved.
7 :     *)
8 :    
9 : jhr 3906 structure CxxNames : sig
10 : jhr 3810
11 : jhr 3900 (* the base type of the world struct *)
12 :     val worldBaseTyName : string
13 : jhr 3810
14 : jhr 3900 (* the world type *)
15 :     val worldTyName : string
16 :     val worldPtrTy : CLang.ty
17 :    
18 :     (* the global variables struct *)
19 :     val globalTyName : string
20 :     val globalPtrTy : CLang.ty
21 :    
22 :     (* the pointer to the command-line options struct *)
23 :     val optionsPtrTy : CodeGenEnv.t -> CLang.ty
24 :    
25 : jhr 3810 (* Run-time system functions for dynamic sequences *)
26 : jhr 3900 val loadDynSeq : APITypes.t -> string
27 :     val loadDynSeqFromFile : APITypes.t -> string
28 :    
29 : jhr 3906 (* standard names for accessing globals and state variables *)
30 : jhr 3908 val globalsVar : CLang.var
31 :     val globalsParam : CLang.param
32 :     val selfVar : CLang.var
33 :     val selfInVar : CLang.var
34 :     val selfOutVar : CLang.var
35 : jhr 3906
36 : jhr 3918 (* wrapper struct for tensor types (to enable overload resolution) *)
37 :     val tensorStruct : int list -> string
38 :     val tensorTy : int list -> CLang.ty
39 :    
40 : jhr 3900 end = struct
41 :    
42 :     structure CL = CLang
43 :     structure Env = CodeGenEnv
44 :    
45 :     (* the base type of the world struct *)
46 :     val worldBaseTyName = "world_base"
47 :    
48 :     (* the world type *)
49 :     val worldTyName = "world"
50 :     val worldPtrTy = CL.T_Ptr(CL.T_Named worldTyName)
51 :    
52 :     (* the global variables struct *)
53 :     val globalTyName = "globals"
54 :     val globalPtrTy = CL.T_Ptr(CL.T_Named globalTyName)
55 :    
56 :     (* the pointer to the command-line options struct *)
57 :     fun optionsPtrTy env =
58 : jhr 3917 CL.T_Ptr(CL.T_Template("diderot::options", [Env.realTy env, Env.intTy env]))
59 : jhr 3900
60 :     (* Run-time system functions for dynamic sequences *)
61 : jhr 3810 (* FIXME: should these be DynSeqLoad<ty>? *)
62 :     fun loadDynSeq ty = (case ty
63 : jhr 3900 of APITypes.BoolTy => "diderot::DynSeqLoadBool"
64 :     | APITypes.IntTy => "diderot::DynSeqLoadInt"
65 :     | APITypes.TensorTy _ => "diderot::DynSeqLoadReal"
66 : jhr 3810 | ty => raise Fail("unsupported sequence type " ^ APITypes.toString ty)
67 :     (* end case *))
68 :    
69 :     fun loadDynSeqFromFile ty = (case ty
70 : jhr 3900 of APITypes.BoolTy => "diderot::DynSeqLoadBoolFromFile"
71 :     | APITypes.IntTy => "diderot::DynSeqLoadIntFromFile"
72 :     | APITypes.TensorTy _ => "diderot::DynSeqLoadRealFromFile"
73 : jhr 3810 | ty => raise Fail("unsupported sequence type " ^ APITypes.toString ty)
74 :     (* end case *))
75 :    
76 : jhr 3917 val globalsVar = "glob"
77 : jhr 3908 val globalsParam = CL.PARAM([], globalPtrTy, globalsVar)
78 :     val selfVar = "self"
79 :     val selfInVar = "selfIn"
80 :     val selfOutVar = "selfOut"
81 : jhr 3906
82 : jhr 3918 fun tensorStruct shape = "tensor_" ^ String.concatWithMap "_" Int.toString shape
83 :     fun tensorTy shape = CL.T_Named(tensorStruct shape)
84 :    
85 : jhr 3810 end

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0