Skip to content

Conversation

@richard-viney
Copy link
Contributor

@richard-viney richard-viney commented Feb 6, 2025

Fixes #797.

The separate version of the function for the JavaScript target is a little bit of an eyesore, but can be removed at some future date once utf_codepoint pattern matching is supported on that target.

Copy link
Member

@lpil lpil left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you!

// target due to not using the `utf8_codepoint` bit array segment type. Once
// the JavaScript target supports `utf8_codepoint` this function should be
// removed.
@target(javascript)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's a shame so much is needed for JavaScript, and this introduces a new @target, which we have been working hard to remove.

How challenging would it be to have utf8_codepoint support in JavaScript? That seems like it would be a better solution.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Bit array pattern matching in JS would need to be expanded to support dynamic sizes first, then utf_codepoint could be implemented on top of that.

I think it's reasonable to wait for that to happen, or alternatively a @target can be avoided by either using the longer JS-compatible version on both targets (it works fine on Erlang), or by implementing the JS version directly in JS as an external function.

@richard-viney richard-viney force-pushed the bit_array_to_string_lossy branch 2 times, most recently from 378c5d3 to f051874 Compare February 14, 2025 11:43
@richard-viney richard-viney force-pushed the bit_array_to_string_lossy branch from f051874 to 26fc288 Compare March 10, 2025 21:18
@richard-viney
Copy link
Contributor Author

This PR is done but can't merge until Gleam supports utf_codepoint in bit array patterns on the JavaScript target.

Converting to draft until that's ready.

@richard-viney richard-viney marked this pull request as draft March 10, 2025 21:21
@richard-viney richard-viney force-pushed the bit_array_to_string_lossy branch from 26fc288 to e39289b Compare March 25, 2025 03:10
@richard-viney richard-viney force-pushed the bit_array_to_string_lossy branch from e39289b to 26d7d90 Compare October 23, 2025 11:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Suggestion: Add bit_array.to_lossy_string() or similar

2 participants