com.palantir.javaformat.PartialInlineability Maven / Gradle / Ivy
/*
* (c) Copyright 2019 Palantir Technologies Inc. All rights reserved.
*
* 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.
*/
package com.palantir.javaformat;
import com.palantir.javaformat.doc.Break;
import com.palantir.javaformat.java.JavaInputAstVisitor;
/**
* What are the conditions for a level to be partially inlineable. Partial inlining refers to the behaviour of
* {@link BreakBehaviours#breakOnlyIfInnerLevelsThenFitOnOneLine} where a level is too large to fit on the current line,
* but a prefix thereof is partially inlined onto the current line.
*
* Specifically, when inlining a level with the above behaviour, the partial inlineability of its first
* child level (and that level's first child, recursively) is queried in order to determine if we need
* to ensure there's enough room for some additional prefix of that level.
*
*
The reason for this is to prevent degenerate formattings like
*
*
* Object foo = someSuperLongMethod(some |
* .fully |
* .qualified |
* .ClassName |
* .doSomething()); |
*
*
* and instead prefer breaking earlier to keep the prefix on the same line, like:
*
*
* Object foo = someSuperLongMethod( |
* some.fully.qualified.ClassName|
* .doSomething()); |
*
*
* Note that this works as a mandatory access control. Namely, if it's allowed to partially inline a level,
* what are the additional conditions that have to be met in order for the inlining to go ahead.
*/
public enum PartialInlineability {
/**
* The level may always be partially inlined, regardless of how much space is left on the current line.
*
*
This is usually only appropriate for levels that start with a direct {@link Break}, as opposed to a Break
* that's nested inside some other levels.
*/
ALWAYS_PARTIALLY_INLINEABLE,
/**
* Partially inlineable if the first inner level of this level fits on the current line.
*
*
This assumes that the next Doc after that starts with a {@link Break} (see {@link StartsWithBreakVisitor}) and
* makes sense in contexts like {@link JavaInputAstVisitor#visitDotWithPrefix} where we want to treat first doc (the
* longest prefix) as a single entity to be fit onto the same line.
*/
IF_FIRST_LEVEL_FITS,
}