| author | wenzelm | 
| Sat, 01 Dec 2018 15:55:04 +0100 | |
| changeset 69382 | d70767e508d7 | 
| parent 62935 | 3c7a35c12e03 | 
| child 73696 | 03e134d5f867 | 
| permissions | -rw-r--r-- | 
| 62508 
d0b68218ea55
discontinued RAW session: bootstrap directly from isabelle_process RAW_ML_SYSTEM;
 wenzelm parents: 
61925diff
changeset | 1 | (* Title: Pure/Concurrent/unsynchronized.ML | 
| 32737 | 2 | Author: Makarius | 
| 3 | ||
| 4 | Raw ML references as unsynchronized state variables. | |
| 5 | *) | |
| 6 | ||
| 62935 | 7 | signature UNSYNCHRONIZED = | 
| 8 | sig | |
| 9 | datatype ref = datatype ref | |
| 10 | val := : 'a ref * 'a -> unit | |
| 11 | val ! : 'a ref -> 'a | |
| 12 |   val change: 'a ref -> ('a -> 'a) -> unit
 | |
| 13 |   val change_result: 'a ref -> ('a -> 'b * 'a) -> 'b
 | |
| 14 | val inc: int ref -> int | |
| 15 | val dec: int ref -> int | |
| 16 |   val setmp: 'a ref -> 'a -> ('b -> 'c) -> 'b -> 'c
 | |
| 17 | end; | |
| 18 | ||
| 19 | structure Unsynchronized: UNSYNCHRONIZED = | |
| 32737 | 20 | struct | 
| 21 | ||
| 22 | datatype ref = datatype ref; | |
| 23 | ||
| 24 | val op := = op :=; | |
| 25 | val ! = !; | |
| 26 | ||
| 27 | fun change r f = r := f (! r); | |
| 28 | fun change_result r f = let val (x, y) = f (! r) in r := y; x end; | |
| 29 | ||
| 30 | fun inc i = (i := ! i + (1: int); ! i); | |
| 31 | fun dec i = (i := ! i - (1: int); ! i); | |
| 32 | ||
| 39616 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 33 | fun setmp flag value f x = | 
| 62923 | 34 | Thread_Attributes.uninterruptible (fn restore_attributes => fn () => | 
| 39616 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 35 | let | 
| 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 36 | val orig_value = ! flag; | 
| 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 37 | val _ = flag := value; | 
| 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 38 | val result = Exn.capture (restore_attributes f) x; | 
| 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 39 | val _ = flag := orig_value; | 
| 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 40 | in Exn.release result end) (); | 
| 
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
 wenzelm parents: 
38799diff
changeset | 41 | |
| 32737 | 42 | end; | 
| 62818 | 43 | |
| 62935 | 44 | ML_Name_Space.forget_val "ref"; | 
| 45 | ML_Name_Space.forget_type "ref"; |