Bugfix: its finally possible to open a levelsubset.
[supertux.git] / src / level.cpp
index 570b4b4..f7906ab 100644 (file)
@@ -158,6 +158,46 @@ Level::get_sector(const std::string& name)
   return i->second;
 }
 
+Sector*
+Level::get_next_sector(const Sector* sector)
+{
+  for(Sectors::iterator i = sectors.begin(); i != sectors.end(); ++i)
+    {
+    if(i->second == sector)
+      {
+      i++;
+      if(i == sectors.end())
+        return NULL;
+      return i->second;
+      }
+    }
+  std::cerr << "Warning: Sector not found on level\n";
+  return NULL;
+}
+
+Sector*
+Level::get_previous_sector(const Sector* sector)
+{
+  for(Sectors::iterator i = sectors.begin(); i != sectors.end(); ++i)
+    {
+    if(i->second == sector)
+      {
+      if(i == sectors.begin())
+        return NULL;
+      i--;
+      return i->second;
+      }
+    }
+  std::cerr << "Warning: Sector not found on level\n";
+  return NULL;
+}
+
+int
+Level::get_total_sectors()
+{
+return sectors.size();
+}
+
 int
 Level::get_total_badguys()
 {
@@ -172,8 +212,8 @@ Level::get_total_coins()
 {
   int total_coins = 0;
   for(Sectors::iterator it = sectors.begin(); it != sectors.end(); ++it)
-    for(int x = 0; x < it->second->solids->get_width(); x++)
-      for(int y = 0; y < it->second->solids->get_height(); y++)
+    for(int x = 0; static_cast<unsigned int>(x) < it->second->solids->get_width(); x++)
+      for(int y = 0; static_cast<unsigned int>(y) < it->second->solids->get_height(); y++)
         if(it->second->solids->get_tile(x,y)->attributes & Tile::COIN)
           total_coins++;
   return total_coins;