View Javadoc

1   /*
2    * db2sa: DB2 Syntax Assistant
3    * Copyright (C) Andres Gomez Casanova
4    *
5    * This file is part of db2sa.
6    *
7    * db2sa is free software: you can redistribute it and/or modify
8    * it under the terms of the GNU Lesser General Public License as published by
9    * the Free Software Foundation; either version 3 of the License, or
10   * (at your option) any later version.
11   *
12   * db2sa is distributed in the hope that it will be useful,
13   * but WITHOUT ANY WARRANTY; without even the implied warranty of
14   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15   * GNU Lesser General Public License for more details.
16   *
17   * You should have received a copy of the GNU Lesser General Public License
18   * along with this library; if not, see <http://www.gnu.org/licenses/>.
19   *
20   * Contact:
21   * a n g o c a  at  y a h o o  dot  c o m
22   * Cra. 45 No 61 - 31, Bogota, Colombia.
23   *
24   * Author:   $LastChangedBy: angoca $:
25   * Date:     $LastChangedDate: 2009-04-12 13:54:19 +0200 (Sun, 12 Apr 2009) $:
26   * Revision: $LastChangedRevision: 44 $:
27   * URL:      $HeadURL: https://db2sa.svn.sourceforge.net/svnroot/db2sa/branches/db2sa_beta/source-code/src/main/java/name/angoca/db2sa/core/syntax/AbstractSyntacticalAnalyzer.java $:
28   */
29  package name.angoca.db2sa.core.syntax;
30  
31  import java.util.List;
32  
33  import name.angoca.db2sa.core.lexical.Token;
34  import name.angoca.db2sa.core.syntax.graph.exception.InvalidGraphException;
35  
36  /**
37   * This object has methods to scan the structure and to find the possibilities
38   * of next tokens, that provide the possible ways that the user can take when
39   * writing a command.<br/>
40   * A phrase is a set of words that can or can't have a meaning for DB2.<br/>
41   * <b>Control Version</b><br />
42   * <ul>
43   * <li>0.0.1 Class creation.</li>
44   * <li>0.1.0</li>
45   * <li>1.0.0 Moved to version 1.</li>
46   * </ul>
47   * 
48   * @author Andres Gomez Casanova <a
49   *         href="mailto:a n g o c a at y a h o o dot c o m">(AngocA)</a>
50   * @version 1.0.0 2009-07-19
51   */
52  public abstract class AbstractSyntacticalAnalyzer {
53  
54      /**
55       * Returns the possible options that a given phrase can have. When no option
56       * is found, the returned array is empty (not null).
57       * 
58       * @param phrase
59       *            Phrase to analyze. This is an ensemble of tokens that are
60       *            sorted in the same way that words were written by the user.
61       * @return The possible answers: the command completed or the options.
62       * @throws InvalidGraphException
63       *             When the graph has an invalid structure.
64       */
65      public abstract GraphAnswer/* <!>! */getOptions(
66              final List<Token>/* <!>! */phrase) throws InvalidGraphException;
67  }