| [79308c8e] | 1 | // | 
|---|
|  | 2 | // Cforall Version 1.0.0 Copyright (C) 2016 University of Waterloo | 
|---|
|  | 3 | // | 
|---|
|  | 4 | // The contents of this file are covered under the licence agreement in the | 
|---|
|  | 5 | // file "LICENCE" distributed with Cforall. | 
|---|
|  | 6 | // | 
|---|
|  | 7 | // result -- Contains the expected value or an error value. | 
|---|
|  | 8 | // | 
|---|
|  | 9 | // Author           : Andrew Beach | 
|---|
| [58daf53] | 10 | // Created On       : Wed May 24 14:45:00 2017 | 
|---|
| [6b0b624] | 11 | // Last Modified By : Peter A. Buhr | 
|---|
|  | 12 | // Last Modified On : Sat Jul 22 10:00:44 2017 | 
|---|
|  | 13 | // Update Count     : 3 | 
|---|
| [79308c8e] | 14 | // | 
|---|
|  | 15 |  | 
|---|
| [6b0b624] | 16 | #pragma once | 
|---|
| [79308c8e] | 17 |  | 
|---|
| [64fc0ba] | 18 | #include <stdbool.h> | 
|---|
| [79308c8e] | 19 |  | 
|---|
|  | 20 | // DO NOT USE DIRECTLY! | 
|---|
| [64fc0ba] | 21 | forall(otype T, otype E) | 
|---|
|  | 22 | union inner_result{ | 
|---|
|  | 23 | T value; | 
|---|
|  | 24 | E error; | 
|---|
|  | 25 | }; | 
|---|
|  | 26 |  | 
|---|
| [79308c8e] | 27 | forall(otype T, otype E) | 
|---|
|  | 28 | struct result { | 
|---|
| [64fc0ba] | 29 | bool has_value; | 
|---|
| [b1672e1] | 30 | inline union inner_result(T, E); | 
|---|
| [79308c8e] | 31 | }; | 
|---|
|  | 32 |  | 
|---|
|  | 33 |  | 
|---|
|  | 34 | forall(otype T, otype E) | 
|---|
| [242a902] | 35 | void ?{}(result(T, E) & this); | 
|---|
| [79308c8e] | 36 |  | 
|---|
|  | 37 | forall(otype T, otype E) | 
|---|
| [242a902] | 38 | void ?{}(result(T, E) & this, one_t, T value); | 
|---|
| [79308c8e] | 39 |  | 
|---|
|  | 40 | forall(otype T, otype E) | 
|---|
| [242a902] | 41 | void ?{}(result(T, E) & this, zero_t, E error); | 
|---|
| [79308c8e] | 42 |  | 
|---|
|  | 43 | forall(otype T, otype E) | 
|---|
| [242a902] | 44 | void ?{}(result(T, E) & this, result(T, E) other); | 
|---|
| [79308c8e] | 45 |  | 
|---|
|  | 46 | forall(otype T, otype E) | 
|---|
| [242a902] | 47 | void ^?{}(result(T, E) & this); | 
|---|
| [79308c8e] | 48 |  | 
|---|
| [58daf53] | 49 | forall(otype T, otype E) | 
|---|
| [242a902] | 50 | result(T, E) ?=?(result(T, E) & this, result(T, E) other); | 
|---|
| [58daf53] | 51 |  | 
|---|
| [79308c8e] | 52 | forall(otype T, otype E) | 
|---|
| [64fc0ba] | 53 | bool ?!=?(result(T, E) this, zero_t); | 
|---|
| [79308c8e] | 54 |  | 
|---|
| [20877d2] | 55 | /* Wating for bug#11 to be fixed. | 
|---|
| [79308c8e] | 56 | forall(otype T, otype E) | 
|---|
|  | 57 | result(T, E) result_value(T value); | 
|---|
|  | 58 |  | 
|---|
|  | 59 | forall(otype T, otype E) | 
|---|
|  | 60 | result(T, E) result_error(E error); | 
|---|
| [20877d2] | 61 | */ | 
|---|
| [79308c8e] | 62 |  | 
|---|
|  | 63 | forall(otype T, otype E) | 
|---|
| [64fc0ba] | 64 | bool has_value(result(T, E) * this); | 
|---|
| [79308c8e] | 65 |  | 
|---|
|  | 66 | forall(otype T, otype E) | 
|---|
|  | 67 | T get(result(T, E) * this); | 
|---|
|  | 68 |  | 
|---|
|  | 69 | forall(otype T, otype E) | 
|---|
|  | 70 | E get_error(result(T, E) * this); | 
|---|
|  | 71 |  | 
|---|
| [58daf53] | 72 | forall(otype T, otype E) | 
|---|
|  | 73 | void set(result(T, E) * this, T value); | 
|---|
|  | 74 |  | 
|---|
|  | 75 | forall(otype T, otype E) | 
|---|
|  | 76 | void set_error(result(T, E) * this, E error); | 
|---|
|  | 77 |  | 
|---|
| [6b0b624] | 78 | // Local Variables: // | 
|---|
|  | 79 | // mode: c // | 
|---|
|  | 80 | // tab-width: 4 // | 
|---|
|  | 81 | // End: // | 
|---|