|
|
 |
 |
 |
 |
|
 |
 |
|
 |
 |
|
 |
|
Spell Support Broken Spells? Want them Fixed? Request it here. |

09-07-2009, 11:00 AM
|
Sarnak
|
|
Join Date: Jul 2003
Posts: 68
|
|
SpellScriber question
Is it possible that the spellscriber will only scribe non-custom spells?
I created a couple of spells that i wanted to be raid dropped, but it appears our spell scriber scribes them everyone who hails them into their books; )
|
 |
|
 |

09-07-2009, 02:51 PM
|
 |
Hill Giant
|
|
Join Date: Jan 2008
Location: VA
Posts: 181
|
|
You can set a statement I believe
Like if is a certain spell
to like opt it out
such as Mage pets spell
:::not 100% on that::: but looks something like this
sub EVENT_SAY {
if($text =~ /hail/i) {
quest::say("Welcome to the server, how can I help
you today? Would you like me to help you [scribe] spells");
}
elsif ($text =~ /scribe/i && $ulevel <= 51 && $class ne Magician) {
quest::say("Very well, here you are $name!");
quest::scribespells($ulevel);
}
elsif($text =~ /scribe/i && $ulevel <= 44 && $class == Magician) {
quest::say("Very well, here you are $name!");
quest::scribespells($ulevel);
}
elsif($text =~ /scribe/i && $ulevel >= 45 && $ulevel <= 51 && $class
== Magician) {
quest::say("Sorry, $name. You are too high to have any spells scribed!");
}
elsif ($text =~ /scribe/i && $ulevel >= 52) {
quest::say("Sorry, $name. You are too high to have any spells scribed!");
}
__________________
"From the deepest desires often come the deadliest hate.”
|
 |
|
 |

09-08-2009, 05:17 AM
|
Sarnak
|
|
Join Date: Jul 2003
Posts: 68
|
|
Seems this script only checks for level but not any specific spell ids or am i too blond again ? 
|

09-08-2009, 08:51 PM
|
 |
Developer
|
|
Join Date: Aug 2006
Location: USA
Posts: 5,946
|
|
Right now, there isn't any easy way to stop certain spells from being scribed. Though, I have had an idea for a while now on how to make a system to do it using quest globals. It hasn't been coded yet, but hopefully it will be at some point.
|

09-09-2009, 04:12 PM
|
Fire Beetle
|
|
Join Date: Aug 2009
Location: LA
Posts: 12
|
|
I've edited a quest command to check spell name for (custom). The edited spells with custom in them (e.g. "Firebolt (custom)" ) would be in my database but not distributed to the players.
Kind of a pain in the ass, but not enough for me to look for a cleaner solution;p
|

09-11-2009, 01:31 AM
|
Developer
|
|
Join Date: Mar 2007
Location: Ohio
Posts: 648
|
|
Quote:
Originally Posted by Nagus69
Is it possible that the spellscriber will only scribe non-custom spells?
|
You could always use the quest object $Client->ScribeSpell(spell_id, slot, update_client= true) in combination with a foreach loop to scribe specific spells (stored in an array, etc).
|

09-16-2009, 03:08 AM
|
Fire Beetle
|
|
Join Date: Feb 2007
Posts: 27
|
|
Quote:
Originally Posted by trevius
Right now, there isn't any easy way to stop certain spells from being scribed. Though, I have had an idea for a while now on how to make a system to do it using quest globals. It hasn't been coded yet, but hopefully it will be at some point.
|
I was actually just in the process of modifying the source so spells we didn't want scribed on our server weren't given out. It involved a new table in the DB, spells_unscribable with one field, spell_id.
Generally I don't like such close-ended solutions, but I wasn't sure of a better way (I was also going to look into passing an array of blocked spell_id's to quest::scribespells() as well). Your quest global idea seems a lot more sensible, and something I'm going to look into now.
|

09-16-2009, 04:00 AM
|
 |
Developer
|
|
Join Date: Aug 2006
Location: USA
Posts: 5,946
|
|
Basically, the idea I had was just to add 2 more fields at the end of the spell table. One of the fields being named something like qglobal_name, and the other being qglobal_value. Then, when spells are scribed, we would simply check each spell that a player could normally scribe to see if it has a name and value set and if so, it will check the qglobals table to see if that player has that particular qglobal and value. So, you could assign players qglobals like "shaman" with a value of "1" and then set a tier of spells in the spells table to have that same setting. You could really organize them however you want, then. You could name them by class like that, or name them after a quest reward or whatever. The only downside to it is that you wouldn't be able to export your whole spells table and then clear it out and import it again. If you did, you would have to setup your qglobal fields again.
|
 |
|
 |

09-16-2009, 11:23 AM
|
 |
Demi-God
|
|
Join Date: Mar 2009
Location: Umm
Posts: 1,492
|
|
hey what happened to good old scrolls? =P
I always consider using that spell scriber to be cheating =P
|
 |
|
 |

09-16-2009, 03:49 PM
|
Fire Beetle
|
|
Join Date: Feb 2007
Posts: 27
|
|
Quote:
Originally Posted by trevius
Basically, the idea I had was just to add 2 more fields at the end of the spell table. One of the fields being named something like qglobal_name, and the other being qglobal_value. Then, when spells are scribed, we would simply check each spell that a player could normally scribe to see if it has a name and value set and if so, it will check the qglobals table to see if that player has that particular qglobal and value. So, you could assign players qglobals like "shaman" with a value of "1" and then set a tier of spells in the spells table to have that same setting. You could really organize them however you want, then. You could name them by class like that, or name them after a quest reward or whatever. The only downside to it is that you wouldn't be able to export your whole spells table and then clear it out and import it again. If you did, you would have to setup your qglobal fields again.
|
Interesting approach. I was actually scared to touch the spells table, I know the Titanium client ends at 202 fields or something, but I don't know what is up with the SoF client or if anything else was being planned for the extra fields in the table. I think taking your idea a step further and creating a new table with a many-to-many relationship for different "spellsets" would add some extra flexibility, but of course would be a little more time consuming to implement correctly.
Still it seems like too much overhead, when in reality most of the time people only want to block a few select spells. I think I'm just going to add an additional parameter to the quest::scribespells() as I said, but since it can't accept arrays I'll just pass in a comma separated list.
I'm no perl expert but I think it would look something like this:
Code:
my @blocked = ();
push(@blocked, 1944); # mage epic
push(@blocked, 1197); # ancient: lullaby of shadow
# etc, this is prolly best for large lists of blocked spells
my $csv = join(",", @blocked);
quest::scribespells($ulevel, 1, $csv);
or simply, if you have a small list of blocked spells.
Code:
quest::scribespells($ulevel, 1, "1944,1197");
|
 |
|
 |
 |
|
 |

09-24-2009, 12:49 AM
|
Fire Beetle
|
|
Join Date: Jul 2008
Location: NA
Posts: 16
|
|
Quote:
Originally Posted by trevius
Basically, the idea I had was just to add 2 more fields at the end of the spell table. One of the fields being named something like qglobal_name, and the other being qglobal_value. Then, when spells are scribed, we would simply check each spell that a player could normally scribe to see if it has a name and value set and if so, it will check the qglobals table to see if that player has that particular qglobal and value. So, you could assign players qglobals like "shaman" with a value of "1" and then set a tier of spells in the spells table to have that same setting. You could really organize them however you want, then. You could name them by class like that, or name them after a quest reward or whatever. The only downside to it is that you wouldn't be able to export your whole spells table and then clear it out and import it again. If you did, you would have to setup your qglobal fields again.
|
this is something that should be added so that spells from each expansion could be selected or from your custom list etc. such a pain in the ass either way :(
|
 |
|
 |
Posting Rules
|
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts
HTML code is Off
|
|
|
All times are GMT -4. The time now is 08:46 AM.
|
|
 |
|
 |
|
|
|
 |
|
 |
|
 |