1. /*
  2. * Copyright 2002,2004 The Apache Software Foundation.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package org.apache.commons.jexl.parser;
  17. import org.apache.commons.jexl.JexlContext;
  18. /**
  19. * Simple identifier -
  20. * $foo or $foo.bar (both parts are identifiers...)
  21. *
  22. * @author <a href="mailto:geirm@apache.org">Geir Magnusson Jr.</a>
  23. * @version $Id: ASTIdentifier.java,v 1.6 2004/02/28 13:45:20 yoavs Exp $
  24. */
  25. public class ASTIdentifier extends SimpleNode
  26. {
  27. protected String val;
  28. public ASTIdentifier(int id)
  29. {
  30. super(id);
  31. }
  32. public ASTIdentifier(Parser p, int id)
  33. {
  34. super(p, id);
  35. }
  36. /** Accept the visitor. **/
  37. public Object jjtAccept(ParserVisitor visitor, Object data)
  38. {
  39. return visitor.visit(this, data);
  40. }
  41. public Object value(JexlContext jc)
  42. throws Exception
  43. {
  44. return jc.getVars().get(val);
  45. }
  46. /**
  47. * returns the value of itself applied to the object.
  48. * We assume that an identifier can be gotten via a get(String)
  49. */
  50. public Object execute(Object obj, JexlContext jc)
  51. throws Exception
  52. {
  53. return ASTArrayAccess.evaluateExpr(obj, val);
  54. }
  55. public String getIdentifierString()
  56. {
  57. return val;
  58. }
  59. }