Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
bucklescript
Advanced tools
Without POSTINSTALL. Just works
A JavaScript backend for OCaml focused on smooth integration and clean generated code.
You can try BuckleScript directly in your browser. Write OCaml in the left panel and watch as it instantly compiles to JavaScript shown in the right panel.
npm install bucklescript
var bucklescript = require("bucklescript")
var compiledJavascript = bucklescript.compile('let test = 1')
console.log(compiledJavascript)
var bucklescript = require("bucklescript")
var testvar = bucklescript.eval('let test = 1')
console.log(testvar)
See http://bloomberg.github.io/bucklescript/Manual.html for detailed documentation on BuckleScript. If you'd like to contribute content see here for the documentation source.
BuckleScript leverages the existing OCaml compiler and toolchain to produce JavaScript that closely resembles the original OCaml. This has several immediate advantages:
These points make the integration of JavaScript with OCaml very clean and smooth. In this way, BuckleScript provides all the benefits of OCaml's excellent compiler and sophisticated type system alongside the rich cross-platform JavaScript ecosystem.
Basic examples of using BuckleScript are provided below. More extensive examples are available at https://github.com/bloomberg/bucklescript-addons.
This example creates a simple http server. The complete code is available here.
The attribute [@bs]
used in the example below is one of the OCaml attributes mentioned earlier.
When BuckleScript generates code, it may use either a curried (OCaml) or uncurried (JavaScript)
calling convention depending on how the code gets optimized. The [@bs]
attribute can be used to
decorate functions and call-sites so that generated code is guaranteed to use the uncurried style.
This guarentee eases integration with existing JavaScript code and avoids unnecessary overhead.
let port = 3000
let hostname = "127.0.0.1"
let create_server http =
let server = http##createServer begin fun [@bs] req resp ->
resp##statusCode #= 200;
resp##setHeader "Content-Type" "text/plain";
resp##_end "Hello world\n"
end
in
server##listen port hostname begin fun [@bs] () ->
Js.log ("Server running at http://"^ hostname ^ ":" ^ Pervasives.string_of_int port ^ "/")
end
let () = create_server Http_types.http
'use strict';
var Pervasives = require("bs-platform/lib/js/pervasives");
var Http = require("http");
var hostname = "127.0.0.1";
function create_server(http) {
var server = http.createServer(function (_, resp) {
resp.statusCode = 200;
resp.setHeader("Content-Type", "text/plain");
return resp.end("Hello world\n");
});
return server.listen(3000, hostname, function () {
console.log("Server running at http://" + (hostname + (":" + (Pervasives.string_of_int(3000) + "/"))));
return /* () */0;
});
}
create_server(Http);
This example demonstrates the use of immutable data structures. The OCaml code uses the BuckleScript
compiled OCaml standard library. The JavaScript code, given as a point of comparison, uses the
Facebook immutable
library.
This comparison is somewhat contrived but nevertheless the BuckleScript compiled version has several nice characteristics:
Execution Time:
Compiled Size:
module IntMap = Map.Make(struct
type t = int
let compare (x : int) y = compare x y
end)
let test () =
let m = ref IntMap.empty in
let count = 1000000 in
for i = 0 to count do
m := IntMap.add i i !m
done;
for i = 0 to count do
ignore (IntMap.find i !m)
done
let () = test()
immutable
)'use strict';
var Immutable = require('immutable');
var Map = Immutable.Map;
var m = new Map();
function test() {
var count = 1000000;
for(var i = 0; i < count; ++i) {
m = m.set(i, i);
}
for(var j = 0; j < count; ++j) {
m.get(j);
}
}
test();
FAQs
Bucklescript Compiler
The npm package bucklescript receives a total of 0 weekly downloads. As such, bucklescript popularity was classified as not popular.
We found that bucklescript demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.