File: SingleAssignment.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 (44 lines) | stat: -rw-r--r-- 1,283 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
(*
    Title:      References that allow a single assignment
    Author:     David Matthews
    Copyright   David Matthews 2010, 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
*)

structure SingleAssignment:>
sig
    type 'a saref (* Equality not allowed *)
    exception Locked
    val saref: unit -> 'a saref
    val savalue: 'a saref -> 'a option
    val saset: 'a saref * 'a -> unit
end
=
struct
    exception Locked

    type 'a saref = 'a option ref

    fun saref () = ref NONE
    
    val savalue = !

    fun saset(saVar as ref NONE, newValue) =
    (
        saVar := SOME newValue;
        RunCall.clearMutableBit saVar
    )
    |   saset _ = raise Locked
end;