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
9f043270
Commit
9f043270
authored
May 31, 2015
by
Pavel Vainerman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(LogAgregator): добавлена поддержка иерархии агрегаторов,
необоходимая для удобства использования LogServer. (uniset-log): сменил названия аргументов командной строки на более "логичные"
parent
3de2c879
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
534 additions
and
293 deletions
+534
-293
log.cc
Utilities/ULog/log.cc
+11
-11
logserver.cc
Utilities/ULog/logserver.cc
+29
-3
ctl-cpp-common.xsl
Utilities/codegen/ctl-cpp-common.xsl
+20
-18
TestGen.cc
Utilities/codegen/tests/TestGen.cc
+16
-0
TestGen.h
Utilities/codegen/tests/TestGen.h
+1
-1
libuniset2.spec
conf/libuniset2.spec
+8
-2
UObject_SK.h
extensions/include/UObject_SK.h
+95
-99
UObject_SK.cc
extensions/lib/UObject_SK.cc
+119
-132
LogAgregator.h
include/LogAgregator.h
+117
-6
LogServerTypes.h
include/LogServerTypes.h
+1
-1
LogSession.h
include/LogSession.h
+2
-0
LogAgregator.cc
src/Log/LogAgregator.cc
+73
-7
LogReader.cc
src/Log/LogReader.cc
+1
-0
LogSession.cc
src/Log/LogSession.cc
+19
-13
test_logserver.cc
tests/test_logserver.cc
+22
-0
No files found.
Utilities/ULog/log.cc
View file @
9f043270
...
...
@@ -20,10 +20,10 @@ static struct option longopts[] =
{
"del"
,
required_argument
,
0
,
'd'
},
{
"set"
,
required_argument
,
0
,
's'
},
{
"off"
,
required_argument
,
0
,
'o'
},
{
"on"
,
required_argument
,
0
,
'
n
'
},
{
"list"
,
no_argument
,
0
,
'
m
'
},
{
"on"
,
required_argument
,
0
,
'
e
'
},
{
"list"
,
no_argument
,
0
,
'
l
'
},
{
"rotate"
,
required_argument
,
0
,
'r'
},
{
"logname"
,
required_argument
,
0
,
'
l
'
},
{
"logname"
,
required_argument
,
0
,
'
n
'
},
{
"command-only"
,
no_argument
,
0
,
'b'
},
{
"timeout"
,
required_argument
,
0
,
'w'
},
{
"reconnect-delay"
,
required_argument
,
0
,
'x'
},
...
...
@@ -36,7 +36,7 @@ static void print_help()
printf
(
"-v, --verbose - Print all messages to stdout
\n
"
);
printf
(
"[-i|--iaddr] addr - LogServer ip or hostname.
\n
"
);
printf
(
"[-p|--port] port - LogServer port.
\n
"
);
printf
(
"[-
l
|--logname] name - Send command only for 'logname'.
\n
"
);
printf
(
"[-
n
|--logname] name - Send command only for 'logname'.
\n
"
);
printf
(
"[-b|--command-only] - Send command and break. (No read logs).
\n
"
);
printf
(
"[-w|--timeout] msec - Timeout for wait data. Default: 0 - endless waiting
\n
"
);
printf
(
"[-x|--reconnect-delay] msec - Pause for repeat connect to LogServer. Default: 5000 msec.
\n
"
);
...
...
@@ -48,9 +48,9 @@ static void print_help()
printf
(
"[--del | -d] info,warn,crit,... - Delete log levels.
\n
"
);
printf
(
"[--set | -s] info,warn,crit,... - Set log levels.
\n
"
);
printf
(
"--off, -o - Off the write log file (if enabled).
\n
"
);
printf
(
"--on, -
n - On
the write log file (if before disabled).
\n
"
);
printf
(
"--on, -
e - On(enable)
the write log file (if before disabled).
\n
"
);
printf
(
"--rotate, -r - rotate log file.
\n
"
);
printf
(
"--list, -
m
- List of managed logs.
\n
"
);
printf
(
"--list, -
l
- List of managed logs.
\n
"
);
}
// --------------------------------------------------------------------------
int
main
(
int
argc
,
char
**
argv
)
...
...
@@ -73,7 +73,7 @@ int main( int argc, char** argv )
try
{
while
(
(
opt
=
getopt_long
(
argc
,
argv
,
"hv
ma:p:i:d:s:l:on
rbx:w:"
,
longopts
,
&
optindex
))
!=
-
1
)
while
(
(
opt
=
getopt_long
(
argc
,
argv
,
"hv
la:p:i:d:s:n:eo
rbx:w:"
,
longopts
,
&
optindex
))
!=
-
1
)
{
switch
(
opt
)
{
...
...
@@ -102,7 +102,7 @@ int main( int argc, char** argv )
}
break
;
case
'
m
'
:
case
'
l
'
:
cmd
=
LogServerTypes
::
cmdList
;
cmdonly
=
1
;
break
;
...
...
@@ -111,7 +111,7 @@ int main( int argc, char** argv )
cmd
=
LogServerTypes
::
cmdOffLogFile
;
break
;
case
'
n
'
:
case
'
e
'
:
cmd
=
LogServerTypes
::
cmdOnLogFile
;
break
;
...
...
@@ -123,7 +123,7 @@ int main( int argc, char** argv )
addr
=
string
(
optarg
);
break
;
case
'
l
'
:
case
'
n
'
:
logname
=
string
(
optarg
);
break
;
...
...
@@ -171,7 +171,7 @@ int main( int argc, char** argv )
data
=
(
int
)
Debug
::
value
(
sdata
);
if
(
verb
)
cout
<<
"SEND COMMAND: '"
<<
(
LogServerTypes
::
Command
)
cmd
<<
" data='"
<<
sdata
<<
"'"
<<
endl
;
cout
<<
"SEND COMMAND: '"
<<
(
LogServerTypes
::
Command
)
cmd
<<
" data='"
<<
sdata
<<
"'
("
<<
(
int
)
data
<<
")
"
<<
endl
;
}
lr
.
readlogs
(
addr
,
port
,
(
LogServerTypes
::
Command
)
cmd
,
data
,
logname
,
verb
);
...
...
Utilities/ULog/logserver.cc
View file @
9f043270
...
...
@@ -91,13 +91,12 @@ int main( int argc, char** argv )
// dlog.addLevel( Debug::type(Debug::CRIT | Debug::WARN | Debug::INFO) );
}
auto
la
=
make_shared
<
LogAgregator
>
();
auto
la
=
make_shared
<
LogAgregator
>
(
"la"
);
cerr
<<
"create LogAgregator: "
<<
la
->
getLogName
()
<<
endl
;
auto
dlog
=
make_shared
<
DebugStream
>
();
dlog
->
setLogName
(
"dlog"
);
la
->
add
(
dlog
);
auto
dlog2
=
la
->
create
(
"dlog2"
);
...
...
@@ -115,11 +114,30 @@ int main( int argc, char** argv )
}
auto
la2
=
make_shared
<
LogAgregator
>
(
"la2"
);
cerr
<<
"create LogAgregator: "
<<
la2
->
getLogName
()
<<
endl
;
auto
dlog3
=
la2
->
create
(
"dlog3"
);
auto
dlog4
=
la2
->
create
(
"dlog4"
);
la
->
add
(
la2
);
if
(
la
->
getLog
(
"la2/dlog3"
)
==
nullptr
)
{
cerr
<<
"Not found 'la2/dlog3'"
<<
endl
;
return
1
;
}
LogServer
ls
(
la
);
ls
.
setMaxSessionCount
(
msess
);
dlog
->
addLevel
(
Debug
::
ANY
);
dlog2
->
addLevel
(
Debug
::
ANY
);
dlog3
->
addLevel
(
Debug
::
ANY
);
dlog4
->
addLevel
(
Debug
::
ANY
);
ls
.
run
(
addr
,
port
,
true
);
...
...
@@ -140,6 +158,14 @@ int main( int argc, char** argv )
dlog2
->
warn
()
<<
": dlog2: WARN message"
<<
endl
;
dlog2
->
crit
()
<<
": dlog2: CRIT message"
<<
endl
;
dlog3
->
info
()
<<
": dlog3: INFO message"
<<
endl
;
dlog3
->
warn
()
<<
": dlog3: WARN message"
<<
endl
;
dlog3
->
crit
()
<<
": dlog3: CRIT message"
<<
endl
;
dlog4
->
info
()
<<
": dlog4: INFO message"
<<
endl
;
dlog4
->
warn
()
<<
": dlog4: WARN message"
<<
endl
;
dlog4
->
crit
()
<<
": dlog4: CRIT message"
<<
endl
;
msleep
(
delay
);
}
...
...
Utilities/codegen/ctl-cpp-common.xsl
View file @
9f043270
...
...
@@ -171,48 +171,50 @@
virtual bool setMsg( UniSetTypes::ObjectId code, bool state = true );
std::shared_ptr
<
DebugStream
>
mylog;
inline std::shared_ptr
<
DebugStream
>
log(){ return mylog; }
inline std::shared_ptr
<
LogAgregator
>
logAgregator(){ return loga; }
void init_dlog( std::shared_ptr
<
DebugStream
>
d );
// "синтаксический сахар"..для логов
#ifndef myinfo
#define myinfo if(
mylog->debugging(Debug::INFO) ) mylog
->info()
#define myinfo if(
log()->debugging(Debug::INFO) ) log()
->info()
#endif
#ifndef mywarn
#define mywarn if(
mylog->debugging(Debug::WARN) ) mylog
->warn()
#define mywarn if(
log()->debugging(Debug::WARN) ) log()
->warn()
#endif
#ifndef mycrit
#define mycrit if(
mylog->debugging(Debug::CRIT) ) mylog
->crit()
#define mycrit if(
log()->debugging(Debug::CRIT) ) log()
->crit()
#endif
#ifndef mylog1
#define mylog1 if(
mylog->debugging(Debug::LEVEL1) ) mylog
->level1()
#define mylog1 if(
log()->debugging(Debug::LEVEL1) ) log()
->level1()
#endif
#ifndef mylog2
#define mylog2 if(
mylog->debugging(Debug::LEVEL2) ) mylog
->level2()
#define mylog2 if(
log()->debugging(Debug::LEVEL2) ) log()
->level2()
#endif
#ifndef mylog3
#define mylog3 if(
mylog->debugging(Debug::LEVEL3) ) mylog
->level3()
#define mylog3 if(
log()->debugging(Debug::LEVEL3) ) log()
->level3()
#endif
#ifndef mylog4
#define mylog4 if(
mylog->debugging(Debug::LEVEL4) ) mylog
->level4()
#define mylog4 if(
log()->debugging(Debug::LEVEL4) ) log()
->level4()
#endif
#ifndef mylog5
#define mylog5 if(
mylog->debugging(Debug::LEVEL5) ) mylog
->level5()
#define mylog5 if(
log()->debugging(Debug::LEVEL5) ) log()
->level5()
#endif
#ifndef mylog6
#define mylog6 if(
mylog->debugging(Debug::LEVEL6) ) mylog
->level6()
#define mylog6 if(
log()->debugging(Debug::LEVEL6) ) log()
->level6()
#endif
#ifndef mylog7
#define mylog7 if(
mylog->debugging(Debug::LEVEL7) ) mylog
->level7()
#define mylog7 if(
log()->debugging(Debug::LEVEL7) ) log()
->level7()
#endif
#ifndef mylog8
#define mylog8 if(
mylog->debugging(Debug::LEVEL8) ) mylog
->level8()
#define mylog8 if(
log()->debugging(Debug::LEVEL8) ) log()
->level8()
#endif
#ifndef mylog9
#define mylog9 if(
mylog->debugging(Debug::LEVEL9) ) mylog
->level9()
#define mylog9 if(
log()->debugging(Debug::LEVEL9) ) log()
->level9()
#endif
#ifndef mylogany
#define mylogany
mylog
->any()
#define mylogany
log()
->any()
#endif
// Вспомогательные функции для удобства логирования
...
...
@@ -305,7 +307,7 @@
bool forceOut; /*!
<
флаг принудительного обноления "выходов" */
std::shared_ptr
<
LogAgregator
>
loga;
std::shared_ptr
<
DebugStream
>
sm
log;
std::shared_ptr
<
DebugStream
>
my
log;
std::shared_ptr
<
LogServer
>
logserv;
std::string logserv_host = {""};
int logserv_port = {0};
...
...
@@ -391,7 +393,7 @@ void <xsl:value-of select="$CLASSNAME"/>_SK::preSysCommand( const SystemMessage*
{
// переоткрываем логи
mylogany
<<
myname
<<
"(preSysCommand): logRotate"
<<
endl;
string fname(
mylog
->getLogFile() );
string fname(
log()
->getLogFile() );
if( !fname.empty() )
{
mylog->logFile(fname.c_str(),true);
...
...
@@ -708,7 +710,7 @@ end_private(false)
conf->initLogStream(mylog,s.str());
}
loga = make_shared
<
LogAgregator
>
();
loga = make_shared
<
LogAgregator
>
(
myname+"-loga"
);
loga-
>
add(mylog);
loga-
>
add(ulog());
...
...
@@ -1099,7 +1101,7 @@ askPause(uniset_conf()->getPIntProp(cnode,"askPause",2000))
conf->initLogStream(mylog, s.str());
}
loga = make_shared
<
LogAgregator
>
(
);
loga = make_shared
<
LogAgregator
>
(myname+"-loga"
);
loga-
>
add(mylog);
loga-
>
add(ulog());
...
...
Utilities/codegen/tests/TestGen.cc
View file @
9f043270
...
...
@@ -38,6 +38,16 @@ void TestGen::sensorInfo( const SensorMessage* sm )
// -----------------------------------------------------------------------------
void
TestGen
::
timerInfo
(
const
TimerMessage
*
tm
)
{
if
(
tm
->
id
==
1
)
{
askTimer
(
1
,
0
);
askTimer
(
2
,
3000
);
}
else
if
(
tm
->
id
==
2
)
{
askTimer
(
1
,
2000
);
askTimer
(
2
,
0
);
}
}
// -----------------------------------------------------------------------------
void
TestGen
::
sigterm
(
int
signo
)
...
...
@@ -45,3 +55,9 @@ void TestGen::sigterm( int signo )
TestGen_SK
::
sigterm
(
signo
);
}
// -----------------------------------------------------------------------------
void
TestGen
::
sysCommand
(
const
UniSetTypes
::
SystemMessage
*
sm
)
{
if
(
sm
->
command
==
SystemMessage
::
StartUp
)
askTimer
(
1
,
2000
);
}
// -----------------------------------------------------------------------------
Utilities/codegen/tests/TestGen.h
View file @
9f043270
...
...
@@ -11,13 +11,13 @@ class TestGen:
TestGen
(
UniSetTypes
::
ObjectId
id
,
xmlNode
*
confnode
=
UniSetTypes
::
uniset_conf
()
->
getNode
(
"TestGen"
)
);
virtual
~
TestGen
();
protected
:
TestGen
();
virtual
void
step
()
override
;
virtual
void
sensorInfo
(
const
UniSetTypes
::
SensorMessage
*
sm
)
override
;
virtual
void
timerInfo
(
const
UniSetTypes
::
TimerMessage
*
tm
)
override
;
virtual
void
sysCommand
(
const
UniSetTypes
::
SystemMessage
*
sm
)
override
;
virtual
void
sigterm
(
int
signo
)
override
;
private
:
...
...
conf/libuniset2.spec
View file @
9f043270
...
...
@@ -13,7 +13,7 @@
Name: libuniset2
Version: 2.1
Release: alt
2
Release: alt
3
Summary: UniSet - library for building distributed industrial control systems
...
...
@@ -455,6 +455,12 @@ mv -f %buildroot%python_sitelibdir_noarch/* %buildroot%python_sitelibdir/%oname
# ..
%changelog
* Sun May 31 2015 Pavel Vainerman <pv@altlinux.ru> 2.1-alt3
- (LogAgregator):
- added support agregator hierarchy
- add docs
- add new tests
* Sat May 30 2015 Pavel Vainerman <pv@altlinux.ru> 2.1-alt2
- (optimization): TransportMessage change format
- (uniset-codegen): minor fixes
...
...
@@ -470,7 +476,7 @@ mv -f %buildroot%python_sitelibdir_noarch/* %buildroot%python_sitelibdir/%oname
- minor fixes
* Sun May 24 2015 Pavel Vainerman <pv@altlinux.ru> 2.0-alt35
- add
supported
LogServer for:
- add
ed support
LogServer for:
SharedMemory,RRDServer,MBTCPMaster,MBSlave,UNetExchange,IOControl,
codegen,DBServer_xxx
...
...
extensions/include/UObject_SK.h
View file @
9f043270
...
...
@@ -3,12 +3,12 @@
/*
DO NOT EDIT THIS FILE. IT IS AUTOGENERATED FILE.
ALL YOUR CHANGES WILL BE LOST.
НЕ РЕДАКТИРУЙТЕ ЭТОТ ФАЙЛ. ЭТОТ ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ.
ВСЕ ВАШИ ИЗМЕНЕНИЯ БУДУТ ПОТЕРЯНЫ.
*/
*/
// --------------------------------------------------------------------------
// generate timestamp: 2015-05-3
0
+03:00
// generate timestamp: 2015-05-3
1
+03:00
// -----------------------------------------------------------------------------
#ifndef UObject_SK_H_
#define UObject_SK_H_
...
...
@@ -28,11 +28,11 @@ class UObject_SK:
public
LT_Object
{
public
:
UObject_SK
(
UniSetTypes
::
ObjectId
id
,
xmlNode
*
node
=
UniSetTypes
::
uniset_conf
()
->
getNode
(
"UObject"
),
const
std
::
string
&
argprefix
=
""
);
UObject_SK
(
UniSetTypes
::
ObjectId
id
,
xmlNode
*
node
=
UniSetTypes
::
uniset_conf
()
->
getNode
(
"UObject"
),
const
std
::
string
&
argprefix
=
""
);
UObject_SK
();
virtual
~
UObject_SK
();
long
getValue
(
UniSetTypes
::
ObjectId
sid
);
void
setValue
(
UniSetTypes
::
ObjectId
sid
,
long
value
);
void
askSensor
(
UniSetTypes
::
ObjectId
sid
,
UniversalIO
::
UIOCommand
,
UniSetTypes
::
ObjectId
node
=
UniSetTypes
::
uniset_conf
()
->
getLocalNode
()
);
...
...
@@ -40,103 +40,105 @@ class UObject_SK:
virtual
bool
setMsg
(
UniSetTypes
::
ObjectId
code
,
bool
state
=
true
);
std
::
shared_ptr
<
DebugStream
>
mylog
;
void
init_dlog
(
std
::
shared_ptr
<
DebugStream
>
d
);
inline
std
::
shared_ptr
<
DebugStream
>
log
(){
return
mylog
;
}
inline
std
::
shared_ptr
<
LogAgregator
>
logAgregator
(){
return
loga
;
}
// "синтаксический сахар"..для логов
#ifndef myinfo
#define myinfo if( mylog->debugging(Debug::INFO) ) mylog->info()
#endif
#ifndef mywarn
#define mywarn if( mylog->debugging(Debug::WARN) ) mylog->warn()
#endif
#ifndef mycrit
#define mycrit if( mylog->debugging(Debug::CRIT) ) mylog->crit()
#endif
#ifndef mylog1
#define mylog1 if( mylog->debugging(Debug::LEVEL1) ) mylog->level1()
#endif
#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
// Вспомогательные функции для удобства логирования
// ------------------------------------------------------------
/*!< вывод в строку значение всех входов и выходов в формате
ObjectName:
in_xxx = val
in_xxx2 = val
out_zzz = val
...
*/
std
::
string
dumpIO
();
/*!< Вывод в строку названия входа/выхода в формате: in_xxx(SensorName)
\param id - идентификатор датчика
\param showLinkName - TRUE - выводить SensorName, FALSE - не выводить
*/
std
::
string
str
(
UniSetTypes
::
ObjectId
id
,
bool
showLinkName
=
true
);
/*!< Вывод значения входа/выхода в формате: in_xxx(SensorName)=val
\param id - идентификатор датчика
\param showLinkName - TRUE - выводить SensorName, FALSE - не выводить
*/
std
::
string
strval
(
UniSetTypes
::
ObjectId
id
,
bool
showLinkName
=
true
);
// ------------------------------------------------------------
void
init_dlog
(
std
::
shared_ptr
<
DebugStream
>
d
);
// "синтаксический сахар"..для логов
#ifndef myinfo
#define myinfo if( log()->debugging(Debug::INFO) ) log()->info()
#endif
#ifndef mywarn
#define mywarn if( log()->debugging(Debug::WARN) ) log()->warn()
#endif
#ifndef mycrit
#define mycrit if( log()->debugging(Debug::CRIT) ) log()->crit()
#endif
#ifndef mylog1
#define mylog1 if( log()->debugging(Debug::LEVEL1) ) log()->level1()
#endif
#ifndef mylog2
#define mylog2 if( log()->debugging(Debug::LEVEL2) ) log()->level2()
#endif
#ifndef mylog3
#define mylog3 if( log()->debugging(Debug::LEVEL3) ) log()->level3()
#endif
#ifndef mylog4
#define mylog4 if( log()->debugging(Debug::LEVEL4) ) log()->level4()
#endif
#ifndef mylog5
#define mylog5 if( log()->debugging(Debug::LEVEL5) ) log()->level5()
#endif
#ifndef mylog6
#define mylog6 if( log()->debugging(Debug::LEVEL6) ) log()->level6()
#endif
#ifndef mylog7
#define mylog7 if( log()->debugging(Debug::LEVEL7) ) log()->level7()
#endif
#ifndef mylog8
#define mylog8 if( log()->debugging(Debug::LEVEL8) ) log()->level8()
#endif
#ifndef mylog9
#define mylog9 if( log()->debugging(Debug::LEVEL9) ) log()->level9()
#endif
#ifndef mylogany
#define mylogany log()->any()
#endif
// Вспомогательные функции для удобства логирования
// ------------------------------------------------------------
/*!< вывод в строку значение всех входов и выходов в формате
ObjectName:
in_xxx = val
in_xxx2 = val
out_zzz = val
...
*/
std
::
string
dumpIO
();
/*!< Вывод в строку названия входа/выхода в формате: in_xxx(SensorName)
\param id - идентификатор датчика
\param showLinkName - TRUE - выводить SensorName, FALSE - не выводить
*/
std
::
string
str
(
UniSetTypes
::
ObjectId
id
,
bool
showLinkName
=
true
);
/*!< Вывод значения входа/выхода в формате: in_xxx(SensorName)=val
\param id - идентификатор датчика
\param showLinkName - TRUE - выводить SensorName, FALSE - не выводить
*/
std
::
string
strval
(
UniSetTypes
::
ObjectId
id
,
bool
showLinkName
=
true
);
// ------------------------------------------------------------
// Используемые идентификаторы
// Используемые идентификаторы сообщений
// Текущее значение
// --- public variables ---
// --- end of public variables ---
protected
:
// --- protected variables ---
// ---- end of protected variables ----
virtual
void
callback
()
override
;
virtual
void
processingMessage
(
UniSetTypes
::
VoidMessage
*
msg
)
override
;
virtual
void
sysCommand
(
const
UniSetTypes
::
SystemMessage
*
sm
)
{};
virtual
void
askSensors
(
UniversalIO
::
UIOCommand
cmd
)
{}
virtual
void
sensorInfo
(
const
UniSetTypes
::
SensorMessage
*
sm
)
override
{}
virtual
void
timerInfo
(
const
UniSetTypes
::
TimerMessage
*
tm
)
override
{}
virtual
void
sysCommand
(
const
UniSetTypes
::
SystemMessage
*
sm
){};
virtual
void
askSensors
(
UniversalIO
::
UIOCommand
cmd
){}
virtual
void
sensorInfo
(
const
UniSetTypes
::
SensorMessage
*
sm
)
override
{}
virtual
void
timerInfo
(
const
UniSetTypes
::
TimerMessage
*
tm
)
override
{}
virtual
void
sigterm
(
int
signo
)
override
;
virtual
bool
activateObject
()
override
;
virtual
void
testMode
(
bool
state
);
...
...
@@ -156,7 +158,7 @@ class UObject_SK:
int
resetMsgTime
;
// Выполнение очередного шага программы
virtual
void
step
()
{}
virtual
void
step
(){}
int
sleep_msec
;
/*!< пауза между итерациями */
bool
active
;
...
...
@@ -168,45 +170,39 @@ class UObject_SK:
PassiveTimer
ptHeartBeat
;
/*! < период "сердцебиения" */
UniSetTypes
::
ObjectId
idHeartBeat
;
/*! < идентификатор датчика (AI) "сердцебиения" */
int
maxHeartBeat
;
/*! < сохраняемое значение */
xmlNode
*
confnode
;
/*! получить числовое свойство из конф. файла по привязанной confnode */
int
getIntProp
(
const
std
::
string
&
name
)
{
return
UniSetTypes
::
uniset_conf
()
->
getIntProp
(
confnode
,
name
);
}
int
getIntProp
(
const
std
::
string
&
name
)
{
return
UniSetTypes
::
uniset_conf
()
->
getIntProp
(
confnode
,
name
);
}
/*! получить текстовое свойство из конф. файла по привязанной confnode */
inline
const
std
::
string
getProp
(
const
std
::
string
&
name
)
{
return
UniSetTypes
::
uniset_conf
()
->
getProp
(
confnode
,
name
);
}
inline
const
std
::
string
getProp
(
const
std
::
string
&
name
)
{
return
UniSetTypes
::
uniset_conf
()
->
getProp
(
confnode
,
name
);
}
int
smReadyTimeout
;
/*!< время ожидания готовности SM */
std
::
atomic_bool
activated
;
int
activateTimeout
;
/*!< время ожидания готовности UniSetObject к работе */
PassiveTimer
ptStartUpTimeout
;
/*!< время на блокировку обработки WatchDog, если недавно был StartUp */
int
askPause
;
/*!< пауза между неудачными попытками заказать датчики */
IOController_i
::
SensorInfo
si
;
bool
forceOut
;
/*!< флаг принудительного обноления "выходов" */
std
::
shared_ptr
<
LogAgregator
>
loga
;
std
::
shared_ptr
<
DebugStream
>
sm
log
;
std
::
shared_ptr
<
DebugStream
>
my
log
;
std
::
shared_ptr
<
LogServer
>
logserv
;
std
::
string
logserv_host
=
{
""
};
int
logserv_port
=
{
0
};
private
:
// --- private variables ---
// --- end of private variables ---
// предыдущее значение (для работы UpdateValue())
// Используемые идентификаторы сообщений
bool
end_private
;
// вспомогательное поле (для внутреннего использования при генерировании кода)
};
...
...
extensions/lib/UObject_SK.cc
View file @
9f043270
...
...
@@ -6,12 +6,12 @@
/*
DO NOT EDIT THIS FILE. IT IS AUTOGENERATED FILE.
ALL YOUR CHANGES WILL BE LOST.
НЕ РЕДАКТИРУЙТЕ ЭТОТ ФАЙЛ. ЭТОТ ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ.
ВСЕ ВАШИ ИЗМЕНЕНИЯ БУДУТ ПОТЕРЯНЫ.
*/
*/
// --------------------------------------------------------------------------
// generate timestamp: 2015-05-3
0
+03:00
// generate timestamp: 2015-05-3
1
+03:00
// -----------------------------------------------------------------------------
#include <memory>
#include "Configuration.h"
...
...
@@ -31,26 +31,26 @@ using namespace UniSetTypes;
// -----------------------------------------------------------------------------
UObject_SK
::
UObject_SK
()
:
// Инициализация идентификаторов (имена берутся из конф. файла)
// Инициализация идентификаторов (имена берутся из конф. файла)
// Используемые идентификаторы сообщений (имена берутся из конф. файла)
// Используемые идентификаторы сообщений (имена берутся из конф. файла)
// variables
// variables
active
(
false
),
active
(
false
),
idHeartBeat
(
DefaultObjectId
),
maxHeartBeat
(
10
),
confnode
(
0
),
smReadyTimeout
(
0
),
activated
(
false
),
askPause
(
2000
),
forceOut
(
false
),
idHeartBeat
(
DefaultObjectId
),
maxHeartBeat
(
10
),
confnode
(
0
),
smReadyTimeout
(
0
),
activated
(
false
),
askPause
(
2000
),
forceOut
(
false
),
end_private
(
false
)
end_private
(
false
)
{
ucrit
<<
"UObject: init failed!!!!!!!!!!!!!!!"
<<
endl
;
throw
Exception
(
string
(
myname
+
": init failed!!!"
)
);
throw
Exception
(
string
(
myname
+
": init failed!!!"
)
);
}
// -----------------------------------------------------------------------------
// ( val, confval, default val )
...
...
@@ -58,42 +58,41 @@ static const std::string init3_str( const std::string& s1, const std::string& s2
{
if
(
!
s1
.
empty
()
)
return
s1
;
if
(
!
s2
.
empty
()
)
return
s2
;
return
s3
;
}
// -----------------------------------------------------------------------------
UObject_SK
::
UObject_SK
(
ObjectId
id
,
xmlNode
*
cnode
,
const
std
::
string
&
_argprefix
)
:
UniSetObject
(
id
),
argprefix
(
(
_argprefix
.
empty
()
?
myname
+
"-"
:
_argprefix
)
),
// Инициализация идентификаторов (имена берутся из конф. файла)
UniSetObject
(
id
),
argprefix
(
(
_argprefix
.
empty
()
?
myname
+
"-"
:
_argprefix
)
),
// Инициализация идентификаторов (имена берутся из конф. файла)
// Используемые идентификаторы сообщений (имена берутся из конф. файла)
// Используемые идентификаторы сообщений (имена берутся из конф. файла)
// variables
// variables
sleep_msec
(
150
),
active
(
true
),
sleep_msec
(
150
),
active
(
true
),
idHeartBeat
(
DefaultObjectId
),
maxHeartBeat
(
10
),
confnode
(
cnode
),
smReadyTimeout
(
0
),
activated
(
false
),
askPause
(
uniset_conf
()
->
getPIntProp
(
cnode
,
"askPause"
,
2000
)),
forceOut
(
false
),
idHeartBeat
(
DefaultObjectId
),
maxHeartBeat
(
10
),
confnode
(
cnode
),
smReadyTimeout
(
0
),
activated
(
false
),
askPause
(
uniset_conf
()
->
getPIntProp
(
cnode
,
"askPause"
,
2000
)),
forceOut
(
false
),
end_private
(
false
)
end_private
(
false
)
{
auto
conf
=
uniset_conf
();
if
(
UniSetTypes
::
findArgParam
(
"--print-id-list"
,
uniset_conf
()
->
getArgc
(),
uniset_conf
()
->
getArgv
())
!=
-
1
)
if
(
UniSetTypes
::
findArgParam
(
"--print-id-list"
,
uniset_conf
()
->
getArgc
(),
uniset_conf
()
->
getArgv
())
!=
-
1
)
{
// abort();
// abort();
}
...
...
@@ -104,15 +103,15 @@ UObject_SK::UObject_SK( ObjectId id, xmlNode* cnode, const std::string& _argpref
throw
SystemError
(
err
.
str
()
);
}
mylog
=
make_shared
<
DebugStream
>
();
mylog
=
make_shared
<
DebugStream
>
();
mylog
->
setLogName
(
myname
);
{
ostringstream
s
;
s
<<
argprefix
<<
"log"
;
conf
->
initLogStream
(
mylog
,
s
.
str
());
conf
->
initLogStream
(
mylog
,
s
.
str
());
}
loga
=
make_shared
<
LogAgregator
>
();
loga
=
make_shared
<
LogAgregator
>
(
myname
+
"-loga"
);
loga
->
add
(
mylog
);
loga
->
add
(
ulog
());
...
...
@@ -129,15 +128,13 @@ UObject_SK::UObject_SK( ObjectId id, xmlNode* cnode, const std::string& _argpref
logserv_host
=
conf
->
getArg2Param
(
"--"
+
argprefix
+
"logserver-host"
,
it
.
getProp
(
"logserverHost"
),
"localhost"
);
logserv_port
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"logserver-port"
,
it
.
getProp
(
"logserverPort"
),
getId
());
}
forceOut
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"force-out"
,
it
.
getProp
(
"forceOut"
),
false
);
forceOut
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"force-out"
,
it
.
getProp
(
"forceOut"
),
false
);
string
heart
=
conf
->
getArgParam
(
"--"
+
argprefix
+
"heartbeat-id"
,
it
.
getProp
(
"heartbeat_id"
));
string
heart
=
conf
->
getArgParam
(
"--"
+
argprefix
+
"heartbeat-id"
,
it
.
getProp
(
"heartbeat_id"
));
if
(
!
heart
.
empty
()
)
{
idHeartBeat
=
conf
->
getSensorID
(
heart
);
if
(
idHeartBeat
==
DefaultObjectId
)
{
ostringstream
err
;
...
...
@@ -145,38 +142,35 @@ UObject_SK::UObject_SK( ObjectId id, xmlNode* cnode, const std::string& _argpref
throw
SystemError
(
err
.
str
());
}
int
heartbeatTime
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"heartbeat-time"
,
it
.
getProp
(
"heartbeatTime"
),
conf
->
getHeartBeatTime
());
if
(
heartbeatTime
>
0
)
int
heartbeatTime
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"heartbeat-time"
,
it
.
getProp
(
"heartbeatTime"
),
conf
->
getHeartBeatTime
());
if
(
heartbeatTime
>
0
)
ptHeartBeat
.
setTiming
(
heartbeatTime
);
else
ptHeartBeat
.
setTiming
(
UniSetTimer
::
WaitUpTime
);
maxHeartBeat
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"heartbeat-max"
,
it
.
getProp
(
"heartbeat_max"
),
10
);
maxHeartBeat
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"heartbeat-max"
,
it
.
getProp
(
"heartbeat_max"
),
10
);
}
// Инициализация значений
sleep_msec
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"sleep-msec"
,
"150"
,
150
);
sleep_msec
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"sleep-msec"
,
"150"
,
150
);
string
s_resetTime
(
""
);
if
(
s_resetTime
.
empty
()
)
s_resetTime
=
"500"
;
resetMsgTime
=
uni_atoi
(
init3_str
(
conf
->
getArgParam
(
"--"
+
argprefix
+
"resetMsgTime"
),
conf
->
getProp
(
cnode
,
"resetMsgTime"
),
s_resetTime
));
resetMsgTime
=
uni_atoi
(
init3_str
(
conf
->
getArgParam
(
"--"
+
argprefix
+
"resetMsgTime"
),
conf
->
getProp
(
cnode
,
"resetMsgTime"
),
s_resetTime
));
ptResetMsg
.
setTiming
(
resetMsgTime
);
smReadyTimeout
=
conf
->
getArgInt
(
"--"
+
argprefix
+
"sm-ready-timeout"
,
""
);
smReadyTimeout
=
conf
->
getArgInt
(
"--"
+
argprefix
+
"sm-ready-timeout"
,
""
);
if
(
smReadyTimeout
==
0
)
smReadyTimeout
=
60000
;
else
if
(
smReadyTimeout
<
0
)
smReadyTimeout
=
UniSetTimer
::
WaitUpTime
;
smTestID
=
conf
->
getSensorID
(
init3_str
(
conf
->
getArgParam
(
"--"
+
argprefix
+
"sm-test-id"
),
conf
->
getProp
(
cnode
,
"smTestID"
),
""
));
smTestID
=
conf
->
getSensorID
(
init3_str
(
conf
->
getArgParam
(
"--"
+
argprefix
+
"sm-test-id"
),
conf
->
getProp
(
cnode
,
"smTestID"
),
""
));
activateTimeout
=
conf
->
getArgPInt
(
"--"
+
argprefix
+
"activate-timeout"
,
20000
);
...
...
@@ -184,7 +178,7 @@ UObject_SK::UObject_SK( ObjectId id, xmlNode* cnode, const std::string& _argpref
ptStartUpTimeout
.
setTiming
(
msec
);
// ===================== <variables> =====================
// ===================== end of <variables> =====================
}
...
...
@@ -197,17 +191,17 @@ UObject_SK::~UObject_SK()
void
UObject_SK
::
updateValues
()
{
// Опрашиваем все входы...
}
// -----------------------------------------------------------------------------
void
UObject_SK
::
updatePreviousValues
()
{
}
// -----------------------------------------------------------------------------
void
UObject_SK
::
checkSensors
()
{
}
// -----------------------------------------------------------------------------
bool
UObject_SK
::
setMsg
(
UniSetTypes
::
ObjectId
_code
,
bool
_state
)
...
...
@@ -215,24 +209,24 @@ bool UObject_SK::setMsg( UniSetTypes::ObjectId _code, bool _state )
if
(
_code
==
UniSetTypes
::
DefaultObjectId
)
{
mycrit
<<
myname
<<
"(setMsg): попытка послать сообщение с DefaultObjectId"
<<
endl
;
return
false
;
return
false
;
}
mylog8
<<
myname
<<
"(setMsg): "
<<
(
_state
?
"SEND "
:
"RESET "
)
<<
endl
;
// взводим автоматический сброс
if
(
_state
)
ptResetMsg
.
reset
();
mylog8
<<
myname
<<
"(setMsg): "
<<
(
_state
?
"SEND "
:
"RESET "
)
<<
endl
;
// взводим автоматический сброс
if
(
_state
)
ptResetMsg
.
reset
();
mylog8
<<
myname
<<
"(setMsg): not found MessgeOID?!!"
<<
endl
;
mylog8
<<
myname
<<
"(setMsg): not found MessgeOID?!!"
<<
endl
;
return
false
;
}
// -----------------------------------------------------------------------------
void
UObject_SK
::
resetMsg
()
{
// reset messages
// reset messages
}
// -----------------------------------------------------------------------------
...
...
@@ -242,28 +236,28 @@ void UObject_SK::testMode( bool _state )
return
;
// отключаем все выходы
}
// -----------------------------------------------------------------------------
std
::
string
UObject_SK
::
dumpIO
()
{
ostringstream
s
;
s
<<
myname
<<
": "
<<
endl
;
return
s
.
str
();
}
// ----------------------------------------------------------------------------
std
::
string
UObject_SK
::
str
(
UniSetTypes
::
ObjectId
id
,
bool
showLinkName
)
{
ostringstream
s
;
return
""
;
}
// ----------------------------------------------------------------------------
std
::
string
UObject_SK
::
strval
(
UniSetTypes
::
ObjectId
id
,
bool
showLinkName
)
{
ostringstream
s
;
return
""
;
}
// ----------------------------------------------------------------------------
...
...
@@ -284,19 +278,19 @@ void UObject_SK::processingMessage( UniSetTypes::VoidMessage* _msg )
{
case
Message
:
:
SensorInfo
:
preSensorInfo
(
reinterpret_cast
<
SensorMessage
*>
(
_msg
)
);
break
;
break
;
case
Message
:
:
Timer
:
preTimerInfo
(
reinterpret_cast
<
TimerMessage
*>
(
_msg
)
);
break
;
break
;
case
Message
:
:
SysCommand
:
preSysCommand
(
reinterpret_cast
<
SystemMessage
*>
(
_msg
)
);
break
;
break
;
default
:
break
;
}
}
}
catch
(
const
Exception
&
ex
)
{
...
...
@@ -310,13 +304,11 @@ void UObject_SK::preSysCommand( const SystemMessage* _sm )
{
case
SystemMessage
:
:
WatchDog
:
uinfo
<<
myname
<<
"(preSysCommand): WatchDog"
<<
endl
;
if
(
!
active
||
!
ptStartUpTimeout
.
checkTime
()
)
{
uwarn
<<
myname
<<
"(preSysCommand): игнорируем WatchDog, потому-что только-что стартанули"
<<
endl
;
break
;
}
case
SystemMessage
:
:
StartUp
:
{
if
(
!
logserv_host
.
empty
()
&&
logserv_port
!=
0
&&
!
logserv
->
isRunning
()
)
...
...
@@ -336,22 +328,21 @@ void UObject_SK::preSysCommand( const SystemMessage* _sm )
active
=
true
;
break
;
}
case
SystemMessage
:
:
FoldUp
:
case
SystemMessage
:
:
Finish
:
preAskSensors
(
UniversalIO
::
UIODontNotify
);
askSensors
(
UniversalIO
::
UIODontNotify
);
break
;
case
SystemMessage
:
:
LogRotate
:
{
// переоткрываем логи
mylogany
<<
myname
<<
"(preSysCommand): logRotate"
<<
endl
;
string
fname
(
mylog
->
getLogFile
()
);
string
fname
(
log
()
->
getLogFile
()
);
if
(
!
fname
.
empty
()
)
{
mylog
->
logFile
(
fname
.
c_str
(),
true
);
mylog
->
logFile
(
fname
.
c_str
(),
true
);
mylogany
<<
myname
<<
"(preSysCommand): ***************** mylog LOG ROTATE *****************"
<<
endl
;
}
}
...
...
@@ -360,7 +351,7 @@ void UObject_SK::preSysCommand( const SystemMessage* _sm )
default
:
break
;
}
sysCommand
(
_sm
);
}
// -----------------------------------------------------------------------------
...
...
@@ -373,7 +364,7 @@ void UObject_SK::sigterm( int signo )
// -----------------------------------------------------------------------------
bool
UObject_SK
::
activateObject
()
{
// блокирование обработки Startup
// блокирование обработки Startup
// пока не пройдёт инициализация датчиков
// см. preSysCommand()
{
...
...
@@ -399,24 +390,24 @@ void UObject_SK::waitSM( int wait_msec, ObjectId _testID )
if
(
_testID
==
DefaultObjectId
)
return
;
uinfo
<<
myname
<<
"(waitSM): waiting SM ready "
<<
wait_msec
<<
" msec"
<<
" testID="
<<
_testID
<<
endl
;
if
(
!
ui
->
waitReady
(
_testID
,
wait_msec
)
)
<<
wait_msec
<<
" msec"
<<
" testID="
<<
_testID
<<
endl
;
if
(
!
ui
->
waitReady
(
_testID
,
wait_msec
)
)
{
ostringstream
err
;
err
<<
myname
<<
"(waitSM): Не дождались готовности(exist) SharedMemory к работе в течение "
err
<<
myname
<<
"(waitSM): Не дождались готовности(exist) SharedMemory к работе в течение "
<<
wait_msec
<<
" мсек"
;
ucrit
<<
err
.
str
()
<<
endl
;
// terminate();
// abort();
ucrit
<<
err
.
str
()
<<
endl
;
// terminate();
// abort();
raise
(
SIGTERM
);
terminate
();
// throw SystemError(err.str());
// throw SystemError(err.str());
}
...
...
@@ -428,39 +419,37 @@ void UObject_SK::callback()
{
if
(
!
active
)
return
;
try
{
// проверка таймеров
checkTimers
(
this
);
if
(
resetMsgTime
>
0
&&
trResetMsg
.
hi
(
ptResetMsg
.
checkTime
())
)
if
(
resetMsgTime
>
0
&&
trResetMsg
.
hi
(
ptResetMsg
.
checkTime
())
)
{
// cout << myname << ": ********* reset messages *********" << endl;
// cout << myname << ": ********* reset messages *********" << endl;
resetMsg
();
}
// обработка сообщений (таймеров и т.п.)
for
(
unsigned
int
i
=
0
;
i
<
20
;
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
20
;
i
++
)
{
if
(
!
receiveMessage
(
msg
)
)
break
;
processingMessage
(
&
msg
);
updateOutputs
(
forceOut
);
// updatePreviousValues();
// updatePreviousValues();
}
// Выполнение шага программы
step
();
// "сердцебиение"
if
(
idHeartBeat
!=
DefaultObjectId
&&
ptHeartBeat
.
checkTime
()
)
if
(
idHeartBeat
!=
DefaultObjectId
&&
ptHeartBeat
.
checkTime
()
)
{
try
{
ui
->
setValue
(
idHeartBeat
,
maxHeartBeat
);
ui
->
setValue
(
idHeartBeat
,
maxHeartBeat
);
ptHeartBeat
.
reset
();
}
catch
(
const
Exception
&
ex
)
...
...
@@ -475,46 +464,46 @@ void UObject_SK::callback()
}
catch
(
const
Exception
&
ex
)
{
ucrit
<<
myname
<<
"(execute): "
<<
ex
<<
endl
;
ucrit
<<
myname
<<
"(execute): "
<<
ex
<<
endl
;
}
catch
(
const
CORBA
::
SystemException
&
ex
)
{
ucrit
<<
myname
<<
"(execute): СORBA::SystemException: "
<<
ex
.
NP_minorString
()
<<
endl
;
}
catch
(
const
std
::
exception
&
ex
)
{
ucrit
<<
myname
<<
"(execute): catch "
<<
ex
.
what
()
<<
endl
;
ucrit
<<
myname
<<
"(execute): СORBA::SystemException: "
<<
ex
.
NP_minorString
()
<<
endl
;
}
catch
(
const
std
::
exception
&
ex
)
{
ucrit
<<
myname
<<
"(execute): catch "
<<
ex
.
what
()
<<
endl
;
}
if
(
!
active
)
return
;
msleep
(
sleep_msec
);
}
// -----------------------------------------------------------------------------
void
UObject_SK
::
setValue
(
UniSetTypes
::
ObjectId
_sid
,
long
_val
)
{
ui
->
setValue
(
_sid
,
_val
);
ui
->
setValue
(
_sid
,
_val
);
}
// -----------------------------------------------------------------------------
void
UObject_SK
::
updateOutputs
(
bool
_force
)
{
}
// -----------------------------------------------------------------------------
void
UObject_SK
::
preSensorInfo
(
const
UniSetTypes
::
SensorMessage
*
_sm
)
{
sensorInfo
(
_sm
);
}
// -----------------------------------------------------------------------------
void
UObject_SK
::
askSensor
(
UniSetTypes
::
ObjectId
_sid
,
UniversalIO
::
UIOCommand
_cmd
,
UniSetTypes
::
ObjectId
_node
)
{
ui
->
askRemoteSensor
(
_sid
,
_cmd
,
_node
,
getId
());
ui
->
askRemoteSensor
(
_sid
,
_cmd
,
_node
,
getId
());
}
// -----------------------------------------------------------------------------
long
UObject_SK
::
getValue
(
UniSetTypes
::
ObjectId
_sid
)
...
...
@@ -527,7 +516,7 @@ long UObject_SK::getValue( UniSetTypes::ObjectId _sid )
}
catch
(
const
Exception
&
ex
)
{
ucrit
<<
myname
<<
"(getValue): "
<<
ex
<<
endl
;
ucrit
<<
myname
<<
"(getValue): "
<<
ex
<<
endl
;
throw
;
}
}
...
...
@@ -536,35 +525,33 @@ long UObject_SK::getValue( UniSetTypes::ObjectId _sid )
void
UObject_SK
::
preAskSensors
(
UniversalIO
::
UIOCommand
_cmd
)
{
PassiveTimer
ptAct
(
activateTimeout
);
while
(
!
activated
&&
!
ptAct
.
checkTime
()
)
{
{
cout
<<
myname
<<
"(preAskSensors): wait activate..."
<<
endl
;
msleep
(
300
);
if
(
activated
)
break
;
}
if
(
!
activated
)
ucrit
<<
myname
<<
"(preAskSensors): ************* don`t activated?! ************"
<<
endl
;
<<
"(preAskSensors): ************* don`t activated?! ************"
<<
endl
;
for
(
;;
)
{
try
{
return
;
}
catch
(
const
Exception
&
ex
)
{
ucrit
<<
myname
<<
"(preAskSensors): "
<<
ex
<<
endl
;
}
catch
(
const
std
::
exception
&
ex
)
{
ucrit
<<
myname
<<
"(execute): catch "
<<
ex
.
what
()
<<
endl
;
ucrit
<<
myname
<<
"(preAskSensors): "
<<
ex
<<
endl
;
}
catch
(
const
std
::
exception
&
ex
)
{
ucrit
<<
myname
<<
"(execute): catch "
<<
ex
.
what
()
<<
endl
;
}
msleep
(
askPause
);
}
...
...
include/LogAgregator.h
View file @
9f043270
...
...
@@ -8,19 +8,120 @@
#include "DebugStream.h"
#include "LogServerTypes.h"
// -------------------------------------------------------------------------
/*!
\page page_LogAgregator Агрегатор логов (LogAgregator)
- \ref sec_LogA_Comm
- \ref sec_LogA_Hierarchy
- \ref sec_LogA_Regexp
\section sec_LogA_Comm Общее описание
LogAgregator это класс предназначенный для объединения нескольких DebugStream
в один поток. При этом LogAgregator сам является DebugStream и обладает всеми его свойствами.
LogAgregator позволяет управлять каждым из своих логов в отдельности по имени лога.
\code
std::shared_ptr<DebugStream> dlog1 = std::make_shared<DebugStream>();
std::shared_ptr<DebugStream> dlog2 = std::make_shared<DebugStream>();
std::shared_ptr<DebugStream> la1 = make_shared<LogAgregator>("la1");
la1->add(dlog1,"dlog1");
la1->add(dlog1,"dlog2");
// Работа с логами через агрегатор
la1->addLevel("dlog1",Debug::INFO);
\endcode
Помимо этого при помощи агрегатора можно сразу создавать дочерние логи
\code
auto log10 = la1->create("dlog10");
log10->warn() << "WARNING MESSAGE" << endl;
\endcode
\section sec_LogA_Hierarchy Иерархия агрегаторов
Агрегатор позволяет строить иерархии из агрегаторов.
При добавлении дочернего агрегатора, все обращения к подчинённым логам другого агрегатора происходят
по имени включающим в себя имя дочернего агрегатора.
Пример:
\code
// Где-то в программе есть DebugStream (логи)
std::shared_ptr<DebugStream> dlog1 = std::make_shared<DebugStream>();
std::shared_ptr<DebugStream> dlog2 = std::make_shared<DebugStream>();
std::shared_ptr<DebugStream> dlog3 = std::make_shared<DebugStream>();
std::shared_ptr<DebugStream> dlog4 = std::make_shared<DebugStream>();
std::shared_ptr<LogAgregator> la1 = make_shared<LogAgregator>("la1");
la1->add(dlog1,"dlog1");
la1->add(dlog1,"dlog2");
// Работа с логами через агрегатор
la1->addLevel("dlog1",Debug::INFO);
..
// При этом можно выводить и напрямую в агрегатор
la1->info() << "INFO MESSAGE" << endl;
...
std::shared_ptr<LogAgregator> la2 = make_shared<LogAgregator>("la2");
la2->add(dlog1,"dlog3");
la2->add(dlog1,"dlog4");
// работа напрямую...
la2->addLevel("dlog4",Debug::WARN);
// Добавление второго агрегатора в первый..
la1->add(la2);
...
// теперь для обращения к логам второго агрегатора через первый..
// нужно добавлять его имя и разделитель "/" (LogAgregator::sep)
la1->addLevel("la2/dlog4",Debug::CRIT);
\endcode
\note Все эти свойства в полной мере используются при управлении логами через LogServer.
В обычной "жизни" агрегатор вряд ли особо нужен.
\section sec_LogA_Regexp Управление логами с использованием регулярных выражений
Агрегатор позволяет получать список подчинённых ему потоков (DebugStream) по именам удовлетворяющим
заданному регулярному выражению. Пример:
Предположим что иерархия подчинённых потоков выглядит следующим образом
\code
log1
log2
log3
loga2/log1
loga2/log2
loga2/loga3/log1
loga2/loga3/log2
loga2/loga3/log3
...
\endode
Для управления логами можно получить например список всех подчинённых потоков для loga3
\code
auto lst = la->getLogList(".*loga3.*");
for( auto&& l: lst )
{
..что-то делать..
}
\endcode
\note Полнота и формат поддерживаемых регулярных выражений зависит от поддержки компилятором стандарта с++11 (класс <regex>).
*/
// -------------------------------------------------------------------------
class
LogAgregator
:
public
DebugStream
{
public
:
explicit
LogAgregator
(
Debug
::
type
t
=
Debug
::
NONE
);
explicit
LogAgregator
(
char
const
*
f
,
Debug
::
type
t
=
Debug
::
NONE
);
const
std
::
string
sep
=
{
"/"
};
/*< раздедитель для имён подчинённых агрегаторов */
explicit
LogAgregator
(
const
std
::
string
&
name
,
Debug
::
type
t
);
explicit
LogAgregator
(
const
std
::
string
&
name
=
""
);
virtual
~
LogAgregator
();
virtual
void
logFile
(
const
std
::
string
&
f
,
bool
truncate
=
false
)
override
;
void
add
(
std
::
shared_ptr
<
DebugStream
>
log
);
void
add
(
std
::
shared_ptr
<
LogAgregator
>
log
,
const
std
::
string
&
lname
=
""
);
void
add
(
std
::
shared_ptr
<
DebugStream
>
log
,
const
std
::
string
&
lname
=
""
);
std
::
shared_ptr
<
DebugStream
>
create
(
const
std
::
string
&
logname
);
// Управление "подчинёнными" логами
...
...
@@ -28,13 +129,21 @@ class LogAgregator:
void
delLevel
(
const
std
::
string
&
logname
,
Debug
::
type
t
);
void
level
(
const
std
::
string
&
logname
,
Debug
::
type
t
);
struct
LogInfo
{
LogInfo
()
:
log
(
0
),
logfile
(
""
)
{}
LogInfo
(
std
::
shared_ptr
<
DebugStream
>&
l
)
:
log
(
l
),
logfile
(
l
->
getLogFile
())
{}
LogInfo
()
:
log
(
0
),
logfile
(
""
),
logname
(
""
)
{}
LogInfo
(
std
::
shared_ptr
<
DebugStream
>&
l
,
const
std
::
string
&
lname
=
""
)
:
log
(
l
),
logfile
(
l
->
getLogFile
()),
logname
(
lname
.
empty
()
?
l
->
getLogName
()
:
lname
)
{}
std
::
shared_ptr
<
DebugStream
>
log
;
std
::
string
logfile
;
std
::
string
logname
;
// для сортировки "по алфавиту"
inline
bool
operator
<
(
const
LogInfo
&
r
)
const
{
return
logname
<
r
.
logname
;
}
};
std
::
shared_ptr
<
DebugStream
>
getLog
(
const
std
::
string
&
logname
);
...
...
@@ -45,6 +154,8 @@ class LogAgregator:
protected
:
void
logOnEvent
(
const
std
::
string
&
s
);
void
addLog
(
std
::
shared_ptr
<
DebugStream
>
l
,
const
std
::
string
&
lname
);
void
addLogAgregator
(
std
::
shared_ptr
<
LogAgregator
>
la
,
const
std
::
string
&
lname
);
private
:
...
...
include/LogServerTypes.h
View file @
9f043270
...
...
@@ -7,7 +7,7 @@
// -------------------------------------------------------------------------
namespace
LogServerTypes
{
const
unsigned
int
MAGICNUM
=
0x201
40904
;
const
unsigned
int
MAGICNUM
=
0x201
50531
;
enum
Command
{
cmdNOP
,
/*!< отсутствие команды */
...
...
include/LogSession.h
View file @
9f043270
...
...
@@ -10,6 +10,7 @@
#include <mutex>
#include "Mutex.h"
#include "DebugStream.h"
#include "LogAgregator.h"
#include "PassiveTimer.h"
// -------------------------------------------------------------------------
/*! Реализация "сессии" для клиентов LogServer. */
...
...
@@ -66,6 +67,7 @@ class LogSession:
std
::
string
peername
;
std
::
string
caddr
;
std
::
shared_ptr
<
DebugStream
>
log
;
std
::
shared_ptr
<
LogAgregator
>
alog
;
// PassiveTimer ptSessionTimeout;
FinalSlot
slFin
;
...
...
src/Log/LogAgregator.cc
View file @
9f043270
#include <memory>
#include <regex>
#include <sstream>
#include "DebugExtBuf.h"
#include "LogAgregator.h"
// -------------------------------------------------------------------------
LogAgregator
::
LogAgregator
(
const
std
::
string
&
name
)
:
LogAgregator
(
name
,
Debug
::
NONE
)
{
}
// ------------------------------------------------------------------------
#if 0
LogAgregator::LogAgregator( char const* f, Debug::type t ):
DebugStream(f, t)
{
delete rdbuf(new teebuf(&internal->fbuf, &internal->sbuf));
}
#endif
// -------------------------------------------------------------------------
LogAgregator
::
LogAgregator
(
Debug
::
type
t
)
:
LogAgregator
::
LogAgregator
(
const
std
::
string
&
name
,
Debug
::
type
t
)
:
DebugStream
(
t
)
{
setLogName
(
name
);
delete
rdbuf
(
new
teebuf
(
&
internal
->
nbuf
,
&
internal
->
sbuf
));
}
// -------------------------------------------------------------------------
...
...
@@ -48,17 +57,73 @@ std::shared_ptr<DebugStream> LogAgregator::create( const std::string& logname )
return
l
;
}
// -------------------------------------------------------------------------
void
LogAgregator
::
add
(
std
::
shared_ptr
<
DebugStream
>
l
)
void
LogAgregator
::
add
(
std
::
shared_ptr
<
DebugStream
>
l
,
const
std
::
string
&
lname
)
{
auto
lag
=
std
::
dynamic_pointer_cast
<
LogAgregator
>
(
l
);
if
(
lag
)
addLogAgregator
(
lag
,
(
lname
.
empty
()
?
l
->
getLogName
()
:
lname
)
);
else
addLog
(
l
,(
lname
.
empty
()
?
l
->
getLogName
()
:
lname
));
}
// ------------------------------------------------------------------------
void
LogAgregator
::
add
(
std
::
shared_ptr
<
LogAgregator
>
loga
,
const
std
::
string
&
lname
)
{
addLogAgregator
(
loga
,
(
lname
.
empty
()
?
loga
->
getLogName
()
:
lname
)
);
}
// -------------------------------------------------------------------------
void
LogAgregator
::
addLogAgregator
(
std
::
shared_ptr
<
LogAgregator
>
la
,
const
std
::
string
&
lname
)
{
auto
i
=
lmap
.
find
(
lname
);
if
(
i
!=
lmap
.
end
()
)
return
;
auto
lst
=
la
->
getLogList
();
for
(
auto
&&
l
:
lst
)
{
auto
lag
=
std
::
dynamic_pointer_cast
<
LogAgregator
>
(
l
.
log
);
if
(
lag
)
{
std
::
ostringstream
s
;
s
<<
lname
<<
sep
<<
lag
->
getLogName
();
addLogAgregator
(
lag
,
s
.
str
());
// рекурсия..
}
else
{
std
::
ostringstream
s
;
s
<<
lname
<<
sep
<<
l
.
log
->
getLogName
();
addLog
(
l
.
log
,
s
.
str
());
}
}
}
// ------------------------------------------------------------------------
void
LogAgregator
::
addLog
(
std
::
shared_ptr
<
DebugStream
>
l
,
const
std
::
string
&
lname
)
{
auto
i
=
lmap
.
find
(
l
->
getLogName
()
);
auto
i
=
lmap
.
find
(
l
name
);
if
(
i
!=
lmap
.
end
()
)
return
;
l
->
signal_stream_event
().
connect
(
sigc
::
mem_fun
(
this
,
&
LogAgregator
::
logOnEvent
)
);
lmap
[
l
->
getLogName
()]
=
l
;
bool
have
=
false
;
// пока делаем "не оптимальный поиск" / пробегаем по всему списку, зато не храним дополнительный map /
// на то, чтобы не подключаться к одному логу дважды,
// иначе будет дублироваие при выводе потом (на экран)
for
(
const
auto
&
i
:
lmap
)
{
if
(
i
.
second
.
log
==
l
)
{
have
=
true
;
break
;
}
}
if
(
!
have
)
l
->
signal_stream_event
().
connect
(
sigc
::
mem_fun
(
this
,
&
LogAgregator
::
logOnEvent
)
);
LogInfo
li
(
l
,
lname
);
lmap
[
lname
]
=
li
;
}
// ------------------------------------------------------------------------
-
// ------------------------------------------------------------------------
void
LogAgregator
::
addLevel
(
const
std
::
string
&
logname
,
Debug
::
type
t
)
{
auto
i
=
lmap
.
find
(
logname
);
...
...
@@ -129,7 +194,8 @@ std::list<LogAgregator::LogInfo> LogAgregator::getLogList( const std::string& re
for
(
auto
&&
i
:
lmap
)
{
if
(
std
::
regex_match
(
i
.
second
.
log
->
getLogName
(),
rule
)
)
//if( std::regex_match(i.second.log->getLogName(), rule) )
if
(
std
::
regex_match
(
i
.
first
,
rule
)
)
l
.
push_back
(
i
.
second
);
}
}
...
...
src/Log/LogReader.cc
View file @
9f043270
...
...
@@ -202,6 +202,7 @@ void LogReader::readlogs( const std::string& _addr, ost::tpport_t _port, LogServ
{
tcp
->
read
(
buf
,
n
);
buf
[
n
]
=
'\0'
;
log
<<
buf
;
if
(
msg
.
cmd
==
LogServerTypes
::
cmdList
)
...
...
src/Log/LogSession.cc
View file @
9f043270
...
...
@@ -49,6 +49,10 @@ LogSession::LogSession( ost::TCPSocket& server, std::shared_ptr<DebugStream>& _l
log
->
signal_stream_event
().
connect
(
sigc
::
mem_fun
(
this
,
&
LogSession
::
logOnEvent
)
);
else
slog
.
crit
()
<<
"LOG NULL!!"
<<
endl
;
auto
ag
=
dynamic_pointer_cast
<
LogAgregator
>
(
log
);
if
(
ag
)
alog
=
ag
;
}
// -------------------------------------------------------------------------
void
LogSession
::
logOnEvent
(
const
std
::
string
&
s
)
...
...
@@ -109,14 +113,12 @@ void LogSession::run()
if
(
!
cmdLogName
.
empty
()
)
{
auto
lag
=
dynamic_pointer_cast
<
LogAgregator
>
(
log
);
if
(
lag
)
if
(
alog
)
// если у нас "агрегатор", то работаем с его списком потоков
{
if
(
cmdLogName
==
"ALL"
)
loglist
=
la
g
->
getLogList
();
loglist
=
alo
g
->
getLogList
();
else
loglist
=
la
g
->
getLogList
(
cmdLogName
);
loglist
=
alo
g
->
getLogList
(
cmdLogName
);
}
else
{
...
...
@@ -134,21 +136,25 @@ void LogSession::run()
ostringstream
s
;
s
<<
"List of managed logs:"
<<
endl
;
s
<<
"====================="
<<
endl
;
auto
lag
=
dynamic_pointer_cast
<
LogAgregator
>
(
log
);
if
(
!
lag
)
if
(
!
alog
)
{
s
<<
log
->
getLogName
()
<<
endl
;
}
else
{
auto
lst
=
lag
->
getLogList
();
std
::
list
<
LogAgregator
::
LogInfo
>
lst
;
if
(
cmdLogName
.
empty
()
||
cmdLogName
==
"ALL"
)
lst
=
alog
->
getLogList
();
else
lst
=
alog
->
getLogList
(
cmdLogName
);
// красиво отсортируем сперва..
lst
.
sort
([](
const
LogAgregator
::
LogInfo
&
a
,
const
LogAgregator
::
LogInfo
&
b
)
{
return
a
.
logname
<
b
.
logname
;
});
for
(
const
auto
&
i
:
lst
)
s
<<
i
.
log
->
getLogName
()
<<
endl
;
s
<<
i
.
log
name
<<
endl
;
}
s
<<
"====================="
<<
endl
;
s
<<
"====================="
<<
endl
<<
endl
;
if
(
isPending
(
Socket
::
pendingOutput
,
cmdTimeout
)
)
{
...
...
@@ -158,7 +164,7 @@ void LogSession::run()
}
}
// обрабатываем команды только если нашли
log
// обрабатываем команды только если нашли
подходящие логи
for
(
auto
&&
li
:
loglist
)
{
// Обработка команд..
...
...
tests/test_logserver.cc
View file @
9f043270
...
...
@@ -243,3 +243,25 @@ TEST_CASE("MaxSessions", "[LogServer]" )
r2_thr
->
join
();
}
// --------------------------------------------------------------------------
TEST_CASE
(
"Logagregator regexp"
,
"[LogAgregator]"
)
{
auto
la
=
make_shared
<
LogAgregator
>
();
auto
log1
=
la
->
create
(
"log1"
);
auto
log2
=
la
->
create
(
"log2"
);
auto
log3
=
la
->
create
(
"a3/log1"
);
auto
log4
=
la
->
create
(
"a3/log2"
);
auto
log5
=
la
->
create
(
"a3/log3"
);
auto
log6
=
la
->
create
(
"a3/a4/log1"
);
auto
log7
=
la
->
create
(
"a3/a4/log2"
);
auto
lst
=
la
->
getLogList
(
".*/a4/.*"
);
REQUIRE
(
lst
.
size
()
==
2
);
lst
=
la
->
getLogList
(
"a3/.*"
);
REQUIRE
(
lst
.
size
()
==
5
);
lst
=
la
->
getLogList
(
".*log1.*"
);
REQUIRE
(
lst
.
size
()
==
3
);
}
// --------------------------------------------------------------------------
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