World: r3wp
[!REBOL3 GUI]
older newer | first last |
Maxim 5-Aug-2010 [2319] | Although I've implement 5 complete GUI frameworks, so far I've stayed relatively silent on the R3 GUI front cause I'm building my own framework and I don't want to interfere with the R3 system. but I will pitch in here and say that what Henrik proposes is a good idea (I use the same name for a relatively similar feature), though it needs one thing if it is to be usable by newbies. a way for do-face NOT to call attach. the reason is that if you want several cooperating controls, they must not create feedback. |
Henrik 5-Aug-2010 [2320] | you mean circular references? |
Maxim 5-Aug-2010 [2321x2] | for an imperatively driven system like the R3 system, you might want to look at how Amiga OS's BOOPSI system managed this. its relatively easy to code and allows for a much more robust data interchange between controls. |
yes amongst other things. | |
Henrik 5-Aug-2010 [2323] | yes, we could use that. this is one reason Carl didn't like it in the first round. |
Maxim 5-Aug-2010 [2324] | BOOPSI used an intermediate structure which acted as a controler to which you connect everything that has dependencies. then you call do on IT. |
Pekr 5-Aug-2010 [2325] | Henrik - one field change might cause change in multiple other places, not necessarily GUI related. |
Maxim 5-Aug-2010 [2326] | my old VALVE liquid system was similar to this and I could easily have 30 interconnected controls in realtime, all refreshing, some even generating data which where used in other parts of the gui (like backgrounds). so you'd have a control control and the whole "stylesheet" would updated interactively. |
Henrik 5-Aug-2010 [2327] | Pekr, arranging reactors properly should solve that problem. |
Maxim 5-Aug-2010 [2328x2] | an other simpler way, is to have a refinement on do-face, /REACT which indicates that its being driven from another control. so then, you make sure that this face's do-face doesn't follow up on its own. |
though this doesn't allow all of the tricks, it does solve circular references. | |
Henrik 5-Aug-2010 [2330] | yes, I was just thinking that. |
Maxim 5-Aug-2010 [2331x3] | valve worked like that, pretty much. |
the new GLASS engine, using dataflow for every aspects of itself, doesn't have these circular reference issues... its plugable at the data level. | |
so you can plug the graphics directly to the data, and/or any sizing or intermediate processed data together. | |
Robert 5-Aug-2010 [2334x3] | Henrik, let's discuss this idea with Carl and than Lad because it's all about graph-theory how to solve / detect circles, loops etc. |
Petr, the app logic shoudl just get a trigger from the GUI (subscriber pattern) and than do what ever makes sense. | |
We have a VFSM (virtaul finite state machine) imeplementation for this. | |
Henrik 5-Aug-2010 [2337x3] | Robert, I'm not sure how much theory there is in it. It seems more to be a feature that needs to be added to the reactor evaluation part. |
I.E. 2-5 lines of code in the right spots. Of course preferrably with minimum performance loss. | |
but Carl may have some ideas on where to do it. I'm not sure we need to delve into adding whole engines and state machines to do this. 75% of what is needed is already implemented. | |
Gregg 5-Aug-2010 [2340] | State machines are good. |
Maxim 5-Aug-2010 [2341x2] | I also think that this is the kind of thing which should be kept simple to a minimum. this above simple procedure covers the majority of cases. |
if users need something much more complex, then they are fully able to implement their own within the reactors. IMHO, this is a generalized "helper" for those little things which aren't fun to code manually and for which a simple API does the job. | |
Henrik 5-Aug-2010 [2343] | Maxim, DO-FACE doesn't directly chain into other DO-FACEs. I'm therefore assuming that we need to somehow store the caller face? |
Maxim 5-Aug-2010 [2344] | if DO-FACE cannot end-up triggering an ATTACH created function, then you are ok. |
Henrik 5-Aug-2010 [2345] | DO-FACE runs only reactors, so it unavoidably can. |
Gregg 5-Aug-2010 [2346] | I don't want the engine any more complex than necessary, but I also don't want to put the onus on the app developer (that is, me :-) to implement logic that is needed 95% of the time. |
Maxim 5-Aug-2010 [2347] | thing is, remembering who's been visited, doesn't help you if the engine allows cycles. since who was visited first will (potentially) change outcome |
Gregg 5-Aug-2010 [2348x2] | Which is why the dataflow model is good, right? ;-) |
I won't push for that, as I don't think Carl will go for it. | |
Henrik 5-Aug-2010 [2350] | Carl likely won't allow any engines or state machines to be added now, so it has to be grafted onto what's already there. If it can be done in 5-10 lines of code. |
Maxim 5-Aug-2010 [2351x2] | its best to make the actuall API non cyclic directly. so if the various event/data handling systems can identify that they are being only required to RECEIVE data, then they know that they shouldn't cause any reactions of their own. if your reactors are all basically derived from a single or few functions, then its not a big deal to implement. but if each field has its own implementation then it can be quite a tedious effort, since you must revise all of them so they are non propagating. |
and this has to be well documented to people writing reactors/actors always handle this. | |
Henrik 5-Aug-2010 [2353] | The ATTACH and DO reactors are the only one that is able to run other reactors. You can of course freely design your own reactors, but we are basically relying on the content of the reactors to help avoiding screwing things up. |
Robert 5-Aug-2010 [2354x2] | State machine: Not to be meant to be part of the GUI. The reactor code would just trigger the state machine than. |
graph: As Gregg said, if we can link stuff, dataflow is not far away. And this will result in a constraint solver a la Excel. Which would be very cool to have anyway. | |
Graham 6-Aug-2010 [2356] | http://twitter.com/rebol3 Richtext ?? |
Pekr 6-Aug-2010 [2357] | What's your exact question, Graham? :-) |
Henrik 6-Aug-2010 [2358x2] | The dialect is low level, i.e. not a mezzanine, so I guess some conversion work needs to be done. |
Regarding ATTACH, perhaps it's best for now to leave it working as it is, as I'd like to keep it. One big advantage of reactors is that you can write your own very quickly and not affect the GUI system. | |
Graham 6-Aug-2010 [2360] | Anything releasable for us to try? |
Henrik 6-Aug-2010 [2361] | not yet, but I know Bolek and Cyphre are working hard in the background to complete the resizing system. |
Robert 7-Aug-2010 [2362] | I t hink within the next 1-2 weeks a major milestone will be reached. host-kit with fully externalized graphics, resizing system mostly working and a couple of styles using it available. |
Graham 7-Aug-2010 [2363] | An internal milestone? Or an alpha release? |
Robert 7-Aug-2010 [2364] | IMO this can be a next host-kit release. |
shadwolf 7-Aug-2010 [2365x2] | i'm lost i haven't being following here closely but why VID is externalised ? well it always was and optional thing ... the main thing being rebol/core... so this tendency is made more clear. Will this allow people to access the graphical side extension and modifies it independently of rebol/core (the host ?). Are they other side package planned ? |
is it possible to know who work on what in the GUI topic and have a slight idea of the steps done and the steps to be done .... | |
Henrik 7-Aug-2010 [2367] | sure: Robert - DB interface, messaging, state machine, cracking the whip Cyphre - Resizing, low level AGG, rich text, host kit interface Me - Dialogs, form validation, database interface, reactors, messaging, state machine help system Bolek - Styles, resizing Ladislav - Resizing, state machine The above is basically what needs to be done for the first customer app. |
shadwolf 7-Aug-2010 [2368] | hum ..; can i crack the wip too ? it seems fun !!! |
older newer | first last |