mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 06:48:12 +00:00
AK: Make SourceGenerator::fork() infallible
This commit is contained in:
parent
244516142a
commit
0b83717ea2
17 changed files with 142 additions and 142 deletions
|
@ -123,7 +123,7 @@ enum class PropertyID {
|
|||
auto last_property_id = longhand_property_ids.last();
|
||||
|
||||
for (auto& name : shorthand_property_ids) {
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
|
||||
member_generator.append(R"~~~(
|
||||
|
@ -132,7 +132,7 @@ enum class PropertyID {
|
|||
}
|
||||
|
||||
for (auto& name : longhand_property_ids) {
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
|
||||
member_generator.append(R"~~~(
|
||||
|
@ -231,7 +231,7 @@ struct Traits<Web::CSS::PropertyID> : public GenericTraits<Web::CSS::PropertyID>
|
|||
|
||||
ErrorOr<void> generate_bounds_checking_function(JsonObject& properties, SourceGenerator& parent_generator, StringView css_type_name, StringView type_name, Optional<StringView> default_unit_name, Optional<StringView> value_getter)
|
||||
{
|
||||
auto generator = TRY(parent_generator.fork());
|
||||
auto generator = parent_generator.fork();
|
||||
generator.set("css_type_name", TRY(String::from_utf8(css_type_name)));
|
||||
generator.set("type_name", TRY(String::from_utf8(type_name)));
|
||||
|
||||
|
@ -249,7 +249,7 @@ bool property_accepts_@css_type_name@(PropertyID property_id, [[maybe_unused]] @
|
|||
if (type_and_range.first() != css_type_name)
|
||||
continue;
|
||||
|
||||
auto property_generator = TRY(generator.fork());
|
||||
auto property_generator = generator.fork();
|
||||
property_generator.set("property_name:titlecase", TRY(title_casify(name)));
|
||||
|
||||
property_generator.append(R"~~~(
|
||||
|
@ -345,7 +345,7 @@ Optional<PropertyID> property_id_from_camel_case_string(StringView string)
|
|||
TRY(properties.try_for_each_member([&](auto& name, auto& value) -> ErrorOr<void> {
|
||||
VERIFY(value.is_object());
|
||||
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name", TRY(String::from_deprecated_string(name)));
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
member_generator.set("name:camelcase", TRY(camel_casify(name)));
|
||||
|
@ -369,7 +369,7 @@ Optional<PropertyID> property_id_from_string(StringView string)
|
|||
TRY(properties.try_for_each_member([&](auto& name, auto& value) -> ErrorOr<void> {
|
||||
VERIFY(value.is_object());
|
||||
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name", TRY(String::from_deprecated_string(name)));
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
member_generator.append(R"~~~(
|
||||
|
@ -390,7 +390,7 @@ StringView string_from_property_id(PropertyID property_id) {
|
|||
TRY(properties.try_for_each_member([&](auto& name, auto& value) -> ErrorOr<void> {
|
||||
VERIFY(value.is_object());
|
||||
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name", TRY(String::from_deprecated_string(name)));
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
member_generator.append(R"~~~(
|
||||
|
@ -422,7 +422,7 @@ bool is_inherited_property(PropertyID property_id)
|
|||
}
|
||||
|
||||
if (inherited) {
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
member_generator.append(R"~~~(
|
||||
case PropertyID::@name:titlecase@:
|
||||
|
@ -451,7 +451,7 @@ bool property_affects_layout(PropertyID property_id)
|
|||
affects_layout = value.as_object().get_bool("affects-layout"sv).value_or(false);
|
||||
|
||||
if (affects_layout) {
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
member_generator.append(R"~~~(
|
||||
case PropertyID::@name:titlecase@:
|
||||
|
@ -480,7 +480,7 @@ bool property_affects_stacking_context(PropertyID property_id)
|
|||
affects_stacking_context = value.as_object().get_bool("affects-stacking-context"sv).value_or(false);
|
||||
|
||||
if (affects_stacking_context) {
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
member_generator.append(R"~~~(
|
||||
case PropertyID::@name:titlecase@:
|
||||
|
@ -519,7 +519,7 @@ NonnullRefPtr<StyleValue> property_initial_value(JS::Realm& context_realm, Prope
|
|||
VERIFY(initial_value.has_value());
|
||||
auto& initial_value_string = initial_value.value();
|
||||
|
||||
auto member_generator = TRY(generator.fork());
|
||||
auto member_generator = generator.fork();
|
||||
member_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
member_generator.set("initial_value_string", TRY(String::from_deprecated_string(initial_value_string)));
|
||||
member_generator.append(
|
||||
|
@ -560,7 +560,7 @@ bool property_has_quirk(PropertyID property_id, Quirk quirk)
|
|||
auto& quirks = quirks_value.value();
|
||||
|
||||
if (!quirks.is_empty()) {
|
||||
auto property_generator = TRY(generator.fork());
|
||||
auto property_generator = generator.fork();
|
||||
property_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
property_generator.append(R"~~~(
|
||||
case PropertyID::@name:titlecase@: {
|
||||
|
@ -568,7 +568,7 @@ bool property_has_quirk(PropertyID property_id, Quirk quirk)
|
|||
)~~~");
|
||||
for (auto& quirk : quirks.values()) {
|
||||
VERIFY(quirk.is_string());
|
||||
auto quirk_generator = TRY(property_generator.fork());
|
||||
auto quirk_generator = property_generator.fork();
|
||||
quirk_generator.set("quirk:titlecase", TRY(title_casify(quirk.as_string())));
|
||||
quirk_generator.append(R"~~~(
|
||||
case Quirk::@quirk:titlecase@:
|
||||
|
@ -601,7 +601,7 @@ bool property_accepts_type(PropertyID property_id, ValueType value_type)
|
|||
auto& object = value.as_object();
|
||||
if (auto maybe_valid_types = object.get_array("valid-types"sv); maybe_valid_types.has_value() && !maybe_valid_types->is_empty()) {
|
||||
auto& valid_types = maybe_valid_types.value();
|
||||
auto property_generator = TRY(generator.fork());
|
||||
auto property_generator = generator.fork();
|
||||
property_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
property_generator.append(R"~~~(
|
||||
case PropertyID::@name:titlecase@: {
|
||||
|
@ -681,7 +681,7 @@ bool property_accepts_identifier(PropertyID property_id, ValueID identifier)
|
|||
VERIFY(value.is_object());
|
||||
auto& object = value.as_object();
|
||||
|
||||
auto property_generator = TRY(generator.fork());
|
||||
auto property_generator = generator.fork();
|
||||
property_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
property_generator.appendln(" case PropertyID::@name:titlecase@: {");
|
||||
|
||||
|
@ -689,7 +689,7 @@ bool property_accepts_identifier(PropertyID property_id, ValueID identifier)
|
|||
property_generator.appendln(" switch (identifier) {");
|
||||
auto& valid_identifiers = maybe_valid_identifiers.value();
|
||||
for (auto& identifier : valid_identifiers.values()) {
|
||||
auto identifier_generator = TRY(generator.fork());
|
||||
auto identifier_generator = generator.fork();
|
||||
identifier_generator.set("identifier:titlecase", TRY(title_casify(identifier.as_string())));
|
||||
identifier_generator.appendln(" case ValueID::@identifier:titlecase@:");
|
||||
}
|
||||
|
@ -708,7 +708,7 @@ bool property_accepts_identifier(PropertyID property_id, ValueID identifier)
|
|||
if (!type_name_is_enum(type_name))
|
||||
continue;
|
||||
|
||||
auto type_generator = TRY(generator.fork());
|
||||
auto type_generator = generator.fork();
|
||||
type_generator.set("type_name:snakecase", TRY(snake_casify(type_name)));
|
||||
type_generator.append(R"~~~(
|
||||
if (value_id_to_@type_name:snakecase@(identifier).has_value())
|
||||
|
@ -736,7 +736,7 @@ Optional<ValueType> property_resolves_percentages_relative_to(PropertyID propert
|
|||
TRY(properties.try_for_each_member([&](auto& name, auto& value) -> ErrorOr<void> {
|
||||
VERIFY(value.is_object());
|
||||
if (auto resolved_type = value.as_object().get_deprecated_string("percentages-resolve-to"sv); resolved_type.has_value()) {
|
||||
auto property_generator = TRY(generator.fork());
|
||||
auto property_generator = generator.fork();
|
||||
property_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
property_generator.set("resolved_type:titlecase", TRY(title_casify(resolved_type.value())));
|
||||
property_generator.append(R"~~~(
|
||||
|
@ -763,7 +763,7 @@ size_t property_maximum_value_count(PropertyID property_id)
|
|||
if (value.as_object().has("max-values"sv)) {
|
||||
auto max_values = value.as_object().get("max-values"sv);
|
||||
VERIFY(max_values.has_value() && max_values->is_number() && !max_values->is_double());
|
||||
auto property_generator = TRY(generator.fork());
|
||||
auto property_generator = generator.fork();
|
||||
property_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
property_generator.set("max_values", TRY(String::from_deprecated_string(max_values->to_deprecated_string())));
|
||||
property_generator.append(R"~~~(
|
||||
|
@ -799,7 +799,7 @@ Vector<PropertyID> longhands_for_shorthand(PropertyID property_id)
|
|||
auto longhands = value.as_object().get("longhands"sv);
|
||||
VERIFY(longhands.has_value() && longhands->is_array());
|
||||
auto longhand_values = longhands->as_array();
|
||||
auto property_generator = TRY(generator.fork());
|
||||
auto property_generator = generator.fork();
|
||||
property_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
StringBuilder builder;
|
||||
bool first = true;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue