google-java-format

重新格式化Java源代码以符合谷歌Java风格。「Reformats Java source code to comply with Google Java Style.

  • Owner: google/google-java-format
  • Platform: Cross-platform, Linux, Mac, Unix-like, Windows
  • License:: Other
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

google-java-format

google-java-format is a program that reformats Java source code to comply with
Google Java Style.

Using the formatter

from the command-line

Download the formatter
and run it with:

java -jar /path/to/google-java-format-1.7-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.

IntelliJ, Android Studio, and other JetBrains IDEs

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.

Eclipse

A
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.

Third-party integrations

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

<dependency>
  <groupId>com.google.googlejavaformat</groupId>
  <artifactId>google-java-format</artifactId>
  <version>1.7</version>
</dependency>

Gradle

dependencies {
  compile 'com.google.googlejavaformat:google-java-format:1.7'
}

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.

Building from source

mvn install

Contributing

Please see the contributors guide for details.

License

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.

Main metrics

Overview
Name With Ownergoogle/google-java-format
Primary LanguageJava
Program languageJava (Language Count: 4)
PlatformCross-platform, Linux, Mac, Unix-like, Windows
License:Other
所有者活动
Created At2015-05-11 20:38:28
Pushed At2025-05-07 19:49:03
Last Commit At2025-05-07 12:49:03
Release Count34
Last Release Namev1.27.0 (Posted on )
First Release Namegoogle-java-format-0.1-alpha (Posted on )
用户参与
Stargazers Count5.8k
Watchers Count134
Fork Count882
Commits Count855
Has Issues Enabled
Issues Count634
Issue Open Count133
Pull Requests Count272
Pull Requests Open Count22
Pull Requests Close Count311
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private