内容简介:Compile-time compiler that compiles Forth to compile-time trait expressions.Rust's trait system is Turing complete. This crate uses the principles fromHere's a simple factorial implementation, the only non-standard word here is
fortraith
Compile-time compiler that compiles Forth to compile-time trait expressions.
What?
Rust's trait system is Turing complete. This crate uses the principles from trait-eval
to implement necessary
traits for forth evalutaion and provides a forth!
macro that transpiles
forth's syntax to trait expressions.
Show me!
Here's a simple factorial implementation, the only non-standard word here is pred
which is a decrement operator, equivalent to 1 -
:
forth!( : factorial (n -- n) 1 swap fact0 ; : fact0 (n n -- n) dup 1 = if drop else dup rot * swap pred fact0 then ; 5 factorial . );
This prints 120
. As you can see not only you can define functions easily, but even conditional recursion is possible!
Now check out how it looks compiled to trait expressions (courtesy of cargo expand
):
pub trait factorial { type Result; } impl<V, N> factorial for Node<V, N> where Self: one, <Self as one>::Result: swap, <<Self as one>::Result as swap>::Result: fact0, { type Result = <<<Self as one>::Result as swap>::Result as fact0>::Result; } pub trait fact0 { type Result; } impl <V ,N> fact0 for Node <V ,N> where Self: dup, <Self as dup>::Result: one, <<Self as dup>::Result as one>::Result: eq, <<<Self as dup>::Result as one>::Result as eq>::Result: iff, <<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result: drop, <<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result: elsef, <<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result: dup, <<<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result as dup>::Result: rot, <<<<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result as dup>::Result as rot>::Result: mult, <<<<<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result as dup>::Result as rot>::Result as mult>::Result: swap, <<<<<<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result as dup>::Result as rot>::Result as mult>::Result as swap>::Result: pred, <<<<<<<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result as dup>::Result as rot>::Result as mult>::Result as swap>::Result as pred>::Result: fact0, <<<<<<<<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result as dup>::Result as rot>::Result as mult>::Result as swap>::Result as pred>::Result as fact0>::Result: then { type Result = <<<<<<<<<<<<<Self as dup>::Result as one>::Result as eq>::Result as iff>::Result as drop>::Result as elsef>::Result as dup>::Result as rot>::Result as mult>::Result as swap>::Result as pred>::Result as fact0>::Result as then>::Result; } println!("{}", <<<Empty as five>::Result as factorial>::Result as top>::Result::eval());
Yeah, writing that manually would be no fun.
What can I do with it?
Quite a bit is actually supported as you can see above. Every operation from trait-eval
is re-exported to work on the stack (except if
which is done
differently), and a faw additional stack operations are provided. See docs
for the details.
以上所述就是小编给大家介绍的《Forth implemented in Rust trait system》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
现代应用数学手册
《现代应用数学手册》编委会 / 清华大学出版社 / 2005-1-1 / 48.00元
本书是进行科学计算的常备工具书,内容新颖,查阅方便,实用性强。主要介绍生产、科研、管理、数学等实践中在计算机上使用的各种计算方法和技巧。全书分为14章,依次为数值计算概论、插值法、函数逼近与曲线拟合、数值积分与数值微分、方程求根、线性方程组的直接解法和迭代解法、矩阵特征值问题、非线性方程组数值解与最优化方法、常微分方程初值问题和边值问题的数值解法、偏微分方程的数值解法、多重网络法和积分方程数值解法......一起来看看 《现代应用数学手册》 这本书的介绍吧!