aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDavid Walter Seikel2014-05-13 12:03:48 +1000
committerDavid Walter Seikel2014-05-13 12:03:48 +1000
commitbc57556575d79ed64e9d2b7978fb409397adb522 (patch)
tree7e85c8c55d92dafcb717f9153a713fa0a1e2973c
parentAdd some love, er I mean, add the love world server, coz love makes the world... (diff)
downloadSledjHamr-bc57556575d79ed64e9d2b7978fb409397adb522.zip
SledjHamr-bc57556575d79ed64e9d2b7978fb409397adb522.tar.gz
SledjHamr-bc57556575d79ed64e9d2b7978fb409397adb522.tar.bz2
SledjHamr-bc57556575d79ed64e9d2b7978fb409397adb522.tar.xz
Major new TODO details - get llDialog() from the MLP scripts to actually work.
-rw-r--r--docs/README.LuaSL240
1 files changed, 239 insertions, 1 deletions
diff --git a/docs/README.LuaSL b/docs/README.LuaSL
index 1444948..56adf12 100644
--- a/docs/README.LuaSL
+++ b/docs/README.LuaSL
@@ -61,7 +61,7 @@ forever processing any event.
61 61
62Some form of serialization will need to be created for saving script 62Some form of serialization will need to be created for saving script
63state during shutdowns, passing script state to other threads / 63state during shutdowns, passing script state to other threads /
64processes / computers. Aparently Lua is good at this. 64processes / computers. Apparently Lua is good at this.
65 65
66There will have to be a MySQL (and maybe SQLite) client in the system, 66There will have to be a MySQL (and maybe SQLite) client in the system,
67so we can talk directly to the local sim database. Esskyuehl may be 67so we can talk directly to the local sim database. Esskyuehl may be
@@ -98,3 +98,241 @@ etc.
98Performance testing will have to be done on 5000 scripts, to see how 98Performance testing will have to be done on 5000 scripts, to see how
99that compares against XEngine. 99that compares against XEngine.
100 100
101
102The next goal.
103--------------
104
105The next goal is to support llDialog() in extantz. Extantz has enough
106GUI infrastructure now to support a window with a bunch of buttons.
107LuaLSL has always used MLP as the test scripts, which in turn reads some
108note cards and pops up llDialog to suit. I think I have enough bits to
109get this all linked up, or at least start to, and see what missing bits
110there are.
111
112
113 Just off the top of my head -
114 -----------------------------
115
116MLP uses llGetInventory*() functions to find out what note cards are in
117the objects inventory. Then uses llGetNotecardLine() to read the
118notecards. In response, the server sends dataserver events with each
119line, and the system loops until all lines are read.
120
121MLP sets up a listener with llListen(), then uses llDialog() to send a
122"menu" to the client. The client sends a channel message back to the
123server when the user makes a choice. These go to the listen event.
124
125
126 In "reality" -
127 --------------
128
129LuaSL
130 starts up
131 opens an Ecore_Con TCP server at 127.0.0.1:8211
132 sets up the compiler
133 starts luaproc worker thread system
134 waits for input
135 compile() -> compile the script, report warnings and errors
136 run() -> create new Lua state, put it on the worker queue
137 exit() -> shutdown
138 * -> send to SID Lua state
139
140LuaSL_test
141 starts up
142 connects to LuaSL server
143 loops through Test sim/objects looking for *.lsl
144 generates random SID
145 sends "SID compile file.lsl" to LuaSL
146 deal with returned results
147 PW warnings
148 PE errors
149 if compiled send "SID run()" to LuaSL
150 for various llGet*() functions, return random data to LuaSL
151 This includes the llGetInventory*() functions mentioned above.
152 waits for a few seconds
153 sends pretend touch events to LuaSL
154 sends quit() to LuaSL
155 sends exit() to LuaSL
156
157Test sim/objects
158 onefangs test bed
159 the usual MLP style scripts
160 .MENUITEMS
161 .POSITIONS
162 ball object
163
164MLP
165 ~run
166 llSay() to balls telling left over ones to die
167 llGetOwner()
168 loop through an internal list of script names
169 llGetInventoryType() to check if they are there and are scripts.
170 llSetScriptState() to stop them
171 llResetOtherScript()
172 llOwnerSay() to let owner know MLP is turned off
173
174 touch_start()
175 llDetectedKey() to check if it's the owner (current version of MLP doesn't do this)
176 switch to run state
177
178 run state
179 loop through scripts again, turning them on this time.
180
181
182 ~memory
183 llGetInventoryNumber() to count the notecards
184 llGetInventoryName() to find .POSITIONS cards
185 llGetNoteCardLine()
186
187 dataserver()
188 llGetNoteCardLine()
189 change to state on when finished
190
191 on state
192 llMessageLinked()
193
194 link_message()
195 llWhisper()
196
197
198 ~menucfg
199 Same as ~memory.
200 llGetScriptName()
201 llGetFreeMemory()
202
203
204 ~menu
205 llSetTimerEvent() - NOTE doesn't actually setup a timer in the default state.
206 llSleep()
207
208 link_message()
209 llGetLinkNumber()
210 switch to state on
211
212 on state
213 llGetKey() to figure out it's channel
214 llListen()
215
216 listen()
217 llSameGroup()
218 llDialog()
219 llResetTime()
220
221 link_message()
222
223 touch_start()
224 llDetectedKey()
225 llDetectedGroup()
226
227 timer()
228
229Not to mention copius use of list and string functions.
230
231
232LSL.Lua
233 All event stuff is hooked up.
234 events.detected*(list) is all hooked up to save the list in detected* tables.
235 llDetected*() functions return those tables.
236
237 copius list functions implemented, though there's a TODO about negative indexes. Dunno which ones are missing.
238
239 String functions implemented. Actually only llGetSubString() and llSubStringIndex()
240
241 llGetScriptName() implemented.
242
243 State changes implemented, with a TODO about clearing out pending events.
244
245
246 Not implemented -
247 llSay + friends, including llOwnerSay().
248 llGetOwner()
249 llGetInventory*()
250 llGetInventoryType() faked to just return script.
251 llSetScriptState() and llResetOtherScript()
252 llResetTime()
253 llGetNoteCardLine()
254 llMessageLinked()
255 llGetFreeMemory()
256 llSleep() - sorta, not sure how the comment there makes sense. lol
257 llSetTimerEvent()
258 llGetLinkNumber()
259 llGetKey()
260 llDialog()
261 llListen()
262 llSameGroup()
263
264
265 Uses newFunc() to create all the LSL functions.
266 If there is no return type then sends function and arguments to LuaSL's client.
267 If there is a return type then sends function and arguments to LuaSL"s client, then waits for the response.
268 response should be a Lua value as a string. It gets pcall()'d
269 If we implement a function ourselves, then we override the newFunc created definition with our own function.
270
271
272 Uses waitAndProcess() as the main loop, or to wait for responses.
273 Which just runs what ever Lua strings are sent to us from the LuaSL client, unless it's waiting for a response above.
274
275
276 What needs to be done -
277 -----------------------
278
279Extantz fires up love, which in turn fires up LuaSL. Love then
280basically does what LuaSL_test does, sending it scripts to compile and
281run from test sim/objects. Except for the timed fake events.
282
283Generate touch events when user touchs the 3D cube. It will pretend to be
284the "onefang's test bed" object. Fake up llDetected* stuff.
285
286extantz -> love -> LuaSL
287
288
289Respond to llSay() and friends by putting them in purkle's history box.
290With time stamps.
291
292LuaSL -> love -> extantz
293
294
295Fake llGetOwner(), llGetFreeMemory(), and llSameGroup().
296
297LuaSL -> love -> LuaSL
298
299
300Fake llGetLinkNumber() and llGetKey()?
301
302LuaSL -> love -> LuaSL
303
304
305Implement llGetInventory*() by actually looking at the files in the
306"object". While we could hard code where the "object" is, since we are
307starting the run ourselves, we can track which object the scripts are
308in. Again, this should be in the love server part.
309
310LuaSL -> love -> LuaSL
311
312
313Implement llSetScriptState() and friends. Perhaps they should be
314implemented in LuaSL? Though they need to know what other scripts are
315in the "object", so perhaps not? Do them in love for now.
316
317LuaSL (maybe with a round trip to love as well)
318
319
320Implement llSleep(), llSetTimerEvent, and generate timer() events.
321
322LuaSL only.
323
324
325Implement llGetNotecardLine() and generate dataserver() events.
326
327LuaSL -> love
328
329
330Implement llMessageLink() and generate link_message() events.
331
332LuaSL (maybe with a round trip to love as well)
333
334
335Implement llListen(), llDialog() and generate listen() events.
336
337LuaSL -> love -> extantz -> love -> LuaSL
338