enum
ACP::Protocol::Role
Defined in:
acp/protocol/enums.crEnum Members
-
Assistant =
0 -
The AI assistant / agent.
-
User =
1 -
The human user.
Constructors
- .new(pull : JSON::PullParser) : self
-
.parse(value : String) : Role
Parses a wire-format string into a Role.
Class Method Summary
-
.parse?(value : String) : Role | Nil
Parses a wire-format string into a Role.
Instance Method Summary
-
#assistant?
Returns
trueif this enum value equalsAssistant -
#to_json(json : JSON::Builder) : Nil
Serializes this enum member by name.
-
#to_s : String
Returns the wire-format string for this role.
-
#user?
Returns
trueif this enum value equalsUser
Constructor Detail
Parses a wire-format string into a Role. Raises ArgumentError if the string is not recognized.
Class Method Detail
Parses a wire-format string into a Role. Returns nil if the string is not recognized.
Instance Method Detail
Serializes this enum member by name.
For non-flags enums, the serialization is a JSON string. The value is the
member name (see #to_s) transformed with String#underscore.
enum Stages
INITIAL
SECOND_STAGE
end
Stages::INITIAL.to_json # => %("initial")
Stages::SECOND_STAGE.to_json # => %("second_stage")
For flags enums, the serialization is a JSON array including every flagged
member individually serialized in the same way as a member of a non-flags enum.
None is serialized as an empty array, All as an array containing
all members.
@[Flags]
enum Sides
LEFT
RIGHT
end
Sides::LEFT.to_json # => %(["left"])
(Sides::LEFT | Sides::RIGHT).to_json # => %(["left","right"])
Sides::All.to_json # => %(["left","right"])
Sides::None.to_json # => %([])
ValueConverter.to_json offers a different serialization strategy based on the
member value.