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

org.netbeans.modules.turbo.TurboProvider Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.netbeans.modules.turbo;

import java.util.List;

/**
 * SPI, extension point allowing third parties to redefine
 * attribute reading and writing. Must be registered
 * in default {@link org.openide.util.Lookup}.
 * 

* It must generally deternime that they * support given entity key and attribute pair * and if so then perform action. *

* Two providers can theoreticaly clash and support * the same attribute for the same entity key. The * key point is that attribute meaning must be precisely * defined guaranteeing that two independent providers * respond with exactly same value hence making irrelevant * which one is actually choosen. *

* Providers should not cache results. * * @author Petr Kuzel */ public interface TurboProvider { /** * Reports if an attribute is supported by the implementation. */ boolean recognizesAttribute(String name); /** * Reports if the entity identified by key is supported by the implementation. */ boolean recognizesEntity(Object key); /** * Reads given attribute for given fileobject. No method * parameter may be referenced after method execution finishes. * * @param key identifies source entity, never null * @param name identifies requested attribute, never null * @param memoryCache can store speculative results * @return attribute value or null if it does not exist. */ Object readEntry(Object key, String name, MemoryCache memoryCache); /** * Writes given attribute. No method * parameter may be referenced after method execution finishes. * * @param key identifies target entity, never null * @param name identifies attribute, never null * @param value actual attribute value that should be stored or null for removing it * @return false on write failure if provider denies the value. On I/O error it * returns true. */ boolean writeEntry(Object key, String name, Object value); /** * Provides direct access to memory layer (without * delegating to providers layer, here source). */ public static final class MemoryCache { private final boolean enabled; private final List speculative; private final Memory memory; private MemoryCache(boolean enabled) { this.enabled = enabled; speculative = null; memory = null; } private MemoryCache(Memory memory, List speculative) { enabled = true; this.memory = memory; this.speculative = speculative; } /** * Creates instance intercepting speculative results. * @param memory implementation * @param speculative add()s speculative results into it */ static MemoryCache createDefault(Memory memory, List speculative) { return new MemoryCache(memory, speculative); } /** T9Y entry point. */ static MemoryCache getTest() { return new MemoryCache(false); } /** * Writes speculative entry into memory layer. */ public void cacheEntry(Object key, String name, Object value) { if (enabled == false) return; memory.put(key, name, value); if (speculative != null) speculative.add(new Object[] {key, name, value}); } /** Return speculative results []{FileObject,String,Object} silently inserted into memory */ List getSpeculative() { return speculative; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy