fjage
fjage copied to clipboard
Framework for Java and Groovy Agents
fjåge
Framework for Java and Groovy Agents
Introduction
fjåge provides a lightweight and easy-to-learn framework for agent-oriented software development in Java and Groovy. Although most of the functionality of the framework can be used in pure-Java projects, the adoption of Groovy in the project simplifies development immensely. Typically, initialization scripts, shell interaction and command scripts are written in Groovy. Agents and support classes may be written in Java or Groovy.
Key Features
- Lightweight and fast
- Easy to learn, and rapid agent development cycle
- Agent development in Java or Groovy
- Interactive Groovy shell and scripting
- Easy switching between realtime operation and discrete event simulation
- APIs for access from Java, Groovy, Python, C, Julia, and Javascript
- JSON-based protocol to interface with external applications
Documentation
- Release Notes
- Getting Started
- Developer's Guide
- API documentation
Support
Maven Central dependency
<dependency>
<groupId>com.github.org-arl</groupId>
<artifactId>fjage</artifactId>
<version>1.12.3</version>
</dependency>
Contributing
Contributions are always welcome! Clone, develop and do a pull request!
Try to stick to the coding style already in use in the repository. Additionally, some guidelines:
Building:
gradleto build the jars including resources (webshell, fjage.js, etc.)gradle liteto build only the jarsgradle testto run all regression tests (automated through Github actions CI)gradle publishto upload jars to Maven staging (requires credentials)make htmlto build developer's documentation (automated through ReadTheDocs)gradle javadocto build the Java API documentationnpm run docsto build the Javascript API documentation
License
fjåge is licensed under the Simplified (3-clause) BSD license. See LICENSE.txt for more details.