package mazeppa
A modern supercompiler for call-by-value functional languages
Install
Dune Dependency
Authors
Maintainers
Sources
mazeppa-0.5.0.tar.gz
md5=c8e30c7642772fba62b20edff44f07a0
sha512=13bf59e70461397a1fd6b3039bb247f8e450277c4d490a451610e27968595cc4632592fee97008d8f44e71d7646e5636efa292568d07f024b4b1c25492764dd4
doc/CHANGELOG.html
Changelog
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
unreleased
0.5.0 - 2025-03-23
Added
- The
Symbol.freshen
function that generates a fresh symbol according to a given predicate. - The
Raw_term.let'
shortcut function.
Changed
- Do not share syntactically equal arguments during postprocessing.
- Preserve names of global unknowns and constructor parameters in residual code (refreshing if necessary).
- Use a more lenient WQO for strings: set(s1) = set(s2) /\ length(s1) <= length(s2).
Set the minimum
checked_oint
version requirement to0.4.1
.- This fixes compilation on Fedora Linux, openSUSE, FreeBSD, and Oracle Linux.
Fixed
- Do not simplify /(x, 0) and %(x, 0) to avoid incorrect panic messages (issue https://github.com/mazeppa-dev/mazeppa/issues/25).
- Hide empty reduction paths in CLI error messages (issue https://github.com/mazeppa-dev/mazeppa/issues/27).
- Do not overshadow user-specified symbols during residualization (issue https://github.com/mazeppa-dev/mazeppa/issues/28).
- Perform correct variable shadowing in C output via extra scoping (issue https://github.com/mazeppa-dev/mazeppa/issues/29).
0.4.3 - 2024-11-11
Changed
- Set the minimum
checked_oint
version requirement to0.3.0
.
0.4.2 - 2024-10-19
Changed
- Do not extract operands from calls to primitive operations like
+
(issue https://github.com/mazeppa-dev/mazeppa/issues/24).
0.4.1 - 2024-10-18
Fixed
- Set the minimum
menhir
version requirement to20180905
.
0.4.0 - 2024-10-17
Changed
Preserve the order of built-in panics in residual programs (issue https://github.com/mazeppa-dev/mazeppa/issues/23).
- Algebraic simplification now requires operands to be either variables or constants, not compound values.
Eliminate let-bindings for "innocent terms" via postprocessing.
- Innocent terms are variables, integer constants, and zero-arity constructor calls.
- Set the minimum supported OCaml version to 4.14.0.
- Set the minimum
checked_oint
version requirement to0.2.1
.
Removed
- The function
Const.escape_char
is no longer public [BC].
0.3.4 - 2024-10-12
Changed
Reuse predefined thunks for variables standing as constructor arguments.
- This improves output code size and compilation times when C code generation is used.
0.3.3 - 2024-10-03
Fixed
- Tweak the dependencies in
dune-project
after trying to publish the package.
0.3.2 - 2024-10-02
Added
- Expose the
Gensym
module in the public API (previously private).
0.3.1 - 2024-09-23
Added
- The Mazeppa-to-C translator (with GNU11 extensions) via the new
translate
CLI command (issue https://github.com/mazeppa-dev/mazeppa/issues/1). - The
translate_to_c
andmazeppa_h
API functions.
0.3.0 - 2024-08-16
Added
- The
--print-gc-stats
flag forrun
andeval
to observe total memory usage. - Expose the
check
function in the public API.
Changed
- Optimize homeomorphic embedding by maintaining a local result cache (issue https://github.com/mazeppa-dev/mazeppa/issues/20).
Other homeomorphic embedding performance tweaks (issue https://github.com/mazeppa-dev/mazeppa/issues/17).
- In particular, utilize
Weak
hash consing while building function bodies.
- In particular, utilize
- Rename the functions 1)
Symbol.kind
toop_kind
, 2)Symbol.is_lazy
tois_lazy_op
for clarity [BC]. - Hide the middles of long reduction paths with
(N more...)
(issue https://github.com/mazeppa-dev/mazeppa/issues/21).
Fixed
- Evaluation of built-in panics raising an exception (issue https://github.com/mazeppa-dev/mazeppa/issues/22).
Removed
- The function
Raw_term.is_immediate
is no longer public [BC].
0.2.0 - 2024-08-03
Added
- Propagate positive information for inequality (
!=
) tests (issue https://github.com/mazeppa-dev/mazeppa/issues/7). More simplification rules:
- op(op(t)) -> op(t), where op is one of
u8
,u16
,u32
,u64
,u128
,i8
,i16
,i32
,i64
,i128
,string
. - /(0, t) -> 0
- |(t, all ones), |(all ones, t) -> all ones
- &(t, all ones), &(all ones, t) -> t
- op(op(t)) -> op(t), where op is one of
- Add the
check
command to the CLI for checking program well-formedness (issue https://github.com/mazeppa-dev/mazeppa/issues/18). - Expose the
Symbol.list
function in the public API.
Changed
- Only whistle on terms with equal redex signatures (issues https://github.com/mazeppa-dev/mazeppa/issues/9, https://github.com/mazeppa-dev/mazeppa/issues/11).
- Only whistle on equal integers (issue https://github.com/mazeppa-dev/mazeppa/issues/12).
- Rebuild as less terms as possible when substituting contractions (issue https://github.com/mazeppa-dev/mazeppa/issues/14).
- Optimize homeomorphic embedding by storing term sizes (issue https://github.com/mazeppa-dev/mazeppa/issues/17).
Fixed
- Internal compiler errors when analyzing
T
/F
-patterns during driving. Instead, show proper error messages (issue https://github.com/mazeppa-dev/mazeppa/issues/6). - Incorrect exception backtraces (issue https://github.com/mazeppa-dev/mazeppa/issues/8).
- Require constructors to be used consistently [BC] (issue https://github.com/mazeppa-dev/mazeppa/issues/10).
0.1.2 - 2024-07-20
Added
- Function productivity analysis for preventing unneeded specializations (issue https://github.com/mazeppa-dev/mazeppa/issues/2).
pattern_to_string
andpattern_verbatim
(Raw_term
).
Changed
- Simplify horizontal configuration analysis by only checking for renamings instead of matching arbitrary safe instances.
- Do not emit 1) linear let-bindings for redexes, 2) unused let-bindings for immediate terms.
0.1.1 - 2024-07-15
Added
mazeppa eval
: A built-in evaluator for the Mazeppa language (issue https://github.com/mazeppa-dev/mazeppa/issues/5).- Expose the
Const
module in the public API.
Changed
The following simplification rules have been upgraded to handle arbitrary values instead of variables:
- *(x, 0), *(0, x) -> 0
- &(x, 0), &(0, x) -> 0
- %(x, 1) -> 0
- /(x, 0), %(x, 0) -> out of range
- |(x, x), &(x, x) -> x
- =(x, x), >=(x, x), <=(x, x) -> T()
- !=(x, x), >(x, x), <(x, x) -> F()
0.1.0 - 2024-07-11
Added
- The Mazeppa supercompiler.
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
On This Page