All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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, }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy