-
Notifications
You must be signed in to change notification settings - Fork 4
/
dumpmsgs.tcl
executable file
·56 lines (45 loc) · 1.15 KB
/
dumpmsgs.tcl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#!/usr/bin/env tclsh
#
# CLI Script: TCP connection example
# - dump all messages except engine.timer -
#
# Author: Ben Fuhrmannek <[email protected]>
# Date: 2012-09-24
#
# Copyright (c) 2012, Ben Fuhrmannek
# All rights reserved.
#
# - call from command line -
# extmodule.conf listener example:
# [listener tcp5039]
# type=tcp
# addr=127.0.0.1
# port=5039
#
package require Tcl 8.5
## YGI setup
set auto_path [linsert $auto_path 0 [file dirname [info script]]]
package require ygi
## watch handler function
proc watch_handler {id processed name retvalue kv} {
if {$name eq "engine.timer"} { return }
puts "---------> new message: $name $id $processed $retvalue"
foreach {k v} $kv {
puts [format "| %18s %s" $k $v]
}
}
## connect to socket
set fd [socket 127.0.0.1 5039]
set ::ygi::onexit {catch {close $::fd}}
## start message handler
::ygi::start $fd $fd
#set ::ygi::debug true
## first command to socket must be connect
::ygi::connect global
## log or console message
::ygi::log "TCP connection example"
## install watch handler for some/all messages
#::ygi::watch "call.execute" watch_handler
::ygi::watch "" watch_handler
## never stop
::ygi::loop_forever