mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 07:38:10 +00:00
AK: Make SourceGenerator::set() infallible
This commit is contained in:
parent
3d5728ef57
commit
8b936b5912
11 changed files with 141 additions and 142 deletions
|
@ -59,19 +59,19 @@ enum class ValueID;
|
|||
auto& members = value.as_array();
|
||||
|
||||
auto enum_generator = TRY(generator.fork());
|
||||
TRY(enum_generator.set("name:titlecase", TRY(title_casify(name))));
|
||||
TRY(enum_generator.set("name:snakecase", TRY(snake_casify(name))));
|
||||
enum_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
enum_generator.set("name:snakecase", TRY(snake_casify(name)));
|
||||
|
||||
// Find the smallest possible type to use.
|
||||
auto member_max_value = members.size() - 1;
|
||||
if (NumericLimits<u8>::max() >= member_max_value) {
|
||||
TRY(enum_generator.set("enum_type", "u8"_string));
|
||||
enum_generator.set("enum_type", "u8"_string);
|
||||
} else if (NumericLimits<u16>::max() >= member_max_value) {
|
||||
TRY(enum_generator.set("enum_type", "u16"_string));
|
||||
enum_generator.set("enum_type", "u16"_string);
|
||||
} else if (NumericLimits<u32>::max() >= member_max_value) {
|
||||
TRY(enum_generator.set("enum_type", "u32"_string));
|
||||
enum_generator.set("enum_type", "u32"_string);
|
||||
} else {
|
||||
TRY(enum_generator.set("enum_type", "u64"_string));
|
||||
enum_generator.set("enum_type", "u64"_string);
|
||||
}
|
||||
|
||||
TRY(enum_generator.try_appendln("enum class @name:titlecase@ : @enum_type@ {"));
|
||||
|
@ -82,7 +82,7 @@ enum class ValueID;
|
|||
if (member_name.contains('='))
|
||||
continue;
|
||||
auto member_generator = TRY(enum_generator.fork());
|
||||
TRY(member_generator.set("member:titlecase", TRY(title_casify(member_name))));
|
||||
member_generator.set("member:titlecase", TRY(title_casify(member_name)));
|
||||
TRY(member_generator.try_appendln(" @member:titlecase@,"));
|
||||
}
|
||||
|
||||
|
@ -117,8 +117,8 @@ namespace Web::CSS {
|
|||
auto& members = value.as_array();
|
||||
|
||||
auto enum_generator = TRY(generator.fork());
|
||||
TRY(enum_generator.set("name:titlecase", TRY(title_casify(name))));
|
||||
TRY(enum_generator.set("name:snakecase", TRY(snake_casify(name))));
|
||||
enum_generator.set("name:titlecase", TRY(title_casify(name)));
|
||||
enum_generator.set("name:snakecase", TRY(snake_casify(name)));
|
||||
|
||||
TRY(enum_generator.try_append(R"~~~(
|
||||
Optional<@name:titlecase@> value_id_to_@name:snakecase@(ValueID value_id)
|
||||
|
@ -130,11 +130,11 @@ Optional<@name:titlecase@> value_id_to_@name:snakecase@(ValueID value_id)
|
|||
auto member_name = member.to_deprecated_string();
|
||||
if (member_name.contains('=')) {
|
||||
auto parts = member_name.split_view('=');
|
||||
TRY(member_generator.set("valueid:titlecase", TRY(title_casify(parts[0]))));
|
||||
TRY(member_generator.set("member:titlecase", TRY(title_casify(parts[1]))));
|
||||
member_generator.set("valueid:titlecase", TRY(title_casify(parts[0])));
|
||||
member_generator.set("member:titlecase", TRY(title_casify(parts[1])));
|
||||
} else {
|
||||
TRY(member_generator.set("valueid:titlecase", TRY(title_casify(member_name))));
|
||||
TRY(member_generator.set("member:titlecase", TRY(title_casify(member_name))));
|
||||
member_generator.set("valueid:titlecase", TRY(title_casify(member_name)));
|
||||
member_generator.set("member:titlecase", TRY(title_casify(member_name)));
|
||||
}
|
||||
TRY(member_generator.try_append(R"~~~(
|
||||
case ValueID::@valueid:titlecase@:
|
||||
|
@ -158,7 +158,7 @@ ValueID to_value_id(@name:titlecase@ @name:snakecase@_value)
|
|||
auto member_name = member.to_deprecated_string();
|
||||
if (member_name.contains('='))
|
||||
continue;
|
||||
TRY(member_generator.set("member:titlecase", TRY(title_casify(member_name))));
|
||||
member_generator.set("member:titlecase", TRY(title_casify(member_name)));
|
||||
|
||||
TRY(member_generator.try_append(R"~~~(
|
||||
case @name:titlecase@::@member:titlecase@:
|
||||
|
@ -182,8 +182,8 @@ StringView to_string(@name:titlecase@ value)
|
|||
auto member_name = member.to_deprecated_string();
|
||||
if (member_name.contains('='))
|
||||
continue;
|
||||
TRY(member_generator.set("member:css", TRY(String::from_deprecated_string(member_name))));
|
||||
TRY(member_generator.set("member:titlecase", TRY(title_casify(member_name))));
|
||||
member_generator.set("member:css", TRY(String::from_deprecated_string(member_name)));
|
||||
member_generator.set("member:titlecase", TRY(title_casify(member_name)));
|
||||
|
||||
TRY(member_generator.try_append(R"~~~(
|
||||
case @name:titlecase@::@member:titlecase@:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue