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

org.openide.windows.IOFolding Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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 org.openide.windows;

import org.netbeans.api.annotations.common.CheckReturnValue;
import org.netbeans.api.annotations.common.NonNull;
import org.openide.util.Lookup;
import org.openide.util.Lookup.Provider;
import org.openide.util.Parameters;

/**
 * Folding of group of lines in Output Window.
 * 

* Client usage: *

*
 *  InputOutput io = ...;
 *  if (!IOFolding.isSupported(io)) {
 *    throw new Exception("Folding is not supported");
 *  }
 *  io.getOut().println("First Line - start of fold");
 *  FoldHandle fold = IOFolding.startFold(io, true);
 *  io.getOut().println("  Fold Content 1");
 *  io.getOut().println("  The first line of nested fold");
 *  FoldHandle nestedFold = fold.startFold(true);
 *  io.getOut().println("     Nested fold content 1");
 *  nestedFold.finish();
 *  io.getOut().println("  Fold Content 2");
 *  fold.finish();
 *  io.getOut().println("Text outside of the fold.");
 * 
*

* How to support {@link IOFolding} in own {@link IOProvider} implementation: *

*
    *
  • {@link InputOutput} provided by {@link IOProvider} has to implement * {@link Provider}
  • *
  • Extend {@link IOFolding} and implement its abstract methods
  • *
  • Extend {@link FoldHandleDefinition}
  • *
  • Place instance of {@link IOFolding} to {@link Lookup} provided by * {@link InputOutput}
  • *
* * @author jhavlin * @since openide.io/1.38 */ public abstract class IOFolding { /** * Check whether an {@link InputOutput} supports folding. * * @param io The InputOutput to check. * @return True if {@link #startFold(InputOutput, boolean)} can be used with * {@code io}, false otherwise. */ public static boolean isSupported(@NonNull InputOutput io) { Parameters.notNull("parent", io); //NOI18N return findIOFolding(io) != null; } /** * Find folding support in an {@link InputOutput} object. * * @return IOFolding object if folding is supported by the {@code parent} * object, null otherwise. */ private static IOFolding findIOFolding(InputOutput parent) { return (parent instanceof Lookup.Provider) ? ((Lookup.Provider) parent).getLookup().lookup(IOFolding.class) : null; } /** * Create a fold handle definition for the current last line in the output * window. * * @param expanded Initial state of the fold. * @return FoldHandleDefinition for the fold handle. Never null. * * @throws IllegalStateException if the last fold hasn't been finished yet. */ @NonNull protected abstract FoldHandleDefinition startFold(boolean expanded); /** * Create a fold handle for the current last line in the output window. * * @param io InputOutput to create the fold in. * @param expanded Initial state of the fold. * @return The fold handle that can be used to finish the fold or to create * nested folds. * @throws IllegalStateException if the last fold hasn't been finished yet. * @throws UnsupportedOperationException if folding is not supported by the * InputOutput object. */ @CheckReturnValue @NonNull public static FoldHandle startFold( @NonNull InputOutput io, boolean expanded) { Parameters.notNull("io", io); //NOI18N IOFolding folding = findIOFolding(io); if (folding == null) { throw new UnsupportedOperationException( "The InputOutput doesn't support folding"); //NOI18N } else { return new FoldHandle(folding.startFold(expanded)); } } /** * An SPI for creating custom FoldHandle implementations. */ protected abstract static class FoldHandleDefinition { /** * Finish the fold at the current last line. Ensure that nested folds * are finished correctly. * * @throws IllegalStateException if parent fold has been already * finished, or if there is an unfinished nested fold. */ public abstract void finish(); /** * Start a new fold at the current last line. Ensure that the parent * fold hasn't been finished yet. * * @param expanded If false, the fold will be collapsed by default, * otherwise it will be expanded. * @return FoldHandleDefinition of handle for the newly created fold. * @throws IllegalStateException if the fold has been already finished, * or if the last nested fold hasn't been finished yet. */ public abstract FoldHandleDefinition startFold(boolean expanded); /** * Set state of the fold. * * If a nested fold is expanded, expand all parent folds too. * * @param expanded True to expand the fold, false to collapse it. */ public abstract void setExpanded(boolean expanded); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy