CArtHandler.cpp 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #define VCMI_DLL
  2. #include "../stdafx.h"
  3. #include "CArtHandler.h"
  4. #include "CLodHandler.h"
  5. #include <boost/assign/std/vector.hpp>
  6. #include <boost/assign/list_of.hpp>
  7. void loadToIt(std::string &dest, std::string &src, int &iter, int mode);
  8. extern CLodHandler *bitmaph;
  9. using namespace boost::assign;
  10. void CArtHandler::loadArtifacts()
  11. {
  12. std::vector<bool CArtifact::*> slots;
  13. slots += &CArtifact::spellBook, &CArtifact::warMachine4, &CArtifact::warMachine3, &CArtifact::warMachine2,
  14. &CArtifact::warMachine1, &CArtifact::misc5, &CArtifact::misc4, &CArtifact::misc3, &CArtifact::misc2,
  15. &CArtifact::misc1, &CArtifact::feet, &CArtifact::lRing, &CArtifact::rRing, &CArtifact::torso,
  16. &CArtifact::lHand, &CArtifact::rHand, &CArtifact::neck, &CArtifact::shoulders, &CArtifact::head;
  17. std::map<char,EartClass> classes =
  18. map_list_of('S',SartClass)('T',TartClass)('N',NartClass)('J',JartClass)('R',RartClass);
  19. std::string buf = bitmaph->getTextFile("ARTRAITS.TXT"), dump, pom;
  20. int it=0;
  21. for(int i=0; i<2; ++i)
  22. {
  23. loadToIt(dump,buf,it,3);
  24. }
  25. for (int i=0; i<ARTIFACTS_QUANTITY; i++)
  26. {
  27. CArtifact nart;
  28. loadToIt(nart.name,buf,it,4);
  29. loadToIt(pom,buf,it,4);
  30. nart.price=atoi(pom.c_str());
  31. for(int j=0;j<slots.size();j++)
  32. {
  33. loadToIt(pom,buf,it,4);
  34. nart.*slots[j] = (pom[0]=='x');
  35. }
  36. loadToIt(pom,buf,it,4);
  37. nart.aClass = classes[pom[0]];
  38. loadToIt(nart.description,buf,it,3);
  39. nart.id=i;
  40. artifacts.push_back(nart);
  41. }
  42. for(int i=0;i<144;i++) //do 144, bo nie chcemy bzdurek
  43. {
  44. switch (artifacts[i].aClass)
  45. {
  46. case TartClass:
  47. treasures.push_back(&(artifacts[i]));
  48. break;
  49. case NartClass:
  50. minors.push_back(&(artifacts[i]));
  51. break;
  52. case JartClass:
  53. majors.push_back(&(artifacts[i]));
  54. break;
  55. case RartClass:
  56. relics.push_back(&(artifacts[i]));
  57. break;
  58. }
  59. }
  60. }