package net.sourceforge.phpdt.internal.compiler.ast;
+import java.util.List;
+
import net.sourceforge.phpdt.internal.compiler.parser.Outlineable;
-import net.sourceforge.phpdt.internal.compiler.ast.declarations.VariableUsage;
import net.sourceforge.phpdt.internal.ui.PHPUiImages;
+import net.sourceforge.phpeclipse.PHPeclipsePlugin;
+
+import org.eclipse.core.runtime.CoreException;
import org.eclipse.jface.resource.ImageDescriptor;
import org.eclipse.jface.text.Position;
-import java.util.List;
-import java.util.ArrayList;
+import test.PHPParserSuperclass;
/**
* A GlobalStatement statement in php.
public class GlobalStatement extends Statement implements Outlineable {
/** An array of the variables called by this global statement. */
- public String[] variables;
+ public AbstractVariable[] variables;
private Object parent;
private Position position;
public GlobalStatement(final Object parent,
- final String[] variables,
+ final AbstractVariable[] variables,
final int sourceStart,
final int sourceEnd) {
super(sourceStart, sourceEnd);
if (i != 0) {
buff.append(", ");//$NON-NLS-1$
}
- buff.append(variables[i]);
+ buff.append(variables[i].toStringExpression());
}
return buff.toString();
}
/**
* Get the variables from outside (parameters, globals ...)
- * @return the variables from outside
*/
- public List getOutsideVariable() {
- final ArrayList list = new ArrayList(variables.length);
+ public void getOutsideVariable(final List list) {
for (int i = 0; i < variables.length; i++) {
- list.add(new VariableUsage(variables[i],sourceStart));
+ variables[i].getUsedVariable(list);
}
- return list;
}
/**
* get the modified variables.
- * @return the variables modified
*/
- public List getModifiedVariable() {
- return new ArrayList();
+ public void getModifiedVariable(final List list) {
}
/**
* Get the variables used.
- * @return the variables used
*/
- public List getUsedVariable() {
- return new ArrayList();
+ public void getUsedVariable(final List list) {
+ }
+
+ /**
+ * We will analyse the code.
+ * if we have in globals a special variable it will be reported as a warning.
+ * @see Variable#SPECIAL_VARS
+ */
+ public void analyzeCode() {
+ for (int i = 0; i < variables.length; i++) {
+ if (arrayContains(Variable.SPECIAL_VARS, variables[i].getName())) {
+ try {
+ PHPParserSuperclass.setMarker("warning, you shouldn't request " + variables[i].getName() + " as global",
+ variables[i].sourceStart,
+ variables[i].sourceEnd,
+ PHPParserSuperclass.WARNING,
+ "");
+ } catch (CoreException e) {
+ PHPeclipsePlugin.log(e);
+ }
+ }
+ }
}
}