/* * Hibernate Search, full-text search for your domain model * * License: GNU Lesser General Public License (LGPL), version 2.1 or later * See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.search.elasticsearch.analyzer.impl; import java.util.Collections; import java.util.Map; import java.util.TreeMap; import org.hibernate.search.elasticsearch.logging.impl.Log; import org.hibernate.search.elasticsearch.settings.impl.model.AnalyzerDefinition; import org.hibernate.search.elasticsearch.settings.impl.model.CharFilterDefinition; import org.hibernate.search.elasticsearch.settings.impl.model.TokenFilterDefinition; import org.hibernate.search.elasticsearch.settings.impl.model.TokenizerDefinition; import org.hibernate.search.util.logging.impl.LoggerFactory; /** * A simple implementation of {@link ElasticsearchAnalysisDefinitionRegistry}. * <p> * This class also provides access to the mapping from full names to definitions. * * @author Yoann Rodiere */ public final class SimpleElasticsearchAnalysisDefinitionRegistry implements ElasticsearchAnalysisDefinitionRegistry { private static final Log LOG = LoggerFactory.make( Log.class ); private final Map<String, AnalyzerDefinition> analyzerDefinitions = new TreeMap<>(); private final Map<String, TokenizerDefinition> tokenizerDefinitions = new TreeMap<>(); private final Map<String, TokenFilterDefinition> tokenFilterDefinitions = new TreeMap<>(); private final Map<String, CharFilterDefinition> charFilterDefinitions = new TreeMap<>(); @Override public void register(String name, AnalyzerDefinition definition) { AnalyzerDefinition previous = analyzerDefinitions.putIfAbsent( name, definition ); if ( previous != null && previous != definition ) { throw LOG.analyzerNamingConflict( name ); } } @Override public void register(String name, TokenizerDefinition definition) { TokenizerDefinition previous = tokenizerDefinitions.putIfAbsent( name, definition ); if ( previous != null && previous != definition ) { throw LOG.tokenizerNamingConflict( name ); } } @Override public void register(String name, TokenFilterDefinition definition) { TokenFilterDefinition previous = tokenFilterDefinitions.putIfAbsent( name, definition ); if ( previous != null && previous != definition ) { throw LOG.tokenFilterNamingConflict( name ); } } @Override public void register(String name, CharFilterDefinition definition) { CharFilterDefinition previous = charFilterDefinitions.putIfAbsent( name, definition ); if ( previous != null && previous != definition ) { throw LOG.charFilterNamingConflict( name ); } } @Override public AnalyzerDefinition getAnalyzerDefinition(String name) { return analyzerDefinitions.get( name ); } @Override public TokenizerDefinition getTokenizerDefinition(String name) { return tokenizerDefinitions.get( name ); } @Override public TokenFilterDefinition getTokenFilterDefinition(String name) { return tokenFilterDefinitions.get( name ); } @Override public CharFilterDefinition getCharFilterDefinition(String name) { return charFilterDefinitions.get( name ); } public Map<String, AnalyzerDefinition> getAnalyzerDefinitions() { return Collections.unmodifiableMap( analyzerDefinitions ); } public Map<String, TokenizerDefinition> getTokenizerDefinitions() { return Collections.unmodifiableMap( tokenizerDefinitions ); } public Map<String, TokenFilterDefinition> getTokenFilterDefinitions() { return Collections.unmodifiableMap( tokenFilterDefinitions ); } public Map<String, CharFilterDefinition> getCharFilterDefinitions() { return Collections.unmodifiableMap( charFilterDefinitions ); } }