/* * Copyright (c) 2018-2020, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include #include #include #include static String title_casify(const String& dashy_name) { auto parts = dashy_name.split('-'); StringBuilder builder; for (auto& part : parts) { if (part.is_empty()) continue; builder.append(toupper(part[0])); if (part.length() == 1) continue; builder.append(part.substring_view(1, part.length() - 1)); } return builder.to_string(); } int main(int argc, char** argv) { if (argc != 2) { warnln("usage: {} ", argv[0]); return 1; } auto file = Core::File::construct(argv[1]); if (!file->open(Core::IODevice::ReadOnly)) return 1; auto json = JsonValue::from_string(file->read_all()); VERIFY(json.has_value()); VERIFY(json.value().is_object()); StringBuilder builder; SourceGenerator generator { builder }; generator.append(R"~~~( #pragma once #include #include namespace Web::CSS { enum class PropertyID { Invalid, )~~~"); json.value().as_object().for_each_member([&](auto& name, auto& value) { VERIFY(value.is_object()); auto member_generator = generator.fork(); member_generator.set("name:titlecase", title_casify(name)); member_generator.append(R"~~~( @name:titlecase@, )~~~"); }); generator.append(R"~~~( }; PropertyID property_id_from_string(const StringView&); const char* string_from_property_id(PropertyID); bool is_pseudo_property(PropertyID); } // namespace Web::CSS namespace AK { template<> struct Traits : public GenericTraits { static unsigned hash(Web::CSS::PropertyID property_id) { return int_hash((unsigned)property_id); } }; } // namespace AK )~~~"); outln("{}", generator.as_string_view()); }