001 /* Copyright 2000, 2001, Compaq Computer Corporation */ 002 003 /* IF THIS IS A JAVA FILE, DO NOT EDIT IT! 004 005 Most Java files in this directory which are part of the Javafe AST 006 are automatically generated using the astgen comment (see 007 ESCTools/Javafe/astgen) from the input file 'hierarchy.h'. If you 008 wish to modify AST classes or introduce new ones, modify 009 'hierarchy.j.' 010 */ 011 012 package javafe.ast; 013 014 import javafe.util.Assert; 015 import javafe.util.Location; 016 import javafe.util.ErrorSet; 017 018 // Convention: unless otherwise noted, integer fields named "loc" refer 019 // to the location of the first character of the syntactic unit 020 021 022 public abstract class TypeDeclElemPragma 023 extends ASTNode implements TypeDeclElem 024 { 025 /* denotes that a pragma is redundant (e.g. "invariant_redundantly") */ 026 public boolean redundant; 027 028 029 //@ invariant hasParent ==> parent != null; 030 public TypeDecl parent; 031 032 public TypeDecl getParent() { return parent; } 033 public void setParent(TypeDecl p) { parent = p; } 034 public void decorate(ModifierPragmaVec modifierPragmas) {} 035 036 abstract public int getTag(); 037 public int getModifiers() { return 0; } 038 public void setModifiers(int m) {} 039 public ModifierPragmaVec getPModifiers() { return null; } 040 public boolean isRedundant() { return redundant; } 041 public void setRedundant(boolean v) { redundant = v; } 042 043 044 // Generated boilerplate constructors: 045 046 /** 047 * Construct a raw TypeDeclElemPragma whose class invariant(s) have not 048 * yet been established. It is the caller's job to 049 * initialize the returned node's fields so that any 050 * class invariants hold. 051 */ 052 //@ requires I_will_establish_invariants_afterwards; 053 protected TypeDeclElemPragma() {} //@ nowarn Invariant,NonNullInit; 054 055 public void check() { 056 super.check(); 057 } 058 059 }