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

com.github.rvesse.airline.examples.inheritance.GoodGrandchild Maven / Gradle / Ivy

/**
 * Copyright (C) 2010-15 the original author or authors.
 *
 * 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.github.rvesse.airline.examples.inheritance;

import com.github.rvesse.airline.annotations.Command;
import com.github.rvesse.airline.annotations.Option;
import com.github.rvesse.airline.examples.ExampleExecutor;
import com.github.rvesse.airline.examples.modules.Modules;

/**
 * When inheriting from existing classes it is possible to override previously
 * defined options but only if you are explicit about it. In this case Airline
 * uses the bottom-most definition of the option as the effective definition
 * 

* Note that any values set for options are propagated to all declarations in * the inheritance tree since an ancestor class will not have access to fields * set in the descendants. *

* */ @Command(name = "good-grandchild", description = "A legal command which overrides an option defined by a parent") public class GoodGrandchild extends Child { /** * We can override the definition of an existing option under certain * conditions: *
    *
  • {@code arity}, {@code name} and {@code optionType} are unchanged
  • *
  • Type is same or a valid narrowing conversion exists from the * inherited option type to the overridden type
  • *
  • You explicitly declare {@code override} to be {@code true} and the * inherited option does not define {@code sealed} to be {@code true}
  • *
*

* In practise this means you can change some informative properties of the * option such as the title and description. You can also choose to make it * visible/hidden and required/not required as desired. *

*

* Note that often if you find yourself needing to override options * frequently then this can be indicative of poorly thought out option * inheritance in which case using modules may be a better option. See * {@link Modules} for an example of this. *

*/ @Option(name = "--parent", description = "An option can be overridden if we are explicit about it", override = true) private boolean parent; public static void main(String[] args) { ExampleExecutor.executeSingleCommand(GoodGrandchild.class, args); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy