Commit 9dc551bf authored by Claes Sjofors's avatar Claes Sjofors

Crossreference files with simulate references

parent 269cd605
...@@ -39,7 +39,8 @@ typedef enum { ...@@ -39,7 +39,8 @@ typedef enum {
typedef enum { typedef enum {
crrgen_eTable_, crrgen_eTable_,
crrgen_eTable_Object, crrgen_eTable_Object,
crrgen_eTable_Signal crrgen_eTable_Signal,
crrgen_eTable_SimSignal
} crrgen_eTable; } crrgen_eTable;
typedef struct sCrrKey typedef struct sCrrKey
...@@ -133,7 +134,16 @@ static crrgen_tRefList reflist[] = { ...@@ -133,7 +134,16 @@ static crrgen_tRefList reflist[] = {
{ pwr_cClass_Ao, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0}, { pwr_cClass_Ao, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0},
{ pwr_cClass_Ii, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0}, { pwr_cClass_Ii, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0},
{ pwr_cClass_Io, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0}, { pwr_cClass_Io, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0},
{ pwr_cClass_Co, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0} }; { pwr_cClass_Co, "RtBody", "SigChanCon", crrgen_eType_Ref, crrgen_eTable_Object, 0},
{ pwr_cClass_resdi, "DevBody", "DiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_setdi, "DevBody", "DiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_stodi, "DevBody", "DiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_toggledi, "DevBody", "DiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_stopi, "DevBody", "CoObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_cstoai, "DevBody", "AiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_stoai, "DevBody", "AiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_cstoii, "DevBody", "IiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0},
{ pwr_cClass_stoii, "DevBody", "IiObject", crrgen_eType_Write, crrgen_eTable_SimSignal, 0}};
static crrgen_tRefList codelist[] = { static crrgen_tRefList codelist[] = {
{ pwr_cClass_dataarithm, "DevBody", "Code", crrgen_eType_, crrgen_eTable_, 0}, { pwr_cClass_dataarithm, "DevBody", "Code", crrgen_eType_, crrgen_eTable_, 0},
...@@ -234,12 +244,15 @@ wb_crrgen::~wb_crrgen() ...@@ -234,12 +244,15 @@ wb_crrgen::~wb_crrgen()
tree_DeleteTable(&sts, m_signal_th); tree_DeleteTable(&sts, m_signal_th);
} }
void wb_crrgen::load( pwr_tStatus *rsts) void wb_crrgen::load( pwr_tStatus *rsts, int sim)
{ {
pwr_tStatus sts; pwr_tStatus sts;
for ( int i = 0; i < int(sizeof(reflist)/sizeof(reflist[0])); i++) { for ( int i = 0; i < int(sizeof(reflist)/sizeof(reflist[0])); i++) {
if ( !sim && reflist[i].table == crrgen_eTable_SimSignal)
continue;
for ( wb_object o = m_sp->object( reflist[i].cid); o; o = o.next()) { for ( wb_object o = m_sp->object( reflist[i].cid); o; o = o.next()) {
pwr_tAttrRef aref; pwr_tAttrRef aref;
...@@ -276,6 +289,7 @@ void wb_crrgen::load( pwr_tStatus *rsts) ...@@ -276,6 +289,7 @@ void wb_crrgen::load( pwr_tStatus *rsts)
key.type = reflist[i].type; key.type = reflist[i].type;
switch ( reflist[i].table) { switch ( reflist[i].table) {
case crrgen_eTable_Signal: case crrgen_eTable_Signal:
case crrgen_eTable_SimSignal:
tree_Insert(&sts, m_signal_th, &key); tree_Insert(&sts, m_signal_th, &key);
break; break;
case crrgen_eTable_Object: case crrgen_eTable_Object:
......
...@@ -36,7 +36,7 @@ class wb_crrgen { ...@@ -36,7 +36,7 @@ class wb_crrgen {
public: public:
wb_crrgen( wb_session *sp); wb_crrgen( wb_session *sp);
~wb_crrgen(); ~wb_crrgen();
void load( pwr_tStatus *sts); void load( pwr_tStatus *sts, int sim = 0);
void write( pwr_tStatus *sts); void write( pwr_tStatus *sts);
void write_code( pwr_tStatus *rsts); void write_code( pwr_tStatus *rsts);
}; };
......
...@@ -274,7 +274,8 @@ dcli_tCmdTable wnav_command_table[] = { ...@@ -274,7 +274,8 @@ dcli_tCmdTable wnav_command_table[] = {
"/CLASS", "/DEBUG", "/NODECONFIG", "/CLASS", "/DEBUG", "/NODECONFIG",
"/NAME", "/IDENTITY", "/FILES", "/OUT", "/IGNORE", "/NAME", "/IDENTITY", "/FILES", "/OUT", "/IGNORE",
"/DIRECTORY", "/BUILDVERSION", "/DATABASE", "/SERVER", "/DIRECTORY", "/BUILDVERSION", "/DATABASE", "/SERVER",
"/PLCPGM", "/HIERARCHY", "/FROM_PLCPGM", "/TEMPLATE", ""} "/PLCPGM", "/HIERARCHY", "/FROM_PLCPGM", "/TEMPLATE",
"/SIMULATE", ""}
}, },
{ {
"NEW", "NEW",
...@@ -4003,8 +4004,11 @@ static int wnav_create_func( void *client_data, ...@@ -4003,8 +4004,11 @@ static int wnav_create_func( void *client_data,
sts = wnav_wccm_get_ldhsession_cb( wnav, &wnav->ldhses); sts = wnav_wccm_get_ldhsession_cb( wnav, &wnav->ldhses);
if ( EVEN(sts)) return sts; if ( EVEN(sts)) return sts;
int simulate = ODD( dcli_get_qualifier( "/SIMULATE", 0, 0));
wb_crrgen crrgen( (wb_session *)wnav->ldhses); wb_crrgen crrgen( (wb_session *)wnav->ldhses);
crrgen.load( &sts);
crrgen.load( &sts, simulate);
crrgen.write( &sts); crrgen.write( &sts);
crrgen.write_code( &sts); crrgen.write_code( &sts);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment