diff options
Diffstat (limited to 'docs')
-rw-r--r-- | docs/ClientHamr/README | 7 | ||||
-rw-r--r-- | docs/ClientHamr/README.BVJ | 7 | ||||
-rw-r--r-- | docs/ClientHamr/README.GuiLua | 581 | ||||
-rw-r--r-- | docs/ClientHamr/README.IAE | 3 | ||||
-rw-r--r-- | docs/ClientHamr/README.XMPP | 4 | ||||
-rw-r--r-- | docs/ClientHamr/README.bGod | 5 | ||||
-rw-r--r-- | docs/ClientHamr/README.extantz | 24 | ||||
-rw-r--r-- | docs/ClientHamr/README.libpurple | 4 | ||||
-rw-r--r-- | docs/ClientHamr/README.mumble | 5 | ||||
-rw-r--r-- | docs/ClientHamr/README.woMan | 148 | ||||
-rw-r--r-- | docs/ClientHamr/WindowSharing.txt | 84 | ||||
-rw-r--r-- | docs/README.Bookie | 33 | ||||
-rw-r--r-- | docs/README.HamrSpace | 1 | ||||
-rw-r--r-- | docs/README.Lspace | 1 | ||||
-rw-r--r-- | docs/README.LuaSL | 100 | ||||
-rw-r--r-- | docs/README.REST | 2 | ||||
-rw-r--r-- | docs/README.WTF | 5 | ||||
-rw-r--r-- | docs/README.libraries | 31 | ||||
-rw-r--r-- | docs/README.nails | 9 |
19 files changed, 1054 insertions, 0 deletions
diff --git a/docs/ClientHamr/README b/docs/ClientHamr/README new file mode 100644 index 0000000..c82b1ba --- /dev/null +++ b/docs/ClientHamr/README | |||
@@ -0,0 +1,7 @@ | |||
1 | Refer to - http://www.infinitegrid.org/drupal/content/ClientHamr | ||
2 | |||
3 | ClientHamr is the concept that we can apply the unix philosophy to the | ||
4 | viewer. Use individual tools that are good at their job to split off | ||
5 | bits of the big bad blob that is the viewer. Using standard protocals | ||
6 | and tools where we can. | ||
7 | |||
diff --git a/docs/ClientHamr/README.BVJ b/docs/ClientHamr/README.BVJ new file mode 100644 index 0000000..456154a --- /dev/null +++ b/docs/ClientHamr/README.BVJ | |||
@@ -0,0 +1,7 @@ | |||
1 | Refer to - http://www.infinitegrid.org/drupal/content/BVJ | ||
2 | |||
3 | BVJ is extensions to the BVH animation format used by SL technology. | ||
4 | It's in the ClientHamr section coz on the server side, they are just | ||
5 | dealt with as blobs to be sent to the viewers. This may change if we | ||
6 | implement animating link sets, and interaction with the sim physics. | ||
7 | |||
diff --git a/docs/ClientHamr/README.GuiLua b/docs/ClientHamr/README.GuiLua new file mode 100644 index 0000000..f60d7b2 --- /dev/null +++ b/docs/ClientHamr/README.GuiLua | |||
@@ -0,0 +1,581 @@ | |||
1 | GuiLua is basically a redo of my ancient Java based matrix-RAD system, | ||
2 | but using Lua and EFL. Lua is entirely different from Java, and Lua | ||
3 | doesn't run in web browsers, so this version has similar concepts, and | ||
4 | similar names, it's not exactly the same. It's more accurate to say | ||
5 | this is in the spirit of matrix-RAD. | ||
6 | |||
7 | The ultimate goal is for the various ClientHamr parts to be able to | ||
8 | either host their own UI, or have it hosted in the in world 3D window. | ||
9 | Matrix-RAD's ability to run either server or client side, with no change | ||
10 | to the code, is great for this sort of thing. If I can manage the | ||
11 | ability to "tear off" windows, in other words, pull them out of the 3D | ||
12 | window to be real windows, then that's something people have been asking | ||
13 | for from LL forever. | ||
14 | |||
15 | Stdin/out might be good to use. Extantz starts up "client" programs, | ||
16 | with a "use stdin/out" argument, the clients pass skang commands (open | ||
17 | this internal window with these widgets) to extantz through their | ||
18 | stdout, extantz passes skang commands (these values where set by these | ||
19 | widgets) back through their stdin. With no "use stdin/out" argument, | ||
20 | the programs host their own UI. Perhaps extantz can just pass the UI | ||
21 | skang stuff back to the client, which will mean "draw your own window", | ||
22 | to support the "tear off" feature. If I remember skang had suitable | ||
23 | serialization stuff to support this. Lua does anyway. B-) | ||
24 | |||
25 | Naturally, like matrix-RAD, all this UI stuff can happen across a socket | ||
26 | as well as through stdin/out. Should be transparent to the user proggy. | ||
27 | |||
28 | I can redesign skang to be more Lua like, to take advantage of Lua's | ||
29 | meta language capabilities. Since no one used skang anyway, I can get | ||
30 | away with this. Also should add a Lua friendly wrapper around nails, so | ||
31 | that addons for Extantz can be supplied entirely as Lua scripts. In | ||
32 | other words, LuaSL scripts. On top of all that, should also allow | ||
33 | access to the Edje Lua stuff I've already written, but drag it outside | ||
34 | of an edje file. | ||
35 | |||
36 | This pretty much means that GuiLua should be a shared library, coz in | ||
37 | the ClientHamr use case, several programs are gonna be using it at once. | ||
38 | Should also be separate modules for development stuff like the skin | ||
39 | editor, which could be just another proggy using GuiLua. | ||
40 | |||
41 | Initially GuiLua can wrap elementary / evas, with the goal of wrapping | ||
42 | NAWS, just like matrix-RAD was originally planned. Then I can put off | ||
43 | writing NAWS for another decade. lol | ||
44 | |||
45 | Might be nice to have a wrapper that is a web server that generates | ||
46 | standard HTML forms. No JavaScript, no HTML5, just plain old, | ||
47 | compatible with everything, HTML forms. | ||
48 | |||
49 | |||
50 | Design notes | ||
51 | ------------ | ||
52 | |||
53 | Edje Lua does not wrap elementary widgets, and is not likely to due to | ||
54 | elementary being compiled after edje. Smart objects and swallows | ||
55 | probably can deal with that though, I'm not familiar enough with them to | ||
56 | know. Eo on the other hand allegedly offers introspection, which was | ||
57 | always the corner stone of matrix-RAD. So access to elementary widgets | ||
58 | via Eo might be possible. That's kinda the entire hook I'm hoping will | ||
59 | help to make matrix-RAD style stuff work as well as it did there. | ||
60 | Apparently when they promised introspection with Eo, they meant compile | ||
61 | time, not run time. | ||
62 | |||
63 | Edje Lua is restricted to scripts in edje files, AND sandboxed to those | ||
64 | edje files as well. We want to step outside that sandbox, and run stand | ||
65 | alone Lua scripts, as well as GuiLua / LuaSL scripts internal to | ||
66 | extantz. Some merging of LuaSL and Edje Lua, leaving room for GuiLua, | ||
67 | would be great, but I might have to convince Raster. Note that the | ||
68 | socket idea wont work in sandboxed edje Lua scripts, unless the socket | ||
69 | is in C code, that uses edje messages as the internal transport. | ||
70 | |||
71 | Just so it's easier to find, I'll repeat a bit from the Enlightenment | ||
72 | mailing list here, the result of discussions with raster and other | ||
73 | interested parties - | ||
74 | |||
75 | "First step is to write edje functions for generically bundling up one | ||
76 | or more Lua tables into a message, sending that message, then unpacking | ||
77 | it again. This will be able to be done from edje, from C, and from Lua | ||
78 | directly. Perhaps adding that as one more edje messege type. This is | ||
79 | for sending Lua tables between threads. A later addition will be to | ||
80 | send them through the 'net, probably as eet. | ||
81 | |||
82 | Host apps can register arbitrary functions with edje Lua, using a more | ||
83 | generic version of the code I already wrote for letting edje register | ||
84 | lua functions. These host functions are by default not thread safe. | ||
85 | Edje puts a wrapper function around the host app, and registers that | ||
86 | wrapper function with Lua. The wrapper function, when called from Lua, | ||
87 | does this - | ||
88 | |||
89 | ecore_thread_main_loop_begin(); | ||
90 | call the host app callback(); | ||
91 | ecore_thread_main_loop_end(); | ||
92 | |||
93 | The first alternative, which the host app must request, is for the | ||
94 | wrapper function to use the table message functions to marshal the | ||
95 | arguments, send it to the main thread, wait for the response (or do | ||
96 | something else), then unmarshal the result before sending it back to | ||
97 | Lua. | ||
98 | |||
99 | The second alternative, which the host app must REALLY request, is for | ||
100 | the host app to say "I'm REALLY going out of my way to be threadsafe, | ||
101 | just call me direct". No edje wrapper function, BUT the host app still | ||
102 | has to use edje to register this function. | ||
103 | |||
104 | The first two might be done this way - | ||
105 | |||
106 | host_cb = edje_lua2_functions_add(...); | ||
107 | edje_lua2_function_marshal_set(host_cb, function); | ||
108 | |||
109 | The last one could be - | ||
110 | |||
111 | host_cb = edje_lua2_threadsafe_function_add(...); | ||
112 | |||
113 | Note the difference between _functions_ and _function_. The first call | ||
114 | registers an entire metatable full of functions, in the same way that | ||
115 | edje does for it's functions. These are the default sort of | ||
116 | functions. The second call references one of those previously | ||
117 | registered functions, and makes it marshal arguments and results. The | ||
118 | third one registers a single function, but it could be added to an | ||
119 | existing metatable registered by the first function." | ||
120 | |||
121 | and - | ||
122 | |||
123 | "We are actually half way there. Anticipating that there would be way | ||
124 | more edje and evas stuff to add to the edje Lua API in the future, I | ||
125 | created generic wrapper functions to make that easier. Implementing | ||
126 | this would mean exposing those static functions, and writing more of | ||
127 | these generic wrapper stuff. | ||
128 | |||
129 | Lua already provides a mechanism for this sort of thing, but we | ||
130 | currently sandbox that out. We can provide a very limited version of | ||
131 | the package module, that only lets the Lua script load modules that the | ||
132 | host app explicitly provides. This keeps edje Lua in it's strictly | ||
133 | sandboxed state." | ||
134 | |||
135 | Raster also wants to thread lots of edje, likely including having edje | ||
136 | Lua scripts as threads, much like I'm doing with LuaSL already. Plus | ||
137 | LuaJIT SPEEEEED!!. B-) | ||
138 | |||
139 | |||
140 | Skang notes | ||
141 | ----------- | ||
142 | |||
143 | So, what will this variation of skang look like? For a start, the | ||
144 | syntax will have to be more Lua like, so that's a real basic change. | ||
145 | Can't use a space as an argument separator, Lua allows only ',' and | ||
146 | ';'. Strings can still use single or double quotes. | ||
147 | |||
148 | The magic "_123" system I used before to specify "position / size in | ||
149 | characters instead of pixels" just wont work in Lua. Using _ as a table | ||
150 | name with a meta table means that this syntax now becomes "_.123", which | ||
151 | is kinda acceptable. Note that _.123 is syntax sugar for _["123"], so | ||
152 | I'm not sure if using a number there works. An alternative is to just | ||
153 | use a string - | ||
154 | |||
155 | foo = widget.label(0, "1", 100, 0, 'Text goes here") | ||
156 | |||
157 | Uses as many characters, and ends up being a value instead of an index, | ||
158 | which is the right thing to do. While on this subject, anything less | ||
159 | than 1, but more than 0, can be used as a percentage, maybe combined | ||
160 | with "character" mode (this is a new thing) - | ||
161 | |||
162 | foo = widget.label(0, "0.1", 0.5, 0, 'Text goes here") | ||
163 | |||
164 | This could even allow relative placement as mentioned in the skang TODO - | ||
165 | |||
166 | foo = widget.label(0, "otherWidget+0.1", 0.5, 0, 'Text goes here") | ||
167 | |||
168 | |||
169 | "widget" would be a table with functions for dealing with widgets. It | ||
170 | would include metatable stuff for widget set introspection. So | ||
171 | "widget.label" would introspect in our widget set for a widget type of | ||
172 | "label", and return a widget type table. So we could do - | ||
173 | |||
174 | foo = widget.label(0, "0.1", 0.5, 0, 'Text goes here :") | ||
175 | foo:colour(255, 255, 255, 0, 0, 100, 255, 0) | ||
176 | foo:hide() | ||
177 | foo:action("skang.load(some/skang/file.skang)") | ||
178 | |||
179 | Also allow access via table elements - | ||
180 | |||
181 | foo.action = "skang.load('some/skang/file.skang')" | ||
182 | foo.colour.r = 123 | ||
183 | foo.look('some/edje/file/somewhere.edj') | ||
184 | foo.help = 'This is a widget for labelling some foo.' | ||
185 | |||
186 | We can use the concat operator (..) to append things to widgets, like | ||
187 | adding choices in a drop down, rows in a grid, etc. | ||
188 | |||
189 | Hmm, need a skang table as well - | ||
190 | |||
191 | skang.module(Evas) | ||
192 | skang.module(Elementary) | ||
193 | skang.clear() | ||
194 | skang.load('some/skang/file.skang') | ||
195 | |||
196 | |||
197 | I don't think we need variable introspection as much, since in this case | ||
198 | Lua is both the skang and the underlaying language, the variables can | ||
199 | just be accessed directly. Not sure on this, need to experiment. This | ||
200 | is what we normally need variable introspection for - | ||
201 | |||
202 | foo = 'bar' -- Using the metatable to override '=' to set the actual value of the widget, say the text of a label or edit widget. | ||
203 | bar = foo -- The reverse of the above. Though perhaps these can't be done? | ||
204 | foo = foo .. 'stuff' .. 'more stuff' .. 'another line of the dropdown or whatever' | ||
205 | |||
206 | OK, first two can't be done, metatable only overides that for table elements. The third one can only be (I might be wrong there) - | ||
207 | |||
208 | foo.value = 'stuff' .. 'more stuff' | ||
209 | foo.value = foo.value .. 'another line of the dropdown or whatever' | ||
210 | |||
211 | Skang relied on the use of the set command to make sure that any | ||
212 | matching widgets and variables got updated. And the get command. | ||
213 | |||
214 | foo:set('stuff') | ||
215 | bar = foo:get() | ||
216 | |||
217 | On the other hand, given the module / package stuff mentioned below, and | ||
218 | some metatable magic, we could do - | ||
219 | |||
220 | local other = require('otherPackageName') | ||
221 | other.foo = 'stuff' | ||
222 | bar = other.foo | ||
223 | |||
224 | Sooo, how does that squeeze into a "skang" file? | ||
225 | |||
226 | #!skang myApp.skang -- This is Lua, so this might not work. | ||
227 | -- There's an implied local this = require('myApp') | ||
228 | -- There's an implied local skang = require('skang') | ||
229 | local widget = require('EvasWidgets') | ||
230 | local other = require('otherPackageName') | ||
231 | skang.clear | ||
232 | skang.window(200, 200, "G'day planet.") | ||
233 | quitter = widget.button('Quit', 0.5, 0.5, 0.5, 0.5) | ||
234 | quitter:action('quit') -- 'quit' is looked up in ThingSpcae.commands, and translated into the Lua 'skang.quit()'. | ||
235 | other.foo = 'stuff' | ||
236 | this.bar = other.foo | ||
237 | |||
238 | |||
239 | Original Skang infrastructure | ||
240 | ----------------------------- | ||
241 | |||
242 | Skang starts with a Thing as the base. In Java it's a base object for | ||
243 | everything else, with a bunch of methods and elements. We can probably | ||
244 | use a Thing metatable and replicate most of it. The widget used in the | ||
245 | previous section is built on top of Thing. Things are stored in | ||
246 | ThingSpace, which is a BonsaiTree of LeafLike Things. Java's version of | ||
247 | multiple inheritance was used. Commands are a Thing. | ||
248 | |||
249 | ThingSpace is per users session. classCache stores cached class | ||
250 | lookukps, command stores commands, module stores loaded modules, param | ||
251 | stores variables and their values, widget stores widgets and their value | ||
252 | / state. | ||
253 | |||
254 | Skanglet is a generated mapping between actual methods / variables in a | ||
255 | class, and skang. Each method or variable that ends up in the skanglet | ||
256 | was marked by special javadoc tags. It also included some meta data | ||
257 | like version and the default skang. For variables it defined - | ||
258 | |||
259 | "Name", "Field/Method()", "Required", "Shortcut", "Default", "Help text" | ||
260 | |||
261 | ... and for methods - | ||
262 | |||
263 | "Name", "Method", "Syntax", "Help text" | ||
264 | |||
265 | In both cases the "Name" was the skang name, it could be different from | ||
266 | the Java name specified in the second field. Likely we can do away with | ||
267 | the need to generate these skanglet files, and just add stuff to the | ||
268 | Thing. Modules wrap Skanglets, and takes care of loading them into ThingSpace. | ||
269 | |||
270 | Module are used for - | ||
271 | loading the Skanglet for the Thing currently running (match java class name to skang file name). | ||
272 | loading the AWT interface in skang files. | ||
273 | loading OTHER skanglet based Things | ||
274 | loading Squeal, StuffSkang, and Who from java when needed. | ||
275 | |||
276 | So in Lua, we can use the package system. First require(moduleName) to | ||
277 | load up the skang module. Require can return a table, the Lua package | ||
278 | called ends with "return someTable". See LuaLSL for an example. This | ||
279 | package is actually run, so it can figure out what to put in the | ||
280 | returned table. So for instance it could use inlined methods and such - | ||
281 | |||
282 | local skang = require('skang') | ||
283 | local result = {}; | ||
284 | result.author = 'onefang' | ||
285 | result.version = '0.72 alpha 2004-11-19 16:28:00' | ||
286 | local foo | ||
287 | -- The first argument would be the name of a local variable / method. Which could be accessed via _G? | ||
288 | -- Not sure if we could use a global foo, AND use it directly. | ||
289 | result.foo = skang.newParam('foo', "Required", "Shortcut", "Default", "Help text") | ||
290 | result.func = skang.newCommand('arg1_type,arg2_type', 'Help Text', function (arg1, arg2) | ||
291 | ... | ||
292 | end) | ||
293 | return result; | ||
294 | |||
295 | |||
296 | Stuff is the base class used to track database rows and other multi | ||
297 | value things. Would still need to deal with variable sub things, though | ||
298 | that's likely just using tables. SquealStuff is the database version, | ||
299 | using Squeal as the database driver wrapper. Squeal could wrap | ||
300 | esskyuehl? | ||
301 | |||
302 | |||
303 | The pre tokenized structure thingy I had planned in the TODO just wont | ||
304 | work, as it uses symbols. On the other hand, we will be using Lua | ||
305 | tables anyway. B-) | ||
306 | |||
307 | |||
308 | NAWS | ||
309 | ---- | ||
310 | |||
311 | NAWS was always planned, but never actually written. Though some stuff | ||
312 | was kinda prototyped, especially UberMatrix stuff. I think this time | ||
313 | around, NAWS should be written in C, based on pure Evas + Edje. Perhaps | ||
314 | with direct support for introspection? After EO settles down, I might | ||
315 | use that to. | ||
316 | |||
317 | |||
318 | Edje_Lua notes | ||
319 | -------------- | ||
320 | |||
321 | Edje_Lua is sandboxed firmly inside of edje files. This makes it | ||
322 | unsuitable for our use, as we want to step outside that sandbox. | ||
323 | However, we still want to wrap Lua around EFL stuff, preferably using | ||
324 | the same API. Raster fought against using this new eolian stuff to | ||
325 | generate edje_lua2.c, and seems to be against having a "no sandbox" flag | ||
326 | in edje_lua2.c. For now I'll let q66 go ahead with his Edje Lua via | ||
327 | LuaJIT FFI conversion that uses a variation of eolian written in Lua. | ||
328 | Seems like much more work than my way of doing it. shrugs | ||
329 | |||
330 | Unfortunately, this might not be ready soon enough for me, AND it might | ||
331 | not even be suitable. While I agree that LuaJIT FFI stuff might be a | ||
332 | good idea, if I read the docs correctly FFI simply wraps around C | ||
333 | headers and libraries directly, making it less suitable for sandboxes | ||
334 | and other environments where you want to wrap those library functions | ||
335 | differently. | ||
336 | |||
337 | So, I might have to go ahead with my own plan anyway. On the other | ||
338 | hand, for skang, I want to wrap things a bit differently. Might be best | ||
339 | to do that wrapping C side. In other words, the skang and widget Lua | ||
340 | packages get written in C, and are different from edje_lua2.c. | ||
341 | |||
342 | On the gripping hand, there might be use in including edje_lua2.c style | ||
343 | bindings in GuiLua as an edje package, evas package, elementary package, | ||
344 | etc. This could be done by going ahead with my plans to modify | ||
345 | edje_lua2.c to include the "no sandbox" flag, then compile it with that | ||
346 | flag turned on to produce a standard Lua package. Then get eolian to | ||
347 | produce evas_lua.c, elementary_lua.c, etc. | ||
348 | |||
349 | Another idea worth investigating is to rewrite edje_lua2.c to use | ||
350 | introspection directly to figure out it's "combined set and get" style | ||
351 | bindings. | ||
352 | |||
353 | |||
354 | Introspected EFL notes | ||
355 | ---------------------- | ||
356 | |||
357 | See below for the basic EO notes, where I come to the conclusion that | ||
358 | the other EFL devs wont be adding introspection to EO themselves. It's | ||
359 | all too hard they say. Pffft | ||
360 | |||
361 | So, I might have to do this myself, call it "entro".... | ||
362 | |||
363 | Write a patch against eolian that outputs introspection data. That data | ||
364 | is C code for a hash of EO class names. Each hash points to a data | ||
365 | structure that includes a hash of method names for that class, and a | ||
366 | pointer to the class description. Each of those hashes points to a data | ||
367 | structure that includes an array of argument types and names. The | ||
368 | method ID should be in that structure to, and maybe even the doc text. | ||
369 | Might even include an Eo internal data structure that links Op IDs to | ||
370 | that method structure (I dunno what they call that). The final output | ||
371 | is a library of that C code, that includes functions for doing the | ||
372 | actual introspection. | ||
373 | |||
374 | See? Not to hard at all, all described in a paragraph. lol | ||
375 | |||
376 | One function we could include is a way to "compile" eo_do arguments. | ||
377 | That would be an array (va_list actually) of method ID's followed by the | ||
378 | arguments for that method. Some of those arguments might be pointers to | ||
379 | memory structures, so this is not suitable for storing on disk. | ||
380 | Instead, it could be used for "compiling" commonly used code or hot | ||
381 | paths to get the introspection overhead out of the way early. Could | ||
382 | also compile parameterized versions, with numbered place holders that | ||
383 | get filled in later. Certainly we need a Lua interface to eo_do of some | ||
384 | sort. | ||
385 | |||
386 | In the same way that Java skang cached the results of introspection in | ||
387 | ThingSpace.CLASS, we could use cache introspection lookups to speed | ||
388 | things up. Not a great saving, one hash lookup versus two. Caching the | ||
389 | "class.method" string that points to the method structure for any method | ||
390 | we have used already. | ||
391 | |||
392 | NAWS could use the compile function to create eo_do commands needed to | ||
393 | create each of it's widget types, and the window. Yes, I know, NAWS | ||
394 | only has two "widget types". B-) | ||
395 | |||
396 | |||
397 | For quick and dirty early testing, I'll probably write a widget package | ||
398 | that has hard coded mappings between some basic "label", "button", etc. | ||
399 | and ordinary elementary widgets. Proper introspection can come later. | ||
400 | |||
401 | |||
402 | LuaJIT FFI notes | ||
403 | ---------------- | ||
404 | |||
405 | LuaJIT 2.0 FFI needs to have cleaned up versions of C header files | ||
406 | included in the Lua scripts that use it. This is messy. Version 2.1 | ||
407 | (or perhaps 3.0) has on it's road map to include a C pre processor, | ||
408 | which should help that problem. | ||
409 | |||
410 | |||
411 | EO notes | ||
412 | -------- | ||
413 | |||
414 | tl;dr - eo introspection doesn't actually exist, even though it was | ||
415 | "promised" years ago, but looks trivial to add. On the other hand, the | ||
416 | other EFL devs seem to be fighting against it, so I might need to write | ||
417 | my own. sigh | ||
418 | |||
419 | object = eo_add(EVAS_OBJ_LINE_CLASS, canvas); | ||
420 | evas_line.eo.h -> #define EVAS_OBJ_LINE_CLASS evas_obj_line_class_get() | ||
421 | -> const Eo_Class *evas_obj_line_class_get(void) EINA_CONST; | ||
422 | evas_line.eo.c -> EO_DEFINE_CLASS(evas_obj_line_class_get, &_evas_line_class_desc, EVAS_OBJ_CLASS, NULL); | ||
423 | Eo.h -> EO_DEFINE_CLASS is a macro that basically wraps eo_class_new(), and returns it's result. | ||
424 | |||
425 | So Eo_Class is the type of a class, but it's A) opaque, B) deprecated! | ||
426 | It includes a pointor to the Eo_Class_Description, which includes the | ||
427 | actual name. I'm not seeing anywhere the names of the get/set | ||
428 | paramaters being passed into the system, or any way to look up a class | ||
429 | based on name. Not even a way to get to the public Eo_Class_Description | ||
430 | from the opaque Eo_Class. | ||
431 | |||
432 | Eo_Class_Description is at least public. It includes | ||
433 | Eo_Op_Description's and Eo_Event_Description's. Eo_Op_ and Eo_Event_ | ||
434 | include the name and documentation of the op / event. The macro used to | ||
435 | generate Eo_Op_ does NOT pass the name, just the ID number as a string. | ||
436 | There is also Eo_Op_Func_Description, which does not include a name, it | ||
437 | seems to be generated in the constructor. The same Eo_Op_ ID number is | ||
438 | used to index it. Seems to be no direct link between Eo_Class and | ||
439 | Eo_Op_func_, just the same Eo_Op_ ID numbers used internally somehow. | ||
440 | |||
441 | eo_do(obj, evas_obj_line_xy_set(200, 200, 300, 300)); | ||
442 | evas_line.eo.h -> #define evas_obj_line_xy_set(x1, y1, x2, y2) EVAS_OBJ_LINE_ID(EVAS_OBJ_LINE_SUB_ID_XY_SET), EO_TYPECHECK(Evas_Coord , x1), EO_TYPECHECK(Evas_Coord , y1), EO_TYPECHECK(Evas_Coord , x2), EO_TYPECHECK(Evas_Coord , y2) | ||
443 | #define EVAS_OBJ_LINE_ID(sub_id) (EVAS_OBJ_LINE_BASE_ID + sub_id) | ||
444 | extern EAPI Eo_Op EVAS_OBJ_LINE_BASE_ID; | ||
445 | |||
446 | enum | ||
447 | { | ||
448 | EVAS_OBJ_LINE_SUB_ID_XY_SET, | ||
449 | EVAS_OBJ_LINE_SUB_ID_XY_GET, | ||
450 | EVAS_OBJ_LINE_SUB_ID_LAST | ||
451 | }; | ||
452 | evas_line.eo.c -> EAPI Eo_Op EVAS_OBJ_LINE_BASE_ID = EO_NOOP; | ||
453 | static void _gen_evas_line_class_constructor(Eo_Class *klass) | ||
454 | { | ||
455 | const Eo_Op_Func_Description func_desc[] = { | ||
456 | EO_OP_FUNC(EO_BASE_ID(EO_BASE_SUB_ID_CONSTRUCTOR), _eo_obj_evas_line_constructor), | ||
457 | EO_OP_FUNC(EVAS_OBJ_LINE_ID(EVAS_OBJ_LINE_SUB_ID_XY_SET), _eo_obj_evas_line_xy_set), | ||
458 | EO_OP_FUNC(EVAS_OBJ_LINE_ID(EVAS_OBJ_LINE_SUB_ID_XY_GET), _eo_obj_evas_line_xy_get), | ||
459 | EO_OP_FUNC_SENTINEL | ||
460 | }; | ||
461 | eo_class_funcs_set(klass, func_desc); | ||
462 | } | ||
463 | |||
464 | static void | ||
465 | _eo_obj_evas_line_xy_set(Eo *obj, void *_pd, va_list *list) | ||
466 | { | ||
467 | Evas_Coord x1 = va_arg(*list, Evas_Coord); | ||
468 | Evas_Coord y1 = va_arg(*list, Evas_Coord); | ||
469 | Evas_Coord x2 = va_arg(*list, Evas_Coord); | ||
470 | Evas_Coord y2 = va_arg(*list, Evas_Coord); | ||
471 | _evas_line_xy_set(obj, _pd, x1, y1, x2, y2); | ||
472 | } | ||
473 | |||
474 | void _evas_line_xy_set(Eo *obj, Evas_Line_Data *pd, Evas_Coord x1, Evas_Coord y1, Evas_Coord x2, Evas_Coord y2); | ||
475 | |||
476 | evas_object_line.c -> EOLIAN static void _evas_line_xy_set(Eo *eo_obj, Evas_Line_Data *_pd, Evas_Coord x1, Evas_Coord y1, Evas_Coord x2, Evas_Coord y2) | ||
477 | |||
478 | |||
479 | Evas_Object_Line *o = eo_data_scope_get(obj, EVAS_OBJ_LINE_CLASS); | ||
480 | Evas_Object_Line *o = eo_data_ref(obj, EVAS_OBJ_LINE_CLASS); | ||
481 | |||
482 | |||
483 | .. evas_line.eo | ||
484 | |||
485 | class Evas_Line (Evas_Object) | ||
486 | { | ||
487 | legacy_prefix: evas_object_line; | ||
488 | eo_prefix: evas_obj_line; | ||
489 | properties { | ||
490 | xy { | ||
491 | set { | ||
492 | /*@ | ||
493 | @since 1.8 | ||
494 | |||
495 | Sets the coordinates of the end points of the given evas line object. */ | ||
496 | } | ||
497 | get { | ||
498 | /*@ | ||
499 | Retrieves the coordinates of the end points of the given evas line object. | ||
500 | second end point. */ | ||
501 | } | ||
502 | values { | ||
503 | Evas_Coord x1; /*@ The X coordinate of the first point. */ | ||
504 | Evas_Coord y1; /*@ The Y coordinate of the first point. */ | ||
505 | Evas_Coord x2; /*@ The X coordinate of the second point. */ | ||
506 | Evas_Coord y2; /*@ The Y coordinate of the second point. */ | ||
507 | } | ||
508 | } | ||
509 | } | ||
510 | implements { | ||
511 | Eo_Base::constructor; | ||
512 | } | ||
513 | |||
514 | } | ||
515 | |||
516 | ... evas_line.eo.c | ||
517 | |||
518 | EAPI void | ||
519 | evas_object_line_xy_set(Evas_Object *obj, Evas_Coord x1, Evas_Coord y1, Evas_Coord x2, Evas_Coord y2) | ||
520 | { | ||
521 | eo_do((Eo *) obj, evas_obj_line_xy_set(x1, y1, x2, y2)); | ||
522 | return ; | ||
523 | } | ||
524 | |||
525 | |||
526 | static const Eo_Class_Description _evas_line_class_desc = { | ||
527 | EO_VERSION, | ||
528 | "Evas_Line", | ||
529 | EO_CLASS_TYPE_REGULAR, | ||
530 | EO_CLASS_DESCRIPTION_OPS(&EVAS_OBJ_LINE_BASE_ID, _evas_line_op_desc, EVAS_OBJ_LINE_SUB_ID_LAST), | ||
531 | _evas_line_event_desc, | ||
532 | sizeof(Evas_Line_Data), | ||
533 | _gen_evas_line_class_constructor, | ||
534 | NULL | ||
535 | }; | ||
536 | |||
537 | |||
538 | skang vs edje vs LL shit | ||
539 | ------------------------ | ||
540 | |||
541 | EDJE | ||
542 | Verbose, complex. | ||
543 | Used to place and decorate widget parts. | ||
544 | Can be used to place entire widgets through externals and swallows. | ||
545 | Basic parts relative to each other. | ||
546 | Signals and messages. | ||
547 | Embryo scripts. | ||
548 | Lua scripts (sandboxed). | ||
549 | |||
550 | |||
551 | SKANG | ||
552 | Tight, simple. | ||
553 | Used to place widgets, and describe actions. | ||
554 | Can include some really basic scripting. | ||
555 | Widgets in a fixed position, but included stuff for relative placement in the TODO. | ||
556 | Automated associations between widget name and variable (and method?) via introspection. | ||
557 | Actions. | ||
558 | Looks (could easily be extended to edje groups). | ||
559 | Extensible. | ||
560 | Can be used to pass values around. | ||
561 | |||
562 | |||
563 | LL SHIT | ||
564 | Verbose, even worse, XML, more crap than is needed. | ||
565 | Menus. | ||
566 | Windows with widgets relative to each other. | ||
567 | Basically nested rectangles. | ||
568 | Manual association of widgets to methods. | ||
569 | Can include tool tip string, enabled, visible, hover cursor, bounding rectangle?, mouse opaque?, tab groups, font (name, size, style, and alignment). | ||
570 | More stuff, typically hidden in the OO somewhere. sigh | ||
571 | Generally uses fixed image and colour names, which skins overide. | ||
572 | Skins can also overide the XML files. | ||
573 | Translations provide override XML files that need only override the text bits. | ||
574 | |||
575 | |||
576 | old notes | ||
577 | --------- | ||
578 | |||
579 | See if it's possible to disable the Emerald/Phoenix/Firestorm LSL bridge | ||
580 | when connecting to OpenSim. Actually, they finally came to their senses | ||
581 | and support OpenSim now, so that should be sorted already. | ||
diff --git a/docs/ClientHamr/README.IAE b/docs/ClientHamr/README.IAE new file mode 100644 index 0000000..8c0e46c --- /dev/null +++ b/docs/ClientHamr/README.IAE | |||
@@ -0,0 +1,3 @@ | |||
1 | Refer to - http://www.infinitegrid.org/drupal/content/InworldAnimationEditor | ||
2 | |||
3 | IAE is an idea to put an animation editor in world, much like the link set editor. | ||
diff --git a/docs/ClientHamr/README.XMPP b/docs/ClientHamr/README.XMPP new file mode 100644 index 0000000..53058b2 --- /dev/null +++ b/docs/ClientHamr/README.XMPP | |||
@@ -0,0 +1,4 @@ | |||
1 | Viewer integration with XMPP, and using it for as many services as it can. | ||
2 | |||
3 | XMPP / jabber is a good protocol to base presence, IM, groups, and other | ||
4 | related stuff on. We should do so. | ||
diff --git a/docs/ClientHamr/README.bGod b/docs/ClientHamr/README.bGod new file mode 100644 index 0000000..ec48d61 --- /dev/null +++ b/docs/ClientHamr/README.bGod | |||
@@ -0,0 +1,5 @@ | |||
1 | A front end to grid admin tools, though generally OS/SL specific tools. | ||
2 | |||
3 | The name is a reference to SL's god mode, and the Men at Work song "Be | ||
4 | Good Johnny", which itself is a reference to Chuck Berry's "Johnny B. | ||
5 | Goode". | ||
diff --git a/docs/ClientHamr/README.extantz b/docs/ClientHamr/README.extantz new file mode 100644 index 0000000..5fb1d5f --- /dev/null +++ b/docs/ClientHamr/README.extantz | |||
@@ -0,0 +1,24 @@ | |||
1 | Extantz is the main virtual world front end. Also, during this | ||
2 | experimental phase of development, this will be a test bed for all the | ||
3 | GUI stuff. Eventually lots of it will be split off to separate | ||
4 | programs. | ||
5 | |||
6 | Extantz is a made up word. The challenge was to find a word beginning | ||
7 | with E, is as traditional with EFL (Enlightenment Foundation Library) | ||
8 | projects, that has not been done to death, and thus has some reasonable | ||
9 | chance to turn up in google searches. It also helps if it somehow or | ||
10 | other reflects what the project actually is. lol | ||
11 | |||
12 | Extant means "still existing, surviving", or the more archaic meaning, | ||
13 | from it's original Latin roots "standing out, be visible, exist". | ||
14 | |||
15 | Extent means "an area or volume, the range over which a thing extends" | ||
16 | among other things. | ||
17 | |||
18 | So I hope to invoke thoughts of a volume that exists and stands out. In | ||
19 | other words, virtual worlds. Meh, I'm not that artsy, it needed a name. | ||
20 | lol | ||
21 | |||
22 | Extantz will handle all the 3D rendering. The other parts can use nails | ||
23 | to control the world that is rendered, and GuiLua to present their UI | ||
24 | on top of the rendered world. | ||
diff --git a/docs/ClientHamr/README.libpurple b/docs/ClientHamr/README.libpurple new file mode 100644 index 0000000..4e14b9b --- /dev/null +++ b/docs/ClientHamr/README.libpurple | |||
@@ -0,0 +1,4 @@ | |||
1 | Viewer integration with libpurple, using it for generic IM services. | ||
2 | |||
3 | Libpurple is a modular IM system, we could just add a libpurple based IM | ||
4 | system to the viewer, and use that for the XMPP integration. | ||
diff --git a/docs/ClientHamr/README.mumble b/docs/ClientHamr/README.mumble new file mode 100644 index 0000000..1010f18 --- /dev/null +++ b/docs/ClientHamr/README.mumble | |||
@@ -0,0 +1,5 @@ | |||
1 | Viewer integration with mumble and whisper, and using it for as many | ||
2 | audio services as it can. | ||
3 | |||
4 | Mumble is a voice system designed for networked 3D game usage. Sounds | ||
5 | perfect, just what we need. B-) | ||
diff --git a/docs/ClientHamr/README.woMan b/docs/ClientHamr/README.woMan new file mode 100644 index 0000000..1b3bbe0 --- /dev/null +++ b/docs/ClientHamr/README.woMan | |||
@@ -0,0 +1,148 @@ | |||
1 | WoMan is a virtual world account and viewer manager, mostly of the SL | ||
2 | (Second Life) variety since that's my focus. Most SL style virtual | ||
3 | world viewers can be invoked with options to start them logging on, and | ||
4 | skipping the login screen. So this project aims to be that login | ||
5 | screen, doing all the things that can be done from the meta-impy login | ||
6 | screen, plus more. Once the user hits the login button, woMan figures | ||
7 | out what parameters to pass to what viewer, then starts it up and gets | ||
8 | out of the way. Following the ClientHamr philosophy of breaking the | ||
9 | viewer up into modules that do simpler tasks, and do them well. So that | ||
10 | means that meta-impy will eventually loose it's login screen, to be | ||
11 | replaced by woMan. | ||
12 | |||
13 | WoMan starts off looking like any other viewers login screen, showing | ||
14 | the login page of the default, or last visited grid, a small menu at the | ||
15 | top with the usual functions, and the usual login buttons at the bottom. | ||
16 | Added to that will be a better grid manager, with proper user | ||
17 | management, suitable for people with more than one account per grid. | ||
18 | The user will have the ability to choose a virtual world viewer to be | ||
19 | the default, and even to associate a particular viewer with a particular | ||
20 | grid. This is useful, for instance, for grids that have their own | ||
21 | custom viewers, but the user wants to use a more generic viewer for all | ||
22 | the other grids. Or if the user wants to use one viewer for OpenSim | ||
23 | grids, but another for LL (Linden Labs) grids. Coz perhaps their chosen | ||
24 | viewer is not TPVP (Third Party Viewer Policy, an LL thing) compliant, | ||
25 | and LL are just more anal than the rest of the universe. | ||
26 | |||
27 | NOTE: since I started this, LL in their *cough* infinite wisdom *cough*, | ||
28 | decided that support of OpenSIm was a Really Bad Thing, so their viewers | ||
29 | are no longer capable of dealing with other grids. LL have even gone as | ||
30 | far as try to get other viewers to not support other grids. As far as | ||
31 | woMan is concerned, this just means that LL viewers, and viewers that | ||
32 | drank the LL koolaid, are less functional. shrugs | ||
33 | |||
34 | The grid manager will also include some sort of search capability, as is | ||
35 | currently being discussed by various people in the OpenSim universe. | ||
36 | There might even be several search systems in place, so supporting | ||
37 | existing ones, and the ability to add more might be useful. WoMan | ||
38 | should be the only thing registered to handle hop:// and other such URLs | ||
39 | in whatever web browsers you are using. Though most viewers want to | ||
40 | register themselves, so tends to be that which ever one you started up | ||
41 | last, or first, gets that privilege. That's a whole can of worms, sane | ||
42 | policy and code should help. | ||
43 | |||
44 | It might be useful to have woMan be able to download viewers, | ||
45 | including checking for updates and offering to download them. As well | ||
46 | as updates to common things like viewer tag definition files. | ||
47 | |||
48 | WoMan, unlike the LL viewer code base, will be designed for relogging. | ||
49 | Once the viewer it starts quits (or crashes), WoMan, which was still | ||
50 | running, can pop again and let the user relog, or log to some other | ||
51 | grid, or same grid as different a user, or even same grid as same user | ||
52 | with a different viewer. | ||
53 | |||
54 | Viewers can be made woMan aware, like meta-impy will be (since it's | ||
55 | handing it's login screen functionality to woMan). A few more things | ||
56 | make sense to be added in this case. For instance, you might want to | ||
57 | have some or all of your LMs (LandMarks) be usable at the log in | ||
58 | screen, so you can log directly to them. The user might want the choice | ||
59 | when they HG (HyperGrid teleport) to actually start up a new viewer and | ||
60 | just login to the other grid instead (if they already have an account | ||
61 | there). While HGed to some new grid, the user might want to add that | ||
62 | grid to the woMan grid manager at a simple click of a button, perhaps | ||
63 | complete with an LM for their current position. The grid searching | ||
64 | capabilities mentioned earlier might be needed while in world. | ||
65 | Certainly the grid manager functions in meta-impy will be handled by | ||
66 | woMan, even if in world. | ||
67 | |||
68 | In order to display the login page of a grid, which is a web page, a web | ||
69 | browser will be built into woMan. It could be used to display web | ||
70 | pages within an woMan aware viewer. Though perhaps not for MOAP | ||
71 | (Media On A Prim), unless woMan grows the ability to incorporate | ||
72 | itself into the viewers 3D landscape as part of a prim. Which is a good | ||
73 | idea, then meta-impy no longer needs a web browser. Though other things | ||
74 | in the viewer are implemented as web pages, and LL are moving more stuff | ||
75 | to the web. | ||
76 | |||
77 | One of the things on the login screen is the menu option to start up the | ||
78 | preferences window and change the viewers preferences. Viewers use XML | ||
79 | files that not only store the preferences, but also a description of | ||
80 | them. The preferences window and it's various parts are also stored as | ||
81 | XML files. There is a bit missing that is in the viewer source code | ||
82 | that ties all of this together. So it might not be possible to do this | ||
83 | for all viewers. WoMan aware viewers can naturally provide the | ||
84 | missing bits to woMan, even if not running, or even pass that entire | ||
85 | functionality to woMan, just like meta-impy will do. | ||
86 | |||
87 | For the purposes of keeping resource usage low, it should be possible | ||
88 | for the user to configure woMan to go away when it starts a viewer. | ||
89 | Might be a good idea even for woMan aware viewers, that can start it | ||
90 | up again if it's functionality is needed while in world. Note this "go | ||
91 | away" means to stop running and free up any resources it was using; | ||
92 | which is different from the "gets out of the way" it usually does, still | ||
93 | running, just not on screen. | ||
94 | |||
95 | |||
96 | The problem with the web. | ||
97 | ------------------------- | ||
98 | |||
99 | At least that's the theory. In practice, a web browser takes up almost | ||
100 | one third of the viewer, and is only used for three things. Login | ||
101 | pages, simple built in browser window, and MOAP (Media On A Prim). For | ||
102 | the first two full blown web browsers are massive overkill. MOAP is not | ||
103 | supported by meta-impy yet anyway. | ||
104 | |||
105 | WebKit is a pain to compile at the moment, for reasons I wont go into | ||
106 | right now. At the opposite of the spectrum is dillo, which is not quite | ||
107 | up to spec enough for login pages that have fancy stuff. There does not | ||
108 | appear to be any middle ground. So right now, I'll work on using random | ||
109 | web browsers as external windows. That will suffice for everything but | ||
110 | MOAP, which I can leave until later. Just discovered netsurf, a little | ||
111 | smaller than dillo, but perhaps better featured? Might be useful. | ||
112 | |||
113 | The web is a bloated mess, so it's not surprising that a fully featured | ||
114 | web browser component like WebKit is also a bloated mess. | ||
115 | |||
116 | |||
117 | Design. | ||
118 | ------- | ||
119 | |||
120 | A thin window on the left. | ||
121 | |||
122 | Menus across the top. | ||
123 | View tabs. | ||
124 | Grids Accounts Viewers Landmarks | ||
125 | |||
126 | Grids tab is the grid manager, though you can also drill down / tree out | ||
127 | the accounts list per grid. | ||
128 | |||
129 | Accounts shows accounts, though can drill down to grid list per account. | ||
130 | Also consider launching thin viewers, text only ones and such. The | ||
131 | account view is almost a natural for extending into a IM style thingy. | ||
132 | |||
133 | Viewers lists the installed viewers, can install more, and allows | ||
134 | preferences editing. It can handle viewer installs, upgrades, even | ||
135 | compiling them from source. | ||
136 | |||
137 | Landmarks manages LMs from viewers, or log in spots, or SLURLs etc. | ||
138 | |||
139 | A user configurable web browser can open up to fill the right of the | ||
140 | screen. | ||
141 | |||
142 | Log file management features, including viewer stdout, check if only | ||
143 | Linux viewers do that. Including chat logs. | ||
144 | |||
145 | Dillo and uzbl can insert themselves into the windows of others. Should | ||
146 | check that out. Netsurf is allegedly easy to port to things, might be | ||
147 | able to port it to EFL. | ||
148 | |||
diff --git a/docs/ClientHamr/WindowSharing.txt b/docs/ClientHamr/WindowSharing.txt new file mode 100644 index 0000000..1ccd3bb --- /dev/null +++ b/docs/ClientHamr/WindowSharing.txt | |||
@@ -0,0 +1,84 @@ | |||
1 | EnLichtIrrnment. B-) | ||
2 | |||
3 | Elementary and Irrlicht don't like to share windows. | ||
4 | |||
5 | Irrlicht can be told to create a device from a pre existing window, but this is Windows only. | ||
6 | Perhaps it already works for Linux, just the docs are out of date? | ||
7 | It works, sorta. | ||
8 | |||
9 | IVideoDriver::getExposedVideoData() can provide a structure with raw OS level window pointers. | ||
10 | This implies that it's theoretically possible to create a device from things other than Windows windows. | ||
11 | Wont provide any valid info when using the software renderer. | ||
12 | |||
13 | Elementary can provide an Ecore_Wl_Window or an Ecore_X_Window of one of it's windows. elm_win_wl_window_get() and elm_win_xwindow_get(). | ||
14 | |||
15 | Ecore_evas can provide an Ecore_Window with ecore_evas_window_get(). | ||
16 | |||
17 | Ecore_X_Window ecore_x_window_new() | ||
18 | |||
19 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=2&t=31350&sid=0eb6d64c84ec7043fd48103f8e63e930 may help. A little. | ||
20 | |||
21 | |||
22 | "For using OpenGL with an Evas canvas, there is two possibilities in my | ||
23 | opinion. Either put the canvas in a texture and give it to the 3D | ||
24 | engine, or use EvasGL API and make the 3D engine integrate inside | ||
25 | Evas. It is possible to have a direct rendering path with EvasGL and | ||
26 | so have a fastest possible path. | ||
27 | -- | ||
28 | Cedric BAIL" | ||
29 | |||
30 | |||
31 | Apparently Irrlicht's method of providing an external window actually works. Mostly. - | ||
32 | |||
33 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=7&t=32647 | ||
34 | http://sourceforge.net/tracker/index.php?func=detail&aid=2655876&group_id=74339&atid=540676 | ||
35 | |||
36 | Though seems that bug was marked as a duplicate with the duplicate having a better patch, but NO FUCKING LINK to that duplicate. What a horrid bug tracker. | ||
37 | |||
38 | |||
39 | There is also this which gives clues -http://irrlicht.sourceforge.net/forum/viewtopic.php?f=9&t=26506 | ||
40 | |||
41 | |||
42 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=2&t=39872 | ||
43 | http://irrlicht.sourceforge.net/forum//viewtopic.php?t=39719 | ||
44 | |||
45 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=9&t=35197 | ||
46 | |||
47 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=2&t=46087 | ||
48 | |||
49 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=9&t=42450 | ||
50 | |||
51 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=9&t=35251 | ||
52 | |||
53 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=5&t=15338 | ||
54 | http://irrlicht.sourceforge.net/forum//viewtopic.php?f=7&t=12697 | ||
55 | |||
56 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=5&t=44599 | ||
57 | |||
58 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=5&t=18941 I think is ancient and might just be similar to what's in there already. | ||
59 | |||
60 | --------------------------------------------------------- | ||
61 | |||
62 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=4&t=26141 | ||
63 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=4&t=33845 | ||
64 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=4&t=35984 | ||
65 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=4&t=34527 | ||
66 | |||
67 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=4&t=38656 may be of some interest. | ||
68 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=4&t=30943 | ||
69 | http://irrlicht.sourceforge.net/forum/viewtopic.php?f=4&t=46983 where the question I want is not answered. | ||
70 | |||
71 | --------------------------------------------------------- | ||
72 | |||
73 | I could run sed over COpenGLDriver.cpp to turn it into CEvasGLDriver.cpp, then tweak it a bit. | ||
74 | |||
75 | evas_gl_make_current(gld->evasgl, gld->sfc, gld->ctx); | ||
76 | glFoo() -> glapi->glFoo() | ||
77 | |||
78 | |||
79 | Hmm, there will be some source files with random gl() calls, and I'd | ||
80 | need to tweak a few other things to suit. So this wont be a clean "just | ||
81 | drop in this source file" patch. B-( | ||
82 | |||
83 | Probably a lot easier to just figure out what what brand of glue to use | ||
84 | to get Irrlicht using Evas created GL surface and context. | ||
diff --git a/docs/README.Bookie b/docs/README.Bookie new file mode 100644 index 0000000..1a49f27 --- /dev/null +++ b/docs/README.Bookie | |||
@@ -0,0 +1,33 @@ | |||
1 | Shared dynamic libraries is a bit of an issue for cross platform code. | ||
2 | LL viewers deal with it by including their own copies of the libraries | ||
3 | they use. This bypasses the idea of sharing them, and thus uses too | ||
4 | much resources. On the other hand, it seems to be the Windows way of | ||
5 | doing things, lots of Windows packages I have seen include their own | ||
6 | copies of libraries. Mac Os X seems to do the same, each application is | ||
7 | installed as it's own directory, filled with it's own copies of | ||
8 | libraries. Not a lot of sharing going on. Linux and the BSDs do the | ||
9 | right thing, most libraries are actually shared. Except that LL viewers | ||
10 | STILL bring their own libraries. | ||
11 | |||
12 | I think the main difference is having a proper package management | ||
13 | system. Apt, RPM, and portage (I think) can track dependencies on | ||
14 | libraries, install the libraries automatically, and even have different | ||
15 | versions of libraries installed side by side. Without this, the OS has | ||
16 | no official way of tracking library dependencies, so every one has to | ||
17 | supply their own. Sure Mac OS X has had a few package systems ported to | ||
18 | it, but none of them are the official one, so developers can't rely on | ||
19 | them. | ||
20 | |||
21 | SledjHamr has to deal with this, and try to do so in some sort of smart | ||
22 | way. As usual, the right way to do things is generally to do the | ||
23 | opposite of what LL does. lol | ||
24 | |||
25 | Bookie should be a sub system that probes the OS, trying to see if | ||
26 | there's some sort of OS store of libraries, and try to find reasonable | ||
27 | versions of the libraries needed in that. If not found, it could invoke | ||
28 | an OS specific method of installing a suitable library. If that fails, | ||
29 | it can download a SledjHamr specific version into the SledjHamr | ||
30 | installed directory. So it tries to do the right thing first, and | ||
31 | gradually fallsback to doing the wrong thing like LL does. | ||
32 | |||
33 | That's the theory, in practice, gonna be a pain. | ||
diff --git a/docs/README.HamrSpace b/docs/README.HamrSpace new file mode 100644 index 0000000..a2e19cf --- /dev/null +++ b/docs/README.HamrSpace | |||
@@ -0,0 +1 @@ | |||
Inventory server. | |||
diff --git a/docs/README.Lspace b/docs/README.Lspace new file mode 100644 index 0000000..a86de96 --- /dev/null +++ b/docs/README.Lspace | |||
@@ -0,0 +1 @@ | |||
Sim contents server, which is pretty much a web server. | |||
diff --git a/docs/README.LuaSL b/docs/README.LuaSL new file mode 100644 index 0000000..1444948 --- /dev/null +++ b/docs/README.LuaSL | |||
@@ -0,0 +1,100 @@ | |||
1 | Refer to - http://www.infinitegrid.org/drupal/content/LuaSL_New_scripting_engine | ||
2 | |||
3 | LuaSL is a Lua based LSL scripting engine that will aim for LSL | ||
4 | compatability first, then adding Lua extensions. It aims to replace the | ||
5 | woeful XEngine from OpenSim, and at a later stage, be the basis for a | ||
6 | client side scripting engine. | ||
7 | |||
8 | To compile this, you will need Enlightenment Foundation Libraries (EFL) | ||
9 | installed in either /opt/e17 or /usr. These are typical places it get's | ||
10 | installed in. You will also need flex. The rest of the dependencies | ||
11 | are in the ../libraries directory. | ||
12 | |||
13 | |||
14 | Design. | ||
15 | ------- | ||
16 | |||
17 | The basic design will be made up as I go along, but so far I have this - | ||
18 | |||
19 | A parser parses an LSL script, validating it and reporting errors. | ||
20 | |||
21 | A translator takes the result of the parse, and converts it into Lua | ||
22 | source. Each LSL script becomes a Lua state. LSL states are handled as | ||
23 | Lua tables, with each LSL state function being a table function in a | ||
24 | common metatable. LL and OS functions are likely to be C or Lua | ||
25 | functions. Careful testing should be done with LuaJIT FFI, sandboxing, | ||
26 | and performance testing. | ||
27 | |||
28 | The Lua source is compiled by the Lua compiler. | ||
29 | |||
30 | LuaJIT is used as the Lua compiler, library, and runtime. | ||
31 | |||
32 | Luaproc is used to start up operating system threads and hand Lua states | ||
33 | between them. Luaproc messaging is also being used, but might need to | ||
34 | change to edje messaging. Note - luaproc has been extensively rewritten | ||
35 | for this project, mostly converting it to use EFL. That rewrite | ||
36 | substantially shrunk the source code. More might be rewritten in | ||
37 | future. | ||
38 | |||
39 | THIS IS WHERE WE ARE RIGHT NOW. | ||
40 | |||
41 | Nails will be used to pump commands in and out of the LuaSL system. | ||
42 | Incoming commands invoke LSL events via the LuaSL state metatable. LL | ||
43 | and OS functions that impact the world will be converted to nails | ||
44 | commands sent to the command pump. | ||
45 | |||
46 | Initialy, since this is the first thing being written, a nails command | ||
47 | pump client needs to be installed into OpenSim's C# stuff. Though it | ||
48 | might be possible to talk directly to ROBUST instead. Think I'll try | ||
49 | the ROBUST route, see how far I can get. That's the general principle | ||
50 | applying in all of this - try to avoid C# and see how for we can get. | ||
51 | lol | ||
52 | |||
53 | On the other hand, might be better to leverage the existing C# | ||
54 | implementations of LSL functions, just to get things up and running | ||
55 | quickly. To that end, a protocol involving exchanging snippets of Lua | ||
56 | over a network socket has been developed, and the next step is to write | ||
57 | the C# side. sigh | ||
58 | |||
59 | A watchdog thread should be used to make sure no LuaSL script spends | ||
60 | forever processing any event. | ||
61 | |||
62 | Some form of serialization will need to be created for saving script | ||
63 | state during shutdowns, passing script state to other threads / | ||
64 | processes / computers. Aparently Lua is good at this. | ||
65 | |||
66 | There will have to be a MySQL (and maybe SQLite) client in the system, | ||
67 | so we can talk directly to the local sim database. Esskyuehl may be | ||
68 | suitable, though it's still in the prototype stage. | ||
69 | |||
70 | Email, HTTP, and XML-RPC might need to be dealt with by us. A ROBUST | ||
71 | client will be needed to. Azy might be suitable, but it's also in | ||
72 | prototype. | ||
73 | |||
74 | An object is a file system directory, full of LSL scripts as text files, | ||
75 | notecards as text files, animations as BVH (or later BVJ) files, etc. | ||
76 | There will be some sort of metadata in place. This could be created by | ||
77 | our own OpenSim compatible cache module. | ||
78 | |||
79 | |||
80 | Test harness. | ||
81 | ------------- | ||
82 | |||
83 | I'll build a test harness. It will be based on EFL Edje Lua, with | ||
84 | buttons for triggering LSL events, SL style dialogs, and other goodies. | ||
85 | |||
86 | The initial goal will be to run standard MLP scripts. They have minimal | ||
87 | interface to the world, and exercise quite a bit of the rest of LSL. | ||
88 | They are also quite common, and sometimes responsible for a lot of the | ||
89 | script running load. | ||
90 | |||
91 | Later I should add stock standard OpenCollar scripts from SL. They are | ||
92 | a bitch to get working under OpenSim, so would be good compatability | ||
93 | tests. | ||
94 | |||
95 | Various eina logging domains might be used to handle whisper, say, shout, | ||
96 | etc. | ||
97 | |||
98 | Performance testing will have to be done on 5000 scripts, to see how | ||
99 | that compares against XEngine. | ||
100 | |||
diff --git a/docs/README.REST b/docs/README.REST new file mode 100644 index 0000000..2981827 --- /dev/null +++ b/docs/README.REST | |||
@@ -0,0 +1,2 @@ | |||
1 | REST is probaly good to apply to the web server part. Alice wants JSON | ||
2 | to, but see nails. | ||
diff --git a/docs/README.WTF b/docs/README.WTF new file mode 100644 index 0000000..67e55c7 --- /dev/null +++ b/docs/README.WTF | |||
@@ -0,0 +1,5 @@ | |||
1 | Refer to - http://www.infinitegrid.org/drupal/content/OMG_WTF_BBQ | ||
2 | |||
3 | This is where we deal with systems to keep track of where in the web | ||
4 | assets are, and to cache them. | ||
5 | |||
diff --git a/docs/README.libraries b/docs/README.libraries new file mode 100644 index 0000000..a26fda1 --- /dev/null +++ b/docs/README.libraries | |||
@@ -0,0 +1,31 @@ | |||
1 | There are some base libraries that should be used in common. Notable | ||
2 | the Enlightenment Foundation Libraries (EFL), Irrlicht, lemon, LuaJIT, | ||
3 | and luaproc. Other external open source projects that we just use | ||
4 | directly should go here to. Makes it easy to compile it all. | ||
5 | |||
6 | Note that in some cases, there might be changes. Such changes should be | ||
7 | documented, and marked with "// onefang changes". | ||
8 | |||
9 | EFL has been released, so not including that anymore. You can find it | ||
10 | in distro repos, PPA's, etc. Or http://enlightenment.org/ | ||
11 | |||
12 | Irrlicht has been slightly modified to get it to use externally created | ||
13 | GL stuff, and not use their internal copies of bzip, jpeglib, libpng, | ||
14 | and zlib. | ||
15 | |||
16 | Lemon is from http://www.hwaci.com/sw/lemon/. | ||
17 | |||
18 | LuaJIT 2.0 has been released for Ubuntu 13.04 and later, try using | ||
19 | https://launchpad.net/~mwild1/+archive/ppa for 12.04. Not including | ||
20 | that anymore. | ||
21 | |||
22 | luaproc has been hacked up a bit, and will continue to be hacked up. | ||
23 | Merged it into LuaSL, so it's no longer here. | ||
24 | |||
25 | -------------------------------------------------------------------- | ||
26 | |||
27 | These are the libraries written for the SledjHamr project. | ||
28 | |||
29 | LumbrJack is a library of logging stuff, coz every one wants to log. | ||
30 | |||
31 | Runnr is for running Lua scripts. Named (sorta) after a friend of mine. | ||
diff --git a/docs/README.nails b/docs/README.nails new file mode 100644 index 0000000..7db2662 --- /dev/null +++ b/docs/README.nails | |||
@@ -0,0 +1,9 @@ | |||
1 | Refer to - http://www.infinitegrid.org/drupal/content/Nails | ||
2 | |||
3 | Nails bangs it all together, mostly via the command pump. | ||
4 | |||
5 | |||
6 | Not sure where else to put this, but nails I think is the bit that | ||
7 | drives the network traffic the most - | ||
8 | |||
9 | http://gettys.wordpress.com/2013/07/10/low-latency-requires-smart-queuing-traditional-aqm-is-not-enough/ | ||