about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorKartik K. Agaram <vc@akkartik.com>2016-09-15 09:55:14 -0700
committerKartik K. Agaram <vc@akkartik.com>2016-09-15 09:55:14 -0700
commit02796d320d98cc30f5f074d822535f878dba34e5 (patch)
tree48597ebd5e145a2de599a06ed865e68d366130e5
parentcd93f2dd80388bd218a9613343100c458d391f17 (diff)
downloadmu-02796d320d98cc30f5f074d822535f878dba34e5.tar.gz
3357 - multi-ary 'append'
-rw-r--r--061text.mu69
1 files changed, 36 insertions, 33 deletions
diff --git a/061text.mu b/061text.mu
index c6db04da..a5b653ec 100644
--- a/061text.mu
+++ b/061text.mu
@@ -190,6 +190,21 @@ def append buf:address:buffer, c:character -> buf:address:buffer [
   *buf <- put *buf, length:offset, len
 ]
 
+def append buf:address:buffer, t:text -> buf:address:buffer [
+  local-scope
+  load-ingredients
+  len:number <- length *t
+  i:number <- copy 0
+  {
+    done?:boolean <- greater-or-equal i, len
+    break-if done?
+    c:character <- index *t, i
+    buf <- append buf, c
+    i <- add i, 1
+    loop
+  }
+]
+
 scenario buffer-append-works [
   run [
     local-scope
@@ -284,44 +299,18 @@ def buffer-to-array in:address:buffer -> result:text [
   }
 ]
 
-def append a:text, b:text -> result:text [
+def append -> result:text [
   local-scope
   load-ingredients
-  # handle null addresses
-  return-unless a, b
-  return-unless b, a
-  # result = new character[a.length + b.length]
-  a-len:number <- length *a
-  b-len:number <- length *b
-  result-len:number <- add a-len, b-len
-  result <- new character:type, result-len
-  # copy a into result
-  result-idx:number <- copy 0
-  i:number <- copy 0
+  buf:address:buffer <- new-buffer 30
   {
-    # while i < a.length
-    a-done?:boolean <- greater-or-equal i, a-len
-    break-if a-done?
-    # result[result-idx] = a[i]
-    in:character <- index *a, i
-    *result <- put-index *result, result-idx, in
-    i <- add i, 1
-    result-idx <- add result-idx, 1
-    loop
-  }
-  # copy b into result
-  i <- copy 0
-  {
-    # while i < b.length
-    b-done?:boolean <- greater-or-equal i, b-len
-    break-if b-done?
-    # result[result-idx] = a[i]
-    in:character <- index *b, i
-    *result <- put-index *result, result-idx, in
-    i <- add i, 1
-    result-idx <- add result-idx, 1
+    arg:text, arg-found?:boolean <- next-ingredient
+    break-unless arg-found?
+    loop-unless arg
+    buf <- append buf, arg
     loop
   }
+  result <- buffer-to-array buf
 ]
 
 scenario text-append-1 [
@@ -363,6 +352,20 @@ scenario text-append-null-2 [
   ]
 ]
 
+scenario text-append-multiary [
+  run [
+    local-scope
+    x:text <- new [hello, ]
+    y:text <- new [world]
+    z:text <- new [!]
+    z:text <- append x, y, z
+    10:array:character/raw <- copy *z
+  ]
+  memory-should-contain [
+    10:array:character <- [hello, world!]
+  ]
+]
+
 scenario replace-character-in-text [
   run [
     local-scope
p;id=4690ce81e079fc58cae8d6d583e5e3eb3ed81a83'>4690ce81 ^
83fcebf3 ^
32b8fac2 ^
83fcebf3 ^
f5465e12 ^
83fcebf3 ^


4690ce81 ^
83fcebf3 ^
d009e158 ^
83fcebf3 ^



a654e4ec ^
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
45
46
47
48