summaryrefslogtreecommitdiffstats
path: root/crawl-ref/source/shopping.cc
diff options
context:
space:
mode:
authorMatthew Cline <zelgadis@sourceforge.net>2009-11-27 00:28:13 -0800
committerMatthew Cline <zelgadis@sourceforge.net>2009-11-27 00:31:51 -0800
commit3e6a77f46bac1b303645b7391f72e86c882986c9 (patch)
tree719c1a228f6cc508f82a28373a9a6929e4abdade /crawl-ref/source/shopping.cc
parent2eab9ba1136309e98afa1f64bc6c493b8a70401e (diff)
downloadcrawl-ref-3e6a77f46bac1b303645b7391f72e86c882986c9.tar.gz
crawl-ref-3e6a77f46bac1b303645b7391f72e86c882986c9.zip
ShoppingList: simplify.
Diffstat (limited to 'crawl-ref/source/shopping.cc')
-rw-r--r--crawl-ref/source/shopping.cc19
1 files changed, 7 insertions, 12 deletions
diff --git a/crawl-ref/source/shopping.cc b/crawl-ref/source/shopping.cc
index a956f52bd0..c9ecd853be 100644
--- a/crawl-ref/source/shopping.cc
+++ b/crawl-ref/source/shopping.cc
@@ -2389,21 +2389,17 @@ int ShoppingList::size() const
return ( list->size() );
}
-void ShoppingList::move_things(const coord_def &src, const coord_def &dst)
+void ShoppingList::move_things(const coord_def &_src, const coord_def &_dst)
{
+ const level_pos src(level_id::current(), _src);
+ const level_pos dst(level_id::current(), _dst);
+
for (unsigned int i = 0; i < list->size(); i++)
{
CrawlHashTable &thing = (*list)[i];
- level_pos lpos = ShoppingList::thing_pos(thing);
-
- if (lpos.id != level_id::current())
- continue;
- if (lpos.pos == src)
- {
- lpos.pos = dst;
- thing[SHOPPING_THING_POS_KEY] = lpos;
- }
+ if (thing_pos(thing) == src)
+ thing[SHOPPING_THING_POS_KEY] = dst;
}
}
@@ -2412,9 +2408,8 @@ void ShoppingList::forget_pos(const level_pos &pos)
for (unsigned int i = (list->size() - 1); i>= 0; i--)
{
const CrawlHashTable &thing = (*list)[i];
- const level_pos lpos = ShoppingList::thing_pos(thing);
- if (lpos == pos)
+ if (thing_pos(thing) == pos)
list->erase(i);
}
}