# google-java-format **Repository Path**: guorongfeng/google-java-format ## Basic Information - **Project Name**: google-java-format - **Description**: Reformats Java source code to comply with Google Java Style. - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2018-03-26 - **Last Updated**: 2024-05-30 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # google-java-format `google-java-format` is a program that reformats Java source code to comply with [Google Java Style][]. [Google Java Style]: https://google.github.io/styleguide/javaguide.html ## Using the formatter ### from the command-line [Download the formatter](https://github.com/google/google-java-format/releases) and run it with: ``` java -jar /path/to/google-java-format-1.5-all-deps.jar [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`](https://github.com/google/google-java-format/blob/master/scripts/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.* ### IntelliJ A [google-java-format IntelliJ plugin](https://plugins.jetbrains.com/plugin/8527) is available from the plugin repository. The plugin will not be enabled by default. To enable it in the current project, go to "File→Settings...→google-java-format Settings" and check the "Enable" checkbox. 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. ### Eclipse A [google-java-format Eclipse plugin](https://github.com/google/google-java-format/releases/download/google-java-format-1.3/google-java-format-eclipse-plugin-1.3.0.jar) can be downloaded from the releases page. Drop it into the Eclipse [drop-ins folder](http://help.eclipse.org/neon/index.jsp?topic=%2Forg.eclipse.platform.doc.isv%2Freference%2Fmisc%2Fp2_dropins_format.html) 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`. ### as a library 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. #### Maven ```xml com.google.googlejavaformat google-java-format 1.5 ``` #### Gradle ```groovy dependencies { compile 'com.google.googlejavaformat:google-java-format:1.5' } ``` You can then use the formatter through the `formatSource` methods. E.g. ```java String formattedSource = new Formatter().formatSource(sourceString); ``` or ```java CharSource source = ... CharSink output = ... new Formatter().formatSource(source, output); ``` Your starting point should be the instance methods of `com.google.googlejavaformat.java.Formatter`. ## Building from source mvn install ## Contributing Please see [the contributors guide](CONTRIBUTING.md) for details. ## License ```text 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. ```