import java.util.Collection;
import java.util.Comparator;
import java.util.HashMap;
-import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Set;
/**
* Manages the identifer index information for a specific project
- *
+ *
*/
public class IdentifierIndexManager {
public class LineCreator implements ITerminalSymbols {
/**
* Add the information of the current identifier to the line
- *
+ *
* @param typeOfIdentifier
* the type of the identifier ('c'lass, 'd'efine, 'f'unction, 'm'ethod(class), 'v'ariable(class) 'g'lobal variable)
* @param identifier
/**
* Add the information of the current identifier to the line
- *
+ *
* @param typeOfIdentifier
* the type of the identifier ('c'lass, 'd'efine, 'f'unction, 'm'ethod(class), 'v'ariable(class) 'g'lobal variable)
* @param identifier
/**
* Get the next token from input
*/
- private void getNextToken() {
- try {
- fToken = fScanner.getNextToken();
- if (Scanner.DEBUG) {
- int currentEndPosition = fScanner.getCurrentTokenEndPosition();
- int currentStartPosition = fScanner.getCurrentTokenStartPosition();
- System.out.print(currentStartPosition + "," + currentEndPosition + ": ");
- System.out.println(fScanner.toStringAction(fToken));
- }
- return;
- } catch (InvalidInputException e) {
- // ignore errors
- // e.printStackTrace();
+ private void getNextToken() throws InvalidInputException {
+ // try {
+ fToken = fScanner.getNextToken();
+ if (Scanner.DEBUG) {
+ int currentEndPosition = fScanner.getCurrentTokenEndPosition();
+ int currentStartPosition = fScanner.getCurrentTokenStartPosition();
+ System.out.print(currentStartPosition + "," + currentEndPosition + ": ");
+ System.out.println(fScanner.toStringAction(fToken));
}
- fToken = TokenNameERROR;
+ return;
+ // } catch (InvalidInputException e) {
+ // // ignore errors
+ // // e.printStackTrace();
+ // }
+ // fToken = TokenNameERROR;
}
private void parseDeclarations(char[] parent, StringBuffer buf, boolean goBack) {
getNextToken();
}
}
+ } catch (InvalidInputException e) {
+ // ignore errors
} catch (SyntaxError e) {
// TODO Auto-generated catch block
e.printStackTrace();
fScanner.setSource(charArray);
fScanner.setPHPMode(false);
fToken = TokenNameEOF;
- getNextToken();
try {
+ getNextToken();
while (fToken != TokenNameEOF) { // && fToken != TokenNameERROR) {
phpdocOffset = -1;
hasModifiers = false;
getNextToken();
}
}
+ } catch (InvalidInputException e) {
+ // ignore errors
} catch (SyntaxError e) {
// TODO Auto-generated catch block
e.printStackTrace();
/**
* Check if 2 char arrays are equal
- *
+ *
* @param a
* @param b
* @return
/**
* Add the information for a given IFile resource
- *
+ *
*/
public void addFile(IFile fileToParse) {
// InputStream iStream;
/**
* Adds a line of the index file for function, class, class-method and class-variable names
- *
+ *
* @param line
*/
private void addLine(String line) {
addIdentifiers(treeMap, file);
return treeMap;
}
+
public TreeMap getIdentifiers(String startClazz) {
TreeMap treeMap = new TreeMap(new StringComparator());
addIdentifiers(treeMap, startClazz);
return treeMap;
}
-
+
public void addIdentifiers(TreeMap treeMap, IFile file) {
String line = (String) fFileMap.get(file.getProjectRelativePath().toString());
if (line != null) {
PHPIdentifierLocation ident;
ArrayList allClassNames = new ArrayList();
addLine(treeMap, null, line, allClassNames);
- int i=0;
- while (i<allClassNames.size()) {
+ int i = 0;
+ while (i < allClassNames.size()) {
String clazz = (String) allClassNames.get(i++);
addClassName(treeMap, clazz, allClassNames);
}
PHPIdentifierLocation ident;
ArrayList allClassNames = new ArrayList();
addClassName(treeMap, startClazz, allClassNames);
- int i=0;
- while (i<allClassNames.size()) {
+ int i = 0;
+ while (i < allClassNames.size()) {
String clazz = (String) allClassNames.get(i++);
addClassName(treeMap, clazz, allClassNames);
}
String line;
PHPIdentifierLocation ident;
List list = getLocations(clazz);
- if (list==null) {
+ if (list == null) {
return false;
}
boolean result = false;
/**
* Adds a line of the index file for function, class, class-method and class-variable names
- *
+ *
* @param line
*/
public void addLine(TreeMap treeMap, HashMap fileMap, String line, List allClassNames) {
/**
* Change the information for a given IFile resource
- *
+ *
*/
public void changeFile(IFile fileToParse) {
removeFile(fileToParse);
/**
* Get a list of all PHPIdentifierLocation object's associated with an identifier
- *
+ *
* @param identifier
* @return
*/
public List getLocations(String identifier) {
- return (List) fIndentifierMap.get(identifier);
+ List list=(List) fIndentifierMap.get(identifier);
+ if (list!=null) {
+ return list;
+ }
+ return new ArrayList();
}
/**
* Initialize (i.e. clear) the current index information
- *
+ *
*/
public void initialize() {
fIndentifierMap = new TreeMap(new StringComparator());
/**
* Remove the information for a given IFile resource
- *
+ *
*/
public void removeFile(IFile fileToParse) {
// String line = (String)
/**
* Removes a line of the index file for function, class, class-method and class-variable names
- *
+ *
* @param line
*/
private void removeLine(String line) {
/**
* Save the current index information in the projects index file
- *
+ *
*/
public void writeFile() {
FileWriter fileWriter;