https://github.com/yglukhov/closure_compiler
Nim binding to closure compiler
https://github.com/yglukhov/closure_compiler
Last synced: 2 months ago
JSON representation
Nim binding to closure compiler
- Host: GitHub
- URL: https://github.com/yglukhov/closure_compiler
- Owner: yglukhov
- License: mit
- Created: 2015-04-02T12:15:28.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2022-12-18T16:33:25.000Z (almost 3 years ago)
- Last Synced: 2025-04-04T14:51:08.840Z (6 months ago)
- Language: Nim
- Size: 50.9 MB
- Stars: 12
- Watchers: 3
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# closure-compiler
Nim wrapper to [closure compiler](https://developers.google.com/closure/compiler/).# Usage example: nakefile
```Nim
import nake
import browsers
import closure_compilertask "js", "Create Javascript version":
direShell nimExe, "js", "main"
closure_compiler.compileFileAndRewrite("nimcache" / "main.js", ADVANCED_OPTIMIZATIONS)
openDefaultBrowser "main.html"
```
[More about nake](https://github.com/fowlmouth/nake)# Usage example: command line
```sh
nim js main # Compile main.nim and save it to nimcache/main.js
closure_compiler nimcache/main.js # Run closure compiler
```# Why wrapper
The Javascript code generated by Nim is incompatible with Closure compilers advanced
optimization. This wrapper fixes those issues by providing an externs list to the compiler.
The list is formed by analizing the source code.# Performance considerations
The wrapper will first try to find `java` executable and use it to run closure-compiler embedded in the package. If `java` is not found it will fall back to web API. Please note that web API has some limitations:* It is slower than locally installed version.
* There is an input file size limitation.
* It may fail with timeout if your generated `js` file is complex enough.
* It doesn't support source map generation.