Batch close: Difference between revisions
imported>Bale No edit summary |
imported>Heeheehee m "malled" was spelled with three l's. Hagnk's had the n and g transposed. |
||
Line 36: | Line 36: | ||
batch_open(); | batch_open(); | ||
// Empty out | // Empty out Hagnk's if it hasn't been emptied this ascension | ||
if(get_property("lastEmptiedStorage").to_int() != my_ascensions()) | if(get_property("lastEmptiedStorage").to_int() != my_ascensions()) | ||
visit_url("storage.php?action=takeall&pwd"); | visit_url("storage.php?action=takeall&pwd"); | ||
Line 47: | Line 47: | ||
if(is_tradeable(doodad)) // If the item can be malled, put it in the shop | if(is_tradeable(doodad)) // If the item can be malled, put it in the shop | ||
put_shop(historical_price(doodad), 0, doodad); | put_shop(historical_price(doodad), 0, doodad); | ||
else if(autosell_price(doodad) > 0) // If it can't be | else if(autosell_price(doodad) > 0) // If it can't be malled, autosell it | ||
autosell(available_amount(doodad), doodad); | autosell(available_amount(doodad), doodad); | ||
} | } |
Revision as of 07:23, 5 March 2010
Function Syntax
boolean batch_close()
After a batch_open(), certain functions that generate a server hit on each call are queued up, rather than executed immediately. When batch_close() is called, it will then execute all of them at once (hopefully with fewer server hits).
The functions that benefit from being batched include autosell(), mallsell(), and the various put_X(), take_X() functions that move items to or from the closet, storage, display, or stash. Most of the KoL interfaces for these are capable of transferring up to 11 items at once, but that can't otherwise be expressed in ASH. More details:
- Caution is required when using more than one batchable function in a single batch, since they won't be executed in the same order you wrote them.
- What happens in this case is that all instances of the first encountered function are executed, then all instances of the second encountered function, and so on.
- This should produce the expected results in cases such as a loop that pulls an item from storage, and then puts it in your closet.
- Inside of a batch, all the pulls get processed at once, and then all the closet puts.
- put_X() and take_X() with the same source (the closet, for example) cannot be used in the same batch.
- Batches are accumulated on a per-script-invocation basis.
- Having an open batch does not affect execution of any other script that's running at the same time.
- Any commands batched by a script that was aborted are discarded - they won't mysteriously be executed by the next script that calls batch_close()
Any failure of batched commands can be captured and tested via the return value of batch_close(), just as you'd normally check the return value of the individual functions being batched. However, there's no way to tell just how much progress had been made before the failure, so it's unlikely that a script could meaningfully continue after that point.
(Note: this function description taken in its entirety, with only slight formatting changes, from jasonharper's log notes on r7552.)
Code Sample
This short program will mall or autosell everything in the players inventory. Because batch_open() and batch_close() are used, it will mall items 11 at a time to save server hits and similarly minimize the number of commands to remove items from the closet and then autosell.
void sell_everything() {
batch_open();
// Empty out Hagnk's if it hasn't been emptied this ascension
if(get_property("lastEmptiedStorage").to_int() != my_ascensions())
visit_url("storage.php?action=takeall&pwd");
cli_execute("outfit birthday suit"); // Strip naked
// Now check every item in the entire game that the player owns
foreach doodad in $items[] if(available_amount(doodad) > 0) {
if(closet_amount(doodad)>0) // empty the closet of this item
take_closet(closet_amount(doodad), doodad);
if(is_tradeable(doodad)) // If the item can be malled, put it in the shop
put_shop(historical_price(doodad), 0, doodad);
else if(autosell_price(doodad) > 0) // If it can't be malled, autosell it
autosell(available_amount(doodad), doodad);
}
batch_close();
}
void main() {
sell_everything();
}
See Also