001    // This file is part of AceWiki.
002    // Copyright 2008-2012, AceWiki developers.
003    // 
004    // AceWiki is free software: you can redistribute it and/or modify it under the terms of the GNU
005    // Lesser General Public License as published by the Free Software Foundation, either version 3 of
006    // the License, or (at your option) any later version.
007    // 
008    // AceWiki is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
009    // even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
010    // Lesser General Public License for more details.
011    // 
012    // You should have received a copy of the GNU Lesser General Public License along with AceWiki. If
013    // not, see http://www.gnu.org/licenses/.
014    
015    package ch.uzh.ifi.attempto.acewiki.core;
016    
017    import java.util.HashMap;
018    import java.util.Map;
019    
020    /**
021     * This is a partial implementation of a language handler.
022     * 
023     * @author Tobias Kuhn
024     */
025    public abstract class AbstractLanguageHandler implements LanguageHandler {
026    
027            private Map<String, LexiconChanger> lexiconChangers = new HashMap<String, LexiconChanger>();
028    
029            /**
030             * Sets a lexicon changer for the given lexical type.
031             * 
032             * @param type The lexical type.
033             * @param lexiconChanger The lexicon changer.
034             */
035            public void setLexiconChanger(String type, LexiconChanger lexiconChanger) {
036                    lexiconChangers.put(type, lexiconChanger);
037            }
038            
039            public LexiconChanger getLexiconChanger(String type) {
040                    return lexiconChangers.get(type);
041            }
042            
043            public SentenceSuggestion getSuggestion(Sentence sentence) {
044                    return null;
045            }
046    
047    }