Note: If these contribution guidelines are not followed your issue or PR might be closed, so please read these instructions carefully.
See also: the Invertase code of conduct
Globe is a global deployment platform for Dart & Flutter applications.
- If you find a bug, please first report it using GitHub issues.
- First check if there is not already an issue for it; duplicated issues will be closed.
- If you'd like to submit a fix for a bug, please read the How To for how to send a pull request.
- Indicate on the open issue that you are working on fixing the bug and the issue will be assigned to you.
- Write
Fix #xxxxin your PR text, where xxxx is the issue number (if there is one). - Include a test that isolates the bug and verifies that it was fixed.
- If you'd like to add a feature to the library that doesn't already exist, feel free to describe the feature in a new GitHub issue.
- If you'd like to implement the new feature, please wait for feedback from the project maintainers before spending too much time writing the code. In some cases, enhancements may not align well with the project future development direction.
- If applicable, implement the code for the new feature and please read the How To.
- If you have suggestions for improvements to the documentation or examples (or something else), we would love to hear about it.
- As always first file a GitHub issue.
- Implement the changes to the documentation, please read the How To.
- Linux, Mac OS X, or Windows.
- Git (used for source version control).
- An IDE such as Android Studio or Visual Studio Code.
- Ensure all the dependencies described in the previous section are installed.
- Fork
https://github.com/invertase/globeinto your own GitHub account. If you already have a fork, and are now installing a development environment on a new machine, make sure you've updated your fork so that you don't use stale configuration options from long ago. git clone git@github.com:<your_name_here>/globe.gitgit remote add upstream git@github.com:invertase/globe.git(So that you fetch from the main repository, not your clone, when runninggit fetchorgit pull
This repository uses a tool called Melos to manage packages and dependencies, to set it up, run the following command from your terminal:
dart pub global activate melosNext, at the root of your locally cloned repository bootstrap the projects dependencies:
melos bootstrapThe bootstrap command locally links all dependencies within the project without having to
provide manual dependency_overrides. This allows all
plugins, examples and tests to build from the local clone project. You should only need to run this
command once.
You do not need to run
dart pub getonce bootstrap has been completed.
After bootstrapping, run the follwing command to get the latest graphql schema.
melos run download-schemaTo activate the Globe CLI for local development, run the following command inside the package directory:
dart pub global activate --source="path" . --executable="globe"- Create a new local branch from
main(e.g.git checkout -b my-new-feature) - Make your changes (try to split them up with one PR per feature/fix).
- When committing your changes, make sure that each commit message is clear
(e.g.
git commit -m 'docs: Add CONTRIBUTING.md'). - Push your new branch to your own fork into the same remote branch
(e.g.
git push origin my-username.my-new-feature, replaceoriginif you use another remote.)
- Switch to
mainbranch locally. - Run
git pull origin main. - Run
git pull --tagsto make sure all tags are fetched. - Run
melos versionto automatically version packages and update Changelogs. - Run
melos publishto dry run and confirm all packages are publishable. - Run
melos publish --no-dry-run - Run
git push --follow-tagsto ensure the release is pushed to GitHub.
To send us a pull request:
- Go to
https://github.com/invertase/globeand click the "Compare & pull request" button
Please make sure all your check-ins have detailed commit messages explaining the patch.
When naming the title of your pull request, please follow the Conventional Commits guide.
Please also enable “Allow edits by maintainers”, this will help to speed-up the review process as well.