0.2.4 • Published 9 months ago

bimba-cli v0.2.4

Weekly downloads
-
License
MIT
Repository
github
Last release
9 months ago

This tool helps to work with Imba projects under Bun. That is why it is called Bun+IMBA = BIMBA 😉

It includes the plugin for Bun to compile .imba files and also the CLI tool for buiding .imba files, since the plugins can't be passed to Bun via shell command bun build.

First of all install this tool like any other npm package:

bun add bimba-cli -d

Then create a bunfig.toml file in the root folder of your project, and add only one line in it (I could not find any workaround to do this automatically):

preload = ["bimba-cli/plugin.js"]

You are done!

Backend development

Now to run an .imba file in Bun's environment you can use the usual Bun syntax:

bun run src/index.imba

Or with the watch argument:

bun --watch run src/index.imba

Frontend development

For frontend you will need to compile and bundle your source code from .imba to .js. And here the bimba-cli will help:

bunx bimba src/index.imba --outdir public

Or with the watch argument:

bunx bimba src/index.imba --outdir public --watch

Here are all the available argumentsthat you can pass to the bimba:

--watch - Monitors changes in the directory where the entry point is located, and rebuilds the projects when the change occures. Keep entrypoint file in the subfolder, otherwise Bun will trigger several times since the cache dir update also triggers rebuilding.

--clearcache - If is set, the cache directory is deleted when bimba exits. Works only in the watch mode, since when bundling cache will be used next time to speed up the compiling time.

bunx bimba src/index.imba --outdir public --watch --clearcache

--sourcemap - Tells Bun how to inculde sourcemap files in the final .js. It is none by default.

bunx bimba src/index.imba --outdir public --sourcemap inline

--minify - If is set the final JS code in the bundle produced by Bun will be minified. It is false by default.

bunx bimba src/index.imba --outdir public --minify

--platform - The value of this argument will be passed to the Imba compiler. By default it is browswer. The value node does not work under Bun.

bunx bimba src/index.imba --outdir public --platform browser

Live reload

Initially I have implemented the live reload functionality, but then decided to refuse it. There is a pretty good VS Code extension: Lite Server. It does everything needed out of the box.

Just let bimba rebuild the sources on change and Lite Server will reload the page in the browser.

0.2.4

9 months ago

0.2.3

11 months ago

0.2.2

11 months ago

0.2.1

1 year ago

0.2.0

1 year ago

0.1.9

1 year ago

0.1.8

1 year ago

0.1.7

1 year ago

0.1.6

1 year ago

0.1.5

1 year ago

0.1.4

1 year ago

0.1.3

1 year ago

0.1.2

1 year ago

0.1.1

1 year ago