Thanks for your interest in contributing to this SDK! This document provides guidelines for contributing to the project.
- Java 11+
- Gradle
Install the project dependencies:
./gradlew buildBuild the project:
./gradlew buildRun the test suite:
./gradlew testCheck and fix code style:
./gradlew spotlessApplyImportant: Most files in this SDK are automatically generated by Fern from the API definition. Direct modifications to generated files will be overwritten the next time the SDK is generated.
The following directories contain generated code:
src/- API client classes and types- Most Java files in the project
If you need to customize the SDK, you have two options:
For custom code that should persist across SDK regenerations:
- Create a
.fernignorefile in the project root - Add file patterns for files you want to preserve (similar to
.gitignoresyntax) - Add your custom code to those files
Files listed in .fernignore will not be overwritten when the SDK is regenerated.
For more information, see the Fern documentation on custom code.
If you want to change how code is generated for all users of this SDK:
- The Java SDK generator lives in the Fern repository
- Generator code is located at
generators/java-v2/ - Follow the Fern contributing guidelines
- Submit a pull request with your changes to the generator
This approach is best for:
- Bug fixes in generated code
- New features that would benefit all users
- Improvements to code generation patterns
- Create a new branch for your changes
- Make your modifications
- Run tests to ensure nothing breaks:
./gradlew test - Run formatting:
./gradlew spotlessApply - Build the project:
./gradlew build - Commit your changes with a clear commit message
- Push your branch and create a pull request
Write clear, descriptive commit messages that explain what changed and why.
This project uses automated code formatting. Run ./gradlew spotlessApply before committing to ensure your code meets the project's style guidelines.
If you have questions or run into issues:
- Check the Fern documentation
- Search existing GitHub issues
- Open a new issue if your question hasn't been addressed
By contributing to this project, you agree that your contributions will be licensed under the same license as the project.