2010-01-29 03:10:44 -06:00
|
|
|
/*
|
|
|
|
* SchematicInfos.h
|
|
|
|
* openChams
|
|
|
|
*
|
|
|
|
* Created by damien dupuis on 22/01/10.
|
|
|
|
* Copyright 2010 UPMC / LIP6. All rights reserved.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __OPENCHAMS_SCHEMATIC_H__
|
|
|
|
#define __OPENCHAMS_SCHEMATIC_H__
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
|
|
|
|
#include "Name.h"
|
|
|
|
|
|
|
|
namespace OpenChams {
|
|
|
|
class Circuit;
|
|
|
|
class Schematic {
|
|
|
|
public:
|
|
|
|
class Infos {
|
|
|
|
public:
|
|
|
|
Infos(double x, double y, Name sym);
|
|
|
|
|
|
|
|
inline double getX();
|
|
|
|
inline double getY();
|
|
|
|
inline Name getSymetry();
|
|
|
|
|
|
|
|
private:
|
|
|
|
double _x;
|
|
|
|
double _y;
|
|
|
|
Name _sym;
|
|
|
|
};
|
|
|
|
public:
|
|
|
|
Schematic(Circuit*, double);
|
|
|
|
|
|
|
|
void addInstance(Name instanceName, double x, double y, Name sym );
|
|
|
|
|
|
|
|
inline double getZoom();
|
|
|
|
inline bool hasNoInstances();
|
|
|
|
inline const std::map<Name, Infos*>& getInstances();
|
|
|
|
|
|
|
|
private:
|
|
|
|
Circuit* _circuit;
|
|
|
|
double _zoom;
|
|
|
|
std::map<Name, Infos*> _instances;
|
|
|
|
};
|
|
|
|
|
|
|
|
inline double Schematic::getZoom() { return _zoom; };
|
|
|
|
inline bool Schematic::hasNoInstances() { return (_instances.size() == 0) ? true : false; };
|
|
|
|
inline const std::map<Name, Schematic::Infos*>& Schematic::getInstances() { return _instances; };
|
|
|
|
|
|
|
|
inline double Schematic::Infos::getX() { return _x; };
|
|
|
|
inline double Schematic::Infos::getY() { return _y; };
|
|
|
|
inline Name Schematic::Infos::getSymetry() { return _sym; };
|
|
|
|
|
|
|
|
} // namespace
|
2010-01-29 04:49:15 -06:00
|
|
|
#endif
|
|
|
|
|