Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Slots list discussion #86

Open
LeonaMorro opened this issue Jul 18, 2016 · 3 comments
Open

Slots list discussion #86

LeonaMorro opened this issue Jul 18, 2016 · 3 comments
Labels

Comments

@LeonaMorro
Copy link
Member

Howard:
If it is possible to dynamically build the slots list only when needed (handle a new sitter extends the slots list). I haven't given this enough thought to know if it is possible but there are some high hurtles to overcome. This could eliminate the differences between ANIM and SCHMO(E). It could also cut down on memory usage as we are not processing a bloated slots list. Maybe the slave is the only script to benefit from this. I guess just keep this idea in mind as things progress?

@LeonaMorro
Copy link
Member Author

I guess you are talking about it because the slots list may become / is a big chunk of data that is send via a linkmessage on every change?
Yes it is. And like you I also see that an improvement would be fine. But I would not try to make it some kind of dynamical, but to split it into several list for the different scopes. (But maybe that is the kind of dynamic that you talk about.)

First let us check what informations a slot in the list currently contains:

  1. animation name
  2. avatar position
  3. avatar rotation
  4. facials
  5. avatar key
  6. SATMSG
  7. NOTSATMSG
  8. seatName (2 parts: internal name and userdefined name)

All this informations are neccesary (except the internal seat name "seatX", which is redundant), but none of the scripts need them all. So lets see, which script needs which informations (beside the slotnumbers):

Core:

  • avatar key

Slave:

  • avatar key
  • animation name(s)
  • avatar position
  • avatar rotation
  • facials

Menu:

  • avatar key
  • user defined seat name

SAT/NOTSAT Handler:

  • avatar key
  • SATMSG
  • NOTSATMSG

RLV+:

  • avatar key

If I should create a database with the given information pieces I would handle almost any piece of them in different tables, because they represent "different topics" and I guess it would be good to do so in our scripts also. I would make the following lists:

  • Slots: contains the userdefined name
  • SlotsAvatars: contains the avatarkeys and is pointing to the Slots list
  • SlotsPosRot: contains the avatar/slot position and rotation and is pointing to the Slots list
  • SlotsAnimations: contains the animations names and is pointing to the Slots list
  • SlotsFacials: contains the facial names and is pointing to the Slots list
  • SlotsSatNotSat: conatains the SATMSGs and the NOTSATMSGs and is pointing to the Slots list

Which script should hold which list? (R: readonly; RW: readWrite)

Core:

  • Slots (RW)
  • SlotsAvatars (RW)

Slave:

  • Slots (R)
  • SlotsAvatars (R)
  • SlotsPosRot (RW)
  • SlotsAnimations (RW)
  • SlotsFacials (RW)

Menu:

  • Slots (R)
  • SlotsAvatars (R)

SAT/NOTSAT Handler:

  • Slots (R)
  • SlotsAvatars (R)
  • SlotsSatNotSat (RW)

RLV+:

  • Slots (R)
  • SlotsAvatars (R)

Which list should be propagated via linkmessage on change? (that are the lists which are marked as R in some script)

  • Slots
  • SlotsAvatars

To minimize the number of linkmessages it could be possible to merge the Slots and the SlotsAvatars list.

This all are only my first thoughs and (maybe) there are problems that can't be solved.

@HowardBaxton
Copy link
Collaborator

I suggested this line in the hopes that maybe we could do the dynamic slots list in an effort to remove the need for that DEFAULT pose set when only SCHMO(E) are used in the build. I think currently a builder is probably making more seats available than they would usually get in world (I would). This is the bloat which came to my mind. Maybe it isn't possible. I was also thinking the slave did not need to know about empty slots but that is incorrect.

To follow your line of thought I think the core needs the entire slots list to make the decisions as to who sits where (which stride to put a sitter into) and send out the complete seatupdate. One more point is that we really shouldn't limit the seatupdate data because we have no way of knowing what information a custom plugin might need.

Gosh wouldn't it be nice to have database access.

The Menu and SAT/NOTSAT HANDLER only retain a subset of the slots list currently. (i.e. Each script processes the seatupdate and only retains what it actually needs.) The slave script is currently holding the entire slots list and probably shouldn't. It could get rid of (NOT)SATMSG information.

The internal seatName is currently used in many scripts to decide which seat a sitter is in. I agree this could be done in a smarter way than it currently is done. Perhaps simply find the slots list stride for a specific sitter. Early in the development of AssignSlots function I was following a different line of thought and never really removed that unneeded bit of info.

@LeonaMorro
Copy link
Member Author

To follow your line of thought I think the core needs the entire slots list to make the decisions as to who sits where (which stride to put a sitter into) and send out the complete seatupdate.

The core don't need all informations that are currently in our slots list to make that decision. The core only need to know what slots exists and who is sitting in which slot.

One more point is that we really shouldn't limit the seatupdate data because we have no way of knowing what information a custom plugin might need.

Thats true, but there is no need to send all the data in that big chunk of data which is currently send via the seatupdate.

  • we can simply send an update whenever any of the above lists changed.
  • we can make a switch that allows any third party plugin to switch on the sending of updates for a changed list.
  • we can let a third party plugin register for the updates it needs.

So there are ways to do it without sending that big chunck of data

Gosh wouldn't it be nice to have database access.

Yeah! .. Please also vote for no memory limit and multidimensional arrays and ... To be continued ;)
IMHO: The memory limit is the worst: it forces us to separate scripts and write protocols for the scripts to communicate which each other and doing funny stuff to keep that all in sync. I guess we could write nPose with half the of the memory consumption if there wasn't a memory limit. Oh .. and of course it would use less CPU time because there is no need for all that overhead. I realy don't know why LL doesn't see that the memory limit is a very very bad idea. Please vote here: https://jira.secondlife.com/browse/BUG-9382

The Menu and SAT/NOTSAT HANDLER only retain a subset of the slots list currently. (i.e. Each script processes the seatupdate and only retains what it actually needs.) The slave script is currently holding the entire slots list and probably shouldn't. It could get rid of (NOT)SATMSG information.

That isn't exactly that what I have in mind. But I guess you know that.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants