2
0

CArtHandler.cpp 1.8 KB

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