Register to post in forums, or Log in to your existing account
 

Play RetroMUD
Post new topic  Reply to topic     Home » Forums » CMUD General Discussion
Nemireck
Beginner


Joined: 15 Feb 2009
Posts: 10

PostPosted: Mon Sep 13, 2021 5:34 pm   

Disabling Classes within a parent Class
 
Example:

Parent Class "Demon" has 55 "room Classes" within it; "demon1 -> demon55"

Using #t- Demon I can disable "Demon", obviously, but it leaves whatever "demonX" class enabled within it. I would like to ensure all of the room Classes are disabled at the same time as "Demon" is disabled.

Is there a way to disable the demon1-55 classes with a single command, or am I stuck making an alias or trigger with 55 "#t- demonX" lines?
Reply with quote
shalimar
GURU


Joined: 04 Aug 2002
Posts: 4689
Location: Pensacola, FL, USA

PostPosted: Tue Sep 14, 2021 3:11 am   
 
Everything in a given class is disabled when the class is disabled.
This includes nested classes.
Your request is the default behavior.
_________________
Discord: Shalimarwildcat
Reply with quote
Nemireck
Beginner


Joined: 15 Feb 2009
Posts: 10

PostPosted: Wed Sep 15, 2021 3:53 am   
 
No, that's not 100% accurate.

The enabled classes within a disabled parent class remain in enabled status, they just don't function because the parent is disabled.

So for an example of what my script is doing:

When I "StartDemon," the script starts running by enabling "Demon" and "demon1" (which is a sub-class within parent class "Demon) and begins running in sequence by room (demon1-demon55). When it reaches "demon55" it disables "Demon" and "demon55."

If I'm in room "demon35" and I disable the parent class "Demon" for whatever reason, then "demon35" remains enabled until I disable it as well (it just doesn't execute because "Demon" is disabled). If I were to "StartDemon" later on without disabling "demon35" first, the result is that the script starts running with "demon1" and "demon35" both enabled, which causes both classes to fire off their shared triggers, causing mayhem.

Not a big deal if I'm at the computer manually shutting everything down, it's just a couple of commands. But if I wanted to to ensure the "demonX" rooms were all disabled automatically (say... whenever I login), I'm currently of the belief that I would need to make an alias to do something like:

#t- Demon
#t- demon1
#t- demon2
#t- demon3
etc.

I am wondering if there is another, easier way to disable an entire class folder with one command (or two) instead.
Reply with quote
hpoonis2010
Adept


Joined: 18 Jun 2019
Posts: 279

PostPosted: Wed Sep 15, 2021 6:12 am   
 
What shalimar wrote is correct: if the class is disabled, everything in the class is disabled. The fact that the items do NOT appear disabled in the package editor is immaterial.

Test it yourself. Disable a class with an alias in it then try using that alias. Although the alias itself not disabled it will not function due to the parent being disabled.

If you insist upon scripting #T- demon1, demon2, etc then just use something like

#LOOP 1, 55{
#T- demon%i
}
Reply with quote
shalimar
GURU


Joined: 04 Aug 2002
Posts: 4689
Location: Pensacola, FL, USA

PostPosted: Wed Sep 15, 2021 11:23 am   
 
Sounds like you need a placeholder variable.
That way you can ensure that when you start your script, it either knows to pick up where you left off, or it knows to reset everything to the beginning.

Or you can make use of the onConnect #EVENT to reset everything after a crash/reboot.

#EVENT onConnect {#LOOP 1,55 {#T- %concat("demon", %i)}}
_________________
Discord: Shalimarwildcat
Reply with quote
Nemireck
Beginner


Joined: 15 Feb 2009
Posts: 10

PostPosted: Wed Sep 15, 2021 11:54 am   
 
hpoonis2010 wrote:
What shalimar wrote is correct: if the class is disabled, everything in the class is disabled. The fact that the items do NOT appear disabled in the package editor is immaterial.

Test it yourself. Disable a class with an alias in it then try using that alias. Although the alias itself not disabled it will not function due to the parent being disabled.

If you insist upon scripting #T- demon1, demon2, etc then just use something like

#LOOP 1, 55{
#T- demon%i
}


While what you're stating is true, it doesn't solve the problem I'm describing... But, you've actually solved my dilemma anyway.

This is perfect for my needs, and I'm going to play around with what shalimar has suggested as well because it looks helpful too.

Thank you both!
Reply with quote
Display posts from previous:   
Post new topic   Reply to topic     Home » Forums » CMUD General Discussion All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum

© 2009 Zugg Software. Hosted by Wolfpaw.net