aboutsummaryrefslogtreecommitdiff
path: root/stdlib/source/lux/data/text/encoding.lux
diff options
context:
space:
mode:
authorEduardo Julian2020-06-28 21:32:43 -0400
committerEduardo Julian2020-06-28 21:32:43 -0400
commitb1606a5efcba32abe722759dbfca02586ff2179a (patch)
tree74d306f16757eaf8639304f6db46137b49a6076d /stdlib/source/lux/data/text/encoding.lux
parentec29b735396a656862ab9dcdde3627e234c938b0 (diff)
The "for" macro can now work directly with definitions. No text literals necessary.
Diffstat (limited to '')
-rw-r--r--stdlib/source/lux/data/text/encoding.lux68
1 files changed, 34 insertions, 34 deletions
diff --git a/stdlib/source/lux/data/text/encoding.lux b/stdlib/source/lux/data/text/encoding.lux
index 9e94f25af..1ef044080 100644
--- a/stdlib/source/lux/data/text/encoding.lux
+++ b/stdlib/source/lux/data/text/encoding.lux
@@ -174,50 +174,50 @@
(with-expansions [<for-jvm> (as-is (host.import: #long java/lang/String
(new [[byte] java/lang/String])
(getBytes [java/lang/String] [byte])))]
- (`` (for {(~~ (static @.old))
- (as-is <for-jvm>)
-
- (~~ (static @.jvm))
- (as-is <for-jvm>)
-
- (~~ (static @.js))
- (as-is (host.import: Uint8Array)
-
- (host.import: TextEncoder
- (new [host.String])
- (encode [host.String] Uint8Array))
-
- (host.import: TextDecoder
- (new [host.String])
- (decode [Uint8Array] host.String)))})))
+ (for {@.old
+ (as-is <for-jvm>)
+
+ @.jvm
+ (as-is <for-jvm>)
+
+ @.js
+ (as-is (host.import: Uint8Array)
+
+ (host.import: TextEncoder
+ (new [host.String])
+ (encode [host.String] Uint8Array))
+
+ (host.import: TextDecoder
+ (new [host.String])
+ (decode [Uint8Array] host.String)))}))
(def: #export (to-utf8 value)
(-> Text Binary)
- (`` (for {(~~ (static @.old))
- (java/lang/String::getBytes (..name ..utf-8)
- ## The coercion below may seem
- ## gratuitous, but removing it
- ## causes a grave compilation problem.
- (:coerce java/lang/String value))
+ (for {@.old
+ (java/lang/String::getBytes (..name ..utf-8)
+ ## The coercion below may seem
+ ## gratuitous, but removing it
+ ## causes a grave compilation problem.
+ (:coerce java/lang/String value))
- (~~ (static @.jvm))
- (java/lang/String::getBytes (..name ..utf-8) value)
+ @.jvm
+ (java/lang/String::getBytes (..name ..utf-8) value)
- (~~ (static @.js))
- (|> (TextEncoder::new [(..name ..utf-8)])
- (TextEncoder::encode [value]))})))
+ @.js
+ (|> (TextEncoder::new [(..name ..utf-8)])
+ (TextEncoder::encode [value]))}))
(def: #export (from-utf8 value)
(-> Binary (Try Text))
- (`` (for {(~~ (static @.old))
- (#try.Success (java/lang/String::new value (..name ..utf-8)))
+ (for {@.old
+ (#try.Success (java/lang/String::new value (..name ..utf-8)))
- (~~ (static @.jvm))
- (#try.Success (java/lang/String::new value (..name ..utf-8)))
+ @.jvm
+ (#try.Success (java/lang/String::new value (..name ..utf-8)))
- (~~ (static @.js))
- (#try.Success (|> (TextDecoder::new [(..name ..utf-8)])
- (TextDecoder::decode [value])))})))
+ @.js
+ (#try.Success (|> (TextDecoder::new [(..name ..utf-8)])
+ (TextDecoder::decode [value])))}))
(structure: #export UTF-8
(Codec Binary Text)