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
7f491151
Commit
7f491151
authored
Mar 06, 2015
by
Pavel Vainerman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(codegen): Исправление ошибки в предыдущем коммитте (SEGFAULT),
переделал вывод вместо ulog в mylog.
parent
115a78aa
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
161 additions
and
105 deletions
+161
-105
ctl-cpp-cc-alone-ask.xsl
Utilities/codegen/ctl-cpp-cc-alone-ask.xsl
+1
-1
ctl-cpp-cc-alone.xsl
Utilities/codegen/ctl-cpp-cc-alone.xsl
+1
-1
ctl-cpp-cc-ask.xsl
Utilities/codegen/ctl-cpp-cc-ask.xsl
+1
-1
ctl-cpp-cc.xsl
Utilities/codegen/ctl-cpp-cc.xsl
+1
-1
ctl-cpp-common.xsl
Utilities/codegen/ctl-cpp-common.xsl
+60
-34
libuniset2.spec
conf/libuniset2.spec
+5
-1
test_mbtcpmaster.cc
extensions/ModbusMaster/tests/test_mbtcpmaster.cc
+46
-46
UObject_SK.h
extensions/include/UObject_SK.h
+40
-14
UObject_SK.cc
extensions/lib/UObject_SK.cc
+6
-6
No files found.
Utilities/codegen/ctl-cpp-cc-alone-ask.xsl
View file @
7f491151
...
@@ -181,7 +181,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId _si
...
@@ -181,7 +181,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId _si
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
if( _sid ==
<xsl:value-of
select=
"../../@name"
/>
)
if( _sid ==
<xsl:value-of
select=
"../../@name"
/>
)
{
{
ulog2
<<
"(setValue):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= "
<<
_val
<<
endl;
mylog8
<<
"(setValue):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= "
<<
_val
<<
endl;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= _val;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= _val;
<xsl:call-template
name=
"setdata"
/>
<xsl:call-template
name=
"setdata"
/>
return;
return;
...
...
Utilities/codegen/ctl-cpp-cc-alone.xsl
View file @
7f491151
...
@@ -154,7 +154,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId _si
...
@@ -154,7 +154,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId _si
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
if( _sid ==
<xsl:value-of
select=
"../../@name"
/>
)
if( _sid ==
<xsl:value-of
select=
"../../@name"
/>
)
{
{
ulog2
<<
"(setValue):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= "
<<
_val
<<
endl;
mylog8
<<
"(setValue):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= "
<<
_val
<<
endl;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= _val;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"../../@name"
/>
= _val;
return;
return;
}
}
...
...
Utilities/codegen/ctl-cpp-cc-ask.xsl
View file @
7f491151
...
@@ -112,7 +112,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId _si
...
@@ -112,7 +112,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId _si
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
if( _sid ==
<xsl:value-of
select=
"@name"
/>
)
if( _sid ==
<xsl:value-of
select=
"@name"
/>
)
{
{
ulog2
<<
"(setState):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= "
<<
_val
<<
endl;
mylog8
<<
"(setState):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= "
<<
_val
<<
endl;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= _val;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= _val;
<xsl:call-template
name=
"setdata"
/>
<xsl:call-template
name=
"setdata"
/>
return;
return;
...
...
Utilities/codegen/ctl-cpp-cc.xsl
View file @
7f491151
...
@@ -116,7 +116,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId sid
...
@@ -116,7 +116,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::setValue( UniSetTypes::ObjectId sid
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
<xsl:if
test=
"normalize-space(@vartype)='out'"
>
if( sid ==
<xsl:value-of
select=
"@name"
/>
)
if( sid ==
<xsl:value-of
select=
"@name"
/>
)
{
{
ulog2
<<
"(setValue):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= "
<<
val
<<
endl;
mylog8
<<
"(setValue):
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= "
<<
val
<<
endl;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= val;
<xsl:call-template
name=
"setprefix"
/><xsl:value-of
select=
"@name"
/>
= val;
return;
return;
}
}
...
...
Utilities/codegen/ctl-cpp-common.xsl
View file @
7f491151
...
@@ -106,7 +106,7 @@
...
@@ -106,7 +106,7 @@
<xsl:when
test=
"$GENTYPE='A'"
>
<xsl:when
test=
"$GENTYPE='A'"
>
if( _code == mid_
<xsl:value-of
select=
"../../@name"
/>
)
if( _code == mid_
<xsl:value-of
select=
"../../@name"
/>
)
{
{
u
log8
<<
"
<xsl:value-of
select=
"../../@name"
/>
"
<<
endl;
my
log8
<<
"
<xsl:value-of
select=
"../../@name"
/>
"
<<
endl;
m_
<xsl:value-of
select=
"../../@name"
/>
= _state;
m_
<xsl:value-of
select=
"../../@name"
/>
= _state;
try
try
{
{
...
@@ -133,7 +133,7 @@
...
@@ -133,7 +133,7 @@
}
}
catch( const UniSetTypes::Exception
&
ex )
catch( const UniSetTypes::Exception
&
ex )
{
{
ulog1
<<
getName()
<<
ex
<<
endl;
mywarn
<<
getName()
<<
ex
<<
endl;
}
}
}
}
</xsl:when>
</xsl:when>
...
@@ -175,19 +175,45 @@
...
@@ -175,19 +175,45 @@
void init_dlog( std::shared_ptr
<
DebugStream
>
d );
void init_dlog( std::shared_ptr
<
DebugStream
>
d );
// "синтаксический сахар"..для логов
// "синтаксический сахар"..для логов
#define myinfo if( mylog->debugging(Debug::INFO) ) mylog->info()
#ifndef myinfo
#define mywarn if( mylog->debugging(Debug::WARN) ) mylog->warn()
#define myinfo if( mylog->debugging(Debug::INFO) ) mylog->info()
#define mycrit if( mylog->debugging(Debug::CRIT) ) mylog->crit()
#endif
#define mylog1 if( mylog->debugging(Debug::LEVEL1) ) mylog->level1()
#ifndef mywarn
#define mylog2 if( mylog->debugging(Debug::LEVEL2) ) mylog->level2()
#define mywarn if( mylog->debugging(Debug::WARN) ) mylog->warn()
#define mylog3 if( mylog->debugging(Debug::LEVEL3) ) mylog->level3()
#endif
#define mylog4 if( mylog->debugging(Debug::LEVEL4) ) mylog->level4()
#ifndef mycrit
#define mylog5 if( mylog->debugging(Debug::LEVEL5) ) mylog->level5()
#define mycrit if( mylog->debugging(Debug::CRIT) ) mylog->crit()
#define mylog6 if( mylog->debugging(Debug::LEVEL6) ) mylog->level6()
#endif
#define mylog7 if( mylog->debugging(Debug::LEVEL7) ) mylog->level7()
#ifndef mylog1
#define mylog8 if( mylog->debugging(Debug::LEVEL8) ) mylog->level8()
#define mylog1 if( mylog->debugging(Debug::LEVEL1) ) mylog->level1()
#define mylog9 if( mylog->debugging(Debug::LEVEL9) ) mylog->level9()
#endif
#define mylogany mylog->any()
#ifndef mylog2
#define mylog2 if( mylog->debugging(Debug::LEVEL2) ) mylog->level2()
#endif
#ifndef mylog3
#define mylog3 if( mylog->debugging(Debug::LEVEL3) ) mylog->level3()
#endif
#ifndef mylog4
#define mylog4 if( mylog->debugging(Debug::LEVEL4) ) mylog->level4()
#endif
#ifndef mylog5
#define mylog5 if( mylog->debugging(Debug::LEVEL5) ) mylog->level5()
#endif
#ifndef mylog6
#define mylog6 if( mylog->debugging(Debug::LEVEL6) ) mylog->level6()
#endif
#ifndef mylog7
#define mylog7 if( mylog->debugging(Debug::LEVEL7) ) mylog->level7()
#endif
#ifndef mylog8
#define mylog8 if( mylog->debugging(Debug::LEVEL8) ) mylog->level8()
#endif
#ifndef mylog9
#define mylog9 if( mylog->debugging(Debug::LEVEL9) ) mylog->level9()
#endif
#ifndef mylogany
#define mylogany mylog->any()
#endif
</xsl:template>
</xsl:template>
<xsl:template
name=
"COMMON-HEAD-PROTECTED"
>
<xsl:template
name=
"COMMON-HEAD-PROTECTED"
>
...
@@ -458,28 +484,28 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::waitSM( int wait_msec, ObjectId _te
...
@@ -458,28 +484,28 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::waitSM( int wait_msec, ObjectId _te
</xsl:template>
</xsl:template>
<xsl:template
name=
"init-variables"
>
<xsl:template
name=
"init-variables"
>
<xsl:if
test=
"normalize-space(@type)='int'"
>
<xsl:if
test=
"normalize-space(@type)='int'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uni_atoi( init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uni_atoi( init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
</xsl:if>
</xsl:if>
<xsl:if
test=
"normalize-space(@type)='long'"
>
<xsl:if
test=
"normalize-space(@type)='long'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uni_atoi( init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uni_atoi( init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
</xsl:if>
</xsl:if>
<xsl:if
test=
"normalize-space(@type)='float'"
>
<xsl:if
test=
"normalize-space(@type)='float'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(atof( init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
").c_str())),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(atof( init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
").c_str())),
</xsl:if>
</xsl:if>
<xsl:if
test=
"normalize-space(@type)='double'"
>
<xsl:if
test=
"normalize-space(@type)='double'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(atof( init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
").c_str())),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(atof( init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
").c_str())),
</xsl:if>
</xsl:if>
<xsl:if
test=
"normalize-space(@type)='bool'"
>
<xsl:if
test=
"normalize-space(@type)='bool'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uni_atoi( init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uni_atoi( init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
</xsl:if>
</xsl:if>
<xsl:if
test=
"normalize-space(@type)='str'"
>
<xsl:if
test=
"normalize-space(@type)='str'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
")),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
")),
</xsl:if>
</xsl:if>
<xsl:if
test=
"normalize-space(@type)='sensor'"
>
<xsl:if
test=
"normalize-space(@type)='sensor'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uniset_conf()->getSensorID(init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uniset_conf()->getSensorID(init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
</xsl:if>
</xsl:if>
<xsl:if
test=
"normalize-space(@type)='object'"
>
<xsl:if
test=
"normalize-space(@type)='object'"
>
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uniset_conf()->getObjectID(init3_str(uniset_conf()->getArgParam("--" +
argprefix
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
<xsl:value-of
select=
"normalize-space(@name)"
/>
(uniset_conf()->getObjectID(init3_str(uniset_conf()->getArgParam("--" +
(_argprefix.empty() ? myname+"-" : _argprefix)
+ "
<xsl:value-of
select=
"@name"
/>
"),uniset_conf()->getProp(cnode,"
<xsl:value-of
select=
"@name"
/>
"),"
<xsl:value-of
select=
"normalize-space(@default)"
/>
"))),
</xsl:if>
</xsl:if>
</xsl:template>
</xsl:template>
...
@@ -571,7 +597,7 @@ static const std::string init3_str( const std::string& s1, const std::string
...
@@ -571,7 +597,7 @@ static const std::string init3_str( const std::string& s1, const std::string
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK( ObjectId id, xmlNode* cnode, const std::string
&
_argprefix ):
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK::
<xsl:value-of
select=
"$CLASSNAME"
/>
_SK( ObjectId id, xmlNode* cnode, const std::string
&
_argprefix ):
<xsl:if
test=
"normalize-space($BASECLASS)!=''"
><xsl:value-of
select=
"normalize-space($BASECLASS)"
/>
(id),
</xsl:if>
<xsl:if
test=
"normalize-space($BASECLASS)!=''"
><xsl:value-of
select=
"normalize-space($BASECLASS)"
/>
(id),
</xsl:if>
<xsl:if
test=
"normalize-space($BASECLASS)=''"
>
UniSetObject(id),
</xsl:if>
<xsl:if
test=
"normalize-space($BASECLASS)=''"
>
UniSetObject(id),
</xsl:if>
argprefix( (_argprefix.empty() ? myname+"-" : argprefix) ),
argprefix( (_argprefix.empty() ? myname+"-" :
_
argprefix) ),
// Инициализация идентификаторов (имена берутся из конф. файла)
// Инициализация идентификаторов (имена берутся из конф. файла)
<xsl:for-each
select=
"//smap/item"
>
<xsl:for-each
select=
"//smap/item"
>
<xsl:if
test=
"normalize-space(@vartype)!='io'"
>
<xsl:if
test=
"normalize-space(@vartype)!='io'"
>
...
@@ -809,18 +835,18 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
...
@@ -809,18 +835,18 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
{
{
if( _code == UniSetTypes::DefaultObjectId )
if( _code == UniSetTypes::DefaultObjectId )
{
{
u
crit
<<
getName()
my
crit
<<
getName()
<<
"(alarm): попытка послать сообщение с DefaultObjectId"
<<
"(alarm): попытка послать сообщение с DefaultObjectId"
<<
endl;
<<
endl;
return false;
return false;
}
}
ulog1
<<
getName()
<<
"(alarm): "
<<
( _state ? "SEND " : "RESET " )
<<
endl;
mylog8
<<
getName()
<<
"(alarm): "
<<
( _state ? "SEND " : "RESET " )
<<
endl;
<xsl:for-each
select=
"//msgmap/item"
>
<xsl:for-each
select=
"//msgmap/item"
>
if( _code ==
<xsl:value-of
select=
"@name"
/>
)
if( _code ==
<xsl:value-of
select=
"@name"
/>
)
{
{
ulog1
<<
"
<xsl:value-of
select=
"@name"
/>
"
<<
endl;
mylog8
<<
"
<xsl:value-of
select=
"@name"
/>
"
<<
endl;
try
try
{
{
m_
<xsl:value-of
select=
"@name"
/>
= _state;
m_
<xsl:value-of
select=
"@name"
/>
= _state;
...
@@ -832,14 +858,14 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
...
@@ -832,14 +858,14 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
}
}
catch( const std::exception
&
ex )
catch( const std::exception
&
ex )
{
{
u
crit
<<
myname
<<
"(execute): catch "
<<
ex.what()
<<
endl;
my
crit
<<
myname
<<
"(execute): catch "
<<
ex.what()
<<
endl;
}
}
return false;
return false;
}
}
</xsl:for-each>
</xsl:for-each>
ulog1
<<
" not found MessgeOID?!!"
<<
endl;
mylog8
<<
" not found MessgeOID?!!"
<<
endl;
return false;
return false;
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
@@ -858,7 +884,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::resetMsg()
...
@@ -858,7 +884,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::resetMsg()
}
}
catch( const UniSetTypes::Exception
&
ex )
catch( const UniSetTypes::Exception
&
ex )
{
{
ulog1
<<
getName()
<<
ex
<<
endl;
mywarn
<<
getName()
<<
ex
<<
endl;
}
}
}
}
</xsl:for-each>
</xsl:for-each>
...
@@ -917,7 +943,7 @@ activated(false),
...
@@ -917,7 +943,7 @@ activated(false),
askPause(2000),
askPause(2000),
forceOut(false)
forceOut(false)
{
{
u
crit
<<
"
<xsl:value-of
select=
"$CLASSNAME"
/>
: init failed!!!!!!!!!!!!!!!"
<<
endl;
my
crit
<<
"
<xsl:value-of
select=
"$CLASSNAME"
/>
: init failed!!!!!!!!!!!!!!!"
<<
endl;
throw Exception( string(myname+": init failed!!!") );
throw Exception( string(myname+": init failed!!!") );
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
@@ -1094,13 +1120,13 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
...
@@ -1094,13 +1120,13 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
{
{
if( _code == UniSetTypes::DefaultObjectId )
if( _code == UniSetTypes::DefaultObjectId )
{
{
u
crit
<<
getName()
my
crit
<<
getName()
<<
"(alarm): попытка послать сообщение с DefaultObjectId"
<<
"(alarm): попытка послать сообщение с DefaultObjectId"
<<
endl;
<<
endl;
return false;
return false;
}
}
ulog1
<<
getName()
<<
"(alarm): ("
<<
_code
<<
")"
<<
( _state ? "SEND" : "RESET" )
<<
endl;
mylog8
<<
getName()
<<
"(alarm): ("
<<
_code
<<
")"
<<
( _state ? "SEND" : "RESET" )
<<
endl;
<xsl:for-each
select=
"//sensors/item"
>
<xsl:for-each
select=
"//sensors/item"
>
<xsl:call-template
name=
"setmsg"
>
<xsl:call-template
name=
"setmsg"
>
...
@@ -1108,7 +1134,7 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
...
@@ -1108,7 +1134,7 @@ bool <xsl:value-of select="$CLASSNAME"/>_SK::alarm( UniSetTypes::ObjectId _code,
</xsl:call-template>
</xsl:call-template>
</xsl:for-each>
</xsl:for-each>
u
log8
<<
" not found MessgeOID?!!"
<<
endl;
my
log8
<<
" not found MessgeOID?!!"
<<
endl;
return false;
return false;
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
...
conf/libuniset2.spec
View file @
7f491151
...
@@ -12,7 +12,7 @@
...
@@ -12,7 +12,7 @@
Name: libuniset2
Name: libuniset2
Version: 2.0
Version: 2.0
Release: alt1
8
Release: alt1
9
Summary: UniSet - library for building distributed industrial control systems
Summary: UniSet - library for building distributed industrial control systems
...
@@ -409,6 +409,10 @@ mv -f %buildroot%python_sitelibdir_noarch/* %buildroot%python_sitelibdir/%oname
...
@@ -409,6 +409,10 @@ mv -f %buildroot%python_sitelibdir_noarch/* %buildroot%python_sitelibdir/%oname
# ..
# ..
%changelog
%changelog
* Fri Mar 06 2015 Pavel Vainerman <pv@altlinux.ru> 2.0-alt19
- codegen: fixed bug (in previous commit)
- codegen: fixed warning (redefined mylog macroses)
* Sat Feb 28 2015 Pavel Vainerman <pv@altlinux.ru> 2.0-alt18
* Sat Feb 28 2015 Pavel Vainerman <pv@altlinux.ru> 2.0-alt18
- codegen: set default argprefix=myname (object name)
- codegen: set default argprefix=myname (object name)
- codegen: fixed minor bug in mylog..
- codegen: fixed minor bug in mylog..
...
...
extensions/ModbusMaster/tests/test_mbtcpmaster.cc
View file @
7f491151
...
@@ -55,13 +55,13 @@ TEST_CASE("MBTCPMaster: 0x01 (read coil status)","[modbus][0x01][mbmaster][mbtcp
...
@@ -55,13 +55,13 @@ TEST_CASE("MBTCPMaster: 0x01 (read coil status)","[modbus][0x01][mbmaster][mbtcp
CHECK
(
ui
->
isExist
(
mbID
)
);
CHECK
(
ui
->
isExist
(
mbID
)
);
mbs
->
setReply
(
65535
);
mbs
->
setReply
(
65535
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1000
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1000
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1001
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1001
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1002
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1002
)
==
1
);
mbs
->
setReply
(
0
);
mbs
->
setReply
(
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1000
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1000
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1001
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1001
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1002
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1002
)
==
0
);
...
@@ -73,13 +73,13 @@ TEST_CASE("MBTCPMaster: 0x02 (read input status)","[modbus][0x02][mbmaster][mbtc
...
@@ -73,13 +73,13 @@ TEST_CASE("MBTCPMaster: 0x02 (read input status)","[modbus][0x02][mbmaster][mbtc
CHECK
(
ui
->
isExist
(
mbID
)
);
CHECK
(
ui
->
isExist
(
mbID
)
);
mbs
->
setReply
(
65535
);
mbs
->
setReply
(
65535
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1040
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1040
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1041
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1041
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1042
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1042
)
==
1
);
mbs
->
setReply
(
0
);
mbs
->
setReply
(
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1040
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1040
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1041
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1041
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1042
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1042
)
==
0
);
...
@@ -91,25 +91,25 @@ TEST_CASE("MBTCPMaster: 0x03 (read register outputs or memories or read word out
...
@@ -91,25 +91,25 @@ TEST_CASE("MBTCPMaster: 0x03 (read register outputs or memories or read word out
CHECK
(
ui
->
isExist
(
mbID
)
);
CHECK
(
ui
->
isExist
(
mbID
)
);
mbs
->
setReply
(
10
);
mbs
->
setReply
(
10
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1006
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1006
)
==
10
);
mbs
->
setReply
(
-
10
);
mbs
->
setReply
(
-
10
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1006
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1006
)
==
-
10
);
mbs
->
setReply
(
0
);
mbs
->
setReply
(
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1006
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1006
)
==
0
);
mbs
->
setReply
(
65535
);
mbs
->
setReply
(
65535
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1004
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1005
)
==
-
1
);
...
@@ -117,11 +117,11 @@ TEST_CASE("MBTCPMaster: 0x03 (read register outputs or memories or read word out
...
@@ -117,11 +117,11 @@ TEST_CASE("MBTCPMaster: 0x03 (read register outputs or memories or read word out
REQUIRE
(
ui
->
getValue
(
1007
)
==
65535
);
// unsigned
REQUIRE
(
ui
->
getValue
(
1007
)
==
65535
);
// unsigned
mbs
->
setReply
(
0xffff
);
mbs
->
setReply
(
0xffff
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1008
)
==
0xffffffff
);
// I2
REQUIRE
(
ui
->
getValue
(
1008
)
==
0xffffffff
);
// I2
REQUIRE
(
ui
->
getValue
(
1009
)
==
0xffffffff
);
// U2
REQUIRE
(
ui
->
getValue
(
1009
)
==
0xffffffff
);
// U2
mbs
->
setReply
(
0xff
);
mbs
->
setReply
(
0xff
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1008
)
==
0x00ff00ff
);
// I2
REQUIRE
(
ui
->
getValue
(
1008
)
==
0x00ff00ff
);
// I2
REQUIRE
(
ui
->
getValue
(
1009
)
==
0x00ff00ff
);
// U2
REQUIRE
(
ui
->
getValue
(
1009
)
==
0x00ff00ff
);
// U2
...
@@ -136,25 +136,25 @@ TEST_CASE("MBTCPMaster: 0x04 (read input registers or memories or read word outp
...
@@ -136,25 +136,25 @@ TEST_CASE("MBTCPMaster: 0x04 (read input registers or memories or read word outp
CHECK
(
ui
->
isExist
(
mbID
)
);
CHECK
(
ui
->
isExist
(
mbID
)
);
mbs
->
setReply
(
10
);
mbs
->
setReply
(
10
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1013
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1013
)
==
10
);
mbs
->
setReply
(
-
10
);
mbs
->
setReply
(
-
10
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1013
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1013
)
==
-
10
);
mbs
->
setReply
(
0
);
mbs
->
setReply
(
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1013
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1013
)
==
0
);
mbs
->
setReply
(
65535
);
mbs
->
setReply
(
65535
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1010
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1011
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
-
1
);
REQUIRE
(
ui
->
getValue
(
1012
)
==
-
1
);
...
@@ -162,11 +162,11 @@ TEST_CASE("MBTCPMaster: 0x04 (read input registers or memories or read word outp
...
@@ -162,11 +162,11 @@ TEST_CASE("MBTCPMaster: 0x04 (read input registers or memories or read word outp
REQUIRE
(
ui
->
getValue
(
1014
)
==
65535
);
// unsigned
REQUIRE
(
ui
->
getValue
(
1014
)
==
65535
);
// unsigned
mbs
->
setReply
(
0xffff
);
mbs
->
setReply
(
0xffff
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1015
)
==
0xffffffff
);
// I2
REQUIRE
(
ui
->
getValue
(
1015
)
==
0xffffffff
);
// I2
REQUIRE
(
ui
->
getValue
(
1016
)
==
0xffffffff
);
// U2
REQUIRE
(
ui
->
getValue
(
1016
)
==
0xffffffff
);
// U2
mbs
->
setReply
(
0xff
);
mbs
->
setReply
(
0xff
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1015
)
==
0x00ff00ff
);
// I2
REQUIRE
(
ui
->
getValue
(
1015
)
==
0x00ff00ff
);
// I2
REQUIRE
(
ui
->
getValue
(
1016
)
==
0x00ff00ff
);
// U2
REQUIRE
(
ui
->
getValue
(
1016
)
==
0x00ff00ff
);
// U2
...
@@ -182,17 +182,17 @@ TEST_CASE("MBTCPMaster: 0x05 (forces a single coil to either ON or OFF)","[modbu
...
@@ -182,17 +182,17 @@ TEST_CASE("MBTCPMaster: 0x05 (forces a single coil to either ON or OFF)","[modbu
CHECK
(
ui
->
isExist
(
mbID
)
);
CHECK
(
ui
->
isExist
(
mbID
)
);
ui
->
setValue
(
1017
,
0
);
ui
->
setValue
(
1017
,
0
);
REQUIRE
(
ui
->
getValue
(
1017
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1017
)
==
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
CHECK_FALSE
(
mbs
->
getForceSingleCoilCmd
()
);
CHECK_FALSE
(
mbs
->
getForceSingleCoilCmd
()
);
ui
->
setValue
(
1017
,
1
);
ui
->
setValue
(
1017
,
1
);
REQUIRE
(
ui
->
getValue
(
1017
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1017
)
==
1
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
CHECK
(
mbs
->
getForceSingleCoilCmd
()
);
CHECK
(
mbs
->
getForceSingleCoilCmd
()
);
ui
->
setValue
(
1017
,
0
);
ui
->
setValue
(
1017
,
0
);
REQUIRE
(
ui
->
getValue
(
1017
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1017
)
==
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
CHECK_FALSE
(
mbs
->
getForceSingleCoilCmd
()
);
CHECK_FALSE
(
mbs
->
getForceSingleCoilCmd
()
);
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
@@ -203,22 +203,22 @@ TEST_CASE("MBTCPMaster: 0x06 (write register outputs or memories)","[modbus][0x0
...
@@ -203,22 +203,22 @@ TEST_CASE("MBTCPMaster: 0x06 (write register outputs or memories)","[modbus][0x0
CHECK
(
ui
->
isExist
(
mbID
)
);
CHECK
(
ui
->
isExist
(
mbID
)
);
ui
->
setValue
(
1018
,
0
);
ui
->
setValue
(
1018
,
0
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
0
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
0
);
ui
->
setValue
(
1018
,
100
);
ui
->
setValue
(
1018
,
100
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
100
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
100
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
100
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
100
);
ui
->
setValue
(
1018
,
-
100
);
ui
->
setValue
(
1018
,
-
100
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
-
100
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
-
100
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
-
100
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
-
100
);
ui
->
setValue
(
1018
,
0
);
ui
->
setValue
(
1018
,
0
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
0
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
0
);
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
@@ -234,7 +234,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
...
@@ -234,7 +234,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
REQUIRE
(
ui
->
getValue
(
1024
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1024
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1025
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1025
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1026
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1026
)
==
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
REQUIRE
(
q
.
start
==
38
);
REQUIRE
(
q
.
start
==
38
);
...
@@ -245,7 +245,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
...
@@ -245,7 +245,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
{
{
ui
->
setValue
(
1025
,
1
);
ui
->
setValue
(
1025
,
1
);
REQUIRE
(
ui
->
getValue
(
1025
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1025
)
==
1
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
REQUIRE
(
q
.
start
==
38
);
REQUIRE
(
q
.
start
==
38
);
...
@@ -256,7 +256,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
...
@@ -256,7 +256,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
{
{
ui
->
setValue
(
1024
,
1
);
ui
->
setValue
(
1024
,
1
);
REQUIRE
(
ui
->
getValue
(
1024
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1024
)
==
1
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
REQUIRE
(
q
.
start
==
38
);
REQUIRE
(
q
.
start
==
38
);
...
@@ -271,7 +271,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
...
@@ -271,7 +271,7 @@ TEST_CASE("MBTCPMaster: 0x0F (force multiple coils)","[modbus][0x0F][mbmaster][m
REQUIRE
(
ui
->
getValue
(
1024
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1024
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1025
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1025
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1026
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1026
)
==
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
ModbusRTU
::
ForceCoilsMessage
q
=
mbs
->
getLastForceCoilsQ
();
REQUIRE
(
q
.
start
==
38
);
REQUIRE
(
q
.
start
==
38
);
...
@@ -293,7 +293,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
...
@@ -293,7 +293,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
REQUIRE
(
ui
->
getValue
(
1020
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1020
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1021
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1021
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1022
)
==
0
);
REQUIRE
(
ui
->
getValue
(
1022
)
==
0
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
REQUIRE
(
q
.
addr
==
slaveADDR
);
REQUIRE
(
q
.
addr
==
slaveADDR
);
...
@@ -313,7 +313,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
...
@@ -313,7 +313,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
REQUIRE
(
ui
->
getValue
(
1020
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1020
)
==
1
);
REQUIRE
(
ui
->
getValue
(
1021
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1021
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1022
)
==
65535
);
REQUIRE
(
ui
->
getValue
(
1022
)
==
65535
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
REQUIRE
(
q
.
addr
==
slaveADDR
);
REQUIRE
(
q
.
addr
==
slaveADDR
);
...
@@ -331,7 +331,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
...
@@ -331,7 +331,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
REQUIRE
(
ui
->
getValue
(
1019
)
==
-
100
);
REQUIRE
(
ui
->
getValue
(
1019
)
==
-
100
);
REQUIRE
(
ui
->
getValue
(
1021
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1021
)
==
-
10
);
REQUIRE
(
ui
->
getValue
(
1022
)
==
-
32767
);
REQUIRE
(
ui
->
getValue
(
1022
)
==
-
32767
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
REQUIRE
(
q
.
addr
==
slaveADDR
);
REQUIRE
(
q
.
addr
==
slaveADDR
);
...
@@ -346,7 +346,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
...
@@ -346,7 +346,7 @@ TEST_CASE("MBTCPMaster: 0x10 (write register outputs or memories)","[modbus][0x1
{
{
ui
->
setValue
(
1023
,
0xffffffff
);
ui
->
setValue
(
1023
,
0xffffffff
);
REQUIRE
(
ui
->
getValue
(
1023
)
==
0xffffffff
);
REQUIRE
(
ui
->
getValue
(
1023
)
==
0xffffffff
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
ModbusRTU
::
WriteOutputMessage
q
=
mbs
->
getLastWriteOutput
();
REQUIRE
(
q
.
addr
==
slaveADDR
);
REQUIRE
(
q
.
addr
==
slaveADDR
);
...
@@ -366,14 +366,14 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
...
@@ -366,14 +366,14 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
SECTION
(
"read"
)
SECTION
(
"read"
)
{
{
mbs
->
setReply
(
10
);
mbs
->
setReply
(
10
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
10
);
}
}
SECTION
(
"write"
)
SECTION
(
"write"
)
{
{
ui
->
setValue
(
1018
,
10
);
ui
->
setValue
(
1018
,
10
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
10
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
10
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
10
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
10
);
}
}
}
}
...
@@ -387,10 +387,10 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
...
@@ -387,10 +387,10 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
SECTION
(
"read"
)
SECTION
(
"read"
)
{
{
mbs
->
setReply
(
150
);
mbs
->
setReply
(
150
);
msleep
(
2
*
polltime
+
1
00
);
msleep
(
2
*
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
150
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
150
);
mbs
->
setReply
(
-
10
);
mbs
->
setReply
(
-
10
);
msleep
(
2
*
polltime
+
1
00
);
msleep
(
2
*
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
-
10
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
-
10
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
150
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
150
);
}
}
...
@@ -398,11 +398,11 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
...
@@ -398,11 +398,11 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
{
{
ui
->
setValue
(
1018
,
150
);
ui
->
setValue
(
1018
,
150
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
150
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
150
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
150
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
150
);
ui
->
setValue
(
1018
,
155
);
ui
->
setValue
(
1018
,
155
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
155
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
155
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
155
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
155
);
}
}
}
}
...
@@ -416,21 +416,21 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
...
@@ -416,21 +416,21 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
SECTION
(
"read"
)
SECTION
(
"read"
)
{
{
mbs
->
setReply
(
150
);
mbs
->
setReply
(
150
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
150
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
150
);
mbs
->
setReply
(
-
100
);
mbs
->
setReply
(
-
100
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
-
100
);
REQUIRE
(
ui
->
getValue
(
1003
)
==
-
100
);
}
}
SECTION
(
"write"
)
SECTION
(
"write"
)
{
{
ui
->
setValue
(
1018
,
50
);
ui
->
setValue
(
1018
,
50
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
50
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
50
);
msleep
(
2
*
polltime
+
1
00
);
msleep
(
2
*
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
50
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
50
);
ui
->
setValue
(
1018
,
55
);
ui
->
setValue
(
1018
,
55
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
55
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
55
);
msleep
(
2
*
polltime
+
1
00
);
msleep
(
2
*
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
55
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
55
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
50
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
50
);
}
}
...
@@ -445,7 +445,7 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
...
@@ -445,7 +445,7 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
SECTION
(
"read"
)
SECTION
(
"read"
)
{
{
mbs
->
setReply
(
50
);
mbs
->
setReply
(
50
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
50
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
50
);
}
}
SECTION
(
"write"
)
SECTION
(
"write"
)
...
@@ -453,11 +453,11 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
...
@@ -453,11 +453,11 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
// а write работает в этом режиме.. (а чем отличается от writeOnly?)
// а write работает в этом режиме.. (а чем отличается от writeOnly?)
ui
->
setValue
(
1018
,
60
);
ui
->
setValue
(
1018
,
60
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
60
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
60
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
60
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
60
);
ui
->
setValue
(
1018
,
65
);
ui
->
setValue
(
1018
,
65
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
65
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
65
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
65
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
==
65
);
}
}
}
}
...
@@ -471,14 +471,14 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
...
@@ -471,14 +471,14 @@ TEST_CASE("MBTCPMaster: exchangeMode","[modbus][exchangemode][mbmaster][mbtcpmas
SECTION
(
"read"
)
SECTION
(
"read"
)
{
{
mbs
->
setReply
(
70
);
mbs
->
setReply
(
70
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
70
);
REQUIRE
(
ui
->
getValue
(
1003
)
!=
70
);
}
}
SECTION
(
"write"
)
SECTION
(
"write"
)
{
{
ui
->
setValue
(
1018
,
70
);
ui
->
setValue
(
1018
,
70
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
70
);
REQUIRE
(
ui
->
getValue
(
1018
)
==
70
);
msleep
(
polltime
+
1
00
);
msleep
(
polltime
+
2
00
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
70
);
REQUIRE
(
mbs
->
getLastWriteOutputSingleRegister
()
!=
70
);
}
}
...
...
extensions/include/UObject_SK.h
View file @
7f491151
...
@@ -8,7 +8,7 @@
...
@@ -8,7 +8,7 @@
ВСЕ ВАШИ ИЗМЕНЕНИЯ БУДУТ ПОТЕРЯНЫ.
ВСЕ ВАШИ ИЗМЕНЕНИЯ БУДУТ ПОТЕРЯНЫ.
*/
*/
// --------------------------------------------------------------------------
// --------------------------------------------------------------------------
// generate timestamp: 2015-0
2-28
+03:00
// generate timestamp: 2015-0
3-06
+03:00
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
#ifndef UObject_SK_H_
#ifndef UObject_SK_H_
#define UObject_SK_H_
#define UObject_SK_H_
...
@@ -42,19 +42,45 @@ class UObject_SK:
...
@@ -42,19 +42,45 @@ class UObject_SK:
void
init_dlog
(
std
::
shared_ptr
<
DebugStream
>
d
);
void
init_dlog
(
std
::
shared_ptr
<
DebugStream
>
d
);
// "синтаксический сахар"..для логов
// "синтаксический сахар"..для логов
#define myinfo if( mylog->debugging(Debug::INFO) ) mylog->info()
#ifndef myinfo
#define mywarn if( mylog->debugging(Debug::WARN) ) mylog->warn()
#define myinfo if( mylog->debugging(Debug::INFO) ) mylog->info()
#define mycrit if( mylog->debugging(Debug::CRIT) ) mylog->crit()
#endif
#define mylog1 if( mylog->debugging(Debug::LEVEL1) ) mylog->level1()
#ifndef mywarn
#define mylog2 if( mylog->debugging(Debug::LEVEL2) ) mylog->level2()
#define mywarn if( mylog->debugging(Debug::WARN) ) mylog->warn()
#define mylog3 if( mylog->debugging(Debug::LEVEL3) ) mylog->level3()
#endif
#define mylog4 if( mylog->debugging(Debug::LEVEL4) ) mylog->level4()
#ifndef mycrit
#define mylog5 if( mylog->debugging(Debug::LEVEL5) ) mylog->level5()
#define mycrit if( mylog->debugging(Debug::CRIT) ) mylog->crit()
#define mylog6 if( mylog->debugging(Debug::LEVEL6) ) mylog->level6()
#endif
#define mylog7 if( mylog->debugging(Debug::LEVEL7) ) mylog->level7()
#ifndef mylog1
#define mylog8 if( mylog->debugging(Debug::LEVEL8) ) mylog->level8()
#define mylog1 if( mylog->debugging(Debug::LEVEL1) ) mylog->level1()
#define mylog9 if( mylog->debugging(Debug::LEVEL9) ) mylog->level9()
#endif
#define mylogany mylog->any()
#ifndef mylog2
#define mylog2 if( mylog->debugging(Debug::LEVEL2) ) mylog->level2()
#endif
#ifndef mylog3
#define mylog3 if( mylog->debugging(Debug::LEVEL3) ) mylog->level3()
#endif
#ifndef mylog4
#define mylog4 if( mylog->debugging(Debug::LEVEL4) ) mylog->level4()
#endif
#ifndef mylog5
#define mylog5 if( mylog->debugging(Debug::LEVEL5) ) mylog->level5()
#endif
#ifndef mylog6
#define mylog6 if( mylog->debugging(Debug::LEVEL6) ) mylog->level6()
#endif
#ifndef mylog7
#define mylog7 if( mylog->debugging(Debug::LEVEL7) ) mylog->level7()
#endif
#ifndef mylog8
#define mylog8 if( mylog->debugging(Debug::LEVEL8) ) mylog->level8()
#endif
#ifndef mylog9
#define mylog9 if( mylog->debugging(Debug::LEVEL9) ) mylog->level9()
#endif
#ifndef mylogany
#define mylogany mylog->any()
#endif
// Используемые идентификаторы
// Используемые идентификаторы
...
...
extensions/lib/UObject_SK.cc
View file @
7f491151
...
@@ -11,7 +11,7 @@
...
@@ -11,7 +11,7 @@
ВСЕ ВАШИ ИЗМЕНЕНИЯ БУДУТ ПОТЕРЯНЫ.
ВСЕ ВАШИ ИЗМЕНЕНИЯ БУДУТ ПОТЕРЯНЫ.
*/
*/
// --------------------------------------------------------------------------
// --------------------------------------------------------------------------
// generate timestamp: 2015-0
2-28
+03:00
// generate timestamp: 2015-0
3-06
+03:00
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
#include <memory>
#include <memory>
#include "Configuration.h"
#include "Configuration.h"
...
@@ -62,7 +62,7 @@ static const std::string init3_str( const std::string& s1, const std::string& s2
...
@@ -62,7 +62,7 @@ static const std::string init3_str( const std::string& s1, const std::string& s2
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
UObject_SK
::
UObject_SK
(
ObjectId
id
,
xmlNode
*
cnode
,
const
std
::
string
&
_argprefix
)
:
UObject_SK
::
UObject_SK
(
ObjectId
id
,
xmlNode
*
cnode
,
const
std
::
string
&
_argprefix
)
:
UniSetObject
(
id
),
UniSetObject
(
id
),
argprefix
(
(
_argprefix
.
empty
()
?
myname
+
"-"
:
argprefix
)
),
argprefix
(
(
_argprefix
.
empty
()
?
myname
+
"-"
:
_
argprefix
)
),
// Инициализация идентификаторов (имена берутся из конф. файла)
// Инициализация идентификаторов (имена берутся из конф. файла)
// Используемые идентификаторы сообщений (имена берутся из конф. файла)
// Используемые идентификаторы сообщений (имена берутся из конф. файла)
...
@@ -103,7 +103,7 @@ end_private(false)
...
@@ -103,7 +103,7 @@ end_private(false)
mylog
->
setLogName
(
myname
);
mylog
->
setLogName
(
myname
);
{
{
ostringstream
s
;
ostringstream
s
;
s
<<
argprefix
<<
"
-
log"
;
s
<<
argprefix
<<
"log"
;
conf
->
initLogStream
(
mylog
,
s
.
str
());
conf
->
initLogStream
(
mylog
,
s
.
str
());
}
}
...
@@ -186,17 +186,17 @@ bool UObject_SK::alarm( UniSetTypes::ObjectId _code, bool _state )
...
@@ -186,17 +186,17 @@ bool UObject_SK::alarm( UniSetTypes::ObjectId _code, bool _state )
{
{
if
(
_code
==
UniSetTypes
::
DefaultObjectId
)
if
(
_code
==
UniSetTypes
::
DefaultObjectId
)
{
{
u
crit
<<
getName
()
my
crit
<<
getName
()
<<
"(alarm): попытка послать сообщение с DefaultObjectId"
<<
"(alarm): попытка послать сообщение с DefaultObjectId"
<<
endl
;
<<
endl
;
return
false
;
return
false
;
}
}
ulog1
<<
getName
()
<<
"(alarm): "
<<
(
_state
?
"SEND "
:
"RESET "
)
<<
endl
;
mylog8
<<
getName
()
<<
"(alarm): "
<<
(
_state
?
"SEND "
:
"RESET "
)
<<
endl
;
ulog1
<<
" not found MessgeOID?!!"
<<
endl
;
mylog8
<<
" not found MessgeOID?!!"
<<
endl
;
return
false
;
return
false
;
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
...
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