2014-07-23 22:39:29 +02:00
|
|
|
#ifndef IVL_class_type_H
|
|
|
|
|
#define IVL_class_type_H
|
2012-12-10 02:59:16 +01:00
|
|
|
/*
|
2014-07-23 22:39:29 +02:00
|
|
|
* Copyright (c) 2012-2014 Stephen Williams (steve@icarus.com)
|
2012-12-10 02:59:16 +01:00
|
|
|
*
|
|
|
|
|
* This source code is free software; you can redistribute it
|
|
|
|
|
* and/or modify it in source code form under the terms of the GNU
|
|
|
|
|
* General Public License as published by the Free Software
|
|
|
|
|
* Foundation; either version 2 of the License, or (at your option)
|
|
|
|
|
* any later version
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
# include <string>
|
|
|
|
|
# include <vector>
|
|
|
|
|
# include "vpi_priv.h"
|
|
|
|
|
|
2013-01-07 00:42:23 +01:00
|
|
|
class class_property_t;
|
|
|
|
|
class vvp_vector4_t;
|
|
|
|
|
|
2012-12-10 02:59:16 +01:00
|
|
|
/*
|
|
|
|
|
* This represents the TYPE information for a class. A %new operator
|
|
|
|
|
* uses this information to figure out how to construct an actual
|
|
|
|
|
* instance.
|
|
|
|
|
*/
|
|
|
|
|
class class_type : public __vpiHandle {
|
|
|
|
|
|
2013-01-07 00:42:23 +01:00
|
|
|
public:
|
|
|
|
|
struct inst_x;
|
|
|
|
|
typedef inst_x*inst_t;
|
|
|
|
|
|
2012-12-10 02:59:16 +01:00
|
|
|
public:
|
|
|
|
|
explicit class_type(const std::string&nam, size_t nprop);
|
2013-12-03 18:14:18 +01:00
|
|
|
~class_type();
|
2012-12-10 02:59:16 +01:00
|
|
|
|
|
|
|
|
// This is the name of the class type.
|
|
|
|
|
inline const std::string&class_name(void) const { return class_name_; }
|
|
|
|
|
// Number of properties in the class definition.
|
|
|
|
|
inline size_t property_count(void) const { return properties_.size(); }
|
|
|
|
|
|
|
|
|
|
// Set the details about the property. This is used during
|
|
|
|
|
// parse of the .vvp file to fill in the details of the
|
|
|
|
|
// property for the class definition.
|
2014-09-14 06:12:39 +02:00
|
|
|
void set_property(size_t idx, const std::string&name, const std::string&type, uint64_t array_size);
|
2013-01-07 00:42:23 +01:00
|
|
|
|
|
|
|
|
// This method is called after all the properties are
|
2014-01-29 00:50:27 +01:00
|
|
|
// defined. This calculates information about the definition.
|
2013-01-07 00:42:23 +01:00
|
|
|
void finish_setup(void);
|
|
|
|
|
|
|
|
|
|
public:
|
2014-01-31 01:16:19 +01:00
|
|
|
// Constructors and destructors for making instances.
|
2013-01-07 00:42:23 +01:00
|
|
|
inst_t instance_new() const;
|
|
|
|
|
void instance_delete(inst_t) const;
|
|
|
|
|
|
|
|
|
|
void set_vec4(inst_t inst, size_t pid, const vvp_vector4_t&val) const;
|
|
|
|
|
void get_vec4(inst_t inst, size_t pid, vvp_vector4_t&val) const;
|
2013-01-11 03:48:15 +01:00
|
|
|
void set_real(inst_t inst, size_t pid, double val) const;
|
|
|
|
|
double get_real(inst_t inst, size_t pid) const;
|
2013-01-14 02:14:40 +01:00
|
|
|
void set_string(inst_t inst, size_t pid, const std::string&val) const;
|
|
|
|
|
std::string get_string(inst_t inst, size_t pid) const;
|
2014-09-14 06:12:39 +02:00
|
|
|
void set_object(inst_t inst, size_t pid, const vvp_object_t&val, size_t idx) const;
|
|
|
|
|
void get_object(inst_t inst, size_t pid, vvp_object_t&val, size_t idx) const;
|
2012-12-10 02:59:16 +01:00
|
|
|
|
2013-04-28 19:10:36 +02:00
|
|
|
void copy_property(inst_t dst, size_t idx, inst_t src) const;
|
|
|
|
|
|
2013-01-07 00:42:23 +01:00
|
|
|
public: // VPI related methods
|
2012-12-10 02:59:16 +01:00
|
|
|
int get_type_code(void) const;
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
std::string class_name_;
|
|
|
|
|
|
|
|
|
|
struct prop_t {
|
|
|
|
|
std::string name;
|
2013-01-07 00:42:23 +01:00
|
|
|
class_property_t*type;
|
2012-12-10 02:59:16 +01:00
|
|
|
};
|
|
|
|
|
std::vector<prop_t> properties_;
|
2013-01-07 00:42:23 +01:00
|
|
|
size_t instance_size_;
|
2012-12-10 02:59:16 +01:00
|
|
|
};
|
|
|
|
|
|
2014-07-23 22:39:29 +02:00
|
|
|
#endif /* IVL_class_type_H */
|