From b05e08e6a835424df273b70dba85f75b0c9504cd Mon Sep 17 00:00:00 2001 From: Francis Bouvier Date: Mon, 9 Oct 2023 16:27:40 +0200 Subject: [PATCH] text: add splitText method Signed-off-by: Francis Bouvier --- src/dom/text.zig | 15 +++++++++++++++ src/netsurf.zig | 6 ++++++ 2 files changed, 21 insertions(+) diff --git a/src/dom/text.zig b/src/dom/text.zig index 89773a35..cb69e93a 100644 --- a/src/dom/text.zig +++ b/src/dom/text.zig @@ -21,6 +21,13 @@ pub const Text = struct { pub fn get_wholeText(self: *parser.Text) []const u8 { return parser.textWholdeText(self); } + + // JS methods + // ---------- + + pub fn _splitText(self: *parser.Text, offset: u32) *parser.Text { + return parser.textSplitText(self, offset); + } }; // Tests @@ -36,4 +43,12 @@ pub fn testExecFn( .{ .src = "text.wholeText === 'OK'", .ex = "true" }, }; try checkCases(js_env, &get_whole_text); + + var split_text = [_]Case{ + .{ .src = "text.data = 'OK modified'", .ex = "OK modified" }, + .{ .src = "let split = text.splitText('OK'.length)", .ex = "undefined" }, + .{ .src = "split.data === ' modified'", .ex = "true" }, + .{ .src = "text.data === 'OK'", .ex = "true" }, + }; + try checkCases(js_env, &split_text); } diff --git a/src/netsurf.zig b/src/netsurf.zig index d11b043d..42d61fed 100644 --- a/src/netsurf.zig +++ b/src/netsurf.zig @@ -513,6 +513,12 @@ pub fn textWholdeText(text: *Text) []const u8 { return stringToData(s.?); } +pub fn textSplitText(text: *Text, offset: u32) *Text { + var res: ?*Text = undefined; + _ = textVtable(text).dom_text_split_text.?(text, offset, &res); + return res.?; +} + // Comment pub const Comment = c.dom_comment;