Skip to content

Abstract RubyString#9369

Open
headius wants to merge 1 commit intojruby:masterfrom
headius:abstract_string
Open

Abstract RubyString#9369
headius wants to merge 1 commit intojruby:masterfrom
headius:abstract_string

Conversation

@headius
Copy link
Copy Markdown
Member

@headius headius commented Apr 7, 2026

This is the final of three planned abstractions for JRuby 10.1. Abstracting RubyString will allow us to more easily introduce subtypes that compactly represent single bytes or characters, efficiently wrap Java String and CharSequence, and explore alternative backing stores.

@headius headius added this to the JRuby 10.1.0.0 milestone Apr 7, 2026
@headius headius force-pushed the abstract_string branch 2 times, most recently from 8234b5f to 1a98eb2 Compare April 7, 2026 22:36
This is not a particularly good split of functionality; some
methods that are ByteList-agnostic could be moved back up to
RubyString and other methods that can't work without ByteList have
hard errors if unexpected types show up. The goal should be as with
RubyArraySpecialized subclasses, where most of the common
algorithms are implemented in the parent without a dependency on
any internals, and only those that require access to such internals
for performance get reimplemented in the child classes. This
patch sets the stage for such a move, though.
@headius
Copy link
Copy Markdown
Member Author

headius commented Apr 8, 2026

I don't believe this can happen for 10.1 given the exposure of the RubyString constructors. I will push a different PR that deprecates all of them for removal and we will hope to do this some time later.

@headius headius modified the milestones: JRuby 10.1.0.0, 10.2.0.0 Apr 8, 2026
headius added a commit to headius/jruby that referenced this pull request Apr 9, 2026
We would like to make RubyString abstract, so it can be represented
more efficiently when containing a single character or a Java
String. In order to do so, we need users to stop using the public
constructors.

This patch deprecates all of the constructors for removal. They
will not prevent compilation, but they should show up a bit more
boldly and most Java editing tools will highlight them as errors.

See jruby#9369 for the attempt to abstract RubyString. This
effort will be put on hold for now due to the many exposed
constructors.

See jruby/jruby-openssl#355 for an example of an external library
that was using these constructors directly.
headius added a commit to headius/jruby that referenced this pull request Apr 9, 2026
We would like to make RubyString abstract, so it can be represented
more efficiently when containing a single character or a Java
String. In order to do so, we need users to stop using the public
constructors.

This patch deprecates all of the constructors for removal. They
will not prevent compilation, but they should show up a bit more
boldly and most Java editing tools will highlight them as errors.

See jruby#9369 for the attempt to abstract RubyString. This
effort will be put on hold for now due to the many exposed
constructors.

See jruby/jruby-openssl#355 for an example of an external library
that was using these constructors directly.
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.

1 participant