7.3 KiB
Change Log
Unreleased
Notes
Added
Removed
Changed
Fixed
Deprecated
Contributors
5.0.1 - 2019-08-30
Fixed
- Bench dependencies are now dev-dependencies so they are not listed on crates.io as normal dependencies anymore
5.0.0 - 'Sanity' - 2019-08-30
Notes
Finally, 'Sanity' has been released, including a huge bunch of new features. Notably, and providing a reason for the name of this release, function call and tuple semantics have improved a lot. Functions now always take exactly one argument, but this can then be a tuple. It is now possible to construct tuples of tuples, such that mode complex values can be constructed. As of now there is no way to deconstruct them though.
A lot has been done on string processing, special thanks for that goes to bittrance.
Specifically, under the feature flag regex_support
two regex functions for strings are hiding now.
Also, the operators +
and comparison operators have been fitted to support strings.
Thanks to lovasoa, we now have a nice macro for context creation.
Thanks to Atul9, the crate is now Rust 2018 compliant.
Thanks to mestachs' request, we now have functions to iterate over identifiers within an expression.
Internally, the structure of the operator tree changed from being &dyn
-based to being enum
-based.
Also, we have benchmarks now to observe performance changes in future releases.
Added
- Iterator over all identifiers within an expression, including duplicates
- Iterators over only variable or only function identifiers within an expression, including duplicates
- Overload the
+
operator to concatenate strings - Overload
<
,<=
,>
and>=
for strings using lexical ordering (Note:==
and!=
compare strings as expected) - Add
len
,str::regex_matches
,str::regex_replace
,str::to_lowercase
,str::to_uppercase
,str::trim
functions for strings - Add a macro for more convenient definition of contexts including the direct definition of static contexts
- Add API for value decomposition
- Allow using context operations in
eval
calls without context - Operator assignment operators for each binary operation (
+=
,-=
, ...) - The
Operator
enum is now public for better error types - Benchmarks for observing performance of future releases
Removed
- Function arguments are not decomposed anymore. The function implementation will receive exactly one argument now. This allows the function to be called on a tuple properly.
Changed
- Operators are an enum now instead of trait objects
- Update to Rust 2018
- Updated dependencies
Fixed
- Allow variable assignments in eval calls without context.
A
HashMapContext
is created automatically now. - The error string for
ExpectedNumber
was wrong - Operators panicked when adding a number to a string
- Some documentation was not updated for the 4.x releases
Contributors
My warmhearted thanks goes to
4.1.0 - 2019-03-31
Added
- Export
expect_function_argument_amount
4.0.0 - 2019-03-30
Added
- String constants
3.1.0 - 2019-03-28
Added
- Add serde support to
HashMapContext
- Make
HashMapContext
deriveDefault
andDebug
Changed
- Changed name of serde feature flag to
serde_support
3.0.0 - 2019-03-28
Notes
The 3.0.0 update transforms the expression evaluator evalexpr
to a tiny scripting language.
It allows assignments and chaining of expressions.
Some changes in this update are breaking, hence the major release.
Added
- Methods
Node::eval_<type>_with_context_mut
and crate leveleval_<type>_with_context_mut
- Empty type and corresponding shortcut methods. The empty type is emitted by empty expressions or empty subexpressions
()
. - The assignment operator
=
- The expression chaining operator
;
Removed
- Generic arguments from
Context
traits are now static to allow using trait objects ofContext
EvalexprError::EmptyExpression
is not required anymore since empty expressions now evaluate to the empty type
Changed
- Merge
ContextMut
trait intoContext
trait
2.0.0 - 2019-03-28
Notes
The 2.0.0 update is the first step to transform evalexpr to a tiny scripting language with support of at least variable assignment.
The main change for now is that Configuration
is called Context
, which seems to be a more proper naming for a set of variables that can not only be read, but also manipulated via expressions.
This update includes further renamings and some inconsistencies in the API were fixed.
For more details, see the following subsections.
Added
- Add the
ContextMut
trait, that is a manipulable configuration/context - Add
ContextNotManipulable
error variant for theEmptyContext
- Make the
TupleType
alias public - Add the
ValueType
enum that represents the type of a value for easier comparisons and matchings - Add
EvalexprResult<T>
type that uses theEvalexprError
type (renamed fromError
) - Add
Node::eval_number
andNode::eval_number_with_context
to evaluate to int or float and silently converting to float - Add
eval_number
andeval_number_with_context
crate methods to evaluate to int or float and silently converting to float
Changed
- Get rid of some unwraps to improve safety
- Rename
Error
toEvalexprError
- Rename
Configuration
toContext
- Rename
HashMapConfiguration
toHashMapContext
andEmptyConfiguration
toEmptyContext
- Rename
Value::as_float
toValue::as_number
and add newValue::as_float
that fails if value is an integer
1.2.0 - 2019-03-23
Added
- Add
serde
feature - Implement
serde::de::Deserialize
forNode
- Document
serde
usage - Add custom error type with a
String
message
Changed
- Highlighting in documentation
1.1.0 - 2019-03-20
Added
- Internal aliases
IntType
andFloatType
used by theValue
enum are now public - Type alias
TupleType
used to represent tuples was added - Error types like
Error::ExpectedInt
for expecting each value type were added - Shortcut functions like
eval_int
oreval_int_with_configuration
to evaluate directly into a value type were added - Documentation for the shortcut functions was added
- Functions to decompose
Value
s were added and documented
Removed
- Integration tests were removed from shipped crate
Fixed
- Wording of some documentation items was changed to improve readability
1.0.0 - 2019-03-20
- First stable release