diff options
| author | 2022-03-17 19:18:08 -0700 | |
|---|---|---|
| committer | 2022-03-17 19:18:08 -0700 | |
| commit | 881a3b28a7b28475a06f8508c6ff2ab375275dba (patch) | |
| tree | 47812d91bf44cf2bdcb4e3751490a94a5497d268 /src/javascript/jsc/api | |
| parent | b3f4f8db24b6f9e0fc5e88eec08174df466672a1 (diff) | |
| download | bun-881a3b28a7b28475a06f8508c6ff2ab375275dba.tar.gz bun-881a3b28a7b28475a06f8508c6ff2ab375275dba.tar.zst bun-881a3b28a7b28475a06f8508c6ff2ab375275dba.zip | |
[bun.js] Implement `import.meta.resolve`
Diffstat (limited to 'src/javascript/jsc/api')
| -rw-r--r-- | src/javascript/jsc/api/bun.zig | 42 | 
1 files changed, 18 insertions, 24 deletions
| diff --git a/src/javascript/jsc/api/bun.zig b/src/javascript/jsc/api/bun.zig index e2af7ed95..c66c5f0f1 100644 --- a/src/javascript/jsc/api/bun.zig +++ b/src/javascript/jsc/api/bun.zig @@ -698,7 +698,7 @@ fn doResolve(          return null;      } -    return doResolveWithArgs(ctx, specifier.getZigString(ctx.ptr()), from.getZigString(ctx.ptr()), exception); +    return doResolveWithArgs(ctx, specifier.getZigString(ctx.ptr()), from.getZigString(ctx.ptr()), exception, false);  }  fn doResolveWithArgs( @@ -706,15 +706,25 @@ fn doResolveWithArgs(      specifier: ZigString,      from: ZigString,      exception: js.ExceptionRef, +    comptime is_file_path: bool,  ) ?JSC.JSValue {      var errorable: ErrorableZigString = undefined; -    VirtualMachine.resolveForAPI( -        &errorable, -        ctx.ptr(), -        specifier, -        from, -    ); +    if (comptime is_file_path) { +        VirtualMachine.resolve( +            &errorable, +            ctx.ptr(), +            specifier, +            from, +        ); +    } else { +        VirtualMachine.resolveForAPI( +            &errorable, +            ctx.ptr(), +            specifier, +            from, +        ); +    }      if (!errorable.success) {          exception.* = bun.cast(JSC.JSValueRef, errorable.result.err.ptr.?); @@ -759,22 +769,7 @@ export fn Bun__resolve(  ) JSC.JSValue {      var exception_ = [1]JSC.JSValueRef{null};      var exception = &exception_; -    const value = doResolveWithArgs(global.ref(), specifier.getZigString(global), source.getZigString(global), exception) orelse { -        return JSC.JSPromise.rejectedPromiseValue(global, JSC.JSValue.fromRef(exception[0])); -    }; -    return JSC.JSPromise.resolvedPromiseValue(global, value); -} - -export fn Bun__resolveSync( -    global: *JSGlobalObject, -    specifier: JSValue, -    source: JSValue, -    exception_: ?*JSValue, -) JSC.JSValue { -    var exception_ = [1]JSC.JSValueRef{null}; -    var exception = &exception_; -    exception_.* = exception[0]; -    const value = doResolveWithArgs(global.ref(), specifier.getZigString(global), source.getZigString(global), exception) orelse { +    const value = doResolveWithArgs(global.ref(), specifier.getZigString(global), source.getZigString(global), exception, true) orelse {          return JSC.JSPromise.rejectedPromiseValue(global, JSC.JSValue.fromRef(exception[0]));      };      return JSC.JSPromise.resolvedPromiseValue(global, value); @@ -783,7 +778,6 @@ export fn Bun__resolveSync(  comptime {      if (!is_bindgen) {          _ = Bun__resolve; -        _ = Bun__resolveSync;      }  } | 
