
/*
 * Copyright (c) 1999-2008 Mark D. Hill and David A. Wood
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met: redistributions of source code must retain the above copyright
 * notice, this list of conditions and the following disclaimer;
 * redistributions in binary form must reproduce the above copyright
 * notice, this list of conditions and the following disclaimer in the
 * documentation and/or other materials provided with the distribution;
 * neither the name of the copyright holders nor the names of its
 * contributors may be used to endorse or promote products derived from
 * this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

/*
 * Var.hh
 *
 * Description:
 *
 * $Id$
 *
 * */

#ifndef VAR_H
#define VAR_H

#include "mem/slicc/slicc_global.hh"
#include "mem/slicc/symbols/Symbol.hh"
#include "mem/slicc/symbols/Type.hh"

class StateMachine;

class Var : public Symbol {
public:
  // Constructors
  Var(string id, const Location& location,
      Type* type_ptr, string code,
      const Map<string, string>& pairs,
      StateMachine* machine_ptr = NULL);

  //  Var(string id, const Location& location,
  //      Type* type_ptr, string code) : Symbol(id, location) { m_type_ptr = type_ptr; m_code = code; }

  // Destructor
  ~Var() {}

  // Public Methods
  string cIdent() const { return m_c_id; }
  void writeCFiles(string path)  {}
  string getCode() const { return m_code; }
  Type* getType() const { return m_type_ptr; }
  StateMachine* getMachine() const { return m_machine_ptr; }

  void print(ostream& out) const;
private:
  // Private Methods

  // Private copy constructor and assignment operator
  Var(const Var& obj);
  Var& operator=(const Var& obj);

  // Data Members (m_ prefix)
  string m_c_id;
  Type* m_type_ptr;
  string m_code;
  StateMachine* m_machine_ptr;
};

// Output operator declaration
ostream& operator<<(ostream& out, const Var& obj);

// ******************* Definitions *******************

// Output operator definition
extern inline
ostream& operator<<(ostream& out, const Var& obj)
{
  obj.print(out);
  out << flush;
  return out;
}

#endif //VAR_H
