Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
U
uniset2
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
1
Issues
1
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
UniSet project repositories
uniset2
Commits
bd6b3433
Commit
bd6b3433
authored
Oct 27, 2011
by
Pavel Vainerman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(codegen): Убрал по умолчанию всё касающееся "тестового режима".
Добавил возможность задать какой датчик использовать в качестве теста, для доступности SM.
parent
b1553de9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
77 additions
and
23 deletions
+77
-23
ctl-cpp-cc-alone-ask.xsl
Utilities/codegen/ctl-cpp-cc-alone-ask.xsl
+6
-2
ctl-cpp-cc-alone.xsl
Utilities/codegen/ctl-cpp-cc-alone.xsl
+5
-2
ctl-cpp-cc-ask.xsl
Utilities/codegen/ctl-cpp-cc-ask.xsl
+6
-2
ctl-cpp-cc.xsl
Utilities/codegen/ctl-cpp-cc.xsl
+5
-3
ctl-cpp-common.xsl
Utilities/codegen/ctl-cpp-common.xsl
+45
-11
ctl-cpp-h-alone.xsl
Utilities/codegen/ctl-cpp-h-alone.xsl
+3
-1
ctl-cpp-h.xsl
Utilities/codegen/ctl-cpp-h.xsl
+3
-0
ctl-cpp-main.xsl
Utilities/codegen/ctl-cpp-main.xsl
+3
-1
testgen.src.xml
Utilities/codegen/tests/testgen.src.xml
+1
-1
No files found.
Utilities/codegen/ctl-cpp-cc-alone-ask.xsl
View file @
bd6b3433
...
...
@@ -15,6 +15,9 @@
<xsl:variable
name=
"OID"
>
<xsl:call-template
name=
"settings-alone"
><xsl:with-param
name=
"varname"
select=
"'ID'"
/></xsl:call-template>
</xsl:variable>
<xsl:variable
name=
"TESTMODE"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'testmode'"
/></xsl:call-template>
</xsl:variable>
<xsl:template
match=
"/"
>
<!-- BEGIN CC-FILE -->
...
...
@@ -31,7 +34,8 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
if( !active )
return;
try
{
{
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
isTestMode = checkTestMode();
if( trTestMode.change(isTestMode) )
testMode(isTestMode);
...
...
@@ -44,7 +48,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
msleep( sleep_msec );
return;
}
</xsl:if>
// проверка таймеров
checkTimers(this);
...
...
Utilities/codegen/ctl-cpp-cc-alone.xsl
View file @
bd6b3433
...
...
@@ -15,6 +15,9 @@
<xsl:variable
name=
"OID"
>
<xsl:call-template
name=
"settings-alone"
><xsl:with-param
name=
"varname"
select=
"'ID'"
/></xsl:call-template>
</xsl:variable>
<xsl:variable
name=
"TESTMODE"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'testmode'"
/></xsl:call-template>
</xsl:variable>
<xsl:template
match=
"/"
>
<!-- BEGIN CC-FILE -->
...
...
@@ -33,7 +36,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
// NOTE: Нужно ли здесь опрашивать текущее значение выходов?!!
// Опрос входов
updateValues();
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
if( idLocalTestMode_S != DefaultObjectId )
{
isTestMode = checkTestMode();
...
...
@@ -49,7 +52,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
return;
}
}
</xsl:if>
// проверка таймеров
checkTimers(this);
...
...
Utilities/codegen/ctl-cpp-cc-ask.xsl
View file @
bd6b3433
...
...
@@ -14,6 +14,9 @@
<xsl:variable
name=
"OID"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'ID'"
/></xsl:call-template>
</xsl:variable>
<xsl:variable
name=
"TESTMODE"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'testmode'"
/></xsl:call-template>
</xsl:variable>
<!-- Генерирование cc-файла -->
<xsl:template
match=
"/"
>
...
...
@@ -32,7 +35,8 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
if( !active )
return;
try
{
{
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
isTestMode = checkTestMode();
if( trTestMode.change(isTestMode) )
testMode(isTestMode);
...
...
@@ -45,7 +49,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
msleep( sleep_msec );
return;
}
</xsl:if>
// проверка таймеров
checkTimers(this);
...
...
Utilities/codegen/ctl-cpp-cc.xsl
View file @
bd6b3433
...
...
@@ -14,7 +14,9 @@
<xsl:variable
name=
"OID"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'ID'"
/></xsl:call-template>
</xsl:variable>
<xsl:variable
name=
"TESTMODE"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'testmode'"
/></xsl:call-template>
</xsl:variable>
<!-- Генерирование cc-файла -->
<xsl:template
match=
"/"
>
...
...
@@ -35,7 +37,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
// NOTE: Нужно ли здесь опрашивать текущее значение выходов?!!
// Опрос входов
updateValues();
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
if( idLocalTestMode_S != DefaultObjectId )
{
isTestMode = checkTestMode();
...
...
@@ -51,7 +53,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::callback()
return;
}
}
</xsl:if>
checkSensors();
// проверка таймеров
...
...
Utilities/codegen/ctl-cpp-common.xsl
View file @
bd6b3433
...
...
@@ -180,7 +180,9 @@
void updatePreviousValues();
void checkSensors();
void updateOutputs( bool force );
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
bool checkTestMode();
</xsl:if>
void preSensorInfo( UniSetTypes::SensorMessage* sm );
void preTimerInfo( UniSetTypes::TimerMessage* tm );
void waitSM( int wait_msec, UniSetTypes::ObjectId testID = UniSetTypes::DefaultObjectId );
...
...
@@ -195,12 +197,15 @@
int sleep_msec; /*!
<
пауза между итерациями */
bool active;
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
bool isTestMode;
Trigger trTestMode;
UniSetTypes::ObjectId idTestMode_S; /*!
<
идентификатор для флага тестовго режима (для всех) */
UniSetTypes::ObjectId idLocalTestMode_S; /*!
<
идентификатор для флага тестовго режима (для данного узла) */
bool in_TestMode_S;
bool in_LocalTestMode_S;
</xsl:if>
UniSetTypes::ObjectId smTestID; /*!
<
идентификатор датчика для тестирования готовности SM */
// управление датчиком "сердцебиения"
PassiveTimer ptHeartBeat; /*!
<
период "сердцебиения" */
...
...
@@ -301,14 +306,6 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::sysCommand( SystemMessage* _sm )
unideb.logFile(fname.c_str());
unideb
<<
myname
<<
"(sysCommand): ***************** UNIDEB LOG ROTATE *****************"
<<
endl;
}
unideb
<<
myname
<<
"(sysCommand): logRotate"
<<
endl;
fname = unideb.getLogFile();
if( !fname.empty() )
{
unideb.logFile(fname.c_str());
unideb
<<
myname
<<
"(sysCommand): ***************** GGDEB LOG ROTATE *****************"
<<
endl;
}
}
break;
...
...
@@ -322,11 +319,13 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setState( UniSetTypes::ObjectId _si
setValue(_sid, _state ? 1 : 0 );
}
// -----------------------------------------------------------------------------
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
bool
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::checkTestMode()
{
return (in_TestMode_S
&&
in_LocalTestMode_S);
}
// -----------------------------------------------------------------------------
</xsl:if>
void
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::sigterm( int signo )
{
<xsl:if
test=
"normalize-space($BASECLASS)!=''"
><xsl:value-of
select=
"normalize-space($BASECLASS)"
/>
::sigterm(signo);
</xsl:if>
...
...
@@ -356,9 +355,14 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::preTimerInfo( UniSetTypes::TimerMes
// ----------------------------------------------------------------------------
void
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::waitSM( int wait_msec, ObjectId _testID )
{
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
if( _testID == DefaultObjectId )
_testID = idTestMode_S;
</xsl:if>
if( _testID == DefaultObjectId )
_testID = smTestID;
if( _testID == DefaultObjectId )
return;
...
...
@@ -383,6 +387,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::waitSM( int wait_msec, ObjectId _te
throw SystemError(err.str());
}
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
if( idTestMode_S != DefaultObjectId )
{
if( !ui.waitWorking(idTestMode_S,wait_msec) )
...
...
@@ -399,6 +404,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::waitSM( int wait_msec, ObjectId _te
throw SystemError(err.str());
}
}
</xsl:if>
}
// ----------------------------------------------------------------------------
</xsl:template>
...
...
@@ -462,9 +468,11 @@ node_<xsl:value-of select="@name"/>(DefaultObjectId),
</xsl:if>
</xsl:for-each>
active(false),
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
isTestMode(false),
idTestMode_S(DefaultObjectId),
idLocalTestMode_S(DefaultObjectId),
</xsl:if>
idHeartBeat(DefaultObjectId),
maxHeartBeat(10),
confnode(0),
...
...
@@ -516,11 +524,13 @@ node_<xsl:value-of select="normalize-space(@name)"/>(conf->getNodeID( conf->getP
</xsl:for-each>
sleep_msec(
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'sleep-msec'"
/></xsl:call-template>
),
active(true),
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
isTestMode(false),
idTestMode_S(conf->getSensorID("TestMode_S")),
idLocalTestMode_S(conf->getSensorID(conf->getProp(cnode,"LocalTestMode_S"))),
in_TestMode_S(false),
in_LocalTestMode_S(false),
</xsl:if>
idHeartBeat(DefaultObjectId),
maxHeartBeat(10),
confnode(cnode),
...
...
@@ -612,6 +622,12 @@ askPause(conf->getPIntProp(cnode,"askPause",2000))
else if( smReadyTimeout
<
0 )
smReadyTimeout = UniSetTimer::WaitUpTime;
std::string tmp_smtestID("");
<xsl:for-each
select=
"//smap/item"
>
<xsl:if
test=
"normalize-space(@smTestID)!=''"
>
tmp_smtestID = "
<xsl:value-of
select=
"@name"
/>
";
</xsl:if>
</xsl:for-each>
smTestID = conf->getSensorID(init3_str(conf->getArgParam("--
<xsl:value-of
select=
"../@arg_prefix"
/>
sm-test-id"),conf->getProp(cnode,"smTestID"),tmp_smtestID));
activateTimeout = conf->getArgPInt("--activate-timeout", 20000);
int msec = conf->getArgPInt("--startup-timeout", 10000);
...
...
@@ -647,9 +663,10 @@ askPause(conf->getPIntProp(cnode,"askPause",2000))
void
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::updateValues()
{
// Опрашиваем все входы...
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
in_TestMode_S = (idTestMode_S!=DefaultObjectId) ? ui.getState(idTestMode_S):false;
in_LocalTestMode_S = (idLocalTestMode_S!=DefaultObjectId) ? ui.getState(idLocalTestMode_S):false;
</xsl:if>
<xsl:for-each
select=
"//smap/item"
>
<xsl:choose>
<xsl:when
test=
"normalize-space(@vartype)='in'"
><xsl:call-template
name=
"getdata"
/></xsl:when>
...
...
@@ -765,6 +782,17 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::testMode( bool _state )
<xsl:template
name=
"COMMON-CC-ALONE-FUNCS"
>
// -----------------------------------------------------------------------------
// ( val, confval, default val )
static const std::string init3_str(const std::string s1, const std::string s2, const std::string s3 )
{
if( !s1.empty() )
return s1;
if( !s2.empty() )
return s2;
return s3;
}
// -----------------------------------------------------------------------------
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK():
<xsl:for-each
select=
"//sensors/item"
>
<xsl:call-template
name=
"setvar"
>
...
...
@@ -777,9 +805,11 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::testMode( bool _state )
</xsl:call-template>
</xsl:for-each>
active(false),
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
isTestMode(false),
idTestMode_S(DefaultObjectId),
idLocalTestMode_S(DefaultObjectId),
</xsl:if>
idHeartBeat(DefaultObjectId),
maxHeartBeat(10),
confnode(0),
...
...
@@ -807,11 +837,13 @@ askPause(2000)
</xsl:for-each>
sleep_msec(
<xsl:call-template
name=
"settings-alone"
><xsl:with-param
name=
"varname"
select=
"'sleep-msec'"
/></xsl:call-template>
),
active(true),
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
isTestMode(false),
idTestMode_S(conf->getSensorID("TestMode_S")),
idLocalTestMode_S(conf->getSensorID(conf->getProp(cnode,"LocalTestMode_S"))),
in_TestMode_S(false),
in_LocalTestMode_S(false),
</xsl:if>
idHeartBeat(DefaultObjectId),
maxHeartBeat(10),
confnode(cnode),
...
...
@@ -860,6 +892,7 @@ askPause(conf->getPIntProp(cnode,"askPause",2000))
else if( smReadyTimeout
<
0 )
smReadyTimeout = UniSetTimer::WaitUpTime;
smTestID = conf->getSensorID(init3_str(conf->getArgParam("--
<xsl:value-of
select=
"../@arg_prefix"
/>
sm-test-id"),conf->getProp(cnode,"smTestID"),""));
activateTimeout = conf->getArgPInt("--activate-timeout", 20000);
int msec = conf->getArgPInt("--startup-timeout", 10000);
...
...
@@ -874,9 +907,10 @@ askPause(conf->getPIntProp(cnode,"askPause",2000))
// -----------------------------------------------------------------------------
void
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::updateValues()
{
<xsl:if
test=
"normalize-space($TESTMODE)!=''"
>
in_TestMode_S = (idTestMode_S!=DefaultObjectId) ? ui.getState(idTestMode_S):false;
in_LocalTestMode_S = (idLocalTestMode_S!=DefaultObjectId) ? ui.getState(idLocalTestMode_S):false;
</xsl:if>
// Опрашиваем все входы...
<xsl:for-each
select=
"//sensors/item/consumers/consumer"
>
<xsl:choose>
...
...
Utilities/codegen/ctl-cpp-h-alone.xsl
View file @
bd6b3433
...
...
@@ -14,7 +14,9 @@
<xsl:variable
name=
"OID"
>
<xsl:call-template
name=
"settings-alone"
><xsl:with-param
name=
"varname"
select=
"'ID'"
/></xsl:call-template>
</xsl:variable>
<xsl:variable
name=
"TESTMODE"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'testmode'"
/></xsl:call-template>
</xsl:variable>
<!-- Генерирование заголовочного файла -->
<xsl:template
match=
"/"
>
...
...
Utilities/codegen/ctl-cpp-h.xsl
View file @
bd6b3433
...
...
@@ -14,6 +14,9 @@
<xsl:variable
name=
"OID"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'ID'"
/></xsl:call-template>
</xsl:variable>
<xsl:variable
name=
"TESTMODE"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'testmode'"
/></xsl:call-template>
</xsl:variable>
<!-- Генерирование заголовочного файла -->
<xsl:template
match=
"/"
>
...
...
Utilities/codegen/ctl-cpp-main.xsl
View file @
bd6b3433
...
...
@@ -14,7 +14,9 @@
<xsl:variable
name=
"OID"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'ID'"
/></xsl:call-template>
</xsl:variable>
<xsl:variable
name=
"TESTMODE"
>
<xsl:call-template
name=
"settings"
><xsl:with-param
name=
"varname"
select=
"'testmode'"
/></xsl:call-template>
</xsl:variable>
<!-- Генерирование main для UniSet_FSM -->
<xsl:template
match=
"/"
>
...
...
Utilities/codegen/tests/testgen.src.xml
View file @
bd6b3433
...
...
@@ -36,7 +36,7 @@
</variables>
<smap>
<!-- name - название переменной в конф. файле -->
<item
name=
"input1_s"
vartype=
"in"
iotype=
"DI"
comment=
"comment for input1"
/>
<item
name=
"input1_s"
vartype=
"in"
iotype=
"DI"
comment=
"comment for input1"
smTestID=
"1"
/>
<item
name=
"input2_s"
vartype=
"in"
iotype=
"DI"
comment=
"comment for input2"
/>
<item
name=
"output1_c"
vartype=
"out"
iotype=
"DO"
omment=
"comment for output1"
no_check_id=
"1"
/>
</smap>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment