Scroll inventory manager (script): Difference between revisions
Line 8: | Line 8: | ||
[[Image:Scrolls-cropped.png|thumb|upright=0.5|Personal output]] |
[[Image:Scrolls-cropped.png|thumb|upright=0.5|Personal output]] |
||
[[Image:ShopScrolls-cropped.png|thumb|upright=0.5|Shop output]] |
[[Image:ShopScrolls-cropped.png|thumb|upright=0.5|Shop output]] |
||
This script will compile a list of scrolls, their locations (including their index - e.g. first, second, etc.) and which spells they contain. It can be used for both scrolls on your person as well as scrolls for sale in a shop. |
This script will compile a list of scrolls, their locations (including their index - e.g. first, second, etc.) and which spells they contain. It can be used for both scrolls on your person as well as scrolls for sale in a shop. The list is only a snapshot of the scroll inventory at the time the script was run and does not track them if they move around. |
||
These lists are both displayed in their own windows to aid in quickly locating the scroll you need, and so you can compare your inventory side by side with that of a shop if desired. |
These lists are both displayed in their own windows to aid in quickly locating the scroll you need, and so you can compare your inventory side by side with that of a shop if desired. |
Revision as of 20:48, 1 March 2015
Scroll inventory manager (script) | |
---|---|
Category | utility |
Front-end | Genie |
Author | ABSOLON |
Description
This script will compile a list of scrolls, their locations (including their index - e.g. first, second, etc.) and which spells they contain. It can be used for both scrolls on your person as well as scrolls for sale in a shop. The list is only a snapshot of the scroll inventory at the time the script was run and does not track them if they move around.
These lists are both displayed in their own windows to aid in quickly locating the scroll you need, and so you can compare your inventory side by side with that of a shop if desired.
Scrolls that have not been labelled by reading yet will be listed as 'Unknown' in the output.
Instructions
There are four user variables in the script that need to be set manually.
- personal_scrolls_output_window - The name of the window that you want your scrolls to display in. Default: Scrolls
- shop_scrolls_output_window - The name of the window that you want shop scrolls to display in. Default: ShopScrolls
- container - The list of containers you carry scrolls in. Entries should be separated with a | character. (E.g. scroll case|backpack) The default is set to what I use, so it will likely need to be changed to match your containers.
- container_total - The number of containers you included in the above list.
Syntax
.scroll
- Used without any arguments, the script will sort through the list of containers on your person that are set in the user variables section of the script.
.scroll shop
- Used with the 'shop' argument, the script will search all shop surfaces for any scrolls.
Genie settings
There are no required settings, although I recommend using the following highlight to help make unidentified scrolls easier to notice. Several other highlights are automatically handled by the script without affecting your highlights file.
#highlight {string} {Red} {Unknown}
Also, if you adjust the font, location, and size of the windows the script creates make sure to save your layout and profile so you don't have to do it again the next time you open Genie.
Notes
Because of the way the game engine does not allow index values over eleventh, the script is not currently capable of displaying more than eleven scrolls with the same base noun in the same container. The script will indicate this may be the case when it occurs.
Planned features
- Adding price to the shop output.
- Adding links to each scroll that would GET the specific scroll from your container or BUY it from the shop. (This is awaiting a solution to display issues with the way Genie handles the #link and #echo commands.)
- Possibly implementing global variables to remember where each scroll is.
- Add vault to personal list if inside your vault.
Changelog
None yet.
Script
### .scroll - Written by ABSOLON 3/1/2015 ### Updates will be found at https://elanthipedia.play.net/mediawiki/index.php/Scroll_inventory_manager_(script) ### User Variables - Change these to suit your needs var personal_scrolls_output_window Scrolls var shop_scrolls_output_window ShopScrolls var container scroll case|thigh pouch|rucksack var container_total 3 echo ****************************** echo * Usage: .scroll echo * -sorts through all your scrolls and outputs their contents and locations. echo * -set which containers the script will search in the user variables section at the top of the script. echo * echo * Usage: .scroll shop echo * -sorts through all of a shop's scrolls and outputs their contents and locations. echo * echo * Note: All options are limited to the 11th index of a scroll in/on a given container due to the game engine. echo * This can be worked around to some degree for scrolls on your person using SORT <scroll> in <container> to reverse the order. echo ****************************** if_1 then goto parse_input goto start parse_input: if %1 = "shop" then goto start pause echo echo *********** echo * Invalid option entered. Please try again. echo *********** exit start: ### Script variables - Do not change these unless changing how the script works var shop 0 if %1 = "shop" then var shop 1 var index first|second|third|fourth|fifth|sixth|seventh|eighth|ninth|tenth|eleventh var index_total 11 var scroll_type scroll|roll|parchment|vellum|bark|ostracon|papyrus|leaf|tablet var scroll_type_total 9 var surface_array altar|armoir|armoire|bale|bar|barn|barrel|basket|bedroll|bench|bin|block|blossom|boar|board|bookcase|bookshelf|bookshelves|bookstand|box|branch|breakfront|broomstick|bucket|buffet|bull|bureau|bust|butterflies|butterfly|cabinet|carpet|cart|carton|case|catalog|cauldron|chair|chest|closet|cloud|coffer|container|cord|cornucopia|corral|cot|counter|cradle|crate|cushion|desk|display|drawer|dresser|drum|dummies|dummy|easel|endtable|fence|firepit|footrest|fountain|framework|garderobe|goblin|gourd|grinder|hand|hanger|hatstand|head|highboy|hole|hook|hooks|horse|jar|keg|lattice|locker|mannequin|mantel|mantle|moon|net|niche|ogre|pail|pallet|panel|peccaries|peccary|pedestal|peg|pegboard|pew|pillow|pipe|pit|plank|planter|platter|plinth|podium|pole|post|pumpkin|quilt|rack|rope|rug|salver|sawhorse|shelf|shell|shelves|showcase|sidebar|sideboard|skeleton|skippet|spittoon|stable|stand|star|stool|stove|stump|sun|table|tomb|tray|tree|trestle|trough|trunk|turtle|urn|valet|vanities|vanity|vat|wall|wardrobe|waterwheel|web|webbing|workbench|worktable var container_counter 0 if %shop then { var container placeholder var container_total 0 var output_window %shop_scrolls_output_window } else { var preposition in my var output_window %personal_scrolls_output_window } if %shop then { action (parse) goto no_shop when ^There is nothing to buy here action (parse) var raw_container $4 $5;eval container replacere(%container,%container,%container.%raw_container);math container_total add 1 when ( +)a(|n)(.*\b)(.+\b) (%surface_array)( |$) action (parse) on pause 0.1 put shop pause action (parse) off if length(%container) >= 12 then eval container substr(%container,12) eval container replacere(%container,"\.","|") } ### Set-up send #window show %output_window send #clear %output_window if %shop then send #echo Yellow,DarkBlue >%output_window $roomname ### Actions action var spell_name $1 when ^It is labeled \"(.+)\.\" action var spell_name $1 Unknown when ^Illustrations of complex, three-dimensional shapes cover much of the action var index_counter 0;math scroll_type_counter add 1;goto loop when ^I could not find what you were referring to. if %shop then { action instant var preposition in when ^In .+, you see:$ action instant var preposition on when ^On .+, you see:$ } action goto continue when ^It is labeled|^Illustrations action goto continue2 when ^I could not find main: var index_counter 0 var current_index var scroll_type_counter 0 var current_scroll var sort_command eval current_container element("%container",%container_counter) if %current_container = "" then goto done if %shop then { send shop %current_container pause } send #echo Yellow >%output_window %current_container: loop: pause 0.1 if %scroll_type_counter >= %scroll_type_total then goto next_container eval current_scroll_type element("%scroll_type", %scroll_type_counter) if %index_counter = 0 then { ##send #echo Green >%output_window %current_scroll_type: } eval current_index element("%index", %index_counter) put look %current_index %current_scroll_type %preposition %current_container pause 10 send #echo >%output_window ************* send #echo >%output_window * Script timed out! send #echo >%output_window ************* exit continue: if ((%index_counter = 0) && (%scroll_type_counter > 0)) then { send #echo >%output_window } continue2: send #echo >%output_window %current_index %current_scroll_type: %spell_name math index_counter add 1 if %index_counter >= %index_total then { send #echo Red >%output_window There may be more of these. if !%shop then { eval sort_command toupper("sort %current_scroll_type in my %current_container") send #echo Red >%output_window To see the rest try using %sort_command and running the script again. } var index_counter 0 math scroll_type_counter add 1 } goto loop next_container: math container_counter add 1 send #echo >%output_window if %container_counter >= %container_total then goto done goto main no_shop: pause 0.1 echo ***************** echo * You are not in a shop! echo ***************** exit done: send #echo Gray >%output_window Complete! exit