Jump to content

[SHARE] How to make a script and its rules!


xTheVioLaToR

Recommended Posts

Rule 1: Always save as Unicode

When saving the file, use notepad and select Unicode for the encoding. Go to the tutorials section for more information.

Rule 2: Dont use Tabs

If you use tabs, your script will not function properly. Notice none of my scripts use tabs. This makes the script hard to read, but it has to be so.

Rule 3: Don't use spaces

Just like you can't use tabs, you can't use spaces, unless they are used to seperate words in comments, npc names, item names, or skill names. You may also use spaces in some of the control syntax, such as Call(), Jmp() or Label()

Rule 4: Conditions within conditions DON'T work

 

Something like this:

 

CharStatus(CHP,>=,1000)

{

Msg(Condition: Should Not Show 1)

CharStatus(CHP,>=,1000)

{

Msg(Condition: Should Not Show 2)

}

Msg(Condition: Should Not Show 3)

}

Will not work. The opening bracket { will seek the first closing bracket }. Code directly after the closing bracket will be executed. In this case, that would be the Msg(Condition: Should Not Show 3).

Note: Some of my older scripts (if not updated) use conditions within conditions. They should, however, work fine nevertheless. This is because the conditions are not necessary, but put in as a form of backup coding before I knew the information here. It is, in other words a backup feature that does not work :P

Control:

/

This is a comment. Its sole purpose is to mark sections code. Walker will ignore anything written after a comment, as long as it is on the same line. A comment could consist of a foreward slash /, several foreward slashes //////, or foreward slashes and any text beyond it ////[ East Guard ]////

 

Here are a few more examples:

Code

////[ How to use a comment 101 ]////

/This is a comment you can write anything here even this:

/Exit()

/the Exit() function above will do nothing at all.

/This is because there is a comment placed in front of it.

 

/This however will make your script exit:

Exit()/

/This is because the comment is placed after the code.

 

//////////You may use any number of foreward slashes

Delay()/<----[You may also use comments like this]

/if you do so, the the code before the comment will still work.

Call(Text)

Call() goes to a Label(), then upon the command Return() it returns back to where the Call() was placed. Take a look at this code for example:

CODE

Call(Test1)

Delay(1000)//1

Call(Test1)

Delay(1000)//2

Call(Test1)

Delay(1000)//3

Call(Test1)

Delay(1000)//4

 

EXIT()

 

Label(Test1)

Delay(2000)//Call1

Return()

 

The first Call(Test1) will jump to the Label(Test1), carry out the codes following it then return back to the first Call(Test1) once it hits Return().

 

It will then perform the Delay(1000)//1 function and continue to the second Call(Test1).

 

The second Call(Test1) will also jump to the Label(Test1) and perform the functions following but this time, upon the Return() code it will not return to the first Call(Test1) but to the second Call(Test1) and then perform the Delay(1000)//2 function.

 

This will continue to happen for each Call(Test1) and will return to that specific Call(Test1) upon the command Return()

 

If i had used Jmp() instead of Call(), the return would be ineffective, and the code would not return back to the Jmp() upon the Return() code. It would, rather, continue on with the scrip. In the case of the above script, it would end after the Delay(2000)//Call1 as there are no more effective codes following it.

 

I hope this explains it.

 

Try this script to see what i mean...then try replacing all the Call() code with Jmp() code and see what happens.

 

Delay(Milliseconds)

This will stop the script for the defined ammount of time. For example, Delay(2000) will stop the script for 2 seconds. 1000 milliseconds is 1 second.

Exit(Text)

This will terminate the script

 

GoHome(Text)

This function goes to town if you are dead. Does nothing if you are alive

 

Jmp(Text)

Refer to the Call() function found above

 

Label(Text)

Refer to the Call() function found above

 

Pause(Text)

This will pause the script indefinately. Press Continue on the script panel to continue to the script

 

Return()

Refer to the Call() function found above. The misconception about Return() is that it is used to restart the script, which it does not.

 

Say(Message)

This will display the message inside the brackets to the L2walker chat area. Other players CAN see the output of this script. If you were to write say(I am a bot!), you would be saying to other players "I am a bot!"

NPC Interaction:

Here is an example of NPC Commands:

CODE

LABEL(Wirphy)

NPCSEL(Wirphy)

DELAY(1000)

NPCDLG(Wirphy)

DELAY(1000)

DLGSEL(Quest)

DELAY(1000)

StrInDlg(Say you will help)

{

DLGSEL(Say you will help)

JMP(Wirphy)

}

StrNotInDlg(Say you will help)

{

DELAY(1000)

NPCDLG(Wirphy)

DELAY(1000)

DLGSEL(Go to another village)

DLGSEL(Go to another village)

DLGSEL(The Northeast Coast - 700 ??)

DELAY (30000)

}

 

 

DlgSel(Diologue)

Selects the defined dilogue in a diologue window

 

NPCDlg(NPCNAME[iD=#])

Enables diologue with the defined NPC

 

NPCSel(NPCNAME[iD=#])

Selects an NPC

 

StrInDlg(Diologue)

Looks for a certain string in the dilogue and if it exists performs functions withiin a mathematica brace { }. The brace MUST follow this statement for it to function correctly

 

StrNotInDlg(Diologue)

Looks for a certain strin in the dilogue and if it does not exists, the script will performs functions in a mathematica brace { }. a mathematica brace { } must follow the script.

BuyItem(ITEMNAME[iD=#],#;)

Buys Item. Must have the buy window open with the desired npc

 

BuySeed(SEEDNAME[iD=#],#;)

Buys seed. Must have the buy seed window open with the desired npc

 

LoadItem(ITEMNAME[iD=#],#;)

takes out the desired item from the warehouse. Withdraw window must be opened. Use semicolon ; to add other items. Here is an example:

CODE

LoadItem(Stem[iD=1864],50;Varnish[iD=1865],50)

This code will remove 50 stems and 50 varnish from the warehouse

 

SaveItem(ITEMNAME[iD=#],#;)

similar to the above, except that it will put items into the warehouse instead of take them out. Here is an example:

CODE

LABEL(Itemdeposit)

NPCSEL(Airy[iD=7522])

DELAY(1000)

NPCDLG(Airy[iD=7522])

DELAY(1000)

DLGSEL(Deposit Item (Private Warehouse))

DELAY(1000)

ITEMCOUNT(Stem[iD=1864],>,0)

{

SaveItem(Stem[iD=1864],9999)

CALL(Itemdeposit)

Delay(2000)

}

The first part of this script is not necessary. It selects the desired npc (in this case, Airy), and opens the "Deposit Item" window (see NPCs section below for more information). Similar to the above load item syntax, which removes 50 stems and 50 varnish, it will place 9999 stems (or all, if you don't have that many) into the warehouse.

SellItem(ITEMNAME[iD=#],#;)

Similar to the BuyItem(ITEMNAME [iD=#],#;) function. The buy window must be open with an NPC. This code will buy the desired items, provided that the NPC carries them and you have the required adena.

 

SellSeed(SEEDNAME[iD=#],#;)

Similar to the BuySeed() function, but it sells seeds instead

 

Character

I am not entirely familiar with the UseSkill syntax. When it comes to this section, I advise you use common sense.

UseSkill(NAME[iD=#],NPC,TARGETNAME)

This syntax is used to make your character cast a spell on an NPC target. The target name has to be specified.

UseSkill(NAME[iD=#],Party,TARGETNAME)

I am unfamiliar with the use of this syntax. If anyone knows, please email me.

UseSkill(NAME[iD=#],Pet,TARGETNAME)

UseSkill(NAME[iD=#],Player,TARGETNAME)

UseSkill(NAME[iD=#],Self,TARGETNAME)

ChangeWaitType(0|1)

Sets the character to either sit or stand. 0 = sit, 1 = stand.

 

UseItem(ITEMNAME [iD=#];)

Uses a desired item or items

Settings:

Set(DefPath,Add,x,y,z,radii)

This syntax adds a Path point to the Define PathPoint section (found on the Pathing tab) of l2walker.

Set(DefPath,Clear)

This syntax clears all path points

Set(DefRange,Add,x,y,z)

This syntax adds a point to the Define Range section of the Pathing tab in L2-Walker options.

Set(DefRange,CLEAR)

This syntax clears all Define Range positions

Set(FIGHTSTART)

This syntax enables fighting mode.

Set(FIGHTSTOP)

This syntax disables fighting mode

Set(Item,NoPick,NAME[iD=#])

This syntax sets a

Set(Item,Pick,NAME[iD=#])

Set(Item,Save,NAME[iD=#])

Set(L2Walker,Disable)

This syntax disables L2-Walker. Scripts still function when L2-Walker is disabled

Set(L2Walker,Enable)

This syntax enables L2-Walker. Scripts still function when L2-Walker is disabled

Set(Mon,Attack,NAME [iD=#])

This syntax sets the settings of a perticular monster (as defined by Name[iD=#]) to Attack. In other words, Walker will attack that perticular monster.

Set(Mon,AttackOne,NAME [iD=#])

This syntax sets the settings of a perticular monster (as defined by Name[iD=#]) to Attack alone. In other words, Walker will attack that perticular monster, but only if that monster is found to be by itself.

Set(Mon,NoAttack,NAME [iD=#])

This syntax sets the settings of a perticular monster (as defined by Name[iD=#]) to Not Attack. In other words, Walker will not attack that perticular monster, unless that monster initiates combat.

Set(RangeType,Defpath)

This syntax sets the perimiters of fighting to the Define Path Point mode.

Set(RangeType,DefPos,x,y,z,radii)

This syntax sets the perimiters of fighting to the Center of an x, y and z Point, with a radius as defined by the radii.

Set(RangeType,DefRange)

This syntax sets the perimiters of fighting to the Define Range mode.

Set(RangeType,RAnd)

This syntax sets the perimiters of fighting to the RAnd mode (what ever that does).

Set(RangeType,StartPos,radii)

This syntax sets the perimiters of fighting to the "Combat Begin Point is Center Point" mode with a radius as defined by radii.

Conditions:

CharStatus(CHP,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Must be followed by a mathematical brace { }. This script is to be followed by a mathematical brace { }. This code will calculate the character's current HP value, and if the conditons >=|> |==|!=|<|<= satisfy the number to the right #, the script within the a mathematical brace { } will be executed .

CharStatus(CMP,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Similar to the first of the conditions series, but it calculates the MP value. If it satisfies the conditions it will perform the script within the a mathematical brace { }.

CharStatus(HP,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Similar to the first of the conditions series, but it calculates the HP percenage. If it satisfies the conditions it will perform the script within the brackets { }.

CharStatus(LV,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Similar to the first of the conditions series, but it calculates the HP percenage. If it satisfies the conditions it will perform the script within the a mathematical brace { }.

CharStatus(MP,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Similar to the first of the conditions series, but it calculates the MP percenage. If it satisfies the conditions it will perform the script within the a mathematical brace { }.

CharStatus(RACE,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Similar to the first of the conditions series, but it checks the character's race (by this, I assume they mean Class). If it satisfies the conditions it will perform the script within the a mathematical brace { }.

CharStatus(SP,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Similar to the first code of the CharStatus() seires, but it calculates the SP value. If it satisfies the conditions it will perform the script within the a mathematical brace { }.

CharStatus(STAND,>=|>|==|!=|<|<=,0|1)

{

//code to be executed goes here

}

Similar to the first code of the CharStatus() sequence, but it checks wether or not the character is standing. 0 = sit, 1 = stand. If it satisfies the conditions it will perform the script within the a mathematical brace { }.

CharStatus(WEIGHT,>=|>|==|!=|<|<=,#)

{

//code to be executed goes here

}

Similar to the first code of the CharStatus() sequence, but it calculates the weight value of the character's inventory. If it satisfies the conditions it will perform the script within the a mathematical brace { }.

PosInRange(x,y,z,radii)

{

//code to be executed goes here

}

Must be followed by a mathematical brace { }. Checks wether or not the character is within the specified area (detirmened by the x, y and z axis as the epicenter of the location and the radius as the possible distance away from that location). If the character is found within this area, the code within the a mathematical brace { } is executed.

PosOutRange(x,y,z,radii)

{

//code to be executed goes here

}

Must be followed by a mathematical brace { }. Checks wether or not the character is within the specified area (detirmened by the x, y and z axis as the epicenter of the location and the radius as the possible distance away from that location). If the character is NOT found within this area, the code within the a mathematical brace { } is executed.

ItemCount(ITEMNAME[iD=#],>=|>|==|!=|<|<=,1)

{

//code to be executed goes here

}

This code is to be followedby a mathematical brace { }. Make sure both the open and close bracket is on a seperate line. This code Checks wether or not you have a certain ammount of items in your inventory (including what your character is equiped with) and if it satisfies the conditions it will perform the script within the a mathematical brace { }. Here is an example:

CODE

ITEMCOUNT(Wooden Arrow[iD=17],<=,20)

{

DELAY(1000)

Call(ToTown)

}

Operators:

{

//code to be executed goes here

}

Mathematical Brace . These are preceeded by a conditonal statement, such as a CharStatus() code. if the condition is satisfied, the code in the a mathematical brace will be executed. otherwise, it will be skipped. This is not to be used alone as a means of defining an object or a section of code. The opening and closing braces are to be each ALONE on a seperate line with no other characters or spaces preceeding and/or following it on that same line.

==

Equal to. Used in conditional statements

>

Greater Than. Used in conditional statements

>=

Greater Than or Equal To. Used in conditional statements

<

Less Than. Used in conditional statements

<=

Less Than, or Equal to. Used in conditional statements

!=

Not Equal to. Used in conditional statements

;

A semicolon seperates item names in many of the codes under the "Items" section. This lets you define more than one type of item to be stored, sold, bought, withdrawn in a single code. The example under the LoadItems() script, found above, shows how the semicolon would be used.

 

 

I hope i helped you guys...guide is mine and i spent over 1,5 hour to create it....so i hope that i helped you

 

Link to comment
Share on other sites

  • 4 weeks later...
  • 3 weeks later...
  • 3 months later...

Hello, I'm creating a script to join the tvt in l2walker

but I need a little help

 

Why only read the first POSINRANGE?

 

and label (join tvt) call (join tvt) not working anymore

 

please help

 

 

Thnx

 

 

LABEL(join tvt)

NPCSEL(Parina)

NPCDLG(Parina)

DLGSEL(PARTICIPATECLOSE)

POSINRANGE(175394,20269,-3245,2000)

{

Call(TOTOWN)

}

DELAY(100)

POSINRANGE(9837,15620,-4569,400)

{

Call(rpscroll)

}

DELAY(100)

POSINRANGE(12970,16482,-4580,400)

{

Call(respawn die)

}

CALL(join tvt)

 

/////////////////Scroll in c1

LABEL(TOTOWN)

USEITEM(Scroll of Escape to Dark Elf Village[iD=7119])

 

////////////////after scroll

LABEL(rpscroll)

POSINRANGE(9837,15620,-4569,400)

{

MOVETO(10253,16967,-4569)

MOVETO(11132,16940,-4569)

MOVETO(12228,16596,-4584)

MOVETO(14734,16062,-4469)

}

POSINRANGE(14734,16062,-4469,200)

{

Call(join tvt)

}

////////////////die in c1 (respwn after tvt)

LABEL(respawn die)

delay(100)

POSINRANGE(12413,16610,-4580,400)

{

MOVETO(14734,16062,-4469)

}

POSINRANGE(14734,16062,-4469,400)

{

Call(join tvt)

}

call(join tvt)

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • to my store : https://topestore.mysellix.io/fr/ 2015-2022 Aged Discord Account 2015 Discord Account : 50.99 $ 2016 Discord Account : 10$ 2017 Discord Account :3.99 $ 2018 Discord Account : 3.50$ 2019 Discord Account : 2.70 $ 2020 Discord Account :1.50$ 2021 Discord Account :0.99$ 2022 Discord Account :0.70$ Warranty :Lifetime Payment Methods : Crypto/ PayPal Contact Me On Discord Or Telegram Discord : @ultrasstore11 Telegram : https://t.me/ultrastore11 Whatsapp ; +212614849119
    • 2 Factor Authentication Code for 100% secure login. Account provided with full information (email, password, dob, gender, etc).
    • ready server for sale, also available for testing with ready and beautiful npc zone pvp with custom 2 epic core orfen lvl2 with all maps ready all quests work at 100% ready comm  board with buffer teleport gm shop service anyone interested send me a pm many more that I forget  Exp/Sp : x30 (Premium: x40)    Adena : x7 (Premium: x10)   Drop : x7 (Premium: 10)   Spoil : x7 (Premium: 10)   Seal Stones : x7 (Premium: 10)   Raid Boss EXP/SP : x10   Raid Boss Drop : x3 (Premium: x5)   Epic Boss Drop : x1 Enchants   Safe Enchant : +3   Max Enchant : +16   Normal Scroll of Enchant Chance : 55%   Blessed Scroll of Enchant Chance : 60% Game Features   GMShop (Max. B-Grade)   Mana Potions (1000 MP, 10 sec Cooldown)   NPC Buffer (Include all buffs, 2h duration)   Auto-learn skills (Except Divine Inspiration)   Global Gatekeeper   Skill Escape: 15 seconds or /unstuck   1st Class Transfer (Free)   2nd Class Transfer (Free)   3rd Class Transfer (700 halisha mark)   Subclass (Items required from Cabrio / Hallate / Kernon / Golkonda + Top B Weapon + 984 Cry B)   Subclass 5 Subclasses + Main (Previous subclasses to level 75 to add new one)   Noblesse (Full Retail Quest)   Buff Slots: 24 (28 with Divine Inspiration LVL 4)   Skill Sweeper Festival added (Scavenger level 36)   Skill Block Buff added   Maximum delevel to keep Skills: 10 Levels   Shift + Click to see Droplist   Global Shout & Trade Chat   Retail Geodata and Pathnodes   Seven Signs Retail   Merchant and Blacksmith of Mammon at towns   Dimensional Rift (Min. 3 people in party to enter - Instance)   Tyrannosaurus drop Top LS with fixed 50% chance   Fast Augmentation System (Using Life Stones from Inventory)   Chance of getting skills (Normal 1%, Mid 3%, High 5%, Top 10%)   Wedding System with 30 seconds teleport to husband/wife Olympiad & Siege   Olympiad circle 14 days. (Maximum Enchant +6)   Olympiads time 18:00 - 00:00 (GMT +3)   Non-class 5 minimum participants to begin   Class based disabled   Siege every week.   To gain the reward you need to keep the Castle 2 times. Clans, Alliances & Limits   Max Clients/PC: 2   Max Clan Members: 36   Alliances allowed (Max 1 Clans)   24H Clan Penalties   Alliance penalty reset at daily restart (3-5 AM)   To bid for a Clan Hall required Clan Level 6 Quests x3   Alliance with the Ketra Orcs   Alliance with the Varka Silenos   War with Ketra Orcs   War with the Varka Silenos   The Finest Food   A Powerful Primeval Creature   Legacy of Insolence   Exploration of Giants Cave Part 1   Exploration of Giants Cave Part 2   Seekers of the Holy Grail   Guardians of the Holy Grail   Hunt of the Golden Ram Mercenary Force   The Zero Hour   Delicious Top Choice Meat   Heart in Search of Power   Rise and Fall of the Elroki Tribe   Yoke of the Past     Renegade Boss (Monday to Friday 20:00)   All Raid Boss 18+1 hours random respawn   Core (Jewel +1 STR +1 DEX) Monday, Wednesday and Friday 20:00 - 21:00 (Maximum level allowed to enter Cruma Tower: 80)   Orfen (Jewel +1 INT +1 WIT) Monday to Friday, 20:00 - 21:00 (Maximum level allowed to enter Sea of Spores: 80)   Ant Queen Monday and Friday 21:00 - 22:00 (Maximum level allowed to enter Ant Nest: 80)   Zaken Monday,Wednesday,Friday 22:00 - 23:00 (Maximum level allowed to enter Devil's Isle: 80)   Frintezza Tuesday, Thursday and Sunday 22:00 – 23:00 (Need CC of 4 party and 7 people in each party min to join the lair, max is 8 party of 9 people each)   Baium (lvl80) Saturday 22:00 – 23:00   Antharas Every 2 Saturdays 22:00 - 23:00 Every 2 Sundays (alternating with Valakas) 22:00 – 23:00   Valakas Every 2 Saturdays 22:00 - 23:00 Every 2 Sundays (alternating with Antharas) 22:00 – 23:00   Subclass Raids (Cabrio, Kernon, Hallate, Golkonda) 18hours + 1 random   Noblesse Raid (Barakiel) 6 hours + 15min random   Varka’s Hero Shadith 8 hours + 30 mins random (4th lvl of alliance with Ketra)   Ketra’s Hero Hekaton 8 hours + 30 mins random (4th lvl of alliance with Varka)   Varka’s Commander Mos 8 hours + 30 mins random (5th lvl of alliance with Ketra)   Ketra’s Commander Tayr 8 hours + 30 mins random (5th lvl of alliance with Varka)
    • Have a great day! Unfortunately, we can not give you the codes at the moment, but they will be distributed as soon as trial is back online, thanks for understanding! Other users also can reply there for codes, we will send them out some time after.
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock