AK: Remove fallible SourceGenerator::try_append()

And fall back to the infallible append().
This commit is contained in:
Andreas Kling 2023-08-21 16:39:43 +02:00
parent a1d694ccdc
commit 244516142a
Notes: sideshowbarker 2024-07-16 20:39:14 +09:00
9 changed files with 293 additions and 297 deletions

View file

@ -44,7 +44,7 @@ ErrorOr<void> generate_header_file(JsonObject& easing_data, Core::File& file)
StringBuilder builder;
SourceGenerator generator { builder };
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
#pragma once
#include <AK/Optional.h>
@ -53,7 +53,7 @@ ErrorOr<void> generate_header_file(JsonObject& easing_data, Core::File& file)
namespace Web::CSS {
)~~~"));
)~~~");
generator.appendln("enum class EasingFunction {");
TRY(easing_data.try_for_each_member([&](auto& name, auto&) -> ErrorOr<void> {
@ -67,7 +67,7 @@ namespace Web::CSS {
generator.appendln("Optional<EasingFunction> easing_function_from_string(StringView);");
generator.appendln("StringView to_string(EasingFunction);");
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
enum class EasingFunctionParameterType {
Integer,
Number,
@ -84,7 +84,7 @@ struct EasingFunctionMetadata {
Vector<EasingFunctionParameter> parameters;
};
EasingFunctionMetadata easing_function_metadata(EasingFunction);
)~~~"));
)~~~");
generator.appendln("\n}");
@ -97,68 +97,68 @@ ErrorOr<void> generate_implementation_file(JsonObject& easing_data, Core::File&
StringBuilder builder;
SourceGenerator generator { builder };
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
#include <LibWeb/CSS/EasingFunctions.h>
#include <AK/Assertions.h>
namespace Web::CSS {
)~~~"));
)~~~");
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
Optional<EasingFunction> easing_function_from_string(StringView name)
{
)~~~"));
)~~~");
TRY(easing_data.try_for_each_member([&](auto& name, auto&) -> ErrorOr<void> {
auto member_generator = TRY(generator.fork());
member_generator.set("name", TRY(String::from_deprecated_string(name)));
member_generator.set("name:titlecase", TRY(title_casify(name)));
TRY(member_generator.try_append(R"~~~(
member_generator.append(R"~~~(
if (name.equals_ignoring_ascii_case("@name@"sv))
return EasingFunction::@name:titlecase@;
)~~~"));
)~~~");
return {};
}));
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
return {};
}
)~~~"));
)~~~");
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
StringView to_string(EasingFunction easing_function)
{
switch (easing_function) {
)~~~"));
)~~~");
TRY(easing_data.try_for_each_member([&](auto& name, auto&) -> ErrorOr<void> {
auto member_generator = TRY(generator.fork());
member_generator.set("name", TRY(String::from_deprecated_string(name)));
member_generator.set("name:titlecase", TRY(title_casify(name)));
TRY(member_generator.try_append(R"~~~(
member_generator.append(R"~~~(
case EasingFunction::@name:titlecase@:
return "@name@"sv;
)~~~"));
)~~~");
return {};
}));
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
default:
VERIFY_NOT_REACHED();
}
}
)~~~"));
)~~~");
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
EasingFunctionMetadata easing_function_metadata(EasingFunction easing_function)
{
switch (easing_function) {
)~~~"));
)~~~");
TRY(easing_data.try_for_each_member([&](auto& name, auto& value) -> ErrorOr<void> {
VERIFY(value.is_object());
auto member_generator = TRY(generator.fork());
member_generator.set("name:titlecase", TRY(title_casify(name)));
TRY(member_generator.try_append(R"~~~(
member_generator.append(R"~~~(
case EasingFunction::@name:titlecase@:
return EasingFunctionMetadata {
.parameters = {)~~~"));
.parameters = {)~~~");
if (auto parameters = value.as_object().get_array("parameters"sv); parameters.has_value()) {
bool first = true;
@ -189,28 +189,28 @@ EasingFunctionMetadata easing_function_metadata(EasingFunction easing_function)
else
VERIFY_NOT_REACHED();
TRY(member_generator.try_append(first ? " "sv : ", "sv));
member_generator.append(first ? " "sv : ", "sv);
first = false;
TRY(member_generator.try_append(TRY(String::formatted(
member_generator.append(TRY(String::formatted(
"{{ EasingFunctionParameterType::{}, {} }}",
parameter_type,
is_optional ? "true"sv : "false"sv))));
is_optional ? "true"sv : "false"sv)));
return {};
}));
}
TRY(member_generator.try_append(R"~~~( }
member_generator.append(R"~~~( }
};
)~~~"));
)~~~");
return {};
}));
TRY(generator.try_append(R"~~~(
generator.append(R"~~~(
default:
VERIFY_NOT_REACHED();
}
}
)~~~"));
)~~~");
generator.appendln("\n}");