Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Итоговый PR: mouseartiom #6

Open
wants to merge 92 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 90 commits
Commits
Show all changes
92 commits
Select commit Hold shift + click to select a range
8d368e7
added readme
stanf0rd Apr 7, 2018
45851b5
Создана базовая версия библиотеки для абстрактных классов.
Moleque Apr 7, 2018
3eec2bf
Исправлены ошибки компиляции
stanf0rd Apr 7, 2018
ae6d278
Добавлены новые классы предметов (subjects .h/.cpp).
Moleque Apr 8, 2018
b03829f
Конфликты разрешены.
Moleque Apr 8, 2018
1c9a669
Merge branch 'salman' into test
stanf0rd Apr 9, 2018
b4ee6c1
base .gitignore added
stanf0rd Apr 9, 2018
c0b02ee
Переименованны MovAble. Изменены конструкторы классов в subjects. Уда…
Moleque Apr 9, 2018
3d35bbf
abstract class Action added
stanf0rd Apr 10, 2018
47528ac
short chenged to int_fast8_t
stanf0rd Apr 10, 2018
77e8c10
Обновленный base.h
Moleque Apr 10, 2018
e598b20
merge test and salman branches
stanf0rd Apr 10, 2018
1150164
Initial commit
eadium Apr 10, 2018
14ab8f6
Merge branch 'mouseartiom' of github.com:Rasseki-Studios/rasseki.game…
eadium Apr 10, 2018
75405c8
Updated .gitignore
eadium Apr 10, 2018
094d958
added constructor/destructor
eadium Apr 10, 2018
fab1a91
Добавлены методы рассчета маршрута Move() и перемещения Step(). Id до…
Moleque Apr 11, 2018
866f45c
delete readme.md from test
Apr 11, 2018
f0c9cff
delete readme.md from test
Apr 11, 2018
2aedb01
delete readme.md from branch
Apr 11, 2018
13cc973
delete readme.md from branch
Apr 11, 2018
11a3566
Merge remote-tracking branch 'origin/salman' into salman
Apr 11, 2018
359a41d
delete readme.md from branch
Apr 11, 2018
4c61732
added getter and one color
eadium Apr 11, 2018
ec1c69e
Merge branch 'mouseartiom' of github.com:Rasseki-Studios/rasseki.game…
eadium Apr 11, 2018
7a99dcc
updated .gitignore
eadium Apr 11, 2018
728bab5
delete readme.md from branch
Apr 11, 2018
f6b95a0
Updated .gitignore
eadium Apr 11, 2018
291b5a7
Updated .gitignore
eadium Apr 11, 2018
4beb074
Merge branch 'mouseartiom' of github.com:Rasseki-Studios/rasseki.game…
eadium Apr 11, 2018
9bca0ee
const and inline added, pedantic lines swaps made
stanf0rd Apr 11, 2018
806dc48
Merge branch 'stanford' of github.com:Rasseki-Studios/rasseki.game in…
stanf0rd Apr 11, 2018
4a47cb9
Merge branch 'stanford' of github.com:Rasseki-Studios/rasseki.game in…
stanf0rd Apr 11, 2018
117a12a
ID are strings now, std::string can be used as str
stanf0rd Apr 12, 2018
b35eb9f
basic event.h and event.cpp added, class IFactory added
stanf0rd Apr 12, 2018
a5ddf66
IDs are now strings
stanf0rd Apr 12, 2018
dac9c26
id -> ID
stanf0rd Apr 12, 2018
949ca60
added namespace
eadium Apr 12, 2018
b91667f
Merge branch 'test' of github.com:Rasseki-Studios/rasseki.game into m…
eadium Apr 12, 2018
ce5db1e
Добавлены const к Get ф-циям.
Moleque Apr 12, 2018
24de712
slightly code refactored, removed namespace and added statics
eadium Apr 12, 2018
7d8b3e3
basic event reading added, base improved
stanf0rd Apr 12, 2018
8c18fe4
JV: add Qt project to Develop branch
Apr 12, 2018
a4d3713
save before move
Apr 12, 2018
3719cc5
Separate Qt project from Base, Map and Subjects
Apr 12, 2018
725f248
Remove .DS_Store from main folder
Apr 12, 2018
01ce70e
EventFabric can now read and use all event jsons
stanf0rd Apr 12, 2018
ccda882
libs were taken to libs folder
stanf0rd Apr 12, 2018
dc6ee0d
Merge branch 'stanford' into develop
stanf0rd Apr 12, 2018
c2a28d5
salman and develop branches merged
stanf0rd Apr 13, 2018
68ee06b
definition of class Movable was taken to individual file
stanf0rd Apr 13, 2018
a92b10d
fixed a small spelling error
stanf0rd Apr 13, 2018
e45f7b8
method getFromJson getting filename replaced method create
stanf0rd Apr 13, 2018
408afe4
catching exceptions in jsons, invalid events are skipping now
stanf0rd Apr 14, 2018
22b296a
Merge branch 'test' of github.com:Rasseki-Studios/rasseki.game into s…
stanf0rd Apr 14, 2018
c18fe16
fixed small spelling error
stanf0rd Apr 14, 2018
5c25f1a
EasyBMP library added
stanf0rd Apr 14, 2018
8def7a7
base transformed to item, movable and location parts
stanf0rd Apr 14, 2018
cd596b0
events support new base headers now
stanf0rd Apr 14, 2018
0d40f96
map renamed to mapdata
stanf0rd Apr 14, 2018
9246da3
mapdata updated for work with new base
stanf0rd Apr 14, 2018
3a70dea
stanford, test and mouseartiom branches are synchronized
stanf0rd Apr 14, 2018
68ddc13
updated .gitignore
eadium Apr 15, 2018
cb07a42
added eventsList but compilation fails
eadium Apr 17, 2018
b883c88
modified mapdata structure and added EventData class
eadium Apr 19, 2018
b4fa607
EventData -> EventsMapData and appropriate changes are made but this …
eadium Apr 20, 2018
e3e8bfb
added class EntityData but compilation fails though
eadium Apr 21, 2018
867879d
class EntityData made up to an end, small refactoring also
eadium Apr 21, 2018
38e25b1
removed files not corresponding to me
eadium Apr 21, 2018
116a39e
removed Qt
eadium May 1, 2018
47238a3
started work at sessions
eadium May 3, 2018
2854e54
code edited according to Google Style
eadium May 5, 2018
cbc78ac
small style improvements, new includes
stanf0rd May 7, 2018
02074f6
added GameData interfaces
eadium May 7, 2018
09bd86b
mapdata work comments for Artem
stanf0rd May 8, 2018
dfdf850
added MapScanner class
eadium May 8, 2018
f91d0e8
magic numbers were replaced ny enums
eadium May 9, 2018
11c583c
released alpha ver. of SessionData
eadium May 13, 2018
39d7b1c
Delete entitydata.cpp
eadium May 13, 2018
47bec5a
Delete entitydata.h
eadium May 13, 2018
b666d90
added validators for point and radius, removed unnecessary comments
eadium May 14, 2018
53c17c6
Merge branch 'mouseartiom' of github.com:Rasseki-Studios/rasseki.game…
eadium May 14, 2018
891f9fb
SurfaceData is now in surface.h. Namespace SessionData added.
eadium May 15, 2018
ea9832c
SurfaceData moved back to session_data.h
eadium May 15, 2018
1f5d458
added IsWalkable & GameData::Init(). Small fixes.
eadium May 15, 2018
3ffbe3b
Revert "added IsWalkable & GameData::Init(). Small fixes."
eadium May 16, 2018
615791c
session_data revived
eadium May 16, 2018
c346a49
renamed validators
eadium May 16, 2018
3985fb4
refactored code to be compilable
eadium May 16, 2018
ca6425c
changed project sructure for easier navigation
eadium May 31, 2018
3e7fa1d
synchronized with test
eadium Jun 13, 2018
7a508ea
synched with test
eadium Jun 20, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
*.[oa]
*vgcore*
.vscode/**
*.txt
*.out
*.exe
*test*
*.gch
2 changes: 0 additions & 2 deletions README.md

This file was deleted.

151 changes: 151 additions & 0 deletions database/items_data.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
#include "session_data.h"
// #include "event_factory.h"
#include "mapscanner.h"
#include <algorithm>
#include <vector>

using std::vector;
using namespace SessionData;

//---------------------------------------------------------
//----------------- EventsData ----------------------------
//---------------------------------------------------------

bool EventsData::Init() {
EventFactory eFactory;
str path = systemData.resourcesDirectory + systemData.nextLocationName + "/events";
eFactory.InitAll(path, currentEventList); // hardcoded just for debugging
// using unique_ptr for two-dim array isn't a good idea though
// std::unique_ptr<Event[][]> eventMatrix (nullptr);

eventMatrix = new std::vector<Event>** [gameData.mapHeight];
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

почему используется двойной указатель на вектор?
это же очень не очень

for (int i = 0; i != gameData.mapHeight; i++) {
eventMatrix[i] = new std::vector<Event>*;
for (int j = 0; j != gameData.mapWidth; j++) {
eventMatrix[i][j] = NULL;
}
}

PulverizeEvents(currentEventList);
return true;
}

Event* EventsData::getEvent(const str key) {
return &currentEventList.at(key);
}

Event* EventsData::getEvent(Coord point) {
if (!surfaceData.CoordIsValid(point)) return NULL;
if (!eventMatrix[point.x][point.y]) return NULL;
auto ev = eventMatrix[point.x][point.y];
if (!eventMatrix[point.x][point.y]->empty())
return &eventMatrix[point.x][point.y]->front();
else return NULL;
}

void EventsData::PulverizeEvents(std::unordered_map<str, Event>& list) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

интересное название метода

/*
parsing map - getting event and spraying it at the map.
get event
add event to map
*/
for (auto i : list) {
Event event = i.second;

int width = gameData.mapWidth;
int height = gameData.mapHeight;

Coord eventCenter = event.GetCoord();
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

можно использовать auto, чтобы не писать лишнего. Тип сам выведется

if (eventCenter.x > width || eventCenter.y > height) throw "coordinates are out of range";
if (eventCenter.x < 0 || eventCenter.y < 0) throw "invalid coordinates";

for (int i = eventCenter.x - event.getRadius(); i <= eventCenter.x + event.getRadius(); i++) {
for (int j = eventCenter.y - event.getRadius(); j <= eventCenter.y + event.getRadius(); j++) {

if (
eventCenter.y + event.getRadius() > height ||
eventCenter.x + event.getRadius() > width ||
eventCenter.y - event.getRadius() < 0 ||
eventCenter.x - event.getRadius() < 0
) break; //total size of event mark exceeded the map

// if (!SurfaceMap::getSurface(eventCenter)) break;

if (!eventMatrix[eventCenter.x][eventCenter.y]) {
eventMatrix[eventCenter.x][eventCenter.y] = new std::vector<Event>;
eventMatrix[eventCenter.x][eventCenter.y]->push_back(event);
}
else {
eventMatrix[eventCenter.x][eventCenter.y]->push_back(event);

std::push_heap( // SIC! that wasn't tested
eventMatrix[eventCenter.x][eventCenter.y]->begin(),
eventMatrix[eventCenter.x][eventCenter.y]->end(),
[](Event& a, Event& b) {
return a.getPriority() < b.getPriority();
}
);
}
}
}
}
}

void EventsData::RemoveFrontEvent(Coord point) {
Event* event = getEvent(point);
Coord center = event->GetCoord();
int radius = event->getRadius();

for (int i = center.x - radius ; i < center.x + radius; i++) {
for (int j = center.y - radius ; j < center.y + radius; j++) {
if ( surfaceData.CoordIsValid( {i, j} ) ) {
std::pop_heap(eventMatrix[i][j]->begin(),
eventMatrix[i][j]->end(),
[](Event& a, Event& b) {
return a.getPriority() < b.getPriority();
} );
};
}
}
}

bool EventsData::EventExists(str ID) {
return currentEventList.count(ID);
}

//---------------------------------------------------------
//---------------- ArtifactsData --------------------------
//---------------------------------------------------------

bool ArtifactsData::Init() {
ArtifactFactory aFactory;
str path = systemData.resourcesDirectory + systemData.nextLocationName + "/artifacts";
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

этот путь должен передаваться в конструкторе
/ - это системный разделитель - используйте системную функцию/std::filesystem

aFactory.InitAll(path, currentArtifactsList);
return true;
}

Artifact* ArtifactsData::getArtifact(const str key) {
return &currentArtifactsList.at(key);
}

bool ArtifactsData::ArtifactExists(str ID) {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

const метод

return currentArtifactsList.count(ID);
}

//---------------------------------------------------------
//--------------------- GameData --------------------------
//---------------------------------------------------------



//---------------------------------------------------------
//--------------------- SystemData ------------------------
//---------------------------------------------------------

SystemData::SystemData(str _nextLocationName)
:
resourcesDirectory("resources/"),
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

это должно задаваться ещё выше

nextLocationName(_nextLocationName),
mapName("map") {

}
57 changes: 57 additions & 0 deletions database/items_data.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
#ifndef ITEMSDATA
#define ITEMSDATA

#include <string>
#include <unordered_map>

#include "hero.h"
#include "event_factory.h"
#include "artifact.h"
// #include "artifact_factory.h"
#include "surface.h" //here is SurfaceData, temporary solution.

class SystemData {
public:
SystemData(str nextLocationName = "default_location");
str resourcesDirectory; // directory with all the resources
str nextLocationName; // ID of a map going to be loaded
str currentLocationName; // ID of a map loaded
str mapName; // name of the .bmp file
};

class GameData {
// stores finished events and other stuff
public:
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

если это public class, то лучше использовать struct...

int mapHeight;
int mapWidth;
str diaryString; // what we are writin'
str character; // who is writin'
};

class EventsData {
public:
bool Init();
Event* getEvent(const str);
Event* getEvent(Coord);
bool EventExists(str);
void RemoveFrontEvent(Coord);
// more methods coming in future
private:
void PulverizeEvents(std::unordered_map<str, Event>&); //pulverizes events from eventList
std::vector<Event> ***eventMatrix;
// std::unique_ptr<Event[][]> eventMatrix;
std::unordered_map<str, Event> currentEventList;
// std::unordered_map<str, Event> globalEventList;
};

class ArtifactsData {
public:
bool Init();
bool ArtifactExists(str);
Artifact* getArtifact(const str);
private:
std::unordered_map<str, Artifact> currentArtifactsList;
// std::unordered_map<str, Artifact> globalArtifactsList;
};

#endif //SESSION
20 changes: 20 additions & 0 deletions database/session_data.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
#include "session_data.h"
#include <iostream>

namespace SessionData {
SystemData systemData;
GameData gameData;
SurfaceData surfaceData;
EventsData eventsData;
ArtifactsData artifactsData;

str diaryString;
str writer;

// hero initialization
std::string name = "Moleque";
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

это не должно инициализироваться тут

std::string id = "super_hero";
Coord start(200, 200);
Hero hero(id, name, 1, 10, start);
}

19 changes: 19 additions & 0 deletions database/session_data.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
#ifndef SESSIONDATA
#define SESSIONDATA

#include "items_data.h"

namespace SessionData {
extern SurfaceData surfaceData;
extern GameData gameData;
extern SystemData systemData;
extern ArtifactsData artifactsData;
// extern CreatureData creatureData;
extern EventsData eventsData;
// hero initialization
extern Hero hero;
extern str diaryString;
extern str writer;
}

#endif // SESSIONDATA
Loading