commit | c1dd08d349b098f4bceb5b71aa1d6c2251de4f6d | [log] [tgz] |
---|---|---|
author | Christian Stein <sormuras@gmail.com> | Wed Nov 25 10:47:19 2020 -0800 |
committer | google-java-format Team <google-java-format-dev+copybara@google.com> | Wed Nov 25 10:47:47 2020 -0800 |
tree | 91ac19671af22318a3a227a307b3f987a63b2b34 | |
parent | 3ce093515ad0bc1458e8965fdf71f78482f87968 [diff] |
Introduce GitHub Actions based CI workflow This PR introduces a CI workflow using GitHub Actions and removes the Travis CI configuration file. Find new workflow runs for this PR here: https://github.com/sormuras/google-java-format/actions #### TODO - [x] Email [Notifications](https://docs.github.com/en/free-pro-team@latest/github/managing-subscriptions-and-notifications-on-github/configuring-notifications) -- register `google-java-format-dev+ci@google.com` as a watcher or let each interested use register themself? - [ ] Test publish snapshot job on `google:master` -- after storing credential [secrets](https://github.com/google/google-java-format/settings/secrets/actions). - [ ] Remove AppVeyor [integration](https://github.com/google/google-java-format/settings/installations) and delete `appveyor.yml` configuration file. Closes #543 Fixes #544 COPYBARA_INTEGRATE_REVIEW=https://github.com/google/google-java-format/pull/544 from sormuras:github-action a689f6234aed2e32bd7aca093b92e391ac6c8170 PiperOrigin-RevId: 344280060
google-java-format
is a program that reformats Java source code to comply with Google Java Style.
Download the formatter and run it with:
java -jar /path/to/google-java-format-1.9-all-deps.jar <options> [files...]
The formatter can act on whole files, on limited lines (--lines
), on specific offsets (--offset
), passing through to standard-out (default) or altered in-place (--replace
).
To reformat changed lines in a specific patch, use google-java-format-diff.py
.
Note: There is no configurability as to the formatter's algorithm for formatting. This is a deliberate design decision to unify our code formatting on a single format.
A google-java-format IntelliJ plugin is available from the plugin repository. To install it, go to your IDE's settings and select the Plugins
category. Click the Marketplace
tab, search for the google-java-format
plugin, and click the Install
button.
The plugin will be disabled by default. To enable it in the current project, go to File→Settings...→google-java-format Settings
(or IntelliJ IDEA→Preferences...→Other Settings→google-java-format Settings
on macOS) and check the Enable google-java-format
checkbox. (A notification will be presented when you first open a project offering to do this for you.)
To enable it by default in new projects, use File→Other Settings→Default Settings...
.
When enabled, it will replace the normal Reformat Code
action, which can be triggered from the Code
menu or with the Ctrl-Alt-L (by default) keyboard shortcut.
The import ordering is not handled by this plugin, unfortunately. To fix the import order, download the IntelliJ Java Google Style file and import it into File→Settings→Editor→Code Style.
Version 1.6 of the google-java-format Eclipse plugin can be downloaded from the releases page. Drop it into the Eclipse drop-ins folder to activate the plugin.
The plugin adds a google-java-format
formatter implementation that can be configured in Window > Preferences > Java > Code Style > Formatter > Formatter Implementation
.
The formatter can be used in software which generates java to output more legible java code. Just include the library in your maven/gradle/etc. configuration.
<dependency> <groupId>com.google.googlejavaformat</groupId> <artifactId>google-java-format</artifactId> <version>1.9</version> </dependency>
dependencies { compile 'com.google.googlejavaformat:google-java-format:1.9' }
You can then use the formatter through the formatSource
methods. E.g.
String formattedSource = new Formatter().formatSource(sourceString);
or
CharSource source = ... CharSink output = ... new Formatter().formatSource(source, output);
Your starting point should be the instance methods of com.google.googlejavaformat.java.Formatter
.
mvn install
Please see the contributors guide for details.
Copyright 2015 Google Inc. 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.