Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/calypso-lang/calypso
Calypso is a mostly imperative language with some functional influences that is focused on flexibility and simplicity.
https://github.com/calypso-lang/calypso
Last synced: 25 days ago
JSON representation
Calypso is a mostly imperative language with some functional influences that is focused on flexibility and simplicity.
- Host: GitHub
- URL: https://github.com/calypso-lang/calypso
- Owner: calypso-lang
- License: apache-2.0
- Created: 2020-08-11T05:20:22.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-04-26T17:47:49.000Z (8 months ago)
- Last Synced: 2024-04-26T18:49:31.734Z (8 months ago)
- Language: Rust
- Homepage: https://calypso-lang.github.io/
- Size: 1.37 MB
- Stars: 62
- Watchers: 3
- Forks: 4
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE-APACHE
- Security: SECURITY.md
Awesome Lists containing this project
- programming-languages - Calypso - Mostly imperative language with some functional influences that is focused on flexibility and simplicity. (Functional)
README
# Calypso
[![CI Status][b3]][l3] [![License][b4]][l4] [![Discord](https://img.shields.io/discord/822290196057948171?style=flat-square&color=blue)](https://discord.gg/26X6ChQQcG) ![Lines of Code][b2]
[![All Contributors](https://img.shields.io/badge/all_contributors-2-orange.svg?style=flat-square)](#contributors-)Calypso is a mostly imperative language with some functional influences that is focused on flexibility and simplicity.
Note that this code is very work-in-progress. Contributions are welcome (and encouraged!), but it's not recommended to use this in production unless you're ready for some serious pain. Or code that just doesn't work.
## Example
The following example is an implementation of [FizzBuzz](https://en.wikipedia.org/wiki/Fizz_buzz) that goes until a number specified in the CLI arguments of the program, or 100 if that is not present. Note that this is currently psuedocode and may change.
```zig
import standard.process.Argsfn main(args: Args) ->
args
|> _.get(0)
|> _.unwrap_or("100")
|> uint.from_string
|> _.unwrap_or(100)
|> fizzbuzz
|> _.each(&println("{}", &1))fn fizzbuzz(max: uint): [string] ->
1.to_incl(max).map(fn n ->
case do
15.divides(n) -> "FizzBuzz",
3.divides(n) -> "Fizz",
5.divides(n) -> "Buzz",
_ -> n.to_string
end)
```## Compatibility
The MSRV (Minimum Supported Rust Version) is currently Rust 1.66.1.
Calypso is automatically tested on:
- x86_64 linux, Rust 1.66.1
- x86_64 linux, latest stable
- x86_64 linux, latest nightlyas well as manually tested on x86_64 linux with the latest stable build of Rust
Calypso is developed and tested on these platforms:
- Arch Linux, latest stable
- I'd hope there's more in the future...but I don't currently have the infra to test those :(## License
Licensed under either of
* Apache License, Version 2.0
([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license
([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)at your option.
## Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.## [crates.io][crates.io] statuses
I'm currently holding various crates related to Calypso. These will actually be used but they are being held so that no one uses them for malicious purposes or confuses anyone.
> Note: A version number of `0.0.0` indicates an unreleased crate.
| Crate Name | Version | [docs.rs][docs.rs] Status |
|:----------------------:|:--------------------------------------:|:------------------------------------------:|
| `calypso` | [![calypso][bcio1]][lcio1] | [![calypso][bdrs1]][ldrs1] |
| `calypso_base` | [![calypso_base][bcio2]][lcio2] | [![calypso_base][bdrs2]][ldrs2] |
| `calypso_error` | [![calypso_error][bcio9]][lcio9] | [![calypso_error][bdrs9]][ldrs9] |
| `calypso_diagnostic` | [![calypso_diagnostic][bcio3]][lcio3] | [![calypso_diagnostic][bdrs3]][ldrs3] |
| `calypso_filety` | [![calypso_filety][bcio7]][lcio7] | [![calypso_filety][bdrs7]][ldrs7] |
| `calypso_opt` | [![calypso_opt][bcio8]][lcio8] | [![calypso_opt][bdrs8]][ldrs8] |
| `calypso_parsing` | [![calypso_parsing][bcio4]][lcio4] | [![calypso_parsing][bdrs4]][ldrs4] |
| `calypso_repl` | [![calypso_repl][bcio5]][lcio5] | [![calypso_repl][bdrs5]][ldrs5] |
| `calypso_util` | [![calypso_util][bcio6]][lcio6] | [![calypso_util][bdrs6]][ldrs6] |For the status of SaturnVM crates, see [its README](libs/saturnvm/README.md).
[bcio1]: https://img.shields.io/crates/v/calypso
[lcio1]: https://crates.io/crates/calypso
[bdrs1]: https://docs.rs/calypso/badge.svg
[ldrs1]: https://docs.rs/calypso/*[bcio2]: https://img.shields.io/crates/v/calypso_base
[lcio2]: https://crates.io/crates/calypso_base
[bdrs2]: https://docs.rs/calypso_base/badge.svg
[ldrs2]: https://docs.rs/calypso_base/*[bcio3]: https://img.shields.io/crates/v/calypso_diagnostic
[lcio3]: https://crates.io/crates/calypso_diagnostic
[bdrs3]: https://docs.rs/calypso_diagnostic/badge.svg
[ldrs3]: https://docs.rs/calypso_diagnostic/*[bcio4]: https://img.shields.io/crates/v/calypso_parsing
[lcio4]: https://crates.io/crates/calypso_parsing
[bdrs4]: https://docs.rs/calypso_parsing/badge.svg
[ldrs4]: https://docs.rs/calypso_parsing/*[bcio5]: https://img.shields.io/crates/v/calypso_repl
[lcio5]: https://crates.io/crates/calypso_repl
[bdrs5]: https://docs.rs/calypso_repl/badge.svg
[ldrs5]: https://docs.rs/calypso_repl/*calypso_util[bcio6]: https://img.shields.io/crates/v/calypso_util
[lcio6]: https://crates.io/crates/calypso_util
[bdrs6]: https://docs.rs/calypso_util/badge.svg
[ldrs6]: https://docs.rs/calypso_util/*[bcio7]: https://img.shields.io/crates/v/calypso_filety
[lcio7]: https://crates.io/crates/calypso_filety
[bdrs7]: https://docs.rs/calypso_filety/badge.svg
[ldrs7]: https://docs.rs/calypso_filety/*[bcio8]: https://img.shields.io/crates/v/calypso_opt
[lcio8]: https://crates.io/crates/calypso_opt
[bdrs8]: https://docs.rs/calypso_opt/badge.svg
[ldrs8]: https://docs.rs/calypso_opt/*[bcio9]: https://img.shields.io/crates/v/calypso_error
[lcio9]: https://crates.io/crates/calypso_error
[bdrs9]: https://docs.rs/calypso_error/badge.svg
[ldrs9]: https://docs.rs/calypso_error/*Docs for the `main` branch can be found [here](https://calypso-lang.github.io/rustdoc/calypso/index.html).
## SaturnVM
SaturnVM is the VM I'm writing for Calypso. It's meant to be mostly standalone but at the moment there may be some connections or dependencies between it and Calypso. SaturnVM's top-level crate can be found in `libs/saturnvm` and some of its subcrates will be found in `libs/` under the name `saturnvm_*`. The `calypso_vm` crate will probably be a Calypso-specific interface to SaturnVM.
For more information, see [its README](libs/saturnvm/README.md).
## Logo Credits
The logo was modified from an image by [Freepik](https://www.freepik.com) on [Flaticon](https://www.flaticon.com). The original image can be found [here](https://www.flaticon.com/free-icon/saturn_124559) or in [`logo-base.svg`](https://raw.githubusercontent.com/calypso-lang/assets/main/logo/logo-base.svg) in the [assets](https://github.com/calypso-lang/assets) repository.
## Contributors ✨
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!
[b2]: https://img.shields.io/tokei/lines/github/calypso-lang/calypso?style=flat-square
[b3]: https://img.shields.io/github/workflow/status/calypso-lang/calypso/CI?style=flat-square
[l3]: https://github.com/calypso-lang/calypso/actions[b4]: https://img.shields.io/badge/license-MIT%2FApache--2.0-blue?style=flat-square
[l4]: ./LICENSE[crates.io]: https://crates.io/
[docs.rs]: https://docs.rs/