diff options
| author | 2022-02-21 15:10:26 -0800 | |
|---|---|---|
| committer | 2022-02-21 15:10:26 -0800 | |
| commit | 1d58a7aadd0e4521b5b99a261ab3db346106601d (patch) | |
| tree | 85590e607de0e754f5991967f2a04d75df0108b5 /src | |
| parent | f49c3416d591c127f66098e03ae2d6ed823dcb3d (diff) | |
| download | bun-1d58a7aadd0e4521b5b99a261ab3db346106601d.tar.gz bun-1d58a7aadd0e4521b5b99a261ab3db346106601d.tar.zst bun-1d58a7aadd0e4521b5b99a261ab3db346106601d.zip | |
Update javascript.zig
Diffstat (limited to 'src')
| -rw-r--r-- | src/javascript/jsc/javascript.zig | 73 | 
1 files changed, 73 insertions, 0 deletions
| diff --git a/src/javascript/jsc/javascript.zig b/src/javascript/jsc/javascript.zig index 7849ca9e9..766f9f686 100644 --- a/src/javascript/jsc/javascript.zig +++ b/src/javascript/jsc/javascript.zig @@ -1010,6 +1010,76 @@ pub const Bun = struct {          }      }; +    pub const Timer = struct { +        last_id: i32 = 0, +        warned: bool = false, + +        pub fn getNextID() callconv(.C) i32 { +            VirtualMachine.vm.timer.last_id += 1; +            return VirtualMachine.vm.timer.last_id; +        } + +        pub fn setTimeout( +            _: *JSGlobalObject, +            _: JSValue, +            _: JSValue, +        ) callconv(.C) JSValue { +            VirtualMachine.vm.timer.last_id += 1; + +            Output.prettyWarnln("setTimeout is not implemented yet", .{}); + +            // For now, we are going to straight up lie +            return JSValue.jsNumber(@intCast(i32, VirtualMachine.vm.timer.last_id)); +        } +        pub fn setInterval( +            _: *JSGlobalObject, +            _: JSValue, +            _: JSValue, +        ) callconv(.C) JSValue { +            VirtualMachine.vm.timer.last_id += 1; + +            Output.prettyWarnln("setInterval is not implemented yet", .{}); + +            // For now, we are going to straight up lie +            return JSValue.jsNumber(@intCast(i32, VirtualMachine.vm.timer.last_id)); +        } +        pub fn clearTimeout( +            _: *JSGlobalObject, +            _: JSValue, +        ) callconv(.C) JSValue { +            return JSValue.jsUndefined(); +        } +        pub fn clearInterval( +            _: *JSGlobalObject, +            _: JSValue, +        ) callconv(.C) JSValue { +            return JSValue.jsUndefined(); +        } + +        const Shimmer = @import("./bindings/shimmer.zig").Shimmer; + +        pub const shim = Shimmer("Bun", "Timer", @This()); +        pub const name = "Bun__Timer"; +        pub const include = ""; +        pub const namespace = shim.namespace; + +        pub const Export = shim.exportFunctions(.{ +            .@"setTimeout" = setTimeout, +            .@"setInterval" = setInterval, +            .@"clearTimeout" = clearTimeout, +            .@"clearInterval" = clearInterval, +            .@"getNextID" = getNextID, +        }); + +        comptime { +            @export(setTimeout, .{ .name = Export[0].symbol_name }); +            @export(setInterval, .{ .name = Export[1].symbol_name }); +            @export(clearTimeout, .{ .name = Export[2].symbol_name }); +            @export(clearInterval, .{ .name = Export[3].symbol_name }); +            @export(getNextID, .{ .name = Export[4].symbol_name }); +        } +    }; +      /// EnvironmentVariables is runtime defined.      /// Also, you can't iterate over process.env normally since it only exists at build-time otherwise      // This is aliased to Bun.env @@ -1344,6 +1414,9 @@ pub const VirtualMachine = struct {      regular_event_loop: EventLoop = EventLoop{},      event_loop: *EventLoop = undefined, +    is_set_timeout_enabled: bool = false, +    is_set_interval_enabled: bool = false, +      pub inline fn eventLoop(this: *VirtualMachine) *EventLoop {          return this.event_loop;      } | 
