org.gradle.model.internal.registry.ModelRegistry Maven / Gradle / Ivy
/*
* Copyright 2013 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.model.internal.registry;
import org.gradle.api.Nullable;
import org.gradle.model.RuleSource;
import org.gradle.model.internal.core.*;
import org.gradle.model.internal.type.ModelType;
public interface ModelRegistry {
/**
* Get the fully defined model element at the given path as the given type.
*
* No attempt to mutate the returned object should be made.
*
* @param path the path for the node
* @param type the type to project the node as
* @param the type to project the node as
* @return the node as the given type
*/
T realize(ModelPath path, ModelType type);
T realize(String path, ModelType type);
T realize(String path, Class type);
/**
* Get the fully defined model element at the given path.
*
* No attempt to mutate the returned object should be made.
*
* @param path the path for the node
* @return the node.
*/
ModelNode realizeNode(ModelPath path);
/**
* Get the fully defined model element at the given path as the given type, if present.
*
* No attempt to mutate the returned object should be made.
*
* @param path the path for the node
* @param type the type to project the node as
* @param the type to project the node as
* @return the node as the given type or null if no such element.
*/
@Nullable
T find(ModelPath path, ModelType type);
@Nullable
T find(String path, ModelType type);
@Nullable
T find(String path, Class type);
/**
* Returns the node at the given path at the desired state or later, if it exists.
*
* If there is no known node at that path, an {@link IllegalStateException} is thrown.
*
* If the node is at an earlier state than desired it will be irrevocably transitioned to the desired state and returned.
* If it is at the desired state or later it is returned.
*
* @param path the path for the node
* @param state the desired node state
* @return the node at the desired state
*/
ModelNode atStateOrLater(ModelPath path, ModelNode.State state);
T atStateOrLater(ModelPath path, ModelType type, ModelNode.State state);
ModelNode.State state(ModelPath path);
void remove(ModelPath path);
/**
* Attempts to bind the references of all model rules known at this point in time.
*
* This method effectively validates that all references bind (i.e. all rules are executable).
* It should be called when the model registry is at some kind of logical checkpoint, in that it is reasonable
* to expect that all rules have been discovered.
*
* However, it does not prevent rules from being added after being called.
* This is necessary as mutation rules can add rules etc.
* As such, this method can be called multiple times.
* Subsequent invocations will bind the references of rules added since the previous invocation.
*
* If any reference cannot successfully bind, an exception will be thrown.
*
* @throws UnboundModelRulesException if there are unbindable references
*/
void bindAllReferences() throws UnboundModelRulesException;
ModelRegistry register(ModelRegistration registration);
/**
* Bind the given action directly to its subject node in the given role. Calling {@link #bindAllReferences()} fails
* if the subject of the action is not matched by any node.
*/
ModelRegistry configure(ModelActionRole role, ModelAction action);
/**
* Registers a listener and binds the given action in the given role whenever a node that matches the spec is discovered.
* Matching nodes that are already discovered when {@code configureMatching()} is called are bound directly.
* Unlike with {@link #configure(ModelActionRole, ModelAction)}, {@link #bindAllReferences()} will not fail
* if no nodes match the given spec.
*
* @throws IllegalArgumentException if the given action has a path
set.
*/
ModelRegistry configureMatching(ModelSpec spec, ModelActionRole role, ModelAction action);
/**
* Registers a listener and applies the given {@link RuleSource} whenever a node that matches the spec is discovered.
* Matching nodes that are already discovered when {@code configureMatching()} is called are bound directly.
* Unlike with {@link #configure(ModelActionRole, ModelAction)}, {@link #bindAllReferences()} will not fail
* if no nodes match the given spec.
*/
ModelRegistry configureMatching(ModelSpec spec, Class extends RuleSource> rules);
MutableModelNode getRoot();
}