001// Licensed under the Apache License, Version 2.0 (the "License");
002// you may not use this file except in compliance with the License.
003// You may obtain a copy of the License at
004//
005// http://www.apache.org/licenses/LICENSE-2.0
006//
007// Unless required by applicable law or agreed to in writing, software
008// distributed under the License is distributed on an "AS IS" BASIS,
009// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
010// See the License for the specific language governing permissions and
011// limitations under the License.
012
013package org.apache.tapestry5.internal.services;
014
015import org.apache.tapestry5.internal.parser.ComponentTemplate;
016import org.apache.tapestry5.model.ComponentModel;
017import org.apache.tapestry5.services.InvalidationEventHub;
018import org.apache.tapestry5.services.pageload.ComponentResourceSelector;
019
020/**
021 * Provides access to cached {@link org.apache.tapestry5.internal.parser.ComponentTemplate}s. The source acts as a
022 * invalidation event hub, and will broadcast invalidation events when any loaded template resource changes. The
023 * listener for these invalidation events is the page source, which stores cached page instances.
024 *
025 * Any search for a template will end with success (a non-null template), but the template returned may be the
026 * {@link ComponentTemplate#isMissing() missing template}.
027 */
028public interface ComponentTemplateSource
029{
030    /**
031     * Provides access to a template. The template will be parsed as necessary. If no template for the exact component
032     * is found, then the template for the component's parent is returned. In this way, it is possible for a component
033     * to extend the behavior of its super-class without duplicating the super-class component's template.
034     *
035     * In some cases, the empty template will be returned.
036     * 
037     * @param componentModel
038     *            model for the component whose template is to be accessed
039     * @param selector
040     *            defines locale and other information needed to locate template
041     * @return the cached template instance
042     */
043    ComponentTemplate getTemplate(ComponentModel componentModel, ComponentResourceSelector selector);
044
045    /**
046     * Event hub used to notify listeners that underlying component template files have changed.
047     * 
048     * @see org.apache.tapestry5.services.ComponentTemplates
049     * @since 5.1.0.0
050     */
051    InvalidationEventHub getInvalidationEventHub();
052}