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

org.gradle.model.internal.registry.ModelRegistry Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * 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.model.RuleSource;
import org.gradle.model.internal.core.ModelAction;
import org.gradle.model.internal.core.ModelActionRole;
import org.gradle.model.internal.core.ModelNode;
import org.gradle.model.internal.core.ModelPath;
import org.gradle.model.internal.core.ModelRegistration;
import org.gradle.model.internal.core.ModelSpec;
import org.gradle.model.internal.core.MutableModelNode;
import org.gradle.model.internal.type.ModelType;

import javax.annotation.Nullable;

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 rules); MutableModelNode getRoot(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy