-
Notifications
You must be signed in to change notification settings - Fork 5.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
proposal: separate Caching + TypeScript from Deno core into std #2676
Comments
I would like to simplify core as much as possible. TS support is quite a large amount of complexity. So I'm very open to such ideas. That said, using V8 snapshots allows us to startup TS compilation very quickly - and it's not clear how that could be achieved without building it into core. |
Could you please elaborate on how V8 snapshots make the TS compilation startup faster? I would argue that the compilation startup speed might be negligible compared to the time it takes to compile a typescript file (especially when doing remote fetch, full compilation including type checking and source map generation). Plain TypeScript transpilation is on the other hand quite fast and when js is already in local cache it is completely free. So I would say that the benefit of having the possibility to choose a proper I also think that Deno core should be just a simple browser compatible JS runtime environment. Everything else should probably be implemented as std libraries. EDIT: When I think about it, Deno Core could allow to include a
This way Deno Core remains very lightweight (without TypeScript, Prettier, cache, authorization, module resolution, remote fetch) and all these features are offloaded to external scripts that can be overwritten by the user if necessary. |
First a little clarification. When I referrer to "deno core" I mean the glorified v8 rust bindings( A couple problems here:
We have discussed custom compilers before, and I think the basic requirements boil down to:
If what you want is the ability to customize a javascript runtime(more easily than embedding v8), I'm working on a lib for embedding deno core in deno cli. I think that would be a better approach to achieve a customized runtime implemented in javascript/typescript. I have a working version, but it only works with a rebase of #2385 ontop of #2612. I hope to be able to bring my lib to deno_std in the future when the necessary prerequisites exist in released version of deno cli. |
I was thinking about it and what I value most about deno is that it aims to strictly follow browser compatibility. The way I proposed the custom module resolution is in direct conflict with how browsers do it and therefore I take it back :). But how about to implement service workers. With service workers people can intercept any request and do their own module resolution, compilation (typescript, flow, prettier) and caching. An example use: main.js:
service-worker.js
In the above example, the Even though I love typescript I see it as breaking browser compatibility. E.g. browser does not care about import file extensions but it is a crucial information for Deno to distinguish between javascript files and typescript files. So what would work in browser will not work in Deno. To assure browser compatibility, there should probably be an option in Deno to deactivate typescript. You could also consider moving the typescript compilation into a default Deno service worker. That way it would be possible to overwrite the default service worker by providing a custom service worker. |
The compiler is currently implemented as a web worker, though it isn't exposed or started via the main runtime isolate. Service Workers are a specific type of web worker geared for proxying network requests. Not really designed for what the compiler does/needs to do. |
We define browser compatibility this way in the manual:
|
I propose to separate Caching and TypeScript compilation from Deno to a separate std library. I believe that both scenarios could be solved by the following trick:
where resolveModule has type of
(importPath: string) => Promise<string (javascript text)>
.resolveModule
function can throw / reject which would show an error in Deno console.As I see it, the
resolveModule
function could support caching, transpilation, type checking, source maps, prettier and other things that are currently included in Deno core. It could also support the future versions of TypeScript or other compilers such asFlow
etc.You could provide a default
import.meta.resolveModule
implementation that would do everything Deno does today but would allow to be overwritten if desired.What do you think, is there any reason why it cannot be done?
The text was updated successfully, but these errors were encountered: