source: src/libcfa/containers/result.c@ cdbfab0

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors deferred_resn demangler enum forall-pointer-decay jacob/cs343-translation jenkins-sandbox new-ast new-ast-unique-expr new-env no_list persistent-indexer pthread-emulation qualifiedEnum resolv-new with_gc
Last change on this file since cdbfab0 was 9236060, checked in by Rob Schluntz <rschlunt@…>, 8 years ago

Merge branch 'master' into references

  • Property mode set to 100644
File size: 2.6 KB
RevLine 
[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.c -- Contains the expected value or an error value.
8//
9// Author : Andrew Beach
[58daf53]10// Created On : Wed May 24 15:40:00 2017
[91c389a]11// Last Modified By : Peter A. Buhr
12// Last Modified On : Thu Jul 20 15:23:58 2017
13// Update Count : 2
[79308c8e]14//
15
16#include <containers/result>
[91c389a]17#include <assert.h>
[79308c8e]18
19
20forall(otype T, otype E)
[242a902]21void ?{}(result(T, E) & this) {
22 this.has_value = false;
23 (this.error){};
[79308c8e]24}
25
26forall(otype T, otype E)
[242a902]27void ?{}(result(T, E) & this, one_t, T value) {
28 this.has_value = true;
29 (this.value){value};
[79308c8e]30}
31
32forall(otype T, otype E)
[242a902]33void ?{}(result(T, E) & this, zero_t, E error) {
34 this.has_value = false;
35 (this.error){error};
[79308c8e]36}
37
38forall(otype T, otype E)
[242a902]39void ?{}(result(T, E) & this, result(T, E) other) {
40 this.has_value = other.has_value;
[79308c8e]41 if (other.has_value) {
[242a902]42 (this.value){other.value};
[79308c8e]43 } else {
[242a902]44 (this.error){other.error};
[58daf53]45 }
46}
47
48forall(otype T, otype E)
[242a902]49result(T, E) ?=?(result(T, E) & this, result(T, E) that) {
50 if (this.has_value & that.has_value) {
51 this.value = that.value;
52 } else if (this.has_value) {
53 ^(this.value){};
54 this.has_value = false;
55 (this.error){that.error};
[58daf53]56 } else if (that.has_value) {
[242a902]57 ^(this.error){};
58 this.has_value = true;
59 (this.value){that.value};
[58daf53]60 } else {
[242a902]61 this.error = that.error;
[79308c8e]62 }
63}
64
65forall(otype T, otype E)
[242a902]66void ^?{}(result(T, E) & this) {
67 if (this.has_value) {
68 ^(this.value){};
[79308c8e]69 } else {
[242a902]70 ^(this.error){};
[79308c8e]71 }
72}
73
74forall(otype T, otype E)
[64fc0ba]75bool ?!=?(result(T, E) this, zero_t) {
[20877d2]76 return this.has_value;
[79308c8e]77}
78
79forall(otype T, otype E)
80result(T, E) result_value(T value) {
[64fc0ba]81 return (result(T, E)){1, value};
[79308c8e]82}
83
84forall(otype T, otype E)
85result(T, E) result_error(E error) {
[64fc0ba]86 return (result(T, E)){0, error};
[79308c8e]87}
88
89forall(otype T, otype E)
[64fc0ba]90bool has_value(result(T, E) * this) {
[79308c8e]91 return this->has_value;
92}
93
94forall(otype T, otype E)
95T get(result(T, E) * this) {
[64fc0ba]96 assertf(this->has_value, "attempt to get from result without value");
[79308c8e]97 return this->value;
98}
99
100forall(otype T, otype E)
101E get_error(result(T, E) * this) {
[20877d2]102 assertf(!this->has_value, "attempt to get from result without error");
[79308c8e]103 return this->error;
104}
[58daf53]105
106forall(otype T, otype E)
107void set(result(T, E) * this, T value) {
108 if (this->has_value) {
109 this->value = value;
110 } else {
[242a902]111 ^(this->error){};
[58daf53]112 this->has_value = true;
[242a902]113 (this->value){value};
[58daf53]114 }
115}
116
117forall(otype T, otype E)
118void set_error(result(T, E) * this, E error) {
119 if (this->has_value) {
[242a902]120 ^(this->value){};
[58daf53]121 this->has_value = false;
[242a902]122 (this->error){error};
[58daf53]123 } else {
124 this->error = error;
125 }
126}
Note: See TracBrowser for help on using the repository browser.