Skip to content

Commit

Permalink
Update for spicy-1.12.0 release.
Browse files Browse the repository at this point in the history
  • Loading branch information
bbannier committed Jan 6, 2025
1 parent 6be5c6d commit d300532
Show file tree
Hide file tree
Showing 3 changed files with 111 additions and 25 deletions.
132 changes: 109 additions & 23 deletions NEWS.rst
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,22 @@ This following summarizes the most important changes in recent Spicy releases.
For an exhaustive list of all changes, see the :repo:`CHANGES` file coming with
the distribution.

Version 1.12 (in progress)
Version 1.13 (in progress)
==========================

.. rubric:: New Functionality

.. rubric:: Changed Functionality

.. rubric:: Bug fixes

.. rubric:: Documentation

Version 1.12
============

.. rubric:: New Functionality

- We now support ``if`` around a block of unit items:

.. code-block:: spicy
Expand Down Expand Up @@ -37,47 +48,122 @@ Version 1.12 (in progress)
};
};
- We now support attaching an ``%error`` handler to an individual
field:
- We now support attaching an ``%error`` handler to an individual
field:

.. code-block:: spicy
.. code-block:: spicy
type Test = unit {
a: b"A";
b: b"B" %error { print "field B %error", self; }
c: b"C";
};
type Test = unit {
a: b"A";
b: b"B" %error { print "field B %error", self; }
c: b"C";
};
With input ``AxC``, that handler will trigger, whereas with ``ABx``
it won't. If the unit had a unit-wide ``%error`` handler as well,
that one would trigger in both cases (i.e., for ``b``, in addition
to its field local handler).

The handler can also be provided separately from the field:

With input ``AxC``, that handler will trigger, whereas with ``ABx``
it won't. If the unit had a unit-wide ``%error`` handler as well,
that one would trigger in both cases (i.e., for ``b``, in addition
to its field local handler).
.. code-block:: spicy
on b %error { ... }
In that separate version, one can receive the error message as well by
declaring a corresponding string parameter:

.. code-block:: spicy
on b(msg: string) %error { ... }
This works externally, from outside the unit, as well:

The handler can also be provided separately from the field:
.. code-block:: spicy
.. code-block:: spicy
on Test::b(msg: string) %error { ... }
on b %error { ... }
- GH-1856: We added support for specifying a dedicated error message for ``requires`` failures.

In that separate version, one can receive the error message as well by
declaring a corresponding string parameter:
This now allows creating custom error messages when a ``&require``
condition fails. Example:

.. code-block:: spicy
.. code-block:: spicy
on b(msg: string) %error { ... }
type Foo = unit {
x: uint8 &requires=($$ == 1 : error"Deep trouble!'");
This works externally, from outside the unit, as well:
# or, shorter:
y: uint8 &requires=($$ == 1 : "Deep trouble!'");
};
.. code-block:: spicy
This is powered by a new condition test expression ``COND : ERROR``.

on Test::b(msg: string) %error { ... }
- We reworked C++ code generation so now many parsers should compile faster.
This is accomplished by both improved dependency tracking when emitting C++
code for a module as well as by a couple of new peephole optimization passes
which additionally reduced the emitted code.

.. rubric:: Changed Functionality

- Add ``CMAKE_CXX_FLAGS`` to ``HILTI_CONFIG_RUNTIME_LD_FLAGS``.
- Speed up compilation of many parsers by streamlining generated C++ code.
- Add ``starts_with`` ``split``, ``split1``, ``lower`` and ``upper`` methods to ``string``.
- GH-1874: Add new library function ``spicy::bytes_to_mac``.
- Optimize ``spicy::bytes_to_hexstring`` and ``spicy::bytes_to_mac``.
- Improve validation of attributes so incompatible or invalid attributes should be rejected more reliably.
- Optimize parsing for ``bytes`` of fixed size as well as literals.
- Add a couple of peephole optimizations to reduce emitted C++ code.
- GH-1790: Provide proper error message when trying access an unknown unit field.
- GH-1792: Prioritize error message reporting unknown field.
- GH-1803: Fix namespacing of ``hilti`` IDs in Spicy-side diagnostic output.
- GH-1895: Do no longer escape backslashes when printing strings or bytes.
- GH-1857: Support ``&requires`` for individual vector items.
- GH-1859: Improve error message when a unit parameter is used as a field.
- GH-1898: Disallow attributes on "type aliases".
- GH-1938: Deprecate ``&count`` attribute.
- GH-1928: Deprecate ``&anchor`` with regular expression constructors.
- GH-1935: Allow defining parser alias names when running spicy-driver.

.. rubric:: Bug fixes

- GH-1815: Disallow expanding limited ``View``'s again with ``limit``.
- Fix ``to_uint(ByteOrder)`` for empty byte ranges.
- Fix undefined shifts of 32bit integer in ``toInt()``.
- GH-1817: Prevent null ptr dereference when looking on nodes without ``Scope``.
- Fix use of move'd from variable.
- GH-1823: Don't qualify magic linker symbols with C++ namespace.
- Fix diagnostics seen when compiling with GCC.
- GH-1852: Fix ``skip`` with units.
- GH-1832: Fail for vectors with bytes but no stop.
- GH-1860: Fix parsing for vectors of literals.
- GH-1847: Fix resynchronization issue with trimmed input.
- GH-1844: Fix nested look-ahead parsing.
- GH-1842: Fix when input redirection becomes visible.
- GH-1846: Fix bug with captures groups.
- GH-1875: Fix potential nullptr dereference when comparing streams.
- GH-1867: Fix infinite loops with recursive types.
- GH-1868: Associate source code locations with current fiber instead of current thread.
- GH-1871: Fix ``&max-size`` on unit containing a ``switch``.
- GH-1791: Fix usage of ``&convert`` with unit's requiring parameters.
- GH-1858: Fix the literals parsers not following coercions.
- GH-1893: Encompass child node's location in parent.
- GH-1919: Validate that sets are sortable.
- GH-1918: Fix potential segfault with stream iterators.
- GH-1856: Disallow dereferencing a ``result<void>`` value.
- Fix issue with type inference for ``result`` constructor.
- GH-1933: Fix ``HILTI_CXX_FLAGS`` for when multiple flags are passed.
- GH-1829: Catch integer shifts exceeding the width of the operand.

.. rubric:: Documentation

- Redo error handling docs
- Document ``continue`` statements.
- GH-1063: Document arguments to ``new`` operator.
- Updates ``<bytes>.to_int()``/``<bytes>.to_uint()`` documentation.
- GH-1914: Make ``$$`` documentation more precise.
- Fix doc code snippet that won't compile.

Version 1.11
============

Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
<tr>
<td>Build status</td>
<td>
<a href="https://cirrus-ci.com/github/zeek/spicy/release/1.11"><img src="https://api.cirrus-ci.com/github/zeek/spicy.svg?branch=release/1.11" alt="Build status release"></a>
<a href="https://cirrus-ci.com/github/zeek/spicy/release/1.12"><img src="https://api.cirrus-ci.com/github/zeek/spicy.svg?branch=release/1.12" alt="Build status release"></a>
</td>
<td>
<a href="https://cirrus-ci.com/github/zeek/spicy/main"><img src="https://api.cirrus-ci.com/github/zeek/spicy.svg" alt="Build status development"></a>
Expand Down
2 changes: 1 addition & 1 deletion doc/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
author = "Zeek Project"

version = open("../VERSION").readline()
release = "1.11.3" # most recent release version
release = "1.12.0" # most recent release version

# -- General configuration ---------------------------------------------------

Expand Down

0 comments on commit d300532

Please sign in to comment.