Skip to content

Instantly share code, notes, and snippets.

@podhmo
Last active January 30, 2026 10:05
Show Gist options
  • Select an option

  • Save podhmo/c176db2a047dcb60ee32ec0cee85744f to your computer and use it in GitHub Desktop.

Select an option

Save podhmo/c176db2a047dcb60ee32ec0cee85744f to your computer and use it in GitHub Desktop.
moonbit online

kimiでつくらせた

moonbitのいろいろな機能を使った1ファイルのコードを作ってください。ただし使えるのは標準ライブラリまでです。 https://docs.moonbitlang.com/en/latest/tutorial/for-go-programmers/index.html を参考にしてください。

以下は、MoonBitの様々な機能(列挙型、パターンマッチング、トレイト、エラーハンドリング、ジェネリック、制御フローなど)を網羅したシングルファイルのサンプルコードです。

https://podhmo.github.io/moonbit-online/#%2F%2F%20%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%0A%2F%2F%20MoonBit%20Comprehensive%20Feature%20Demo%0A%2F%2F%20Standard%20Library%20Only%0A%2F%2F%20%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%3D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%201.%20Error%20Types%20(suberror)%0A%2F%2F%20----------------------------------------%0Asuberror%20EvalError%20%7B%0A%20%20DivByZero%0A%20%20UnknownVariable(String)%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%202.%20Algebraic%20Data%20Types%20(Enum%20with%20payloads)%0A%2F%2F%20----------------------------------------%0Aenum%20Expression%20%7B%0A%20%20Number(Double)%0A%20%20Variable(String)%0A%20%20Add(Expression%2C%20Expression)%0A%20%20Mul(Expression%2C%20Expression)%0A%20%20Div(Expression%2C%20Expression)%0A%20%20Let(String%2C%20Expression%2C%20Expression)%20%20%2F%2F%20let%20x%20%3D%20e1%20in%20e2%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%203.%20Structs%20with%20mut%20fields%0A%2F%2F%20----------------------------------------%0Astruct%20Environment%20%7B%0A%20%20bindings%20%3A%20Map%5BString%2C%20Double%5D%0A%20%20mut%20eval_count%20%3A%20Int%0A%7D%0A%0Astruct%20Stats%20%7B%0A%20%20sum%20%3A%20Double%0A%20%20mean%20%3A%20Double%0A%20%20samples%20%3A%20Array%5BDouble%5D%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%204.%20Traits%20(Type%20Classes)%0A%2F%2F%20----------------------------------------%0Atrait%20Show%20%7B%0A%20%20to_string(Self)%20-%3E%20String%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%205.%20Methods%20and%20Trait%20Implementations%0A%2F%2F%20----------------------------------------%0A%0A%2F%2F%20Environment%20methods%0Afn%20Environment%3A%3Anew()%20-%3E%20Environment%20%7B%0A%20%20%7B%20bindings%3A%20Map%3A%3Anew()%2C%20eval_count%3A%200%20%7D%0A%7D%0A%0Afn%20Environment%3A%3Aextend(self%20%3A%20Environment%2C%20name%20%3A%20String%2C%20value%20%3A%20Double)%20-%3E%20Environment%20%7B%0A%20%20let%20new_bindings%20%3D%20self.bindings.copy()%0A%20%20new_bindings.set(name%2C%20value)%0A%20%20%7B%20bindings%3A%20new_bindings%2C%20eval_count%3A%20self.eval_count%20%7D%0A%7D%0A%0Afn%20Environment%3A%3Alookup(self%20%3A%20Environment%2C%20name%20%3A%20String)%20-%3E%20Double%3F%20%7B%0A%20%20self.eval_count%20%3D%20self.eval_count%20%2B%201%0A%20%20self.bindings.get(name)%0A%7D%0A%0A%2F%2F%20Show%20trait%20for%20Expression%0Aimpl%20Show%20for%20Expression%20with%20to_string(self)%20%7B%0A%20%20match%20self%20%7B%0A%20%20%20%20Number(n)%20%3D%3E%20n.to_string()%0A%20%20%20%20Variable(name)%20%3D%3E%20name%0A%20%20%20%20Add(e1%2C%20e2)%20%3D%3E%20%22(%5C%7Be1.to_string()%7D%20%2B%20%5C%7Be2.to_string()%7D)%22%0A%20%20%20%20Mul(e1%2C%20e2)%20%3D%3E%20%22(%5C%7Be1.to_string()%7D%20*%20%5C%7Be2.to_string()%7D)%22%0A%20%20%20%20Div(e1%2C%20e2)%20%3D%3E%20%22(%5C%7Be1.to_string()%7D%20%2F%20%5C%7Be2.to_string()%7D)%22%0A%20%20%20%20Let(name%2C%20e1%2C%20e2)%20%3D%3E%20%22(let%20%5C%7Bname%7D%20%3D%20%5C%7Be1.to_string()%7D%20in%20%5C%7Be2.to_string()%7D)%22%0A%20%20%7D%0A%7D%0A%0A%2F%2F%20Show%20for%20Stats%0Aimpl%20Show%20for%20Stats%20with%20to_string(self)%20%7B%0A%20%20%22Stats(mean%3A%20%5C%7Bself.mean%7D%2C%20sum%3A%20%5C%7Bself.sum%7D%2C%20n%3A%20%5C%7Bself.samples.length()%7D)%22%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%206.%20Pattern%20Matching%20%26%20Error%20Handling%0A%2F%2F%20----------------------------------------%0A%0Afn%20Expression%3A%3Aeval(self%20%3A%20Expression%2C%20env%20%3A%20Environment)%20-%3E%20Double%20raise%20EvalError%20%7B%0A%20%20match%20self%20%7B%0A%20%20%20%20Number(n)%20%3D%3E%20n%0A%20%20%20%20Variable(name)%20%3D%3E%20%7B%0A%20%20%20%20%20%20match%20env.lookup(name)%20%7B%0A%20%20%20%20%20%20%20%20Some(v)%20%3D%3E%20v%0A%20%20%20%20%20%20%20%20None%20%3D%3E%20raise%20EvalError%3A%3AUnknownVariable(name)%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%7D%0A%20%20%20%20Add(e1%2C%20e2)%20%3D%3E%20e1.eval(env)%20%2B%20e2.eval(env)%0A%20%20%20%20Mul(e1%2C%20e2)%20%3D%3E%20e1.eval(env)%20*%20e2.eval(env)%0A%20%20%20%20Div(e1%2C%20e2)%20%3D%3E%20%7B%0A%20%20%20%20%20%20let%20divisor%20%3D%20e2.eval(env)%0A%20%20%20%20%20%20if%20divisor%20%3D%3D%200.0%20%7B%0A%20%20%20%20%20%20%20%20raise%20EvalError%3A%3ADivByZero%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20e1.eval(env)%20%2F%20divisor%0A%20%20%20%20%7D%0A%20%20%20%20Let(name%2C%20e1%2C%20e2)%20%3D%3E%20%7B%0A%20%20%20%20%20%20let%20val%20%3D%20e1.eval(env)%0A%20%20%20%20%20%20let%20new_env%20%3D%20env.extend(name%2C%20val)%0A%20%20%20%20%20%20e2.eval(new_env)%0A%20%20%20%20%7D%0A%20%20%7D%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%207.%20Generic%20Functions%20%26%20Named%20Parameters%0A%2F%2F%20----------------------------------------%0A%0Afn%5BT%5D%20option_or_default(opt%20%3A%20T%3F%2C%20default~%20%3A%20T)%20-%3E%20T%20%7B%0A%20%20match%20opt%20%7B%0A%20%20%20%20Some(v)%20%3D%3E%20v%0A%20%20%20%20None%20%3D%3E%20default%0A%20%20%7D%0A%7D%0A%0Afn%5BT%2C%20U%2C%20E%5D%20result_map(result%20%3A%20Result%5BT%2C%20E%5D%2C%20f%20%3A%20(T)%20-%3E%20U)%20-%3E%20Result%5BU%2C%20E%5D%20%7B%0A%20%20match%20result%20%7B%0A%20%20%20%20Ok(v)%20%3D%3E%20Ok(f(v))%0A%20%20%20%20Err(e)%20%3D%3E%20Err(e)%0A%20%20%7D%0A%7D%0A%0A%2F%2F%20Named%20parameters%20with%20defaults%0Afn%20create_stats(%0A%20%20data%20%3A%20Array%5BDouble%5D%2C%0A%20%20include_mean~%20%3A%20Bool%20%3D%20true%0A)%20-%3E%20Stats%20%7B%0A%20%20let%20n%20%3D%20data.length()%0A%20%20let%20sum%20%3D%20if%20n%20%3D%3D%200%20%7B%0A%20%20%20%200.0%0A%20%20%7D%20else%20%7B%0A%20%20%20%20%2F%2F%20Loop%20expression%20with%20accumulator%0A%20%20%20%20loop%20(0%2C%200.0)%20%7B%0A%20%20%20%20%20%20(i%2C%20acc)%20%3D%3E%20%7B%0A%20%20%20%20%20%20%20%20if%20i%20%3E%3D%20n%20%7B%0A%20%20%20%20%20%20%20%20%20%20break%20acc%20%20%2F%2F%20break%20returns%20value%20from%20loop%0A%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20continue%20(i%20%2B%201%2C%20acc%20%2B%20data%5Bi%5D)%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%7D%0A%20%20%7D%0A%20%20%0A%20%20let%20mean%20%3D%20if%20include_mean%20%26%26%20n%20%3E%200%20%7B%0A%20%20%20%20sum%20%2F%20n.to_double()%0A%20%20%7D%20else%20%7B%0A%20%20%20%200.0%0A%20%20%7D%0A%20%20%0A%20%20%7B%20sum%2C%20mean%2C%20samples%3A%20data%20%7D%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%208.%20Array%20Operations%20%26%20Pattern%20Matching%0A%2F%2F%20----------------------------------------%0A%0Afn%20analyze_list(lst%20%3A%20Array%5BInt%5D)%20-%3E%20String%20%7B%0A%20%20match%20lst%20%7B%0A%20%20%20%20%5B%5D%20%3D%3E%20%22Empty%20list%22%0A%20%20%20%20%5Bx%5D%20%3D%3E%20%22Single%20element%3A%20%5C%7Bx%7D%22%0A%20%20%20%20%5Bfirst%2C%20second%2C%20..%20rest%5D%20%3D%3E%20%7B%0A%20%20%20%20%20%20let%20len%20%3D%20lst.length()%0A%20%20%20%20%20%20let%20rest_sum%20%3D%20loop%20(0%2C%200)%20%7B%0A%20%20%20%20%20%20%20%20(i%2C%20acc)%20%3D%3E%20%7B%0A%20%20%20%20%20%20%20%20%20%20if%20i%20%3E%3D%20rest.length()%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20break%20acc%0A%20%20%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20%20%20continue%20(i%20%2B%201%2C%20acc%20%2B%20rest%5Bi%5D)%0A%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%22First%20two%3A%20%5C%7Bfirst%7D%2C%20%5C%7Bsecond%7D%3B%20Total%20length%3A%20%5C%7Blen%7D%3B%20Rest%20sum%3A%20%5C%7Brest_sum%7D%22%0A%20%20%20%20%7D%0A%20%20%7D%0A%7D%0A%0Afn%20array_sum(arr%20%3A%20Array%5BInt%5D)%20-%3E%20Int%20%7B%0A%20%20%2F%2F%20For%20loop%20as%20expression%0A%20%20for%20i%20%3D%200%2C%20acc%20%3D%200%3B%20i%20%3C%20arr.length()%3B%20i%20%3D%20i%20%2B%201%20%7B%0A%20%20%20%20continue%20i%20%2B%201%2C%20acc%20%2B%20arr%5Bi%5D%0A%20%20%7D%20else%20%7B%0A%20%20%20%20acc%0A%20%20%7D%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%209.%20String%20Processing%20with%20Views%0A%2F%2F%20----------------------------------------%0A%0Afn%20is_palindrome(s%20%3A%20String)%20-%3E%20Bool%20%7B%0A%20%20let%20view%20%3D%20s.view()%0A%20%20fn%20check(v%20%3A%20StringView)%20-%3E%20Bool%20%7B%0A%20%20%20%20match%20v%20%7B%0A%20%20%20%20%20%20%5B%5D%20%7C%20%5B_%5D%20%3D%3E%20true%0A%20%20%20%20%20%20%5Bfirst%2C%20..%20rest%2C%20last%5D%20%3D%3E%20%7B%0A%20%20%20%20%20%20%20%20if%20first%20%3D%3D%20last%20%7B%0A%20%20%20%20%20%20%20%20%20%20check(rest)%0A%20%20%20%20%20%20%20%20%7D%20else%20%7B%0A%20%20%20%20%20%20%20%20%20%20false%0A%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%7D%0A%20%20%7D%0A%20%20check(view)%0A%7D%0A%0A%2F%2F%20----------------------------------------%0A%2F%2F%2010.%20Main%20Function%20-%20Demonstration%0A%2F%2F%20----------------------------------------%0A%0Afn%20main%20%7B%0A%20%20println(%22%3D%3D%3D%20MoonBit%20Feature%20Showcase%20%3D%3D%3D%5Cn%22)%0A%20%20%0A%20%20%2F%2F%20--%20Variable%20bindings%20--%0A%20%20let%20immutable_val%20%3D%2042%0A%20%20let%20mut%20mutable_val%20%3D%200%0A%20%20mutable_val%20%3D%20immutable_val%20%2F%202%0A%20%20%0A%20%20println(%22Immutable%3A%20%5C%7Bimmutable_val%7D%2C%20Mutable%3A%20%5C%7Bmutable_val%7D%22)%0A%20%20%0A%20%20%2F%2F%20--%20Expression%20evaluation%20with%20error%20handling%20--%0A%20%20let%20env%20%3D%20Environment%3A%3Anew()%0A%20%20let%20expr%20%3D%20Let(%22x%22%2C%20%0A%20%20%20%20Number(10.0)%2C%0A%20%20%20%20Add(%0A%20%20%20%20%20%20Variable(%22x%22)%2C%0A%20%20%20%20%20%20Mul(Number(2.0)%2C%20Div(Number(6.0)%2C%20Number(2.0)))%0A%20%20%20%20)%0A%20%20)%0A%20%20%0A%20%20println(%22%5CnExpression%3A%20%5C%7Bexpr.to_string()%7D%22)%0A%20%20%0A%20%20try%20%7B%0A%20%20%20%20let%20result%20%3D%20expr.eval(env)%0A%20%20%20%20println(%22Evaluated%20to%3A%20%5C%7Bresult%7D%22)%0A%20%20%20%20println(%22Total%20variable%20lookups%3A%20%5C%7Benv.eval_count%7D%22)%0A%20%20%7D%20catch%20%7B%0A%20%20%20%20EvalError%3A%3ADivByZero%20%3D%3E%20println(%22Error%3A%20Division%20by%20zero!%22)%0A%20%20%20%20EvalError%3A%3AUnknownVariable(name)%20%3D%3E%20println(%22Error%3A%20Unknown%20variable%20'%5C%7Bname%7D'%22)%0A%20%20%7D%0A%20%20%0A%20%20%2F%2F%20--%20Loop%20expressions%20--%0A%20%20println(%22%5Cn--%20Loop%20Expressions%20--%22)%0A%20%20let%20factorial_5%20%3D%20loop%20(5%2C%201)%20%7B%0A%20%20%20%20(n%2C%20acc)%20%3D%3E%20%7B%0A%20%20%20%20%20%20if%20n%20%3C%3D%201%20%7B%0A%20%20%20%20%20%20%20%20break%20acc%0A%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20continue%20(n%20-%201%2C%20acc%20*%20n)%0A%20%20%20%20%7D%0A%20%20%7D%0A%20%20println(%225!%20%3D%20%5C%7Bfactorial_5%7D%22)%0A%20%20%0A%20%20%2F%2F%20--%20For%20loop%20as%20expression%20--%0A%20%20let%20numbers%20%3D%20%5B1%2C%202%2C%203%2C%204%2C%205%2C%206%2C%207%2C%208%2C%209%2C%2010%5D%0A%20%20let%20sum_even%20%3D%20for%20i%20%3D%200%2C%20sum%20%3D%200%3B%20i%20%3C%20numbers.length()%3B%20i%20%3D%20i%20%2B%201%20%7B%0A%20%20%20%20if%20numbers%5Bi%5D%20%25%202%20%3D%3D%200%20%7B%0A%20%20%20%20%20%20continue%20i%20%2B%201%2C%20sum%20%2B%20numbers%5Bi%5D%0A%20%20%20%20%7D%20else%20%7B%0A%20%20%20%20%20%20continue%20i%20%2B%201%2C%20sum%0A%20%20%20%20%7D%0A%20%20%7D%20else%20%7B%0A%20%20%20%20sum%0A%20%20%7D%0A%20%20println(%22Sum%20of%20even%20numbers%3A%20%5C%7Bsum_even%7D%22)%0A%20%20%0A%20%20%2F%2F%20--%20While%20loop%20with%20break%20value%20--%0A%20%20let%20mut%20count%20%3D%200%0A%20%20let%20found%20%3D%20while%20count%20%3C%20100%20%7B%0A%20%20%20%20count%20%3D%20count%20%2B%207%0A%20%20%20%20if%20count%20%3E%2050%20%7B%0A%20%20%20%20%20%20break%20%22Found%20at%20%5C%7Bcount%7D%22%0A%20%20%20%20%7D%0A%20%20%7D%20else%20%7B%0A%20%20%20%20%22Not%20found%22%0A%20%20%7D%0A%20%20println(%22While%20result%3A%20%5C%7Bfound%7D%22)%0A%20%20%0A%20%20%2F%2F%20--%20Pattern%20matching%20on%20arrays%20--%0A%20%20println(%22%5Cn--%20Array%20Patterns%20--%22)%0A%20%20let%20test_list%20%3D%20%5B1%2C%202%2C%203%2C%204%2C%205%5D%0A%20%20println(analyze_list(test_list))%0A%20%20%0A%20%20%2F%2F%20--%20Option%20and%20Result%20types%20--%0A%20%20println(%22%5Cn--%20Optional%20Values%20--%22)%0A%20%20let%20maybe_value%20%3A%20Int%3F%20%3D%20Some(42)%0A%20%20let%20defaulted%20%3D%20option_or_default(maybe_value%2C%20default%3D0)%0A%20%20println(%22Option%20value%3A%20%5C%7Bdefaulted%7D%22)%0A%20%20%0A%20%20let%20division_result%20%3A%20Result%5BDouble%2C%20EvalError%5D%20%3D%20try%3F%20%7B%0A%20%20%20%20Expression%3A%3ADiv(Number(10.0)%2C%20Number(0.0)).eval(Environment%3A%3Anew())%0A%20%20%7D%0A%20%20%0A%20%20match%20division_result%20%7B%0A%20%20%20%20Ok(v)%20%3D%3E%20println(%22Division%20succeeded%3A%20%5C%7Bv%7D%22)%0A%20%20%20%20Err(_)%20%3D%3E%20println(%22Division%20failed%20as%20expected%22)%0A%20%20%7D%0A%20%20%0A%20%20%2F%2F%20--%20Statistics%20with%20named%20parameters%20--%0A%20%20println(%22%5Cn--%20Statistics%20--%22)%0A%20%20let%20data%20%3D%20%5B2.5%2C%203.5%2C%204.5%2C%205.5%2C%206.5%5D%0A%20%20let%20stats%20%3D%20create_stats(data%2C%20include_mean%3Dtrue)%0A%20%20println(stats.to_string())%0A%20%20%0A%20%20%2F%2F%20--%20String%20view%20pattern%20matching%20--%0A%20%20println(%22%5Cn--%20String%20Processing%20--%22)%0A%20%20let%20words%20%3D%20%5B%22radar%22%2C%20%22moonbit%22%2C%20%22level%22%2C%20%22hello%22%2C%20%22%E4%B8%96%E7%95%8C%E7%95%8C%E4%B8%96%22%5D%0A%20%20for%20word%20in%20words%20%7B%0A%20%20%20%20if%20is_palindrome(word)%20%7B%0A%20%20%20%20%20%20println(%22'%5C%7Bword%7D'%20is%20a%20palindrome%22)%0A%20%20%20%20%7D%0A%20%20%7D%0A%20%20%0A%20%20%2F%2F%20--%20Map%20operations%20--%0A%20%20println(%22%5Cn--%20Map%20Operations%20--%22)%0A%20%20let%20map%20%3A%20Map%5BString%2C%20Int%5D%20%3D%20Map%3A%3Anew()%0A%20%20map.set(%22one%22%2C%201)%0A%20%20map.set(%22two%22%2C%202)%0A%20%20map.set(%22three%22%2C%203)%0A%20%20%0A%20%20for%20key%2C%20value%20in%20map%20%7B%0A%20%20%20%20println(%22%5C%7Bkey%7D%20%3D%3E%20%5C%7Bvalue%7D%22)%0A%20%20%7D%0A%20%20%0A%20%20println(%22%5Cn%3D%3D%3D%20End%20of%20Demo%20%3D%3D%3D%22)%0A%7D

// ============================================
// MoonBit Comprehensive Feature Demo
// Standard Library Only
// ============================================
// ----------------------------------------
// 1. Error Types (suberror)
// ----------------------------------------
suberror EvalError {
DivByZero
UnknownVariable(String)
}
// ----------------------------------------
// 2. Algebraic Data Types (Enum with payloads)
// ----------------------------------------
enum Expression {
Number(Double)
Variable(String)
Add(Expression, Expression)
Mul(Expression, Expression)
Div(Expression, Expression)
Let(String, Expression, Expression) // let x = e1 in e2
}
// ----------------------------------------
// 3. Structs with mut fields
// ----------------------------------------
struct Environment {
bindings : Map[String, Double]
mut eval_count : Int
}
struct Stats {
sum : Double
mean : Double
samples : Array[Double]
}
// ----------------------------------------
// 4. Traits (Type Classes)
// ----------------------------------------
trait Show {
to_string(Self) -> String
}
// ----------------------------------------
// 5. Methods and Trait Implementations
// ----------------------------------------
// Environment methods
fn Environment::new() -> Environment {
{ bindings: Map::new(), eval_count: 0 }
}
fn Environment::extend(self : Environment, name : String, value : Double) -> Environment {
let new_bindings = self.bindings.copy()
new_bindings.set(name, value)
{ bindings: new_bindings, eval_count: self.eval_count }
}
fn Environment::lookup(self : Environment, name : String) -> Double? {
self.eval_count = self.eval_count + 1
self.bindings.get(name)
}
// Show trait for Expression
impl Show for Expression with to_string(self) {
match self {
Number(n) => n.to_string()
Variable(name) => name
Add(e1, e2) => "(\{e1.to_string()} + \{e2.to_string()})"
Mul(e1, e2) => "(\{e1.to_string()} * \{e2.to_string()})"
Div(e1, e2) => "(\{e1.to_string()} / \{e2.to_string()})"
Let(name, e1, e2) => "(let \{name} = \{e1.to_string()} in \{e2.to_string()})"
}
}
// Show for Stats
impl Show for Stats with to_string(self) {
"Stats(mean: \{self.mean}, sum: \{self.sum}, n: \{self.samples.length()})"
}
// ----------------------------------------
// 6. Pattern Matching & Error Handling
// ----------------------------------------
fn Expression::eval(self : Expression, env : Environment) -> Double raise EvalError {
match self {
Number(n) => n
Variable(name) => {
match env.lookup(name) {
Some(v) => v
None => raise EvalError::UnknownVariable(name)
}
}
Add(e1, e2) => e1.eval(env) + e2.eval(env)
Mul(e1, e2) => e1.eval(env) * e2.eval(env)
Div(e1, e2) => {
let divisor = e2.eval(env)
if divisor == 0.0 {
raise EvalError::DivByZero
}
e1.eval(env) / divisor
}
Let(name, e1, e2) => {
let val = e1.eval(env)
let new_env = env.extend(name, val)
e2.eval(new_env)
}
}
}
// ----------------------------------------
// 7. Generic Functions & Named Parameters
// ----------------------------------------
fn[T] option_or_default(opt : T?, default~ : T) -> T {
match opt {
Some(v) => v
None => default
}
}
fn[T, U, E] result_map(result : Result[T, E], f : (T) -> U) -> Result[U, E] {
match result {
Ok(v) => Ok(f(v))
Err(e) => Err(e)
}
}
// Named parameters with defaults
fn create_stats(
data : Array[Double],
include_mean~ : Bool = true
) -> Stats {
let n = data.length()
let sum = if n == 0 {
0.0
} else {
// Loop expression with accumulator
loop (0, 0.0) {
(i, acc) => {
if i >= n {
break acc // break returns value from loop
}
continue (i + 1, acc + data[i])
}
}
}
let mean = if include_mean && n > 0 {
sum / n.to_double()
} else {
0.0
}
{ sum, mean, samples: data }
}
// ----------------------------------------
// 8. Array Operations & Pattern Matching
// ----------------------------------------
fn analyze_list(lst : Array[Int]) -> String {
match lst {
[] => "Empty list"
[x] => "Single element: \{x}"
[first, second, .. rest] => {
let len = lst.length()
let rest_sum = loop (0, 0) {
(i, acc) => {
if i >= rest.length() {
break acc
}
continue (i + 1, acc + rest[i])
}
}
"First two: \{first}, \{second}; Total length: \{len}; Rest sum: \{rest_sum}"
}
}
}
fn array_sum(arr : Array[Int]) -> Int {
// For loop as expression
for i = 0, acc = 0; i < arr.length(); i = i + 1 {
continue i + 1, acc + arr[i]
} else {
acc
}
}
// ----------------------------------------
// 9. String Processing with Views
// ----------------------------------------
fn is_palindrome(s : String) -> Bool {
let view = s.view()
fn check(v : StringView) -> Bool {
match v {
[] | [_] => true
[first, .. rest, last] => {
if first == last {
check(rest)
} else {
false
}
}
}
}
check(view)
}
// ----------------------------------------
// 10. Main Function - Demonstration
// ----------------------------------------
fn main {
println("=== MoonBit Feature Showcase ===\n")
// -- Variable bindings --
let immutable_val = 42
let mut mutable_val = 0
mutable_val = immutable_val / 2
println("Immutable: \{immutable_val}, Mutable: \{mutable_val}")
// -- Expression evaluation with error handling --
let env = Environment::new()
let expr = Let("x",
Number(10.0),
Add(
Variable("x"),
Mul(Number(2.0), Div(Number(6.0), Number(2.0)))
)
)
println("\nExpression: \{expr.to_string()}")
try {
let result = expr.eval(env)
println("Evaluated to: \{result}")
println("Total variable lookups: \{env.eval_count}")
} catch {
EvalError::DivByZero => println("Error: Division by zero!")
EvalError::UnknownVariable(name) => println("Error: Unknown variable '\{name}'")
}
// -- Loop expressions --
println("\n-- Loop Expressions --")
let factorial_5 = loop (5, 1) {
(n, acc) => {
if n <= 1 {
break acc
}
continue (n - 1, acc * n)
}
}
println("5! = \{factorial_5}")
// -- For loop as expression --
let numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
let sum_even = for i = 0, sum = 0; i < numbers.length(); i = i + 1 {
if numbers[i] % 2 == 0 {
continue i + 1, sum + numbers[i]
} else {
continue i + 1, sum
}
} else {
sum
}
println("Sum of even numbers: \{sum_even}")
// -- While loop with break value --
let mut count = 0
let found = while count < 100 {
count = count + 7
if count > 50 {
break "Found at \{count}"
}
} else {
"Not found"
}
println("While result: \{found}")
// -- Pattern matching on arrays --
println("\n-- Array Patterns --")
let test_list = [1, 2, 3, 4, 5]
println(analyze_list(test_list))
// -- Option and Result types --
println("\n-- Optional Values --")
let maybe_value : Int? = Some(42)
let defaulted = option_or_default(maybe_value, default=0)
println("Option value: \{defaulted}")
let division_result : Result[Double, EvalError] = try? {
Expression::Div(Number(10.0), Number(0.0)).eval(Environment::new())
}
match division_result {
Ok(v) => println("Division succeeded: \{v}")
Err(_) => println("Division failed as expected")
}
// -- Statistics with named parameters --
println("\n-- Statistics --")
let data = [2.5, 3.5, 4.5, 5.5, 6.5]
let stats = create_stats(data, include_mean=true)
println(stats.to_string())
// -- String view pattern matching --
println("\n-- String Processing --")
let words = ["radar", "moonbit", "level", "hello", "世界界世"]
for word in words {
if is_palindrome(word) {
println("'\{word}' is a palindrome")
}
}
// -- Map operations --
println("\n-- Map Operations --")
let map : Map[String, Int] = Map::new()
map.set("one", 1)
map.set("two", 2)
map.set("three", 3)
for key, value in map {
println("\{key} => \{value}")
}
println("\n=== End of Demo ===")
}
@podhmo
Copy link
Author

podhmo commented Jan 30, 2026

Click the link to view conversation with Kimi AI Assistant https://www.kimi.com/share/19c0e5a2-7b02-884d-8000-00003bb5bf42

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment