forked from jamesoff/bmotion
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbMotion.tcl
executable file
·272 lines (223 loc) · 6.69 KB
/
bMotion.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
#bMotion core
#
# $Id$
#
#
# #5270 +(28)- [X]
#
# <Procyan> is there like 1 person on earth that knows tcl/tk and is writing all of the apps?
# <unSlider> procyan: no, there are a bunch of people who dont know tcl/tk but are writing apps for it anyway
# (www.bash.org)
### Set some important variables
if {![info exists bMotionRoot]} {
set bMotionRoot "scripts/bmotion"
}
set bMotionModules "$bMotionRoot/modules"
set bMotionPlugins "$bMotionRoot/plugins"
set bMotionLocal "$bMotionRoot/local"
### We need to do this early on in case something breaks
setudef flag bmotion
if {![info exists bMotion_log_regexp]} {
set bMotion_log_regexp ""
}
if {![info exists bMotion_testing]} {
putloglev d * "bMotion: bMotion_testing is not defined, setting to 0."
set bMotion_testing 0
}
source "$bMotionRoot/VERSION"
if {$bMotion_testing == 0} {
putlog "bMotion $bMotionVersion starting up..."
}
if {$bMotion_testing == 1} {
putlog "bMotion: INFO: Code loading in testing mode"
set bMotion_loading 0
} else {
putloglev 1 * "bMotion: INFO: Code loading in running mode"
set bMotion_loading 1
}
proc bMotion_putloglev { level star text } {
global bMotion_testing bMotion_log_regexp
if {$bMotion_log_regexp != ""} {
if {![regexp -nocase $bMotion_log_regexp $text]} {
return 0
}
}
regsub "bMotion:" $text "" text
set text2 ""
if {$level != "d"} {
set text2 [string repeat " " $level]
}
set text "bMotion:$text2 $text"
if {$bMotion_testing == 0} {
if {[string length $text] < 256} {
putloglev $level $star "($level)$text"
} else {
while {[string length $text] >= 256} {
set thistext [string range $text 0 255]
set text [string range $text 256 [string length $text]]
putloglev $level $star "($level)$thistext"
}
putloglev $level $star "($level)$text"
}
}
}
# load settings
if {$bMotion_testing == 1} {
putlog "... loading settings"
}
set bMotion_loaded_settings_from [list]
# try the original location first
set bMotion_loaded_settings 0
if [file exists "$bMotionModules/settings.tcl"] {
source "$bMotionModules/settings.tcl"
bMotion_putloglev d * "loaded settings from modules directory"
set bMotion_loaded_settings 1
lappend bMotion_loaded_settings_from "$bMotionModules/settings.tcl"
}
#try to load from the local dir
if [file exists "$bMotionLocal/settings.tcl"] {
source "$bMotionLocal/settings.tcl"
bMotion_putloglev d * "loaded local settings from $bMotionLocal/settings.tcl"
set bMotion_loaded_settings 1
lappend bMotion_loaded_settings_from "$bMotionLocal/settings.tcl"
}
#try to load a file for this bot
catch {
if {${botnet-nick} != ""} {
source "$bMotionModules/settings_${botnet-nick}.tcl"
bMotion_putloglev d * "loaded settings for this bot from settings_${botnet-nick}.tcl"
set bMotion_loaded_settings 1
lappend bMotion_loaded_settings_from "$bMotionModules/settings_${botnet-nick}.tcl"
}
}
#try to load a file for this bot
catch {
if {${botnet-nick} != ""} {
source "$bMotionLocal/settings_${botnet-nick}.tcl"
bMotion_putloglev d * "loaded settings for this bot from settings_${botnet-nick}.tcl"
set bMotion_loaded_settings 1
lappend bMotion_loaded_settings_from "$bMotionLocal/settings_${botnet-nick}.tcl"
}
}
if {$bMotion_loaded_settings == 0} {
putlog "bMotion: FATAL! Could not load from any settings file! bMotion is not going to work! :("
putlog "bMotion: Aborting script startup"
putlog "bMotion: Hint: mkdir -p local && cp modules/settings.sample.tcl local/settings.tcl"
return
}
putlog "bMotion: loaded settings from the following files: $bMotion_loaded_settings_from"
#load redis
if {$bMotion_testing == 1} {
putlog "... loading redis"
}
source "$bMotionModules/redis.tcl"
# needed for variables
if {$bMotion_testing == 1} {
putlog "... loading plugin settings"
}
source "$bMotionModules/plugins_settings.tcl"
# init default variables
if {$bMotion_testing == 1} {
putlog "... loading variables"
}
source "$bMotionModules/variables.tcl"
#load system functions
if {$bMotion_testing == 1} {
putlog "... loading system"
}
source "$bMotionModules/system.tcl"
#load new abstract system
if {$bMotion_testing == 1} {
putlog "... loading abstract system"
}
source "$bMotionModules/abstract.tcl"
# load output functions
if {$bMotion_testing == 1} {
putlog "... loading output"
}
source "$bMotionModules/output.tcl"
# load event functions
if {$bMotion_testing == 1} {
putlog "... loading events"
}
source "$bMotionModules/events.tcl"
if {$bMotion_testing == 1} {
putlog "... loading events support"
}
source "$bMotionModules/events_support.tcl"
# load interbot bits
if {$bMotion_testing == 1} {
putlog "... loading interbot"
}
source "$bMotionModules/interbot.tcl"
# load friendship code
if {$bMotion_testing == 1} {
putlog "... loading friendship"
}
source "$bMotionModules/friendship.tcl"
# load anti-flood code
if {$bMotion_testing == 1} {
putlog "... loading flood"
}
source "$bMotionModules/flood.tcl"
# load queue code
if {$bMotion_testing == 1} {
putlog "... loading queue"
}
source "$bMotionModules/queue.tcl"
# load plugins
if {$bMotion_testing == 1} {
putlog "... loading plugins"
}
source "$bMotionModules/plugins.tcl"
# load mood functions
if {$bMotion_testing == 1} {
putlog "... loading mood"
}
source "$bMotionModules/mood.tcl"
### That's everything but the plugins stuff loaded. Now load extra modules
bMotion_putloglev d * "looking for 3rd party modules..."
set files [lsort [glob -nocomplain "$bMotionModules/extra/*.tcl"]]
foreach f $files {
bMotion_putloglev 1 * "... loading extra module: $f"
catch {
source $f
}
}
### Done, load the plugins:
#load local abstracts
catch {
source "$bMotionLocal/abstracts.tcl"
bMotion_putloglev d * "loaded abstracts for this bot from local abstracts.tcl"
}
# load other bits
if {$bMotion_testing == 1} {
putlog "... loading leet"
}
source "$bMotionModules/leet.tcl"
# load diagnostics
catch {
if {$bMotion_testing == 1} {
putlog "... loading self-diagnostics"
}
source "$bMotionModules/diagnostics.tcl"
}
# Ignition!
bMotion_startTimers
if {$bMotion_testing == 0} {
bMotion_diagnostic_utimers
bMotion_diagnostic_timers
putlog "\002bMotion $bMotionVersion AI online\002 :D"
}
set bMotion_loading 0
set bMotion_testing 0
# To hide this message from your bot's startup/rehash, edit your settings.tcl and change
# the bMotion_show_copyright value to 0
if {![info exists bMotion_show_copyright]} {
set bMotion_show_copyright 1
}
if {$bMotion_show_copyright == 1} {
putlog "bMotion is Copyright (C) 2001-2012 James Seward. bMotion comes with ABSOLUTELY NO WARRANTY;"
putlog "This is free software, and you are welcome to redistribute it under certain conditions."
putlog "See the COPYRIGHT file for details. See bMotion.tcl to hide this message once you have read it."
}