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

org.gradle.api.plugins.ExtensionAware Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2011 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 org.gradle.api.plugins;

import org.gradle.api.tasks.Internal;

/**
 * Objects that can be extended at runtime with other objects.
 *
 * 
 * // Extensions are just plain objects, there is no interface/type
 * class MyExtension {
 *   String foo
 *
 *   MyExtension(String foo) {
 *     this.foo = foo
 *   }
 * }
 *
 * // Add new extensions via the extension container
 * project.extensions.create('custom', MyExtension, "bar")
 * //                       («name»,   «type»,       «constructor args», …)
 *
 * // extensions appear as properties on the target object by the given name
 * assert project.custom instanceof MyExtension
 * assert project.custom.foo == "bar"
 *
 * // also via a namespace method
 * project.custom {
 *   assert foo == "bar"
 *   foo = "other"
 * }
 * assert project.custom.foo == "other"
 *
 * // Extensions added with the extension container's create method are themselves extensible
 * assert project.custom instanceof ExtensionAware
 * project.custom.extensions.create("nested", MyExtension, "baz")
 * assert project.custom.nested.foo == "baz"
 *
 * // All extension aware objects have a special “ext” extension of type ExtraPropertiesExtension
 * assert project.hasProperty("myProperty") == false
 * project.ext.myProperty = "myValue"
 *
 * // Properties added to the “ext” extension are promoted to the owning object
 * assert project.myProperty == "myValue"
 * 
* * Many Gradle objects are extension aware. This includes; projects, tasks, configurations, dependencies etc. *

* For more on adding & creating extensions, see {@link ExtensionContainer}. *

* For more on extra properties, see {@link ExtraPropertiesExtension}. *

* An ExtensionAware object has several 'scopes' that Gradle searches for properties. These scopes are:

* *
    *
  • The object itself. This scope includes any property getters and setters declared by the * implementation class. The properties of this scope are readable or writable depending on the presence * of the corresponding getter or setter method.
  • * *
  • Groovy Meta-programming methods implemented by the object's class, like propertyMissing(). Care must be taken by plugin authors to * ensure propertyMissing() is implemented such that if a property is not found a MissingPropertyException(String, Class) exception is thrown. * If propertyMissing() always returns a value for any property, Gradle will not search the rest of the scopes below.
  • * *
  • The extra properties of the object. Each object maintains a map of extra properties, which * can contain any arbitrary name -> value pair. Once defined, the properties of this scope are readable and writable.
  • * *
  • The extensions added to the object by plugins. Each extension is available as a read-only property with the same name as the extension.
  • *
*/ public interface ExtensionAware { /** * The container of extensions. */ @Internal ExtensionContainer getExtensions(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy