|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Quests::Q&A This is the quest support section |
07-17-2007, 02:45 PM
|
The Solo Server
|
|
Join Date: May 2007
Posts: 416
|
|
BuffBot
OK, what did I do wrong...if I hand in ANY of the plat amt is casts ALL spells?
sub EVENT_ITEM() {
if ($platinum = 500) {quest::selfcast(3360);}
if ($platinum = 200) {quest::selfcast(2570);}
if ($platinum = 50) {quest::selfcast(1693);}
if ($platinum = 20) {quest::selfcast(174);}
if ($platinum = 400) {quest::selfcast(1710);}
if ($platinum = 300) {quest::selfcast(1729);}
if ($platinum = 60) {quest::selfcast(10);}
if ($platinum = 30) {quest::selfcast(39);}
}
|
07-17-2007, 04:10 PM
|
Demi-God
|
|
Join Date: Jul 2006
Posts: 1,552
|
|
Not sure, but doesn't perl use "eq" for "="? I thought both worked, but maybe with integers, it's different?
|
07-17-2007, 04:16 PM
|
Hill Giant
|
|
Join Date: Oct 2006
Posts: 248
|
|
try using:
if( $platinum == $somevalue )
in reference to eq, that is the operator for "string" equivalence. == is the operator for numerical equivalence.
== sfisque
|
07-17-2007, 07:53 PM
|
Hill Giant
|
|
Join Date: Nov 2004
Posts: 160
|
|
It's been a looooong time since i scripted any perl but wasn't all based in copper value no matter what you wrote? so 500 'plat' really is 500 copper which is less than 1 plat so no matter how much you give him as long as it's over 5 gold you've met all requirements...
I dunno maybe it's fixed so labling plat really does work and all this doesn't mean anything, but that was my initial guess...
|
07-17-2007, 08:19 PM
|
AX Classic Developer
|
|
Join Date: May 2006
Location: filler
Posts: 2,049
|
|
try using elsif , that way it will stop at the first one it finds agreeable. I think a string of "ifs" prompts perl to look at all the options.
so if you gave 500 plat (500 plat being the most), this will satisfy all the if's.
are all "nested" under the first if
Code:
if
elsif
elsif
elsif
are "standalone" "ifs
You can also use level checks (why would a level 50 character need a level 20 spell)?
Code:
sub EVENT_ITEM{
if (($platinum>=15)&&($ulevel=> 46)){
$npc->SetAppearance(0);
quest::selfcast(2570);
quest::say("Casting KEI, Good hunting!");
}elsif(($platinum>=5)&&($ulevel<= 45)){
$npc->SetAppearance(0);
$npc->CastSpell(174,$userid);
quest::say("Casting Clarity, Good hunting!");
}else{
quest::say("Thank you for your donation $name, it wasn't enough though ...");
}
}
The latter is my mana caster in PoK
Last edited by Angelox; 07-18-2007 at 04:29 AM..
|
07-17-2007, 09:59 PM
|
Demi-God
|
|
Join Date: Jul 2006
Posts: 1,552
|
|
His "if ... {quest::selfcast(3360);}" is actually ok, since the if is begun { and ended } properly. elsif is not a bad plan either. But yeah, i missed that... 500 would be 5 gold, not 500pp I think. Although, it has to equal, so 500 does not = 200, and should fail. Not sure what the issue is there, aside from '==' vs '='.
|
07-18-2007, 12:33 AM
|
Forum Guide
|
|
Join Date: Sep 2003
Location: California
Posts: 1,474
|
|
Have a look at my quest editor and built in examples,there are a few buff bot examples there.
GeorgeS
|
|
|
|
07-18-2007, 01:06 AM
|
Hill Giant
|
|
Join Date: Oct 2006
Posts: 248
|
|
Quote:
Originally Posted by Irreverent
OK, what did I do wrong...if I hand in ANY of the plat amt is casts ALL spells?
sub EVENT_ITEM() {
if ($platinum = 500) {quest::selfcast(3360);}
if ($platinum = 200) {quest::selfcast(2570);}
if ($platinum = 50) {quest::selfcast(1693);}
if ($platinum = 20) {quest::selfcast(174);}
if ($platinum = 400) {quest::selfcast(1710);}
if ($platinum = 300) {quest::selfcast(1729);}
if ($platinum = 60) {quest::selfcast(10);}
if ($platinum = 30) {quest::selfcast(39);}
}
|
ok. one more time.
in each IF statement, he is ASSIGNING the value to $platinum, not testing for equivalence. in PERL, assignment always evaluates to true, unless the RHS is zero, undef, null, or eof.
SO, every IF statement evaluates to true, and, thus, the buffbott casts everything. there's no need for elsif's. all he needs to do is change "if( $variable = some_value)" to the correct form of "if( $variable == some_value )"
this concludes PERL 101, please take a blue book and exam guide. grades will be posted at the end of the semester.
== sfisque
|
|
|
|
07-18-2007, 06:18 PM
|
Discordant
|
|
Join Date: Jun 2003
Posts: 449
|
|
why not make it so you have to say a command and pay plat to get the buff? otherwise how are people going to know what amount of plat to give and what buff they are getting?
edit:
been a long time since ive been done this but try something like this?
if(($platinum = xxx) && ($text eq 'buff')) {
quest::selfcast(xxxx);
}
i think that would work
Last edited by x-scythe; 07-19-2007 at 02:33 AM..
|
07-18-2007, 06:22 PM
|
AX Classic Developer
|
|
Join Date: May 2006
Location: filler
Posts: 2,049
|
|
If you make a good bot, you'll be able to chat with him and ask how much he charges.
|
07-18-2007, 06:43 PM
|
Discordant
|
|
Join Date: Jun 2003
Posts: 449
|
|
Quote:
Originally Posted by Angelox
If you make a good bot, you'll be able to chat with him and ask how much he charges.
|
aye, thats what i was trying to explain in my post lol
|
|
|
|
07-20-2007, 01:27 PM
|
Sarnak
|
|
Join Date: Aug 2006
Posts: 60
|
|
As a player, I absolutely hate having to give certain odd value of platinum to an npc to get a certain spell. For example, I would think, "Okay, he wants 62 platinum for c3, 54 platinum for Aego, etc". And that is undesirable in my opinion for the server host and the player. The player wants to buff up and move on. And as a host, you want players to quickly get buffs and enjoy content.
I wrote up this as an alternative credit system for obtaining buffs. I've commented out some things just to make it easier to use as a template. Also, I've only tested this with myself, but it should work with multiple players without bugging (unless I missed an undef). The reason I used Y9 instead of F for global expiration time was simply because F was not working for me. Hope this comes in handy as a template.
Code:
sub EVENT_SAY {
if($text=~/Hail/i){
quest::say("Hello, $name. Are you interested in [buffs] or would you like to know your [Credit Info]?");
}
if($text=~/Credit Info/i){
quest::say("Would you like to know how to [obtain] credit, your current [credit value], or available [buffs]?");
}
if($text=~/obtain/i){
quest::say("For every platinum you bring me you shall receive one credit. These credits can be redeemed for buffs at your request.");
}
if($text=~/buffs/i || $text=~/yes/i) { #### What buffs does he offer and how much credit?
quest::say("I have the following to offer you:");
quest::say("[Cleanse] --full health and mana restore-- - FREE");
quest::say("[Temperance] - 25p");
quest::say("[Virtue] - 50p");
quest::say("[C1] - 5p");
quest::say("[C2] - 25p");
quest::say("[C3] - 75p");
}
if($text=~/credit value/){
if ($buffbot >= 1) {
quest::say("Your current credit is $buffbot");
$buffbot = undef;
}
else {
quest::say("You have 0 credit. Would you like to know how much you need to donate obtain [buffs]?");
$buffbot = undef;
}
}
#cleanse
if($text=~/cleanse/i){ #### Restores Mana and Health. I use this as an alternative to simply casting a spell
$client->Heal();
$client->SetMana($client->GetMaxMana());
quest::say("As you wish!");
}
#buffs begins
#buff 1- Temperance
if($text=~/Temperance/i){
if ($buffbot >= 25) {
quest::selfcast(3692);
quest::say("As you wish!");
quest::setglobal("buffbot", $buffbot-25, 0, "Y9");
$buffbot = undef;
}
else {
quest::say("You need more credits!");
$buffbot = undef;
}
}
#temperance ends
#virtue
if($text=~/virtue/i){
if ($buffbot >= 50) {
quest::selfcast(3467);
quest::say("As you wish!");
quest::setglobal("buffbot", $buffbot-50, 0, "Y9");
$buffbot = undef;
}
else {
quest::say("You need more credits!");
$buffbot = undef;
}
}
#c1
if($text=~/c1/i){
if ($buffbot >= 5) {
quest::selfcast(174);
quest::say("As you wish!");
quest::setglobal("buffbot", $buffbot-5, 0, "Y9");
$buffbot = undef;
}
else {
quest::say("You need more credits!");
$buffbot = undef;
}
}
#c2
if($text=~/c2/i){
if ($buffbot >= 25) {
quest::selfcast(1693);
quest::say("As you wish!");
quest::setglobal("buffbot", $buffbot-25, 0, "Y9");
$buffbot = undef;
}
else {
quest::say("You need more credits!");
$buffbot = undef;
}
}
#c3
if($text=~/c3/i){
if ($buffbot >= 75) {
quest::selfcast(2570);
quest::say("As you wish!");
quest::setglobal("buffbot", $buffbot-75, 0, "Y9");
$buffbot = undef;
}
else {
quest::say("You need more credits!");
$buffbot = undef;
}
}
}
sub EVENT_ITEM {
#give a plat, get a credit. Takes any platinum over 1.
if($platinum >= 1){
quest::setglobal("buffbot", $buffbot+$platinum, 0, "Y9");
quest::say("Your credit has been increased by $platinum.");
$buffbot = undef;
quest::settimer(1,1);
}
else {
quest::say("I only accept platinum.");
$buffbot = undef;
}
plugin::return_items(\%itemcount);
}
sub EVENT_TIMER {
if ($timer == 1) {
quest::say("Would you like to know your total [credit value]?");
quest::stoptimer(1);
}
}
With this, you can just use one buff segment, copy and change for a different buff. Previously, I've used checks to make npcs more authenic as well. Like an enchanter saying, "You're too low for KEI to take effect. But, I can cast clarity on you." And given different values for different conditions (like temp free for under level 5). But all of that is just stuff to toy with if you like the way I have it set up.
|
|
|
|
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 07:00 AM.
|
|
|
|
|
|
|
|
|
|
|
|
|