/src/tools/syntax/tree/liberty_ast_feature_definition.e

http://github.com/tybor/Liberty · Specman e · 77 lines · 50 code · 13 blank · 14 comment · 0 complexity · 821ba939532d8034febcafcbd046289c MD5 · raw file

  1. -- This file is part of Liberty Eiffel.
  2. --
  3. -- Liberty Eiffel is free software: you can redistribute it and/or modify
  4. -- it under the terms of the GNU General Public License as published by
  5. -- the Free Software Foundation, version 3 of the License.
  6. --
  7. -- Liberty Eiffel is distributed in the hope that it will be useful,
  8. -- but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. -- GNU General Public License for more details.
  11. --
  12. -- You should have received a copy of the GNU General Public License
  13. -- along with Liberty Eiffel. If not, see <http://www.gnu.org/licenses/>.
  14. --
  15. class LIBERTY_AST_FEATURE_DEFINITION
  16. inherit
  17. LIBERTY_AST_NON_TERMINAL_NODE
  18. create {LIBERTY_NODE_FACTORY}
  19. make
  20. feature {LIBERTY_AST_HANDLER}
  21. indexing_clause: LIBERTY_AST_INDEXING is
  22. do
  23. Result ::= nodes.item(0)
  24. end
  25. signature: LIBERTY_AST_SIGNATURE is
  26. do
  27. Result ::= nodes.item(1)
  28. end
  29. has_routine_definition: BOOLEAN is
  30. do
  31. Result := count = 4 and then nodes.item(3).name.is_equal(once "Routine_Definition")
  32. end
  33. is_constant: BOOLEAN is
  34. do
  35. Result := count = 4 and then nodes.item(3).name.is_equal(once "Manifest_Or_Type_Test")
  36. end
  37. is_unique: BOOLEAN is
  38. do
  39. Result := count = 4 and then nodes.item(3).name.is_equal(once "KW unique")
  40. end
  41. routine_definition: LIBERTY_AST_ROUTINE_DEFINITION is
  42. require
  43. has_routine_definition
  44. do
  45. Result ::= nodes.item(3)
  46. end
  47. constant: LIBERTY_AST_MANIFEST_OR_TYPE_TEST is
  48. require
  49. is_constant
  50. do
  51. Result ::= nodes.item(3)
  52. end
  53. feature {ANY}
  54. count: INTEGER is
  55. do
  56. Result := nodes.count
  57. end
  58. name: STRING is "Feature_Definition"
  59. feature {}
  60. possible_counts: SET[INTEGER] is
  61. once
  62. Result := {AVL_SET[INTEGER] << 2, 4 >> }
  63. end
  64. end