-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
38 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,45 +1,75 @@ | ||
# AttributedString | ||
[![Ruby](https://github.com/instruct-rb/attributed-string/actions/workflows/ruby.yml/badge.svg)](https://github.com/instruct-rb/attributed-string/actions/workflows/ruby.yml) | ||
|
||
An attributed string implementation for Ruby. | ||
|
||
An attributed string contains key-value pairs known as attributes that specify additional information related to ranges of characters within the string. Attributed strings support any key-value pair, but are often used for: | ||
--- | ||
🚧 This gem is in development, and its behaviour might still change before 1.0 🚧 | ||
|
||
--- | ||
|
||
|
||
An attributed string contains key-value pairs known as attributes that specify additional information related to ranges of characters within the string. Attributed strings support any key-value pair, but are often used for: | ||
|
||
- Rendering attributes such as font, color, and other details. | ||
- Attributes for inline-attachments such as images, videos, files, etc. | ||
- Attributes for inline-attachments such as images, videos, files, etc. | ||
- Semantic attributes such as link URLs or tool-tip information | ||
- Language attributes to support automatic gender agreement or verb agreement. | ||
- Language attributes to support automatic gender agreement or verb agreement. | ||
- Accessibility attributes that provide information for assistive technologies | ||
- Custom attributes you define | ||
|
||
You will typically need to create a presenter for an attributed string, as the default shows no attribute information and inspect shows all attributes. | ||
You will typically need to create a presenter for an attributed string, as the default shows no attribute information and inspect shows all attributes. | ||
|
||
This gem is inspired by Apple's [NSAttributedString](https://developer.apple.com/documentation/foundation/nsattributedstring). | ||
|
||
## Installation | ||
|
||
Add this line to your application's Gemfile: | ||
|
||
```ruby | ||
gem 'attributed-string', github: 'instruct-rb/attributed-string', branch: 'main' | ||
gem 'attributed-string' | ||
``` | ||
|
||
|
||
## Usage | ||
|
||
🚧 This gem is a work in progress and the API may change before 1.0. | ||
|
||
```ruby | ||
using AttributedString::Refinements | ||
hello_world1 = AttributedString.new('Hello, World!', color: :red, font: 'Helvetica' ) | ||
hello_world2 = 'Hello, World!'.to_attr_s(color: :red, font: 'Helvetica') | ||
puts hello_world1 == hello_world2 # true | ||
puts hello_world1 == hello_world2 | ||
# => true | ||
|
||
hello_world1.add_attrs(0..4, color: :blue) | ||
hello_world1 += "!!" | ||
puts hello_world1.inspect | ||
# => { color: blue, font: "Helvetica" }Hello{ color: red }, World!{ -color, -font }!! | ||
|
||
puts hello_world1.attrs_at(0) | ||
# => { color: blue, font: "Helvetica" } | ||
``` | ||
|
||
## Attachments | ||
|
||
```ruby | ||
hello_world = AttributedString.new('Hello, World!') | ||
|
||
hello_world.add_attachment("any ruby object", position: string.length) | ||
puts hello_world # => "Hello, World! " | ||
|
||
# Adding an attachment inserts the Object Replacement Character into the | ||
# string, in most fonts it will show as a space | ||
puts hello_world | ||
# => "Hello, World! " | ||
puts hello_world.attachments # => ["any ruby object"] | ||
|
||
# Deleting the character from the string removes the attachment | ||
hello_world[-1..-1] = '' | ||
puts hello_world.attachments # => [] | ||
``` | ||
|
||
## More Examples | ||
See the [test suite](./test). | ||
|
||
## Used By | ||
- [Instruct](https://github.com/instruct-rb/instruct) - Instruct LLMs to do what you want in Ruby |