Popularity
6.6
Growing
Activity
9.3
Declining
143
19
22

Programming language: Kotlin
Tags: Functional Programming    

Arrow Meta alternatives and similar libraries

Based on the "Functional Programming" category

Do you think we are missing an alternative of Arrow Meta or a related project?

Add another 'Functional Programming' Library

README

Λrrow Meta

Latest snapshot Publish artifacts Publish documentation Kotlin version badge License

Functional companion to Kotlin's Compiler & IDE

Getting started

Λrrow Meta is a meta-programming library that cooperates with the Kotlin compiler in all it's phases bringing its full power to the community.

Writing compiler plugins, source transformations, IDEA plugins, linters, type search engines, automatic code refactoring,... are just a few of the use cases of the things that can be accomplished with Meta.

Λrrow Meta examples

[Hello World Compiler Plugin Demo](docs/img/demos/hello-world-compiler-plugin.gif)

Take a look at arrow-meta-examples repository for getting more details.

Build and run in your local environment

Build and run tests

./gradlew buildMeta -Dorg.gradle.debug=true -Dkotlin.compiler.execution.strategy="in-process"

Build and run test + IDE plugin

./gradlew publishAndRunIde -Dorg.gradle.debug=true -Dkotlin.compiler.execution.strategy="in-process"

Testing

Λrrow Meta provides an easy way to write tests about plugins, quotes, etc. thanks to Kotlin Compile Testing, a library developed by Thilo Schuchort.

Contributing

Λrrow Meta is an inclusive community powered by awesome individuals like you. As an actively growing ecosystem, Λrrow Meta and its associated libraries and toolsets are in need of new contributors! We have issues suited for all levels, from entry to advanced, and our maintainers are happy to provide 1:1 mentoring. All are welcome in Λrrow Meta.

If you’re looking to contribute, have questions, or want to keep up-to-date about what’s happening, please follow us here and say hello!

Licence

Copyright (C) 2017 The Λrrow Authors

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.


*Note that all licence references and agreements mentioned in the Arrow Meta README section above are relevant to that project's source code only.