aboutsummaryrefslogtreecommitdiff
path: root/builtins
diff options
context:
space:
mode:
authorBruce Hill <bruce@bruce-hill.com>2024-04-10 13:33:40 -0400
committerBruce Hill <bruce@bruce-hill.com>2024-04-10 13:33:40 -0400
commit17cb6ffd88c4464c513b045f4b06c4e6e46e8f22 (patch)
tree115c43f519f598f98d635502a6660c2a7df14c6f /builtins
parente6f78f1d89acb038cf7893c325ee9acf61a555ad (diff)
Add Bool.from_text()
Diffstat (limited to 'builtins')
-rw-r--r--builtins/bool.c22
-rw-r--r--builtins/bool.h1
2 files changed, 20 insertions, 3 deletions
diff --git a/builtins/bool.c b/builtins/bool.c
index cced8077..ff5d0ec4 100644
--- a/builtins/bool.c
+++ b/builtins/bool.c
@@ -1,16 +1,17 @@
// Boolean methods/type info
+#include <ctype.h>
+#include <err.h>
#include <gc.h>
#include <gc/cord.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>
-#include <ctype.h>
#include <sys/param.h>
-#include <err.h>
-#include "util.h"
#include "bool.h"
+#include "text.h"
#include "types.h"
+#include "util.h"
public CORD Bool$as_text(const bool *b, bool colorize, const TypeInfo *type)
{
@@ -22,6 +23,21 @@ public CORD Bool$as_text(const bool *b, bool colorize, const TypeInfo *type)
return *b ? "yes" : "no";
}
+public Bool_t Bool$from_text(CORD text, bool *success)
+{
+ CORD lower = Text$lower(text);
+ if (CORD_cmp(lower, "yes") == 0 || CORD_cmp(lower, "on") == 0 || CORD_cmp(lower, "true") == 0) {
+ if (success) *success = yes;
+ return yes;
+ } else if (CORD_cmp(lower, "no") == 0 || CORD_cmp(lower, "off") == 0 || CORD_cmp(lower, "false") == 0) {
+ if (success) *success = yes;
+ return no;
+ } else {
+ if (success) *success = no;
+ return no;
+ }
+}
+
public const TypeInfo $Bool = {
.size=sizeof(bool),
.align=__alignof__(bool),
diff --git a/builtins/bool.h b/builtins/bool.h
index d5f4b705..356889d1 100644
--- a/builtins/bool.h
+++ b/builtins/bool.h
@@ -13,6 +13,7 @@
#define no (Bool_t)false
CORD Bool$as_text(const bool *b, bool colorize, const TypeInfo *type);
+bool Bool$from_text(CORD text, bool *success);
extern const TypeInfo $Bool;