Move HTMLElements to generated union

Signed-off-by: Francis Bouvier <francis.bouvier@gmail.com>
This commit is contained in:
Francis Bouvier
2023-05-18 17:36:31 +02:00
parent 12b840b3d5
commit fdafd96003

View File

@@ -1,4 +1,5 @@
const parser = @import("../parser.zig"); const parser = @import("../parser.zig");
const generate = @import("../generate.zig");
const Element = @import("../dom/element.zig").Element; const Element = @import("../dom/element.zig").Element;
@@ -15,132 +16,74 @@ pub const HTMLElement = struct {
} }
}; };
const HTMLElementsTags = enum { const HTMLElementsTypes = .{
unknown, HTMLUnknownElement,
anchor, HTMLAnchorElement,
area, HTMLAreaElement,
audio, HTMLAudioElement,
br, HTMLBRElement,
base, HTMLBaseElement,
body, HTMLBodyElement,
button, HTMLButtonElement,
canvas, HTMLCanvasElement,
dlist, HTMLDListElement,
dialog, HTMLDialogElement,
data, HTMLDataElement,
div, HTMLDivElement,
embed, HTMLEmbedElement,
fieldset, HTMLFieldSetElement,
form, HTMLFormElement,
frameset, HTMLFrameSetElement,
hr, HTMLHRElement,
head, HTMLHeadElement,
heading, HTMLHeadingElement,
html, HTMLHtmlElement,
iframe, HTMLIFrameElement,
img, HTMLImageElement,
input, HTMLInputElement,
li, HTMLLIElement,
label, HTMLLabelElement,
legend, HTMLLegendElement,
link, HTMLLinkElement,
map, HTMLMapElement,
meta, HTMLMetaElement,
meter, HTMLMeterElement,
mod, HTMLModElement,
olist, HTMLOListElement,
object, HTMLObjectElement,
optgroup, HTMLOptGroupElement,
option, HTMLOptionElement,
output, HTMLOutputElement,
paragraph, HTMLParagraphElement,
picture, HTMLPictureElement,
pre, HTMLPreElement,
progress, HTMLProgressElement,
quote, HTMLQuoteElement,
script, HTMLScriptElement,
select, HTMLSelectElement,
source, HTMLSourceElement,
span, HTMLSpanElement,
style, HTMLStyleElement,
table, HTMLTableElement,
tablecaption, HTMLTableCaptionElement,
tablecell, HTMLTableCellElement,
tablecol, HTMLTableColElement,
tablerow, HTMLTableRowElement,
tablesection, HTMLTableSectionElement,
template, HTMLTemplateElement,
textarea, HTMLTextAreaElement,
time, HTMLTimeElement,
title, HTMLTitleElement,
track, HTMLTrackElement,
ulist, HTMLUListElement,
video, HTMLVideoElement,
};
// TODO: generate comptime?
pub const HTMLElements = union(HTMLElementsTags) {
unknown: HTMLUnknownElement,
anchor: HTMLAnchorElement,
area: HTMLAreaElement,
audio: HTMLAudioElement,
br: HTMLBRElement,
base: HTMLBaseElement,
body: HTMLBodyElement,
button: HTMLButtonElement,
canvas: HTMLCanvasElement,
dlist: HTMLDListElement,
dialog: HTMLDialogElement,
data: HTMLDataElement,
div: HTMLDivElement,
embed: HTMLEmbedElement,
fieldset: HTMLFieldSetElement,
form: HTMLFormElement,
frameset: HTMLFrameSetElement,
hr: HTMLHRElement,
head: HTMLHeadElement,
heading: HTMLHeadingElement,
html: HTMLHtmlElement,
iframe: HTMLIFrameElement,
img: HTMLImageElement,
input: HTMLInputElement,
li: HTMLLIElement,
label: HTMLLabelElement,
legend: HTMLLegendElement,
link: HTMLLinkElement,
map: HTMLMapElement,
meta: HTMLMetaElement,
meter: HTMLMeterElement,
mod: HTMLModElement,
olist: HTMLOListElement,
object: HTMLObjectElement,
optgroup: HTMLOptGroupElement,
option: HTMLOptionElement,
output: HTMLOutputElement,
paragraph: HTMLParagraphElement,
picture: HTMLPictureElement,
pre: HTMLPreElement,
progress: HTMLProgressElement,
quote: HTMLQuoteElement,
script: HTMLScriptElement,
select: HTMLSelectElement,
source: HTMLSourceElement,
span: HTMLSpanElement,
style: HTMLStyleElement,
table: HTMLTableElement,
tablecaption: HTMLTableCaptionElement,
tablecell: HTMLTableCellElement,
tablecol: HTMLTableColElement,
tablerow: HTMLTableRowElement,
tablesection: HTMLTableSectionElement,
template: HTMLTemplateElement,
textarea: HTMLTextAreaElement,
time: HTMLTimeElement,
title: HTMLTitleElement,
track: HTMLTrackElement,
ulist: HTMLUListElement,
video: HTMLVideoElement,
}; };
fn generateElements() generate.Union {
return generate.Union.compile(HTMLElementsTypes);
}
const HTMLElementsGenerated = generateElements();
pub const HTMLElements = HTMLElementsGenerated._union;
pub const HTMLElementsTags = HTMLElementsGenerated._enum;
// Deprecated HTMLElements in Chrome (2023/03/15) // Deprecated HTMLElements in Chrome (2023/03/15)
// HTMLContentelement // HTMLContentelement
@@ -765,65 +708,65 @@ pub const HTMLVideoElement = struct {
pub fn ElementToHTMLElementInterface(base: *parser.Element) HTMLElements { pub fn ElementToHTMLElementInterface(base: *parser.Element) HTMLElements {
const tag = parser.nodeTag(parser.elementNode(base)); const tag = parser.nodeTag(parser.elementNode(base));
return switch (tag) { return switch (tag) {
.a => .{ .anchor = HTMLAnchorElement.init(base) }, .a => .{ .HTMLAnchorElement = HTMLAnchorElement.init(base) },
.area => .{ .area = HTMLAreaElement.init(base) }, .area => .{ .HTMLAreaElement = HTMLAreaElement.init(base) },
.audio => .{ .audio = HTMLAudioElement.init(base) }, .audio => .{ .HTMLAudioElement = HTMLAudioElement.init(base) },
.br => .{ .br = HTMLBRElement.init(base) }, .br => .{ .HTMLBRElement = HTMLBRElement.init(base) },
.base => .{ .base = HTMLBaseElement.init(base) }, .base => .{ .HTMLBaseElement = HTMLBaseElement.init(base) },
.body => .{ .body = HTMLBodyElement.init(base) }, .body => .{ .HTMLBodyElement = HTMLBodyElement.init(base) },
.button => .{ .button = HTMLButtonElement.init(base) }, .button => .{ .HTMLButtonElement = HTMLButtonElement.init(base) },
.canvas => .{ .canvas = HTMLCanvasElement.init(base) }, .canvas => .{ .HTMLCanvasElement = HTMLCanvasElement.init(base) },
.dl => .{ .dlist = HTMLDListElement.init(base) }, .dl => .{ .HTMLDListElement = HTMLDListElement.init(base) },
.dialog => .{ .dialog = HTMLDialogElement.init(base) }, .dialog => .{ .HTMLDialogElement = HTMLDialogElement.init(base) },
.data => .{ .data = HTMLDataElement.init(base) }, .data => .{ .HTMLDataElement = HTMLDataElement.init(base) },
.div => .{ .div = HTMLDivElement.init(base) }, .div => .{ .HTMLDivElement = HTMLDivElement.init(base) },
.embed => .{ .embed = HTMLEmbedElement.init(base) }, .embed => .{ .HTMLEmbedElement = HTMLEmbedElement.init(base) },
.fieldset => .{ .fieldset = HTMLFieldSetElement.init(base) }, .fieldset => .{ .HTMLFieldSetElement = HTMLFieldSetElement.init(base) },
.form => .{ .form = HTMLFormElement.init(base) }, .form => .{ .HTMLFormElement = HTMLFormElement.init(base) },
.frameset => .{ .frameset = HTMLFrameSetElement.init(base) }, .frameset => .{ .HTMLFrameSetElement = HTMLFrameSetElement.init(base) },
.hr => .{ .hr = HTMLHRElement.init(base) }, .hr => .{ .HTMLHRElement = HTMLHRElement.init(base) },
.head => .{ .head = HTMLHeadElement.init(base) }, .head => .{ .HTMLHeadElement = HTMLHeadElement.init(base) },
.h1, .h2, .h3, .h4, .h5, .h6 => .{ .heading = HTMLHeadingElement.init(base) }, .h1, .h2, .h3, .h4, .h5, .h6 => .{ .HTMLHeadingElement = HTMLHeadingElement.init(base) },
.html => .{ .html = HTMLHtmlElement.init(base) }, .html => .{ .HTMLHtmlElement = HTMLHtmlElement.init(base) },
.iframe => .{ .iframe = HTMLIFrameElement.init(base) }, .iframe => .{ .HTMLIFrameElement = HTMLIFrameElement.init(base) },
.img => .{ .img = HTMLImageElement.init(base) }, .img => .{ .HTMLImageElement = HTMLImageElement.init(base) },
.input => .{ .input = HTMLInputElement.init(base) }, .input => .{ .HTMLInputElement = HTMLInputElement.init(base) },
.li => .{ .li = HTMLLIElement.init(base) }, .li => .{ .HTMLLIElement = HTMLLIElement.init(base) },
.label => .{ .label = HTMLLabelElement.init(base) }, .label => .{ .HTMLLabelElement = HTMLLabelElement.init(base) },
.legend => .{ .legend = HTMLLegendElement.init(base) }, .legend => .{ .HTMLLegendElement = HTMLLegendElement.init(base) },
.link => .{ .link = HTMLLinkElement.init(base) }, .link => .{ .HTMLLinkElement = HTMLLinkElement.init(base) },
.map => .{ .map = HTMLMapElement.init(base) }, .map => .{ .HTMLMapElement = HTMLMapElement.init(base) },
.meta => .{ .meta = HTMLMetaElement.init(base) }, .meta => .{ .HTMLMetaElement = HTMLMetaElement.init(base) },
.meter => .{ .meter = HTMLMeterElement.init(base) }, .meter => .{ .HTMLMeterElement = HTMLMeterElement.init(base) },
.ins, .del => .{ .mod = HTMLModElement.init(base) }, .ins, .del => .{ .HTMLModElement = HTMLModElement.init(base) },
.ol => .{ .olist = HTMLOListElement.init(base) }, .ol => .{ .HTMLOListElement = HTMLOListElement.init(base) },
.object => .{ .object = HTMLObjectElement.init(base) }, .object => .{ .HTMLObjectElement = HTMLObjectElement.init(base) },
.optgroup => .{ .optgroup = HTMLOptGroupElement.init(base) }, .optgroup => .{ .HTMLOptGroupElement = HTMLOptGroupElement.init(base) },
.option => .{ .option = HTMLOptionElement.init(base) }, .option => .{ .HTMLOptionElement = HTMLOptionElement.init(base) },
.output => .{ .output = HTMLOutputElement.init(base) }, .output => .{ .HTMLOutputElement = HTMLOutputElement.init(base) },
.p => .{ .paragraph = HTMLParagraphElement.init(base) }, .p => .{ .HTMLParagraphElement = HTMLParagraphElement.init(base) },
.picture => .{ .picture = HTMLPictureElement.init(base) }, .picture => .{ .HTMLPictureElement = HTMLPictureElement.init(base) },
.pre => .{ .pre = HTMLPreElement.init(base) }, .pre => .{ .HTMLPreElement = HTMLPreElement.init(base) },
.progress => .{ .progress = HTMLProgressElement.init(base) }, .progress => .{ .HTMLProgressElement = HTMLProgressElement.init(base) },
.blockquote, .q => .{ .quote = HTMLQuoteElement.init(base) }, .blockquote, .q => .{ .HTMLQuoteElement = HTMLQuoteElement.init(base) },
.script => .{ .script = HTMLScriptElement.init(base) }, .script => .{ .HTMLScriptElement = HTMLScriptElement.init(base) },
.select => .{ .select = HTMLSelectElement.init(base) }, .select => .{ .HTMLSelectElement = HTMLSelectElement.init(base) },
.source => .{ .source = HTMLSourceElement.init(base) }, .source => .{ .HTMLSourceElement = HTMLSourceElement.init(base) },
.span => .{ .span = HTMLSpanElement.init(base) }, .span => .{ .HTMLSpanElement = HTMLSpanElement.init(base) },
.style => .{ .style = HTMLStyleElement.init(base) }, .style => .{ .HTMLStyleElement = HTMLStyleElement.init(base) },
.table => .{ .table = HTMLTableElement.init(base) }, .table => .{ .HTMLTableElement = HTMLTableElement.init(base) },
.caption => .{ .tablecaption = HTMLTableCaptionElement.init(base) }, .caption => .{ .HTMLTableCaptionElement = HTMLTableCaptionElement.init(base) },
.th, .td => .{ .tablecell = HTMLTableCellElement.init(base) }, .th, .td => .{ .HTMLTableCellElement = HTMLTableCellElement.init(base) },
.col => .{ .tablecol = HTMLTableColElement.init(base) }, .col => .{ .HTMLTableColElement = HTMLTableColElement.init(base) },
.tr => .{ .tablerow = HTMLTableRowElement.init(base) }, .tr => .{ .HTMLTableRowElement = HTMLTableRowElement.init(base) },
.thead, .tbody, .tfoot => .{ .tablesection = HTMLTableSectionElement.init(base) }, .thead, .tbody, .tfoot => .{ .HTMLTableSectionElement = HTMLTableSectionElement.init(base) },
.template => .{ .template = HTMLTemplateElement.init(base) }, .template => .{ .HTMLTemplateElement = HTMLTemplateElement.init(base) },
.textarea => .{ .textarea = HTMLTextAreaElement.init(base) }, .textarea => .{ .HTMLTextAreaElement = HTMLTextAreaElement.init(base) },
.time => .{ .time = HTMLTimeElement.init(base) }, .time => .{ .HTMLTimeElement = HTMLTimeElement.init(base) },
.title => .{ .title = HTMLTitleElement.init(base) }, .title => .{ .HTMLTitleElement = HTMLTitleElement.init(base) },
.track => .{ .track = HTMLTrackElement.init(base) }, .track => .{ .HTMLTrackElement = HTMLTrackElement.init(base) },
.ul => .{ .ulist = HTMLUListElement.init(base) }, .ul => .{ .HTMLUListElement = HTMLUListElement.init(base) },
.video => .{ .video = HTMLVideoElement.init(base) }, .video => .{ .HTMLVideoElement = HTMLVideoElement.init(base) },
.undef => .{ .unknown = HTMLUnknownElement.init(base) }, .undef => .{ .HTMLUnknownElement = HTMLUnknownElement.init(base) },
}; };
} }