diff --git a/src/bun.js/ConsoleObject.zig b/src/bun.js/ConsoleObject.zig index 185924190a7922..58141dec839b21 100644 --- a/src/bun.js/ConsoleObject.zig +++ b/src/bun.js/ConsoleObject.zig @@ -1118,7 +1118,7 @@ pub const Formatter = struct { // Is this a react element? if (js_type.isObject()) { - if (value.get(globalThis, "$$typeof")) |typeof_symbol| { + if (value.getOwnTruthy(globalThis, "$$typeof")) |typeof_symbol| { var reactElement = ZigString.init("react.element"); var react_fragment = ZigString.init("react.fragment"); diff --git a/src/bun.js/api/BunObject.zig b/src/bun.js/api/BunObject.zig index 064396593c8572..12aff1d40d562b 100644 --- a/src/bun.js/api/BunObject.zig +++ b/src/bun.js/api/BunObject.zig @@ -475,11 +475,11 @@ pub fn braces( if (arguments.nextEat()) |opts_val| { if (opts_val.isObject()) { if (comptime bun.Environment.allow_assert) { - if (opts_val.getTruthy(globalThis, "tokenize")) |tokenize_val| { + if (opts_val.getOwnTruthy(globalThis, "tokenize")) |tokenize_val| { tokenize = if (tokenize_val.isBoolean()) tokenize_val.asBoolean() else false; } - if (opts_val.getTruthy(globalThis, "parse")) |tokenize_val| { + if (opts_val.getOwnTruthy(globalThis, "parse")) |tokenize_val| { parse = if (tokenize_val.isBoolean()) tokenize_val.asBoolean() else false; } } @@ -607,11 +607,11 @@ pub fn which( if (arguments.nextEat()) |arg| { if (!arg.isEmptyOrUndefinedOrNull() and arg.isObject()) { - if (arg.get(globalThis, "PATH")) |str_| { + if (arg.getOwn(globalThis, "PATH")) |str_| { path_str = str_.toSlice(globalThis, globalThis.bunVM().allocator); } - if (arg.get(globalThis, "cwd")) |str_| { + if (arg.getOwn(globalThis, "cwd")) |str_| { cwd_str = str_.toSlice(globalThis, globalThis.bunVM().allocator); } } @@ -660,7 +660,7 @@ pub fn inspect( const arg1 = arguments[1]; if (arg1.isObject()) { - if (arg1.getTruthy(globalThis, "depth")) |opt| { + if (arg1.getOwnTruthy(globalThis, "depth")) |opt| { if (opt.isInt32()) { const arg = opt.toInt32(); if (arg < 0) { @@ -932,7 +932,7 @@ pub fn openInEditor( if (arguments.nextEat()) |opts| { if (!opts.isUndefinedOrNull()) { - if (opts.getTruthy(globalThis, "editor")) |editor_val| { + if (opts.getOwnTruthy(globalThis, "editor")) |editor_val| { var sliced = editor_val.toSlice(globalThis, arguments.arena.allocator()); const prev_name = edit.name; @@ -952,11 +952,11 @@ pub fn openInEditor( } } - if (opts.getTruthy(globalThis, "line")) |line_| { + if (opts.getOwnTruthy(globalThis, "line")) |line_| { line = line_.toSlice(globalThis, arguments.arena.allocator()).slice(); } - if (opts.getTruthy(globalThis, "column")) |column_| { + if (opts.getOwnTruthy(globalThis, "column")) |column_| { column = column_.toSlice(globalThis, arguments.arena.allocator()).slice(); } } @@ -1828,7 +1828,7 @@ pub const Crypto = struct { pub fn fromJS(globalObject: *JSC.JSGlobalObject, value: JSC.JSValue) ?Value { if (value.isObject()) { - if (value.getTruthy(globalObject, "algorithm")) |algorithm_value| { + if (value.getOwnTruthy(globalObject, "algorithm")) |algorithm_value| { if (!algorithm_value.isString()) { globalObject.throwInvalidArgumentType("hash", "algorithm", "string"); return null; @@ -1845,7 +1845,7 @@ pub const Crypto = struct { .bcrypt = PasswordObject.Algorithm.Value.bcrpyt_default, }; - if (value.getTruthy(globalObject, "cost")) |rounds_value| { + if (value.getOwnTruthy(globalObject, "cost")) |rounds_value| { if (!rounds_value.isNumber()) { globalObject.throwInvalidArgumentType("hash", "cost", "number"); return null; @@ -1866,7 +1866,7 @@ pub const Crypto = struct { inline .argon2id, .argon2d, .argon2i => |tag| { var argon = Algorithm.Argon2Params{}; - if (value.getTruthy(globalObject, "timeCost")) |time_value| { + if (value.getOwnTruthy(globalObject, "timeCost")) |time_value| { if (!time_value.isNumber()) { globalObject.throwInvalidArgumentType("hash", "timeCost", "number"); return null; @@ -1882,7 +1882,7 @@ pub const Crypto = struct { argon.time_cost = @as(u32, @intCast(time_cost)); } - if (value.getTruthy(globalObject, "memoryCost")) |memory_value| { + if (value.getOwnTruthy(globalObject, "memoryCost")) |memory_value| { if (!memory_value.isNumber()) { globalObject.throwInvalidArgumentType("hash", "memoryCost", "number"); return null; @@ -4610,11 +4610,11 @@ fn stringWidth(globalObject: *JSC.JSGlobalObject, callframe: *JSC.CallFrame) JSC var ambiguous_as_wide = false; if (options_object.isObject()) { - if (options_object.getTruthy(globalObject, "countAnsiEscapeCodes")) |count_ansi_escapes_value| { + if (options_object.getOwnTruthy(globalObject, "countAnsiEscapeCodes")) |count_ansi_escapes_value| { if (count_ansi_escapes_value.isBoolean()) count_ansi_escapes = count_ansi_escapes_value.toBoolean(); } - if (options_object.getTruthy(globalObject, "ambiguousIsNarrow")) |ambiguous_is_narrow| { + if (options_object.getOwnTruthy(globalObject, "ambiguousIsNarrow")) |ambiguous_is_narrow| { if (ambiguous_is_narrow.isBoolean()) ambiguous_as_wide = !ambiguous_is_narrow.toBoolean(); } @@ -4795,7 +4795,7 @@ pub const JSZlib = struct { library = .zlib; } - if (options_val.getTruthy(globalThis, "library")) |library_value| { + if (options_val.getOwnTruthy(globalThis, "library")) |library_value| { if (!library_value.isString()) { globalThis.throwInvalidArguments("Expected library to be a string", .{}); return .zero; @@ -4922,7 +4922,7 @@ pub const JSZlib = struct { library = .zlib; } - if (options_val.getTruthy(globalThis, "library")) |library_value| { + if (options_val.getOwnTruthy(globalThis, "library")) |library_value| { if (!library_value.isString()) { globalThis.throwInvalidArguments("Expected library to be a string", .{}); return .zero; diff --git a/src/bun.js/api/JSBundler.zig b/src/bun.js/api/JSBundler.zig index 4e65c306637821..fa179b8b3c5a38 100644 --- a/src/bun.js/api/JSBundler.zig +++ b/src/bun.js/api/JSBundler.zig @@ -100,8 +100,8 @@ pub const JSBundler = struct { globalThis.throwInvalidArguments("Expected plugin to be an object", .{}); return error.JSError; } - if (try plugin.getObject(globalThis, "SECRET_SERVER_COMPONENTS_INTERNALS")) |internals| { - if (internals.get(globalThis, "router")) |router_value| { + if (try plugin.getOwnObject(globalThis, "SECRET_SERVER_COMPONENTS_INTERNALS")) |internals| { + if (internals.getOwn(globalThis, "router")) |router_value| { if (router_value.as(JSC.API.FileSystemRouter) != null) { this.server_components.router.set(globalThis, router_value); } else { @@ -110,7 +110,7 @@ pub const JSBundler = struct { } } - const directive_object = (try internals.getObject(globalThis, "directive")) orelse { + const directive_object = (try internals.getOwnObject(globalThis, "directive")) orelse { globalThis.throwInvalidArguments("Expected directive to be an object", .{}); return error.JSError; }; @@ -154,7 +154,7 @@ pub const JSBundler = struct { // }; // defer decl.deinit(); - if (plugin.getOptional(globalThis, "name", ZigString.Slice) catch null) |slice| { + if (plugin.getOwnOptional(globalThis, "name", ZigString.Slice) catch null) |slice| { defer slice.deinit(); if (slice.len == 0) { globalThis.throwInvalidArguments("Expected plugin to have a non-empty name", .{}); @@ -198,24 +198,24 @@ pub const JSBundler = struct { } } - if (config.getTruthy(globalThis, "macros")) |macros_flag| { + if (config.getOwnTruthy(globalThis, "macros")) |macros_flag| { if (!macros_flag.coerce(bool, globalThis)) { this.no_macros = true; } } - if (try config.getOptionalEnum(globalThis, "target", options.Target)) |target| { + if (try config.getOwnOptionalEnum(globalThis, "target", options.Target)) |target| { this.target = target; } var has_out_dir = false; - if (try config.getOptional(globalThis, "outdir", ZigString.Slice)) |slice| { + if (try config.getOwnOptional(globalThis, "outdir", ZigString.Slice)) |slice| { defer slice.deinit(); try this.outdir.appendSliceExact(slice.slice()); has_out_dir = true; } - if (config.getTruthy(globalThis, "sourcemap")) |source_map_js| { + if (config.getOwnTruthy(globalThis, "sourcemap")) |source_map_js| { if (bun.FeatureFlags.breaking_changes_1_2 and config.isBoolean()) { if (source_map_js == .true) { this.source_map = if (has_out_dir) @@ -232,11 +232,11 @@ pub const JSBundler = struct { } } - if (try config.getOptionalEnum(globalThis, "packages", options.PackagesOption)) |packages| { + if (try config.getOwnOptionalEnum(globalThis, "packages", options.PackagesOption)) |packages| { this.packages = packages; } - if (try config.getOptionalEnum(globalThis, "format", options.Format)) |format| { + if (try config.getOwnOptionalEnum(globalThis, "format", options.Format)) |format| { switch (format) { .esm => {}, else => { @@ -246,28 +246,28 @@ pub const JSBundler = struct { } } - // if (try config.getOptional(globalThis, "hot", bool)) |hot| { + // if (try config.getOwnOptional(globalThis, "hot", bool)) |hot| { // this.hot = hot; // } - if (try config.getOptional(globalThis, "splitting", bool)) |hot| { + if (try config.getOwnOptional(globalThis, "splitting", bool)) |hot| { this.code_splitting = hot; } - if (config.getTruthy(globalThis, "minify")) |hot| { + if (config.getOwnTruthy(globalThis, "minify")) |hot| { if (hot.isBoolean()) { const value = hot.coerce(bool, globalThis); this.minify.whitespace = value; this.minify.syntax = value; this.minify.identifiers = value; } else if (hot.isObject()) { - if (try hot.getOptional(globalThis, "whitespace", bool)) |whitespace| { + if (try hot.getOwnOptional(globalThis, "whitespace", bool)) |whitespace| { this.minify.whitespace = whitespace; } - if (try hot.getOptional(globalThis, "syntax", bool)) |syntax| { + if (try hot.getOwnOptional(globalThis, "syntax", bool)) |syntax| { this.minify.syntax = syntax; } - if (try hot.getOptional(globalThis, "identifiers", bool)) |syntax| { + if (try hot.getOwnOptional(globalThis, "identifiers", bool)) |syntax| { this.minify.identifiers = syntax; } } else { @@ -291,19 +291,19 @@ pub const JSBundler = struct { return error.JSError; } - if (config.getTruthy(globalThis, "emitDCEAnnotations")) |flag| { + if (config.getOwnTruthy(globalThis, "emitDCEAnnotations")) |flag| { if (flag.coerce(bool, globalThis)) { this.emit_dce_annotations = true; } } - if (config.getTruthy(globalThis, "ignoreDCEAnnotations")) |flag| { + if (config.getOwnTruthy(globalThis, "ignoreDCEAnnotations")) |flag| { if (flag.coerce(bool, globalThis)) { this.ignore_dce_annotations = true; } } - if (config.getTruthy(globalThis, "conditions")) |conditions_value| { + if (config.getOwnTruthy(globalThis, "conditions")) |conditions_value| { if (conditions_value.isString()) { var slice = conditions_value.toSliceOrNull(globalThis) orelse { globalThis.throwInvalidArguments("Expected conditions to be an array of strings", .{}); @@ -329,7 +329,7 @@ pub const JSBundler = struct { { const path: ZigString.Slice = brk: { - if (try config.getOptional(globalThis, "root", ZigString.Slice)) |slice| { + if (try config.getOwnOptional(globalThis, "root", ZigString.Slice)) |slice| { break :brk slice; } @@ -358,7 +358,7 @@ pub const JSBundler = struct { try this.rootdir.appendSliceExact(rootdir); } - if (try config.getArray(globalThis, "external")) |externals| { + if (try config.getOwnArray(globalThis, "external")) |externals| { var iter = externals.arrayIterator(globalThis); while (iter.next()) |entry_point| { var slice = entry_point.toSliceOrNull(globalThis) orelse { @@ -370,21 +370,21 @@ pub const JSBundler = struct { } } - // if (try config.getOptional(globalThis, "dir", ZigString.Slice)) |slice| { + // if (try config.getOwnOptional(globalThis, "dir", ZigString.Slice)) |slice| { // defer slice.deinit(); // this.appendSliceExact(slice.slice()) catch unreachable; // } else { // this.appendSliceExact(globalThis.bunVM().bundler.fs.top_level_dir) catch unreachable; // } - if (try config.getOptional(globalThis, "publicPath", ZigString.Slice)) |slice| { + if (try config.getOwnOptional(globalThis, "publicPath", ZigString.Slice)) |slice| { defer slice.deinit(); try this.public_path.appendSliceExact(slice.slice()); } - if (config.getTruthy(globalThis, "naming")) |naming| { + if (config.getOwnTruthy(globalThis, "naming")) |naming| { if (naming.isString()) { - if (try config.getOptional(globalThis, "naming", ZigString.Slice)) |slice| { + if (try config.getOwnOptional(globalThis, "naming", ZigString.Slice)) |slice| { defer slice.deinit(); if (!strings.hasPrefixComptime(slice.slice(), "./")) { try this.names.owned_entry_point.appendSliceExact("./"); @@ -393,7 +393,7 @@ pub const JSBundler = struct { this.names.entry_point.data = this.names.owned_entry_point.list.items; } } else if (naming.isObject()) { - if (try naming.getOptional(globalThis, "entry", ZigString.Slice)) |slice| { + if (try naming.getOwnOptional(globalThis, "entry", ZigString.Slice)) |slice| { defer slice.deinit(); if (!strings.hasPrefixComptime(slice.slice(), "./")) { try this.names.owned_entry_point.appendSliceExact("./"); @@ -402,7 +402,7 @@ pub const JSBundler = struct { this.names.entry_point.data = this.names.owned_entry_point.list.items; } - if (try naming.getOptional(globalThis, "chunk", ZigString.Slice)) |slice| { + if (try naming.getOwnOptional(globalThis, "chunk", ZigString.Slice)) |slice| { defer slice.deinit(); if (!strings.hasPrefixComptime(slice.slice(), "./")) { try this.names.owned_chunk.appendSliceExact("./"); @@ -411,7 +411,7 @@ pub const JSBundler = struct { this.names.chunk.data = this.names.owned_chunk.list.items; } - if (try naming.getOptional(globalThis, "asset", ZigString.Slice)) |slice| { + if (try naming.getOwnOptional(globalThis, "asset", ZigString.Slice)) |slice| { defer slice.deinit(); if (!strings.hasPrefixComptime(slice.slice(), "./")) { try this.names.owned_asset.appendSliceExact("./"); @@ -425,7 +425,7 @@ pub const JSBundler = struct { } } - if (try config.getObject(globalThis, "define")) |define| { + if (try config.getOwnObject(globalThis, "define")) |define| { if (!define.isObject()) { globalThis.throwInvalidArguments("define must be an object", .{}); return error.JSError; @@ -463,7 +463,7 @@ pub const JSBundler = struct { } } - if (try config.getObject(globalThis, "loader")) |loaders| { + if (try config.getOwnObject(globalThis, "loader")) |loaders| { var loader_iter = JSC.JSPropertyIterator(.{ .skip_empty_name = true, .include_value = true, diff --git a/src/bun.js/api/JSTranspiler.zig b/src/bun.js/api/JSTranspiler.zig index 062ade00e28fae..2182ed6ccc9505 100644 --- a/src/bun.js/api/JSTranspiler.zig +++ b/src/bun.js/api/JSTranspiler.zig @@ -330,7 +330,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std return transpiler; } - if (object.getIfPropertyExists(globalObject, "define")) |define| { + if (object.getOwnTruthy(globalObject, "define")) |define| { define: { if (define.isUndefinedOrNull()) { break :define; @@ -379,7 +379,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (object.get(globalThis, "external")) |external| { + if (object.getOwn(globalThis, "external")) |external| { external: { if (external.isUndefinedOrNull()) break :external; @@ -419,7 +419,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (object.get(globalThis, "loader")) |loader| { + if (object.getOwn(globalThis, "loader")) |loader| { if (Loader.fromJS(globalThis, loader, exception)) |resolved| { if (!resolved.isJavaScriptLike()) { JSC.throwInvalidArguments("only JavaScript-like loaders supported for now", .{}, globalObject, exception); @@ -434,7 +434,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (object.get(globalThis, "target")) |target| { + if (object.getOwn(globalThis, "target")) |target| { if (Target.fromJS(globalThis, target, exception)) |resolved| { transpiler.transform.target = resolved.toAPI(); } @@ -444,7 +444,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (object.get(globalThis, "tsconfig")) |tsconfig| { + if (object.getOwn(globalThis, "tsconfig")) |tsconfig| { tsconfig: { if (tsconfig.isUndefinedOrNull()) break :tsconfig; const kind = tsconfig.jsType(); @@ -483,7 +483,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std else => false, }; - if (object.getIfPropertyExists(globalThis, "macro")) |macros| { + if (object.getOwnTruthy(globalThis, "macro")) |macros| { macros: { if (macros.isUndefinedOrNull()) break :macros; if (macros.isBoolean()) { @@ -518,39 +518,39 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (object.getOptional(globalThis, "autoImportJSX", bool) catch return transpiler) |flag| { + if (object.getOwnOptional(globalThis, "autoImportJSX", bool) catch return transpiler) |flag| { transpiler.runtime.auto_import_jsx = flag; } - if (object.getOptional(globalThis, "allowBunRuntime", bool) catch return transpiler) |flag| { + if (object.getOwnOptional(globalThis, "allowBunRuntime", bool) catch return transpiler) |flag| { transpiler.runtime.allow_runtime = flag; } - if (object.getOptional(globalThis, "inline", bool) catch return transpiler) |flag| { + if (object.getOwnOptional(globalThis, "inline", bool) catch return transpiler) |flag| { transpiler.runtime.inlining = flag; } - if (object.getOptional(globalThis, "minifyWhitespace", bool) catch return transpiler) |flag| { + if (object.getOwnOptional(globalThis, "minifyWhitespace", bool) catch return transpiler) |flag| { transpiler.minify_whitespace = flag; } - if (object.getOptional(globalThis, "deadCodeElimination", bool) catch return transpiler) |flag| { + if (object.getOwnOptional(globalThis, "deadCodeElimination", bool) catch return transpiler) |flag| { transpiler.dead_code_elimination = flag; } - if (object.getTruthy(globalThis, "minify")) |hot| { + if (object.getOwnTruthy(globalThis, "minify")) |hot| { if (hot.isBoolean()) { transpiler.minify_whitespace = hot.coerce(bool, globalThis); transpiler.minify_syntax = transpiler.minify_whitespace; transpiler.minify_identifiers = transpiler.minify_syntax; } else if (hot.isObject()) { - if (try hot.getOptional(globalThis, "whitespace", bool)) |whitespace| { + if (try hot.getOwnOptional(globalThis, "whitespace", bool)) |whitespace| { transpiler.minify_whitespace = whitespace; } - if (try hot.getOptional(globalThis, "syntax", bool)) |syntax| { + if (try hot.getOwnOptional(globalThis, "syntax", bool)) |syntax| { transpiler.minify_syntax = syntax; } - if (try hot.getOptional(globalThis, "identifiers", bool)) |syntax| { + if (try hot.getOwnOptional(globalThis, "identifiers", bool)) |syntax| { transpiler.minify_identifiers = syntax; } } else { @@ -559,7 +559,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (object.get(globalThis, "sourcemap")) |flag| { + if (object.getOwn(globalThis, "sourcemap")) |flag| { if (flag.isBoolean() or flag.isUndefinedOrNull()) { if (flag.toBoolean()) { transpiler.transform.source_map = .@"inline"; @@ -576,21 +576,21 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (try object.getOptionalEnum(globalThis, "packages", options.PackagesOption)) |packages| { + if (try object.getOwnOptionalEnum(globalThis, "packages", options.PackagesOption)) |packages| { transpiler.transform.packages = packages.toAPI(); } var tree_shaking: ?bool = null; - if (object.getOptional(globalThis, "treeShaking", bool) catch return transpiler) |treeShaking| { + if (object.getOwnOptional(globalThis, "treeShaking", bool) catch return transpiler) |treeShaking| { tree_shaking = treeShaking; } var trim_unused_imports: ?bool = null; - if (object.getOptional(globalThis, "trimUnusedImports", bool) catch return transpiler) |trimUnusedImports| { + if (object.getOwnOptional(globalThis, "trimUnusedImports", bool) catch return transpiler) |trimUnusedImports| { trim_unused_imports = trimUnusedImports; } - if (object.getTruthy(globalThis, "exports")) |exports| { + if (object.getOwnTruthy(globalThis, "exports")) |exports| { if (!exports.isObject()) { JSC.throwInvalidArguments("exports must be an object", .{}, globalObject, exception); return transpiler; @@ -599,7 +599,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std var replacements = Runtime.Features.ReplaceableExport.Map{}; errdefer replacements.clearAndFree(bun.default_allocator); - if (exports.getTruthy(globalThis, "eliminate")) |eliminate| { + if (exports.getOwnTruthy(globalThis, "eliminate")) |eliminate| { if (!eliminate.jsType().isArray()) { JSC.throwInvalidArguments("exports.eliminate must be an array", .{}, globalObject, exception); return transpiler; @@ -641,7 +641,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std } } - if (exports.getTruthy(globalThis, "replace")) |replace| { + if (exports.getOwnTruthy(globalThis, "replace")) |replace| { if (!replace.isObject()) { JSC.throwInvalidArguments("replace must be an object", .{}, globalObject, exception); return transpiler; @@ -718,7 +718,7 @@ fn transformOptionsFromJSC(globalObject: JSC.C.JSContextRef, temp_allocator: std transpiler.runtime.replace_exports = replacements; } - if (object.getTruthy(globalThis, "logLevel")) |logLevel| { + if (object.getOwnTruthy(globalThis, "logLevel")) |logLevel| { if (logger.Log.Level.Map.fromJS(globalObject, logLevel)) |level| { transpiler.log.level = level; } else { diff --git a/src/bun.js/api/bun/socket.zig b/src/bun.js/api/bun/socket.zig index 8dcb2b5e7d8e1b..44bc2a370d0e6d 100644 --- a/src/bun.js/api/bun/socket.zig +++ b/src/bun.js/api/bun/socket.zig @@ -239,7 +239,7 @@ const Handlers = struct { .{ "onHandshake", "handshake" }, }; inline for (pairs) |pair| { - if (opts.getTruthyComptime(globalObject, pair.@"1")) |callback_value| { + if (opts.getOwnTruthyComptime(globalObject, pair.@"1")) |callback_value| { if (!callback_value.isCell() or !callback_value.isCallable(globalObject.vm())) { exception.* = JSC.toInvalidArguments(comptime std.fmt.comptimePrint("Expected \"{s}\" callback to be a function", .{pair.@"1"}), .{}, globalObject).asObjectRef(); return null; @@ -254,7 +254,7 @@ const Handlers = struct { return null; } - if (opts.getTruthy(globalObject, "binaryType")) |binary_type_value| { + if (opts.getOwnTruthy(globalObject, "binaryType")) |binary_type_value| { if (!binary_type_value.isString()) { exception.* = JSC.toInvalidArguments("Expected \"binaryType\" to be a string", .{}, globalObject).asObjectRef(); return null; @@ -341,13 +341,13 @@ pub const SocketConfig = struct { } hostname_or_unix: { - if (opts.getTruthy(globalObject, "fd")) |fd_| { + if (opts.getOwnTruthy(globalObject, "fd")) |fd_| { if (fd_.isNumber()) { break :hostname_or_unix; } } - if (opts.getTruthy(globalObject, "unix")) |unix_socket| { + if (opts.getOwnTruthy(globalObject, "unix")) |unix_socket| { if (!unix_socket.isString()) { exception.* = JSC.toInvalidArguments("Expected \"unix\" to be a string", .{}, globalObject).asObjectRef(); return null; @@ -365,17 +365,17 @@ pub const SocketConfig = struct { } } - if (opts.getTruthy(globalObject, "exclusive")) |_| { + if (opts.getOwnTruthy(globalObject, "exclusive")) |_| { exclusive = true; } - if (opts.getTruthy(globalObject, "hostname") orelse opts.getTruthy(globalObject, "host")) |hostname| { + if (opts.getOwnTruthy(globalObject, "hostname") orelse opts.getOwnTruthy(globalObject, "host")) |hostname| { if (!hostname.isString()) { exception.* = JSC.toInvalidArguments("Expected \"hostname\" to be a string", .{}, globalObject).asObjectRef(); return null; } - var port_value = opts.get(globalObject, "port") orelse JSValue.zero; + var port_value = opts.getOwn(globalObject, "port") orelse JSValue.zero; hostname_or_unix = hostname.getZigString(globalObject).toSlice(bun.default_allocator); if (port_value.isEmptyOrUndefinedOrNull() and hostname_or_unix.len > 0) { @@ -423,7 +423,7 @@ pub const SocketConfig = struct { return null; } - var handlers = Handlers.fromJS(globalObject, opts.get(globalObject, "socket") orelse JSValue.zero, exception) orelse { + var handlers = Handlers.fromJS(globalObject, opts.getOwn(globalObject, "socket") orelse JSValue.zero, exception) orelse { hostname_or_unix.deinit(); return null; }; @@ -542,7 +542,7 @@ pub const Listener = struct { var exception: JSC.C.JSValueRef = null; - const socket_obj = opts.get(globalObject, "socket") orelse { + const socket_obj = opts.getOwn(globalObject, "socket") orelse { globalObject.throw("Expected \"socket\" object", .{}); return .zero; }; @@ -1069,7 +1069,7 @@ pub const Listener = struct { vm.eventLoop().ensureWaker(); var connection: Listener.UnixOrHost = blk: { - if (opts.getTruthy(globalObject, "fd")) |fd_| { + if (opts.getOwnTruthy(globalObject, "fd")) |fd_| { if (fd_.isNumber()) { const fd = fd_.asFileDescriptor(); break :blk .{ .fd = fd }; @@ -2308,7 +2308,7 @@ fn NewSocket(comptime ssl: bool) type { var exception: JSC.C.JSValueRef = null; - const socket_obj = opts.get(globalObject, "socket") orelse { + const socket_obj = opts.getOwn(globalObject, "socket") orelse { globalObject.throw("Expected \"socket\" option", .{}); return .zero; }; @@ -3082,7 +3082,7 @@ fn NewSocket(comptime ssl: bool) type { return .zero; } - const socket_obj = opts.get(globalObject, "socket") orelse { + const socket_obj = opts.getOwn(globalObject, "socket") orelse { globalObject.throw("Expected \"socket\" option", .{}); return .zero; }; @@ -4007,7 +4007,7 @@ pub fn jsUpgradeDuplexToTLS(globalObject: *JSC.JSGlobalObject, callframe: *JSC.C return .zero; } - const socket_obj = opts.get(globalObject, "socket") orelse { + const socket_obj = opts.getOwn(globalObject, "socket") orelse { globalObject.throw("Expected \"socket\" option", .{}); return .zero; }; diff --git a/src/bun.js/api/bun/subprocess.zig b/src/bun.js/api/bun/subprocess.zig index cd6e04d875dc0e..f51669b5948db4 100644 --- a/src/bun.js/api/bun/subprocess.zig +++ b/src/bun.js/api/bun/subprocess.zig @@ -1716,7 +1716,7 @@ pub const Subprocess = struct { } else if (!args.isObject()) { globalThis.throwInvalidArguments("cmd must be an array", .{}); return .zero; - } else if (args.getTruthy(globalThis, "cmd")) |cmd_value_| { + } else if (args.getOwnTruthy(globalThis, "cmd")) |cmd_value_| { cmd_value = cmd_value_; } else { globalThis.throwInvalidArguments("cmd must be an array", .{}); @@ -1724,7 +1724,7 @@ pub const Subprocess = struct { } if (args.isObject()) { - if (args.getTruthy(globalThis, "argv0")) |argv0_| { + if (args.getOwnTruthy(globalThis, "argv0")) |argv0_| { const argv0_str = argv0_.getZigString(globalThis); if (argv0_str.len > 0) { argv0 = argv0_str.toOwnedSliceZ(allocator) catch { @@ -1735,7 +1735,7 @@ pub const Subprocess = struct { } // need to update `cwd` before searching for executable with `Which.which` - if (args.getTruthy(globalThis, "cwd")) |cwd_| { + if (args.getOwnTruthy(globalThis, "cwd")) |cwd_| { const cwd_str = cwd_.getZigString(globalThis); if (cwd_str.len > 0) { cwd = cwd_str.toOwnedSliceZ(allocator) catch { @@ -1820,10 +1820,10 @@ pub const Subprocess = struct { if (args != .zero and args.isObject()) { // This must run before the stdio parsing happens if (!is_sync) { - if (args.getTruthy(globalThis, "ipc")) |val| { + if (args.getOwnTruthy(globalThis, "ipc")) |val| { if (val.isCell() and val.isCallable(globalThis.vm())) { maybe_ipc_mode = ipc_mode: { - if (args.getTruthy(globalThis, "serialization")) |mode_val| { + if (args.getOwnTruthy(globalThis, "serialization")) |mode_val| { if (mode_val.isString()) { break :ipc_mode IPC.Mode.fromJS(globalThis, mode_val) orelse { if (!globalThis.hasException()) { @@ -1846,7 +1846,7 @@ pub const Subprocess = struct { } } - if (args.getTruthy(globalThis, "onDisconnect")) |onDisconnect_| { + if (args.getOwnTruthy(globalThis, "onDisconnect")) |onDisconnect_| { if (!onDisconnect_.isCell() or !onDisconnect_.isCallable(globalThis.vm())) { globalThis.throwInvalidArguments("onDisconnect must be a function or undefined", .{}); return .zero; @@ -1858,7 +1858,7 @@ pub const Subprocess = struct { onDisconnect_.withAsyncContextIfNeeded(globalThis); } - if (args.getTruthy(globalThis, "onExit")) |onExit_| { + if (args.getOwnTruthy(globalThis, "onExit")) |onExit_| { if (!onExit_.isCell() or !onExit_.isCallable(globalThis.vm())) { globalThis.throwInvalidArguments("onExit must be a function or undefined", .{}); return .zero; @@ -1870,7 +1870,7 @@ pub const Subprocess = struct { onExit_.withAsyncContextIfNeeded(globalThis); } - if (args.getTruthy(globalThis, "env")) |object| { + if (args.getOwnTruthy(globalThis, "env")) |object| { if (!object.isObject()) { globalThis.throwInvalidArguments("env must be an object", .{}); return .zero; @@ -1886,7 +1886,7 @@ pub const Subprocess = struct { }; env_array = envp_managed.moveToUnmanaged(); } - if (args.get(globalThis, "stdio")) |stdio_val| { + if (args.getOwn(globalThis, "stdio")) |stdio_val| { if (!stdio_val.isEmptyOrUndefinedOrNull()) { if (stdio_val.jsType().isArray()) { var stdio_iter = stdio_val.arrayIterator(globalThis); @@ -1925,44 +1925,44 @@ pub const Subprocess = struct { } } } else { - if (args.get(globalThis, "stdin")) |value| { + if (args.getOwn(globalThis, "stdin")) |value| { if (!stdio[0].extract(globalThis, 0, value)) return .zero; } - if (args.get(globalThis, "stderr")) |value| { + if (args.getOwn(globalThis, "stderr")) |value| { if (!stdio[2].extract(globalThis, 2, value)) return .zero; } - if (args.get(globalThis, "stdout")) |value| { + if (args.getOwn(globalThis, "stdout")) |value| { if (!stdio[1].extract(globalThis, 1, value)) return .zero; } } if (comptime !is_sync) { - if (args.get(globalThis, "lazy")) |lazy_val| { + if (args.getOwn(globalThis, "lazy")) |lazy_val| { if (lazy_val.isBoolean()) { lazy = lazy_val.toBoolean(); } } } - if (args.get(globalThis, "detached")) |detached_val| { + if (args.getOwn(globalThis, "detached")) |detached_val| { if (detached_val.isBoolean()) { detached = detached_val.toBoolean(); } } if (Environment.isWindows) { - if (args.get(globalThis, "windowsHide")) |val| { + if (args.getOwn(globalThis, "windowsHide")) |val| { if (val.isBoolean()) { windows_hide = val.asBoolean(); } } - if (args.get(globalThis, "windowsVerbatimArguments")) |val| { + if (args.getOwn(globalThis, "windowsVerbatimArguments")) |val| { if (val.isBoolean()) { windows_verbatim_arguments = val.asBoolean(); } diff --git a/src/bun.js/api/bun/udp_socket.zig b/src/bun.js/api/bun/udp_socket.zig index c2984b56292ca6..b26d327ecf03e3 100644 --- a/src/bun.js/api/bun/udp_socket.zig +++ b/src/bun.js/api/bun/udp_socket.zig @@ -129,7 +129,7 @@ pub const UDPSocketConfig = struct { } const hostname = brk: { - if (options.getTruthy(globalThis, "hostname")) |value| { + if (options.getOwnTruthy(globalThis, "hostname")) |value| { if (!value.isString()) { globalThis.throwInvalidArguments("Expected \"hostname\" to be a string", .{}); return null; @@ -144,7 +144,7 @@ pub const UDPSocketConfig = struct { defer if (globalThis.hasException()) default_allocator.free(hostname); const port: u16 = brk: { - if (options.getTruthy(globalThis, "port")) |value| { + if (options.getOwnTruthy(globalThis, "port")) |value| { const number = value.coerceToInt32(globalThis); if (number < 0 or number > 0xffff) { globalThis.throwInvalidArguments("Expected \"port\" to be an integer between 0 and 65535", .{}); @@ -161,13 +161,13 @@ pub const UDPSocketConfig = struct { .port = port, }; - if (options.getTruthy(globalThis, "socket")) |socket| { + if (options.getOwnTruthy(globalThis, "socket")) |socket| { if (!socket.isObject()) { globalThis.throwInvalidArguments("Expected \"socket\" to be an object", .{}); return null; } - if (options.getTruthy(globalThis, "binaryType")) |value| { + if (options.getOwnTruthy(globalThis, "binaryType")) |value| { if (!value.isString()) { globalThis.throwInvalidArguments("Expected \"socket.binaryType\" to be a string", .{}); return null; @@ -180,7 +180,7 @@ pub const UDPSocketConfig = struct { } inline for (handlers) |handler| { - if (socket.getTruthyComptime(globalThis, handler.@"0")) |value| { + if (socket.getOwnTruthyComptime(globalThis, handler.@"0")) |value| { if (!value.isCell() or !value.isCallable(globalThis.vm())) { globalThis.throwInvalidArguments("Expected \"socket.{s}\" to be a function", .{handler.@"0"}); return null; @@ -198,13 +198,13 @@ pub const UDPSocketConfig = struct { } } - if (options.getTruthy(globalThis, "connect")) |connect| { + if (options.getOwnTruthy(globalThis, "connect")) |connect| { if (!connect.isObject()) { globalThis.throwInvalidArguments("Expected \"connect\" to be an object", .{}); return null; } - const connect_host_js = connect.getTruthy(globalThis, "hostname") orelse { + const connect_host_js = connect.getOwnTruthy(globalThis, "hostname") orelse { globalThis.throwInvalidArguments("Expected \"connect.hostname\" to be a string", .{}); return null; }; @@ -214,7 +214,7 @@ pub const UDPSocketConfig = struct { return null; } - const connect_port_js = connect.getTruthy(globalThis, "port") orelse { + const connect_port_js = connect.getOwnTruthy(globalThis, "port") orelse { globalThis.throwInvalidArguments("Expected \"connect.port\" to be an integer", .{}); return null; }; diff --git a/src/bun.js/api/ffi.zig b/src/bun.js/api/ffi.zig index 25e14d2778ddbd..858595cac263d2 100644 --- a/src/bun.js/api/ffi.zig +++ b/src/bun.js/api/ffi.zig @@ -627,7 +627,7 @@ pub const FFI = struct { } } - const symbols_object = object.get(globalThis, "symbols") orelse .undefined; + const symbols_object = object.getOwn(globalThis, "symbols") orelse .undefined; if (!globalThis.hasException() and (symbols_object == .zero or !symbols_object.isObject())) { _ = globalThis.throwInvalidArgumentTypeValue("symbols", "object", symbols_object); } @@ -647,7 +647,7 @@ pub const FFI = struct { return .zero; } - if (object.get(globalThis, "library")) |library_value| { + if (object.getOwn(globalThis, "library")) |library_value| { compile_c.libraries = StringArray.fromJS(globalThis, library_value, "library"); } @@ -655,7 +655,7 @@ pub const FFI = struct { return .zero; } - if (object.getTruthy(globalThis, "flags")) |flags_value| { + if (object.getOwnTruthy(globalThis, "flags")) |flags_value| { if (flags_value.isArray()) { var iter = flags_value.arrayIterator(globalThis); @@ -692,7 +692,7 @@ pub const FFI = struct { return .zero; } - if (object.getTruthy(globalThis, "define")) |define_value| { + if (object.getOwnTruthy(globalThis, "define")) |define_value| { if (define_value.isObject()) { const Iter = JSC.JSPropertyIterator(.{ .include_value = true, .skip_empty_name = true }); var iter = Iter.init(globalThis, define_value); @@ -722,7 +722,7 @@ pub const FFI = struct { return .zero; } - if (object.getTruthy(globalThis, "include")) |include_value| { + if (object.getOwnTruthy(globalThis, "include")) |include_value| { compile_c.include_dirs = StringArray.fromJS(globalThis, include_value, "include"); } @@ -730,7 +730,7 @@ pub const FFI = struct { return .zero; } - if (object.get(globalThis, "source")) |source_value| { + if (object.getOwn(globalThis, "source")) |source_value| { if (source_value.isArray()) { compile_c.source = .{ .files = .{} }; var iter = source_value.arrayIterator(globalThis); @@ -1301,7 +1301,7 @@ pub const FFI = struct { var abi_types = std.ArrayListUnmanaged(ABIType){}; - if (value.get(global, "args")) |args| { + if (value.getOwn(global, "args")) |args| { if (args.isEmptyOrUndefinedOrNull() or !args.jsType().isArray()) { return ZigString.static("Expected an object with \"args\" as an array").toErrorInstance(global); } @@ -1347,11 +1347,11 @@ pub const FFI = struct { var threadsafe = false; - if (value.getTruthy(global, "threadsafe")) |threadsafe_value| { + if (value.getOwnTruthy(global, "threadsafe")) |threadsafe_value| { threadsafe = threadsafe_value.toBoolean(); } - if (value.getTruthy(global, "returns")) |ret_value| brk: { + if (value.getOwnTruthy(global, "returns")) |ret_value| brk: { if (ret_value.isAnyInt()) { const int = ret_value.toInt32(); switch (int) { diff --git a/src/bun.js/api/filesystem_router.zig b/src/bun.js/api/filesystem_router.zig index 74052edbe6b230..40f28ca9f75c09 100644 --- a/src/bun.js/api/filesystem_router.zig +++ b/src/bun.js/api/filesystem_router.zig @@ -69,7 +69,7 @@ pub const FileSystemRouter = struct { var asset_prefix_slice: ZigString.Slice = .{}; var out_buf: [bun.MAX_PATH_BYTES * 2]u8 = undefined; - if (argument.get(globalThis, "style")) |style_val| { + if (argument.getOwn(globalThis, "style")) |style_val| { if (!style_val.getZigString(globalThis).eqlComptime("nextjs")) { globalThis.throwInvalidArguments("Only 'nextjs' style is currently implemented", .{}); return null; @@ -79,7 +79,7 @@ pub const FileSystemRouter = struct { return null; } - if (argument.get(globalThis, "dir")) |dir| { + if (argument.getOwn(globalThis, "dir")) |dir| { if (!dir.isString()) { globalThis.throwInvalidArguments("Expected dir to be a string", .{}); return null; @@ -104,7 +104,7 @@ pub const FileSystemRouter = struct { arena.* = bun.ArenaAllocator.init(globalThis.allocator()); const allocator = arena.allocator(); var extensions = std.ArrayList(string).init(allocator); - if (argument.get(globalThis, "fileExtensions")) |file_extensions| { + if (argument.getOwn(globalThis, "fileExtensions")) |file_extensions| { if (!file_extensions.jsType().isArray()) { globalThis.throwInvalidArguments("Expected fileExtensions to be an Array", .{}); origin_str.deinit(); @@ -128,7 +128,7 @@ pub const FileSystemRouter = struct { } } - if (argument.getTruthy(globalThis, "assetPrefix")) |asset_prefix| { + if (argument.getOwnTruthy(globalThis, "assetPrefix")) |asset_prefix| { if (!asset_prefix.isString()) { globalThis.throwInvalidArguments("Expected assetPrefix to be a string", .{}); origin_str.deinit(); @@ -174,7 +174,7 @@ pub const FileSystemRouter = struct { return null; }; - if (argument.get(globalThis, "origin")) |origin| { + if (argument.getOwn(globalThis, "origin")) |origin| { if (!origin.isString()) { globalThis.throwInvalidArguments("Expected origin to be a string", .{}); arena.deinit(); diff --git a/src/bun.js/api/glob.zig b/src/bun.js/api/glob.zig index 122aff963b989a..5d48b71caa5afb 100644 --- a/src/bun.js/api/glob.zig +++ b/src/bun.js/api/glob.zig @@ -120,23 +120,23 @@ const ScanOpts = struct { return null; } - if (optsObj.getTruthy(globalThis, "onlyFiles")) |only_files| { + if (optsObj.getOwnTruthy(globalThis, "onlyFiles")) |only_files| { out.only_files = if (only_files.isBoolean()) only_files.asBoolean() else false; } - if (optsObj.getTruthy(globalThis, "throwErrorOnBrokenSymlink")) |error_on_broken| { + if (optsObj.getOwnTruthy(globalThis, "throwErrorOnBrokenSymlink")) |error_on_broken| { out.error_on_broken_symlinks = if (error_on_broken.isBoolean()) error_on_broken.asBoolean() else false; } - if (optsObj.getTruthy(globalThis, "followSymlinks")) |followSymlinksVal| { + if (optsObj.getOwnTruthy(globalThis, "followSymlinks")) |followSymlinksVal| { out.follow_symlinks = if (followSymlinksVal.isBoolean()) followSymlinksVal.asBoolean() else false; } - if (optsObj.getTruthy(globalThis, "absolute")) |absoluteVal| { + if (optsObj.getOwnTruthy(globalThis, "absolute")) |absoluteVal| { out.absolute = if (absoluteVal.isBoolean()) absoluteVal.asBoolean() else false; } - if (optsObj.getTruthy(globalThis, "cwd")) |cwdVal| { + if (optsObj.getOwnTruthy(globalThis, "cwd")) |cwdVal| { if (!cwdVal.isString()) { globalThis.throw("{s}: invalid `cwd`, not a string", .{fnName}); return null; @@ -152,7 +152,7 @@ const ScanOpts = struct { } } - if (optsObj.getTruthy(globalThis, "dot")) |dot| { + if (optsObj.getOwnTruthy(globalThis, "dot")) |dot| { out.dot = if (dot.isBoolean()) dot.asBoolean() else false; } diff --git a/src/bun.js/api/server.zig b/src/bun.js/api/server.zig index c429032cb558ec..a22ebf8c835773 100644 --- a/src/bun.js/api/server.zig +++ b/src/bun.js/api/server.zig @@ -764,7 +764,7 @@ pub const ServerConfig = struct { result.reject_unauthorized = @intFromBool(vm.getTLSRejectUnauthorized()); // Required - if (obj.getTruthy(global, "keyFile")) |key_file_name| { + if (obj.getOwnTruthy(global, "keyFile")) |key_file_name| { var sliced = key_file_name.toSlice(global, bun.default_allocator); defer sliced.deinit(); if (sliced.len > 0) { @@ -780,7 +780,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "key")) |js_obj| { + if (obj.getOwnTruthy(global, "key")) |js_obj| { if (js_obj.jsType().isArray()) { const count = js_obj.getLength(global); if (count > 0) { @@ -863,7 +863,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "certFile")) |cert_file_name| { + if (obj.getOwnTruthy(global, "certFile")) |cert_file_name| { var sliced = cert_file_name.toSlice(global, bun.default_allocator); defer sliced.deinit(); if (sliced.len > 0) { @@ -878,7 +878,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "ALPNProtocols")) |protocols| { + if (obj.getOwnTruthy(global, "ALPNProtocols")) |protocols| { if (JSC.Node.StringOrBuffer.fromJS(global, arena.allocator(), protocols)) |sb| { defer sb.deinit(); const sliced = sb.slice(); @@ -896,7 +896,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "cert")) |js_obj| { + if (obj.getOwnTruthy(global, "cert")) |js_obj| { if (js_obj.jsType().isArray()) { const count = js_obj.getLength(global); if (count > 0) { @@ -979,7 +979,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "requestCert")) |request_cert| { + if (obj.getOwnTruthy(global, "requestCert")) |request_cert| { if (request_cert.isBoolean()) { result.request_cert = if (request_cert.asBoolean()) 1 else 0; any = true; @@ -990,7 +990,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "rejectUnauthorized")) |reject_unauthorized| { + if (obj.getOwnTruthy(global, "rejectUnauthorized")) |reject_unauthorized| { if (reject_unauthorized.isBoolean()) { result.reject_unauthorized = if (reject_unauthorized.asBoolean()) 1 else 0; any = true; @@ -1001,7 +1001,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "ciphers")) |ssl_ciphers| { + if (obj.getOwnTruthy(global, "ciphers")) |ssl_ciphers| { var sliced = ssl_ciphers.toSlice(global, bun.default_allocator); defer sliced.deinit(); if (sliced.len > 0) { @@ -1011,7 +1011,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "serverName") orelse obj.getTruthy(global, "servername")) |server_name| { + if (obj.getOwnTruthy(global, "serverName") orelse obj.getOwnTruthy(global, "servername")) |server_name| { var sliced = server_name.toSlice(global, bun.default_allocator); defer sliced.deinit(); if (sliced.len > 0) { @@ -1021,7 +1021,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "ca")) |js_obj| { + if (obj.getOwnTruthy(global, "ca")) |js_obj| { if (js_obj.jsType().isArray()) { const count = js_obj.getLength(global); if (count > 0) { @@ -1104,7 +1104,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "caFile")) |ca_file_name| { + if (obj.getOwnTruthy(global, "caFile")) |ca_file_name| { var sliced = ca_file_name.toSlice(global, bun.default_allocator); defer sliced.deinit(); if (sliced.len > 0) { @@ -1118,25 +1118,25 @@ pub const ServerConfig = struct { } // Optional if (any) { - if (obj.getTruthy(global, "secureOptions")) |secure_options| { + if (obj.getOwnTruthy(global, "secureOptions")) |secure_options| { if (secure_options.isNumber()) { result.secure_options = secure_options.toU32(); } } - if (obj.getTruthy(global, "clientRenegotiationLimit")) |client_renegotiation_limit| { + if (obj.getOwnTruthy(global, "clientRenegotiationLimit")) |client_renegotiation_limit| { if (client_renegotiation_limit.isNumber()) { result.client_renegotiation_limit = client_renegotiation_limit.toU32(); } } - if (obj.getTruthy(global, "clientRenegotiationWindow")) |client_renegotiation_window| { + if (obj.getOwnTruthy(global, "clientRenegotiationWindow")) |client_renegotiation_window| { if (client_renegotiation_window.isNumber()) { result.client_renegotiation_window = client_renegotiation_window.toU32(); } } - if (obj.getTruthy(global, "dhParamsFile")) |dh_params_file_name| { + if (obj.getOwnTruthy(global, "dhParamsFile")) |dh_params_file_name| { var sliced = dh_params_file_name.toSlice(global, bun.default_allocator); defer sliced.deinit(); if (sliced.len > 0) { @@ -1149,7 +1149,7 @@ pub const ServerConfig = struct { } } - if (obj.getTruthy(global, "passphrase")) |passphrase| { + if (obj.getOwnTruthy(global, "passphrase")) |passphrase| { var sliced = passphrase.toSlice(global, bun.default_allocator); defer sliced.deinit(); if (sliced.len > 0) { @@ -1157,7 +1157,7 @@ pub const ServerConfig = struct { } } - if (obj.get(global, "lowMemoryMode")) |low_memory_mode| { + if (obj.getOwn(global, "lowMemoryMode")) |low_memory_mode| { if (low_memory_mode.isBoolean() or low_memory_mode.isUndefined()) { result.low_memory_mode = low_memory_mode.toBoolean(); any = true; @@ -1240,7 +1240,7 @@ pub const ServerConfig = struct { return args; } - if (arg.get(global, "static")) |static| { + if (arg.getOwn(global, "static")) |static| { if (!static.isObject()) { JSC.throwInvalidArguments("Bun.serve expects 'static' to be an object shaped like { [pathname: string]: Response }", .{}, global, exception); return args; @@ -1285,7 +1285,7 @@ pub const ServerConfig = struct { if (global.hasException()) return args; - if (arg.get(global, "idleTimeout")) |value| { + if (arg.getOwn(global, "idleTimeout")) |value| { if (!value.isUndefinedOrNull()) { if (!value.isAnyInt()) { JSC.throwInvalidArguments("Bun.serve expects idleTimeout to be an integer", .{}, global, exception); @@ -1303,7 +1303,7 @@ pub const ServerConfig = struct { } } - if (arg.getTruthy(global, "webSocket") orelse arg.getTruthy(global, "websocket")) |websocket_object| { + if (arg.getOwnTruthy(global, "webSocket") orelse arg.getOwnTruthy(global, "websocket")) |websocket_object| { if (!websocket_object.isObject()) { JSC.throwInvalidArguments("Expected websocket to be an object", .{}, global, exception); if (args.ssl_config) |*conf| { @@ -1323,7 +1323,7 @@ pub const ServerConfig = struct { } if (global.hasException()) return args; - if (arg.getTruthy(global, "port")) |port_| { + if (arg.getOwnTruthy(global, "port")) |port_| { args.address.tcp.port = @as( u16, @intCast(@min( @@ -1335,7 +1335,7 @@ pub const ServerConfig = struct { } if (global.hasException()) return args; - if (arg.getTruthy(global, "baseURI")) |baseURI| { + if (arg.getOwnTruthy(global, "baseURI")) |baseURI| { var sliced = baseURI.toSlice(global, bun.default_allocator); if (sliced.len > 0) { @@ -1345,7 +1345,7 @@ pub const ServerConfig = struct { } if (global.hasException()) return args; - if (arg.getTruthy(global, "hostname") orelse arg.getTruthy(global, "host")) |host| { + if (arg.getOwnTruthy(global, "hostname") orelse arg.getOwnTruthy(global, "host")) |host| { const host_str = host.toSlice( global, bun.default_allocator, @@ -1359,7 +1359,7 @@ pub const ServerConfig = struct { } if (global.hasException()) return args; - if (arg.getTruthy(global, "unix")) |unix| { + if (arg.getOwnTruthy(global, "unix")) |unix| { const unix_str = unix.toSlice( global, bun.default_allocator, @@ -1376,7 +1376,7 @@ pub const ServerConfig = struct { } if (global.hasException()) return args; - if (arg.get(global, "id")) |id| { + if (arg.getOwn(global, "id")) |id| { if (id.isUndefinedOrNull()) { args.allow_hot = false; } else { @@ -1394,18 +1394,18 @@ pub const ServerConfig = struct { } if (global.hasException()) return args; - if (arg.get(global, "development")) |dev| { + if (arg.getOwn(global, "development")) |dev| { args.development = dev.coerce(bool, global); args.reuse_port = !args.development; } if (global.hasException()) return args; - if (arg.get(global, "reusePort")) |dev| { + if (arg.getOwn(global, "reusePort")) |dev| { args.reuse_port = dev.coerce(bool, global); } if (global.hasException()) return args; - if (arg.get(global, "inspector")) |inspector| { + if (arg.getOwn(global, "inspector")) |inspector| { args.inspector = inspector.coerce(bool, global); if (args.inspector and !args.development) { @@ -1415,14 +1415,14 @@ pub const ServerConfig = struct { } if (global.hasException()) return args; - if (arg.getTruthy(global, "maxRequestBodySize")) |max_request_body_size| { + if (arg.getOwnTruthy(global, "maxRequestBodySize")) |max_request_body_size| { if (max_request_body_size.isNumber()) { args.max_request_body_size = @as(u64, @intCast(@max(0, max_request_body_size.toInt64()))); } } if (global.hasException()) return args; - if (arg.getTruthyComptime(global, "error")) |onError| { + if (arg.getOwnTruthyComptime(global, "error")) |onError| { if (!onError.isCallable(global.vm())) { JSC.throwInvalidArguments("Expected error to be a function", .{}, global, exception); return args; @@ -4191,7 +4191,7 @@ pub const WebSocketServer = struct { var valid = false; - if (object.getTruthyComptime(globalObject, "message")) |message_| { + if (object.getOwnTruthyComptime(globalObject, "message")) |message_| { if (!message_.isCallable(vm)) { globalObject.throwInvalidArguments("websocket expects a function for the message option", .{}); return null; @@ -4202,7 +4202,7 @@ pub const WebSocketServer = struct { valid = true; } - if (object.getTruthy(globalObject, "open")) |open_| { + if (object.getOwnTruthy(globalObject, "open")) |open_| { if (!open_.isCallable(vm)) { globalObject.throwInvalidArguments("websocket expects a function for the open option", .{}); return null; @@ -4213,7 +4213,7 @@ pub const WebSocketServer = struct { valid = true; } - if (object.getTruthy(globalObject, "close")) |close_| { + if (object.getOwnTruthy(globalObject, "close")) |close_| { if (!close_.isCallable(vm)) { globalObject.throwInvalidArguments("websocket expects a function for the close option", .{}); return null; @@ -4224,7 +4224,7 @@ pub const WebSocketServer = struct { valid = true; } - if (object.getTruthy(globalObject, "drain")) |drain_| { + if (object.getOwnTruthy(globalObject, "drain")) |drain_| { if (!drain_.isCallable(vm)) { globalObject.throwInvalidArguments("websocket expects a function for the drain option", .{}); return null; @@ -4235,7 +4235,7 @@ pub const WebSocketServer = struct { valid = true; } - if (object.getTruthy(globalObject, "onError")) |onError_| { + if (object.getOwnTruthy(globalObject, "onError")) |onError_| { if (!onError_.isCallable(vm)) { globalObject.throwInvalidArguments("websocket expects a function for the onError option", .{}); return null; @@ -4245,7 +4245,7 @@ pub const WebSocketServer = struct { onError.ensureStillAlive(); } - if (object.getTruthy(globalObject, "ping")) |cb| { + if (object.getOwnTruthy(globalObject, "ping")) |cb| { if (!cb.isCallable(vm)) { globalObject.throwInvalidArguments("websocket expects a function for the ping option", .{}); return null; @@ -4255,7 +4255,7 @@ pub const WebSocketServer = struct { valid = true; } - if (object.getTruthy(globalObject, "pong")) |cb| { + if (object.getOwnTruthy(globalObject, "pong")) |cb| { if (!cb.isCallable(vm)) { globalObject.throwInvalidArguments("websocket expects a function for the pong option", .{}); return null; @@ -4354,7 +4354,7 @@ pub const WebSocketServer = struct { return null; } - if (object.get(globalObject, "perMessageDeflate")) |per_message_deflate| { + if (object.getOwn(globalObject, "perMessageDeflate")) |per_message_deflate| { getter: { if (per_message_deflate.isUndefined()) { break :getter; @@ -4369,7 +4369,7 @@ pub const WebSocketServer = struct { break :getter; } - if (per_message_deflate.getTruthy(globalObject, "compress")) |compression| { + if (per_message_deflate.getOwnTruthy(globalObject, "compress")) |compression| { if (compression.isBoolean()) { server.compression |= if (compression.toBoolean()) uws.SHARED_COMPRESSOR else 0; } else if (compression.isString()) { @@ -4389,7 +4389,7 @@ pub const WebSocketServer = struct { } } - if (per_message_deflate.getTruthy(globalObject, "decompress")) |compression| { + if (per_message_deflate.getOwnTruthy(globalObject, "decompress")) |compression| { if (compression.isBoolean()) { server.compression |= if (compression.toBoolean()) uws.SHARED_DECOMPRESSOR else 0; } else if (compression.isString()) { @@ -4411,7 +4411,7 @@ pub const WebSocketServer = struct { } } - if (object.get(globalObject, "maxPayloadLength")) |value| { + if (object.getOwn(globalObject, "maxPayloadLength")) |value| { if (!value.isUndefinedOrNull()) { if (!value.isAnyInt()) { globalObject.throwInvalidArguments("websocket expects maxPayloadLength to be an integer", .{}); @@ -4421,7 +4421,7 @@ pub const WebSocketServer = struct { } } - if (object.get(globalObject, "idleTimeout")) |value| { + if (object.getOwn(globalObject, "idleTimeout")) |value| { if (!value.isUndefinedOrNull()) { if (!value.isAnyInt()) { globalObject.throwInvalidArguments("websocket expects idleTimeout to be an integer", .{}); @@ -4441,7 +4441,7 @@ pub const WebSocketServer = struct { server.idleTimeout = idleTimeout; } } - if (object.get(globalObject, "backpressureLimit")) |value| { + if (object.getOwn(globalObject, "backpressureLimit")) |value| { if (!value.isUndefinedOrNull()) { if (!value.isAnyInt()) { globalObject.throwInvalidArguments("websocket expects backpressureLimit to be an integer", .{}); @@ -4452,7 +4452,7 @@ pub const WebSocketServer = struct { } } - if (object.get(globalObject, "closeOnBackpressureLimit")) |value| { + if (object.getOwn(globalObject, "closeOnBackpressureLimit")) |value| { if (!value.isUndefinedOrNull()) { if (!value.isBoolean()) { globalObject.throwInvalidArguments("websocket expects closeOnBackpressureLimit to be a boolean", .{}); @@ -4463,7 +4463,7 @@ pub const WebSocketServer = struct { } } - if (object.get(globalObject, "sendPings")) |value| { + if (object.getOwn(globalObject, "sendPings")) |value| { if (!value.isUndefinedOrNull()) { if (!value.isBoolean()) { globalObject.throwInvalidArguments("websocket expects sendPings to be a boolean", .{}); @@ -4474,7 +4474,7 @@ pub const WebSocketServer = struct { } } - if (object.get(globalObject, "publishToSelf")) |value| { + if (object.getOwn(globalObject, "publishToSelf")) |value| { if (!value.isUndefinedOrNull()) { if (!value.isBoolean()) { globalObject.throwInvalidArguments("websocket expects publishToSelf to be a boolean", .{}); diff --git a/src/bun.js/base.zig b/src/bun.js/base.zig index db0b0ae1ba2d0f..94b2e07c14a7f6 100644 --- a/src/bun.js/base.zig +++ b/src/bun.js/base.zig @@ -1103,7 +1103,7 @@ pub fn wrapInstanceMethod( }, ?JSC.Cloudflare.ContentOptions => { if (iter.nextEat()) |content_arg| { - if (content_arg.get(globalThis.ptr(), "html")) |html_val| { + if (content_arg.getOwn(globalThis.ptr(), "html")) |html_val| { args[i] = .{ .html = html_val.toBoolean() }; } } else { @@ -1267,7 +1267,7 @@ pub fn wrapStaticMethod( }, ?JSC.Cloudflare.ContentOptions => { if (iter.nextEat()) |content_arg| { - if (content_arg.get(globalThis.ptr(), "html")) |html_val| { + if (content_arg.getOwn(globalThis.ptr(), "html")) |html_val| { args[i] = .{ .html = html_val.toBoolean() }; } } else { diff --git a/src/bun.js/bindings/bindings.cpp b/src/bun.js/bindings/bindings.cpp index 5ef057876a4185..2c69eb1a9fdc08 100644 --- a/src/bun.js/bindings/bindings.cpp +++ b/src/bun.js/bindings/bindings.cpp @@ -4883,7 +4883,7 @@ extern "C" void JSC__VM__getAPILock(JSC::VM* vm) vm->apiLock().lock(); } -extern "C" void JSC__VM__releaseAPILock(JSC::VM* vm) +extern "C" void JSC__VM__releaseAPILock(JSC::VM* vm) { // https://github.com/WebKit/WebKit/blob/6cb5017d237ef7cb898582a22f05acca22322845/Source/JavaScriptCore/runtime/JSLock.cpp#L72 RefPtr apiLock(&vm->apiLock()); @@ -5097,6 +5097,20 @@ JSC__JSValue JSC__JSValue__fastGet_(JSC__JSValue JSValue0, JSC__JSGlobalObject* return JSValue::encode(value.getObject()->getIfPropertyExists(globalObject, builtinNameMap(globalObject, arg2))); } +extern "C" JSC__JSValue JSC__JSValue__fastGetOwn(JSC__JSValue JSValue0, JSC__JSGlobalObject* globalObject, unsigned char arg2) +{ + JSC::JSValue value = JSC::JSValue::decode(JSValue0); + ASSERT(value.isCell()); + PropertySlot slot = PropertySlot(value, PropertySlot::InternalMethodType::GetOwnProperty); + const Identifier name = builtinNameMap(globalObject, arg2); + auto* object = value.getObject(); + if (object->getOwnPropertySlot(object, globalObject, name, slot)) { + return JSValue::encode(slot.getValue(globalObject, name)); + } + + return JSValue::encode({}); +} + bool JSC__JSValue__toBooleanSlow(JSC__JSValue JSValue0, JSC__JSGlobalObject* globalObject) { return JSValue::decode(JSValue0).toBoolean(globalObject); diff --git a/src/bun.js/bindings/bindings.zig b/src/bun.js/bindings/bindings.zig index e18a6fa776ffa8..2e9d427843a43b 100644 --- a/src/bun.js/bindings/bindings.zig +++ b/src/bun.js/bindings/bindings.zig @@ -5128,6 +5128,16 @@ pub const JSValue = enum(JSValueReprInt) { return cppFn("fastGet_", .{ this, global, builtin_name }); } + extern fn JSC__JSValue__fastGetOwn(value: JSValue, globalObject: *JSGlobalObject, property: BuiltinName) JSValue; + pub fn fastGetOwn(this: JSValue, global: *JSGlobalObject, builtin_name: BuiltinName) ?JSValue { + const result = JSC__JSValue__fastGetOwn(this, global, builtin_name); + if (result == .zero) { + return null; + } + + return result; + } + pub fn fastGetDirect_(this: JSValue, global: *JSGlobalObject, builtin_name: u8) JSValue { return cppFn("fastGetDirect_", .{ this, global, builtin_name }); } @@ -5199,6 +5209,15 @@ pub const JSValue = enum(JSValueReprInt) { return if (@intFromEnum(value) != 0) value else return null; } + pub fn getOwnTruthy(this: JSValue, global: *JSGlobalObject, property_name: anytype) ?JSValue { + if (getOwn(this, global, property_name)) |prop| { + if (prop == .undefined) return null; + return prop; + } + + return null; + } + /// safe to use on any JSValue pub fn implementsToString(this: JSValue, global: *JSGlobalObject) bool { if (!this.isObject()) @@ -5208,6 +5227,14 @@ pub const JSValue = enum(JSValueReprInt) { return function.isCell() and function.isCallable(global.vm()); } + pub fn getOwnTruthyComptime(this: JSValue, global: *JSGlobalObject, comptime property: []const u8) ?JSValue { + if (comptime bun.ComptimeEnumMap(BuiltinName).has(property)) { + return fastGetOwn(this, global, @field(BuiltinName, property)); + } + + return getOwnTruthy(this, global, property); + } + pub fn getTruthyComptime(this: JSValue, global: *JSGlobalObject, comptime property: []const u8) ?JSValue { if (comptime bun.ComptimeEnumMap(BuiltinName).has(property)) { if (fastGet(this, global, @field(BuiltinName, property))) |prop| { @@ -5295,18 +5322,48 @@ pub const JSValue = enum(JSValueReprInt) { return null; } - pub fn getArray(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8) JSError!?JSValue { - if (getTruthy(this, globalThis, property_name)) |prop| { - if (!prop.jsTypeLoose().isArray()) { - globalThis.throwInvalidArguments(property_name ++ " must be an array", .{}); - return error.JSError; + pub fn getOwnOptionalEnum(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8, comptime Enum: type) JSError!?Enum { + if (comptime BuiltinName.has(property_name)) { + if (fastGetOwn(this, globalThis, @field(BuiltinName, property_name))) |prop| { + if (prop.isEmptyOrUndefinedOrNull()) + return null; + return try toEnum(prop, globalThis, property_name, Enum); } + return null; + } - if (prop.getLength(globalThis) == 0) { + if (getOwn(this, globalThis, property_name)) |prop| { + if (prop.isEmptyOrUndefinedOrNull()) return null; - } + return try toEnum(prop, globalThis, property_name, Enum); + } + return null; + } - return prop; + pub fn coerceToArray(prop: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8) JSError!?JSValue { + if (!prop.jsTypeLoose().isArray()) { + globalThis.throwInvalidArguments(property_name ++ " must be an array", .{}); + return error.JSError; + } + + if (prop.getLength(globalThis) == 0) { + return null; + } + + return prop; + } + + pub fn getArray(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8) JSError!?JSValue { + if (getTruthy(this, globalThis, property_name)) |prop| { + return coerceToArray(prop, globalThis, property_name); + } + + return null; + } + + pub fn getOwnArray(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8) JSError!?JSValue { + if (getOwnTruthy(this, globalThis, property_name)) |prop| { + return coerceToArray(prop, globalThis, property_name); } return null; @@ -5325,6 +5382,19 @@ pub const JSValue = enum(JSValueReprInt) { return null; } + pub fn getOwnObject(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8) JSError!?JSValue { + if (getOwnTruthy(this, globalThis, property_name)) |prop| { + if (!prop.jsTypeLoose().isObject()) { + globalThis.throwInvalidArguments(property_name ++ " must be an object", .{}); + return error.JSError; + } + + return prop; + } + + return null; + } + pub fn getFunction(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8) JSError!?JSValue { if (getTruthy(this, globalThis, property_name)) |prop| { if (!prop.isCell() or !prop.isCallable(globalThis.vm())) { @@ -5338,6 +5408,46 @@ pub const JSValue = enum(JSValueReprInt) { return null; } + pub fn getOwnFunction(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8) JSError!?JSValue { + if (getOwnTruthy(this, globalThis, property_name)) |prop| { + if (!prop.isCell() or !prop.isCallable(globalThis.vm())) { + globalThis.throwInvalidArguments(property_name ++ " must be a function", .{}); + return error.JSError; + } + + return prop; + } + + return null; + } + fn coerceOptional(prop: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8, comptime T: type) JSError!?T { + switch (comptime T) { + bool => { + if (prop.isBoolean()) { + return prop.toBoolean(); + } + + if (prop.isNumber()) { + return prop.coerce(f64, globalThis) != 0; + } + + globalThis.throwInvalidArguments(property_name ++ " must be a boolean", .{}); + return error.JSError; + }, + ZigString.Slice => { + if (prop.isString()) { + if (return prop.toSliceOrNull(globalThis)) |str| { + return str; + } + } + + globalThis.throwInvalidArguments(property_name ++ " must be a string", .{}); + return error.JSError; + }, + else => @compileError("TODO:" ++ @typeName(T)), + } + } + pub fn getOptional(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8, comptime T: type) JSError!?T { const prop = (if (comptime BuiltinName.has(property_name)) fastGet(this, globalThis, @field(BuiltinName, property_name)) @@ -5345,31 +5455,20 @@ pub const JSValue = enum(JSValueReprInt) { get(this, globalThis, property_name)) orelse return null; if (!prop.isEmptyOrUndefinedOrNull()) { - switch (comptime T) { - bool => { - if (prop.isBoolean()) { - return prop.toBoolean(); - } + return coerceOptional(prop, globalThis, property_name, T); + } - if (prop.isNumber()) { - return prop.coerce(f64, globalThis) != 0; - } + return null; + } - globalThis.throwInvalidArguments(property_name ++ " must be a boolean", .{}); - return error.JSError; - }, - ZigString.Slice => { - if (prop.isString()) { - if (return prop.toSliceOrNull(globalThis)) |str| { - return str; - } - } + pub fn getOwnOptional(this: JSValue, globalThis: *JSGlobalObject, comptime property_name: []const u8, comptime T: type) JSError!?T { + const prop = (if (comptime BuiltinName.has(property_name)) + fastGetOwn(this, globalThis, @field(BuiltinName, property_name)) + else + getOwn(this, globalThis, property_name)) orelse return null; - globalThis.throwInvalidArguments(property_name ++ " must be a string", .{}); - return error.JSError; - }, - else => @compileError("TODO:" ++ @typeName(T)), - } + if (!prop.isEmptyOrUndefinedOrNull()) { + return coerceOptional(prop, globalThis, property_name, T); } return null; diff --git a/src/bun.js/node/node_fs.zig b/src/bun.js/node/node_fs.zig index c8468290fb5d38..b55b957a4b2a1d 100644 --- a/src/bun.js/node/node_fs.zig +++ b/src/bun.js/node/node_fs.zig @@ -2275,7 +2275,7 @@ pub const Arguments = struct { }, else => { if (val.isObject()) { - if (val.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding_| { + if (val.get(ctx.ptr(), "encoding")) |encoding_| { encoding = Encoding.fromJS(encoding_, ctx.ptr()) orelse Encoding.utf8; } } @@ -2327,7 +2327,7 @@ pub const Arguments = struct { }, else => { if (val.isObject()) { - if (val.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding_| { + if (val.get(ctx.ptr(), "encoding")) |encoding_| { encoding = Encoding.fromJS(encoding_, ctx.ptr()) orelse Encoding.utf8; } } @@ -2498,7 +2498,7 @@ pub const Arguments = struct { recursive = boolean; } - if (val.getIfPropertyExists(ctx.ptr(), "mode")) |mode_| { + if (val.get(ctx.ptr(), "mode")) |mode_| { mode = JSC.Node.modeFromJS(ctx, mode_, exception) orelse mode; if (exception.* != null) return null; } @@ -2559,7 +2559,7 @@ pub const Arguments = struct { }, else => { if (val.isObject()) { - if (val.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding_| { + if (val.get(ctx.ptr(), "encoding")) |encoding_| { encoding = Encoding.fromJS(encoding_, ctx.ptr()) orelse Encoding.utf8; } } @@ -2630,7 +2630,7 @@ pub const Arguments = struct { }, else => { if (val.isObject()) { - if (val.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding_| { + if (val.get(ctx.ptr(), "encoding")) |encoding_| { encoding = Encoding.fromJS(encoding_, ctx.ptr()) orelse Encoding.utf8; } @@ -3208,7 +3208,7 @@ pub const Arguments = struct { return null; }; } else if (arg.isObject()) { - if (arg.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding_| { + if (arg.get(ctx.ptr(), "encoding")) |encoding_| { if (!encoding_.isUndefinedOrNull()) { encoding = Encoding.fromJS(encoding_, ctx.ptr()) orelse { if (exception.* == null) { @@ -3447,7 +3447,7 @@ pub const Arguments = struct { return null; }; } else if (arg.isObject()) { - if (arg.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding_| { + if (arg.get(ctx.ptr(), "encoding")) |encoding_| { if (!encoding_.isUndefinedOrNull()) { encoding = Encoding.fromJS(encoding_, ctx.ptr()) orelse { if (exception.* == null) { @@ -3463,7 +3463,7 @@ pub const Arguments = struct { } } - if (arg.getIfPropertyExists(ctx.ptr(), "bufferSize")) |buffer_size_| { + if (arg.get(ctx.ptr(), "bufferSize")) |buffer_size_| { buffer_size = buffer_size_.toInt32(); if (buffer_size < 0) { if (exception.* == null) { @@ -3622,7 +3622,7 @@ pub const Arguments = struct { return null; }; } else if (arg.isObject()) { - if (arg.getIfPropertyExists(ctx.ptr(), "mode")) |mode_| { + if (arg.get(ctx.ptr(), "mode")) |mode_| { stream.mode = JSC.Node.modeFromJS(ctx, mode_, exception) orelse { if (exception.* != null) { JSC.throwInvalidArguments( @@ -3636,7 +3636,7 @@ pub const Arguments = struct { }; } - if (arg.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding| { + if (arg.get(ctx.ptr(), "encoding")) |encoding| { stream.encoding = Encoding.fromJS(encoding, ctx.ptr()) orelse { if (exception.* != null) { JSC.throwInvalidArguments( @@ -3664,7 +3664,7 @@ pub const Arguments = struct { }; } - if (arg.getIfPropertyExists(ctx.ptr(), "fd")) |flags| { + if (arg.get(ctx.ptr(), "fd")) |flags| { fd = JSC.Node.fileDescriptorFromJS(ctx, flags, exception) orelse { if (exception.* != null) { JSC.throwInvalidArguments( @@ -3678,23 +3678,23 @@ pub const Arguments = struct { }; } - if (arg.getIfPropertyExists(ctx.ptr(), "autoClose")) |autoClose| { + if (arg.get(ctx.ptr(), "autoClose")) |autoClose| { stream.autoClose = autoClose.toBoolean(); } - if (arg.getIfPropertyExists(ctx.ptr(), "emitClose")) |emitClose| { + if (arg.get(ctx.ptr(), "emitClose")) |emitClose| { stream.emitClose = emitClose.toBoolean(); } - if (arg.getIfPropertyExists(ctx.ptr(), "start")) |start| { + if (arg.get(ctx.ptr(), "start")) |start| { stream.start = start.coerce(i32, ctx); } - if (arg.getIfPropertyExists(ctx.ptr(), "end")) |end| { + if (arg.get(ctx.ptr(), "end")) |end| { stream.end = end.coerce(i32, ctx); } - if (arg.getIfPropertyExists(ctx.ptr(), "highWaterMark")) |highwaterMark| { + if (arg.get(ctx.ptr(), "highWaterMark")) |highwaterMark| { stream.highwater_mark = highwaterMark.toU32(); } } @@ -3760,7 +3760,7 @@ pub const Arguments = struct { return null; }; } else if (arg.isObject()) { - if (arg.getIfPropertyExists(ctx.ptr(), "mode")) |mode_| { + if (arg.get(ctx.ptr(), "mode")) |mode_| { stream.mode = JSC.Node.modeFromJS(ctx, mode_, exception) orelse { if (exception.* != null) { JSC.throwInvalidArguments( @@ -3774,7 +3774,7 @@ pub const Arguments = struct { }; } - if (arg.getIfPropertyExists(ctx.ptr(), "encoding")) |encoding| { + if (arg.get(ctx.ptr(), "encoding")) |encoding| { stream.encoding = Encoding.fromJS(encoding, ctx.ptr()) orelse { if (exception.* != null) { JSC.throwInvalidArguments( @@ -3802,7 +3802,7 @@ pub const Arguments = struct { }; } - if (arg.getIfPropertyExists(ctx.ptr(), "fd")) |flags| { + if (arg.get(ctx.ptr(), "fd")) |flags| { fd = JSC.Node.fileDescriptorFromJS(ctx, flags, exception) orelse { if (exception.* != null) { JSC.throwInvalidArguments( @@ -3816,15 +3816,15 @@ pub const Arguments = struct { }; } - if (arg.getIfPropertyExists(ctx.ptr(), "autoClose")) |autoClose| { + if (arg.get(ctx.ptr(), "autoClose")) |autoClose| { stream.autoClose = autoClose.toBoolean(); } - if (arg.getIfPropertyExists(ctx.ptr(), "emitClose")) |emitClose| { + if (arg.get(ctx.ptr(), "emitClose")) |emitClose| { stream.emitClose = emitClose.toBoolean(); } - if (arg.getIfPropertyExists(ctx.ptr(), "start")) |start| { + if (arg.get(ctx.ptr(), "start")) |start| { stream.start = start.toInt32(); } } diff --git a/src/bun.js/test/pretty_format.zig b/src/bun.js/test/pretty_format.zig index 9f25a93d7c0d28..3b2720b995df05 100644 --- a/src/bun.js/test/pretty_format.zig +++ b/src/bun.js/test/pretty_format.zig @@ -443,7 +443,7 @@ pub const JestPrettyFormat = struct { // Is this a react element? if (js_type.isObject()) { - if (value.get(globalThis, "$$typeof")) |typeof_symbol| { + if (value.getOwnTruthy(globalThis, "$$typeof")) |typeof_symbol| { var reactElement = ZigString.init("react.element"); var react_fragment = ZigString.init("react.fragment"); diff --git a/src/bun.js/webcore.zig b/src/bun.js/webcore.zig index 26aa7f7c18af82..87797253b11302 100644 --- a/src/bun.js/webcore.zig +++ b/src/bun.js/webcore.zig @@ -403,7 +403,7 @@ pub const Crypto = struct { return .zero; } - if (options_value.getTruthy(globalThis, "cost") orelse options_value.get(globalThis, "N")) |N_value| { + if (options_value.getOwnTruthy(globalThis, "cost") orelse options_value.getOwnTruthy(globalThis, "N")) |N_value| { if (cost != null) return throwInvalidParameter(globalThis); const N_int = N_value.to(i64); if (N_int < 0 or !N_value.isNumber()) { @@ -418,7 +418,7 @@ pub const Crypto = struct { } } - if (options_value.getTruthy(globalThis, "blockSize") orelse options_value.get(globalThis, "r")) |r_value| { + if (options_value.getOwnTruthy(globalThis, "blockSize") orelse options_value.getOwn(globalThis, "r")) |r_value| { if (blockSize != null) return throwInvalidParameter(globalThis); const r_int = r_value.to(i64); if (r_int < 0 or !r_value.isNumber()) { @@ -433,7 +433,7 @@ pub const Crypto = struct { } } - if (options_value.getTruthy(globalThis, "parallelization") orelse options_value.get(globalThis, "p")) |p_value| { + if (options_value.getOwnTruthy(globalThis, "parallelization") orelse options_value.getOwn(globalThis, "p")) |p_value| { if (parallelization != null) return throwInvalidParameter(globalThis); const p_int = p_value.to(i64); if (p_int < 0 or !p_value.isNumber()) { @@ -448,7 +448,7 @@ pub const Crypto = struct { } } - if (options_value.getTruthy(globalThis, "maxmem")) |value| { + if (options_value.getOwnTruthy(globalThis, "maxmem")) |value| { const p_int = value.to(i64); if (p_int < 0 or !value.isNumber()) { return throwInvalidParams( diff --git a/src/bun.js/webcore/blob.zig b/src/bun.js/webcore/blob.zig index a66967e74cdd47..069228c7536394 100644 --- a/src/bun.js/webcore/blob.zig +++ b/src/bun.js/webcore/blob.zig @@ -1018,7 +1018,7 @@ pub const Blob = struct { if (args.nextEat()) |options_object| { if (options_object.isObject()) { - if (options_object.getTruthy(globalThis, "createPath")) |create_directory| { + if (options_object.getOwnTruthy(globalThis, "createPath")) |create_directory| { if (!create_directory.isBoolean()) { globalThis.throwInvalidArgumentType("write", "options.createPath", "boolean"); return .zero; diff --git a/src/bun.js/webcore/streams.zig b/src/bun.js/webcore/streams.zig index 9b978eea4a685e..56de7842c7d221 100644 --- a/src/bun.js/webcore/streams.zig +++ b/src/bun.js/webcore/streams.zig @@ -533,7 +533,7 @@ pub const StreamStart = union(Tag) { return .{ .empty = {} }; } - if (value.get(globalThis, "chunkSize")) |chunkSize| { + if (value.getOwn(globalThis, "chunkSize")) |chunkSize| { if (chunkSize.isNumber()) return .{ .chunk_size = @as(Blob.SizeType, @intCast(@as(i52, @truncate(chunkSize.toInt64())))) }; } @@ -557,7 +557,7 @@ pub const StreamStart = union(Tag) { var chunk_size: JSC.WebCore.Blob.SizeType = 0; var empty = true; - if (value.get(globalThis, "asUint8Array")) |val| { + if (value.getOwn(globalThis, "asUint8Array")) |val| { if (val.isBoolean()) { as_uint8array = val.toBoolean(); empty = false; diff --git a/src/bundler.zig b/src/bundler.zig index 4c09202e2bdb79..6d79465e43f5c1 100644 --- a/src/bundler.zig +++ b/src/bundler.zig @@ -143,7 +143,7 @@ pub const PluginRunner = struct { bun.String.init(importer), target, ) orelse return null; - const path_value = on_resolve_plugin.get(global, "path") orelse return null; + const path_value = on_resolve_plugin.getOwn(global, "path") orelse return null; if (path_value.isEmptyOrUndefinedOrNull()) return null; if (!path_value.isString()) { log.addError(null, loc, "Expected \"path\" to be a string") catch unreachable; @@ -176,7 +176,7 @@ pub const PluginRunner = struct { } var static_namespace = true; const user_namespace: bun.String = brk: { - if (on_resolve_plugin.get(global, "namespace")) |namespace_value| { + if (on_resolve_plugin.getOwn(global, "namespace")) |namespace_value| { if (!namespace_value.isString()) { log.addError(null, loc, "Expected \"namespace\" to be a string") catch unreachable; return null; @@ -242,7 +242,7 @@ pub const PluginRunner = struct { importer, target, ) orelse return null; - const path_value = on_resolve_plugin.get(global, "path") orelse return null; + const path_value = on_resolve_plugin.getOwn(global, "path") orelse return null; if (path_value.isEmptyOrUndefinedOrNull()) return null; if (!path_value.isString()) { return JSC.ErrorableString.err( @@ -272,7 +272,7 @@ pub const PluginRunner = struct { } var static_namespace = true; const user_namespace: bun.String = brk: { - if (on_resolve_plugin.get(global, "namespace")) |namespace_value| { + if (on_resolve_plugin.getOwn(global, "namespace")) |namespace_value| { if (!namespace_value.isString()) { return JSC.ErrorableString.err( error.JSErrorObject, diff --git a/src/dns.zig b/src/dns.zig index a72765b4b3d68f..9490f7ba85e15e 100644 --- a/src/dns.zig +++ b/src/dns.zig @@ -74,23 +74,23 @@ pub const GetAddrInfo = struct { if (value.isObject()) { var options = Options{}; - if (value.get(globalObject, "family")) |family| { + if (value.getOwn(globalObject, "family")) |family| { options.family = try Family.fromJS(family, globalObject); } - if (value.get(globalObject, "socketType") orelse value.get(globalObject, "socktype")) |socktype| { + if (value.getOwn(globalObject, "socketType") orelse value.getOwn(globalObject, "socktype")) |socktype| { options.socktype = try SocketType.fromJS(socktype, globalObject); } - if (value.get(globalObject, "protocol")) |protocol| { + if (value.getOwn(globalObject, "protocol")) |protocol| { options.protocol = try Protocol.fromJS(protocol, globalObject); } - if (value.get(globalObject, "backend")) |backend| { + if (value.getOwn(globalObject, "backend")) |backend| { options.backend = try Backend.fromJS(backend, globalObject); } - if (value.get(globalObject, "flags")) |flags| { + if (value.getOwn(globalObject, "flags")) |flags| { if (!flags.isNumber()) return error.InvalidFlags; diff --git a/src/shell/shell.zig b/src/shell/shell.zig index 871cab7f92a137..71ce407d9e2d2d 100644 --- a/src/shell/shell.zig +++ b/src/shell/shell.zig @@ -3860,7 +3860,7 @@ pub fn handleTemplateValue( } if (template_value.isObject()) { - if (template_value.getTruthy(globalThis, "raw")) |maybe_str| { + if (template_value.getOwnTruthy(globalThis, "raw")) |maybe_str| { const bunstr = maybe_str.toBunString(globalThis); defer bunstr.deref(); if (!try builder.appendBunStr(bunstr, false)) { diff --git a/test/js/bun/glob/__snapshots__/scan.test.ts.snap b/test/js/bun/glob/__snapshots__/scan.test.ts.snap index db6f6a636a9b64..91b9cce3207afa 100644 --- a/test/js/bun/glob/__snapshots__/scan.test.ts.snap +++ b/test/js/bun/glob/__snapshots__/scan.test.ts.snap @@ -394,6 +394,7 @@ exports[`fast-glob e2e tests patterns regular relative cwd ./*: ./* 1`] = ` [ "./leak.test.ts", "./match.test.ts", + "./proto.test.ts", "./scan.test.ts", "./stress.test.ts", "./util.ts", diff --git a/test/js/bun/glob/proto.test.ts b/test/js/bun/glob/proto.test.ts new file mode 100644 index 00000000000000..8383eb0b0f525f --- /dev/null +++ b/test/js/bun/glob/proto.test.ts @@ -0,0 +1,46 @@ +import { expect, test } from "bun:test"; +import { tempDirWithFiles, tmpdirSync } from "harness"; +import { symlink } from "fs/promises"; +import path from "path"; + +test("Object prototype followSymlinks", async () => { + const dir = tempDirWithFiles("glob-follow", { + "abc/def/file.txt": "file", + "symed/file2.txt": "file", + }); + + await symlink(path.join(dir, "symed"), path.join(dir, "abc/def/sym"), "dir"); + const glob = new Bun.Glob("**/*.txt"); + + const zero = glob.scanSync({ + "cwd": path.join(dir, "abc"), + onlyFiles: true, + followSymlinks: true, + }); + expect([...zero].map(a => a.replaceAll("\\", "/")).sort()).toEqual(["def/file.txt", "def/sym/file2.txt"]); + + const first = glob.scanSync({ + "cwd": path.join(dir, "abc"), + onlyFiles: true, + }); + expect([...first].map(a => a.replaceAll("\\", "/"))).toEqual(["def/file.txt"]); + + Object.defineProperty(Object.prototype, "followSymlinks", { + value: true, + writable: true, + configurable: true, + enumerable: true, + }); + const second = glob.scanSync({ + "cwd": path.join(dir, "abc"), + onlyFiles: true, + }); + expect([...second].map(a => a.replaceAll("\\", "/"))).toEqual(["def/file.txt"]); + delete Object.prototype.followSymlinks; + + const third = glob.scanSync({ + "cwd": path.join(dir, "abc"), + onlyFiles: true, + }); + expect([...third].map(a => a.replaceAll("\\", "/"))).toEqual(["def/file.txt"]); +});