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 /** 018 * This interface represents a change suggestion for a newly created sentence. The user can decide 019 * whether to follow this suggestion or not. If the suggestion is followed, the sentence is 020 * automatically changed. 021 * 022 * @author Tobias Kuhn 023 */ 024 public interface SentenceSuggestion { 025 026 /** 027 * Returns the message to be presented to the user. This message should explain the suggested 028 * change. 029 * 030 * @return The message text. 031 */ 032 public String getMessage(); 033 034 /** 035 * Returns the options given to the user to change or not change the sentence. 036 * 037 * @return The options. 038 */ 039 public String[] getOptions(); 040 041 /** 042 * Returns the possibly changed sentence accoring to the option chosen by the user. 043 * 044 * @param option The chosen option. 045 * @return The sentence, possibly changed. 046 */ 047 public Sentence getSentence(String option); 048 049 }