package mcrunch
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=92ba7872a7b1ad686eeec9d0f85b2c1b30b7ad7c60e1ee5625c8f255ba29d7fe
sha512=d092cb165d525d509e0186ea256067f6aceaabdc44eb24586bc8cac4cc93975050107fbd54a03f21eb69c62f2c02b3e22660defda7406b57e7c18427bd075728
doc/README.html
mcrunch
mcrunch is a command-line tool that embeds files into OCaml source code. It reads one or more files and produces an OCaml module where each file's contents are encoded as a hexadecimal string array (or list). The generated module can be statically linked into an OCaml program, giving it access to the file contents at runtime without any I/O operations.
This is useful for embedding static assets (configuration files, templates, certificates, binary data) directly into an OCaml binary.
Installation
$ opam install mcrunchUsage
The simplest invocation takes a file and writes an OCaml module to stdout:
$ mcrunch -f foo.txt
let foo_txt = [| "\x66\x6f\x6f\x0a" |]The OCaml binding name is derived from the filename, with characters like . and % replaced by underscores. You can also specify the binding name explicitly using the name:filename syntax:
$ mcrunch -f contents:foo.txt
let contents = [| "\x66\x6f\x6f\x0a" |]Multiple files can be crunched into a single module:
$ mcrunch -f foo.txt -f bar.txt -o assets.mlIf a filename contains the character :, use the prefix -: to let mcrunch infer the name automatically:
$ mcrunch -f -:path:to:fileOptions
-f,--file [NAME|-:]FILENAMEspecifies a file to crunch. This option can be repeated to include multiple files. An optional name can be given before the filename, separated by:.-o,--output FILENAMEwrites the output to the given file instead of stdout. The file must not already exist. Use-for stdout (the default).-a,--arrayserializes each file's contents as an array of strings. This is the default.-l,--listserializes each file's contents as a list of strings instead of an array.-c,--cols COLSsets the number of octets per line in the hex output. Default is 16, maximum is 256.-uuses uppercase hex letters instead of the default lowercase.--with-commentsappends a human-readable ASCII representation of each line as an OCaml comment:
$ mcrunch -f foo.txt --with-comments
let foo_txt = [| "\x66\x6f\x6f\x0a" |] (* foo. *)Example
Given two files index.html and style.css, you can generate an OCaml module that embeds both:
$ mcrunch -f index.html -f style.css -o static.mlThe resulting static.ml contains two bindings, index_html and style_css, each holding the full file contents as a string array. You can then reference these values from your OCaml program and reconstruct the original content with String.concat "" (for arrays, Array.to_list first).