Compare commits
2 Commits
0eee67d3d9
...
97ed3150ec
Author | SHA1 | Date | |
---|---|---|---|
|
97ed3150ec | ||
|
c058783a11 |
13
Customer.cpp
13
Customer.cpp
@ -10,6 +10,7 @@ Customer::Customer(string name_, Verhicle_type verhicle_):
|
|||||||
save_db();
|
save_db();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Customer::Customer(int id_, string name_, string card_code_, Verhicle_type verhicle_, vector<Park_time> instances)
|
Customer::Customer(int id_, string name_, string card_code_, Verhicle_type verhicle_, vector<Park_time> instances)
|
||||||
: name{name_},
|
: name{name_},
|
||||||
card_code{card_code_},
|
card_code{card_code_},
|
||||||
@ -20,19 +21,20 @@ Customer::Customer(int id_, string name_, string card_code_, Verhicle_type verhi
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// clock in/out methods ====================================================================================
|
||||||
// clock methods ====================================================================================
|
|
||||||
/*
|
/*
|
||||||
creert een park_time object met start time= nu, en voegt t toe aan een vector.
|
Create a p_time object with start=now and adds to vector
|
||||||
*/
|
*/
|
||||||
void Customer::clock_in(int s_id) {
|
void Customer::clock_in(int s_id) {
|
||||||
Park_time pt{id, s_id};
|
Park_time pt{id, s_id};
|
||||||
park_instances.push_back(pt);
|
park_instances.push_back(pt);
|
||||||
}
|
}
|
||||||
|
|
||||||
// edit de laatste park_time obj in de vector zodat de end_time = now.
|
// edit last p_time object so end=now
|
||||||
void Customer::clock_out(int s_id) { park_instances[park_instances.size() - 1].clock_out(id, s_id); }
|
void Customer::clock_out(int s_id) { park_instances[park_instances.size() - 1].clock_out(id, s_id); }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// report gen
|
// report gen
|
||||||
void Customer::gen_monthly() {
|
void Customer::gen_monthly() {
|
||||||
std::cout << "NAME: " << name << " card code: " << card_code << "\n";
|
std::cout << "NAME: " << name << " card code: " << card_code << "\n";
|
||||||
@ -44,6 +46,7 @@ void Customer::gen_monthly() {
|
|||||||
std::cout << "-------------------------------------------------\n\n";
|
std::cout << "-------------------------------------------------\n\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//================================================================================================
|
//================================================================================================
|
||||||
// functions that interact with the database
|
// functions that interact with the database
|
||||||
|
|
||||||
@ -53,7 +56,7 @@ void Customer::save_db() {
|
|||||||
statement.insert(38, std::to_string(int(verhicle)));
|
statement.insert(38, std::to_string(int(verhicle)));
|
||||||
statement.insert(36, card_code);
|
statement.insert(36, card_code);
|
||||||
statement.insert(32, name);
|
statement.insert(32, name);
|
||||||
statement.insert(29, "null");
|
statement.insert(29, to_string(id));
|
||||||
SQLite::Transaction transaction(data::db);
|
SQLite::Transaction transaction(data::db);
|
||||||
data::db.exec(statement);
|
data::db.exec(statement);
|
||||||
transaction.commit();
|
transaction.commit();
|
||||||
|
@ -1,21 +1,79 @@
|
|||||||
#include "headers/Park_spot.h"
|
#include "headers/Park_spot.h"
|
||||||
|
|
||||||
Park_spot::Park_spot(int id_){
|
|
||||||
|
|
||||||
|
// constructors
|
||||||
|
|
||||||
|
Park_spot::Park_spot(){
|
||||||
parked = nullptr;
|
parked = nullptr;
|
||||||
id = id_;
|
id = auto_increment_db() + 1;
|
||||||
taken = false;
|
taken = false;
|
||||||
|
save_db();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// clock in en out, calls de juist(in/out) van de customer aan de hand van internal state van taken
|
// clock in en out, calls de juist(in/out) van de customer aan de hand van internal state van taken
|
||||||
void Park_spot::clock(Customer* c_customer){
|
void Park_spot::clock(Customer* c_customer){
|
||||||
if (!taken){
|
if (!taken){
|
||||||
parked = c_customer;
|
parked = c_customer;
|
||||||
taken = true;
|
taken = true;
|
||||||
parked->clock_in(id);
|
parked->clock_in(id);
|
||||||
|
update_db();
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
taken = false;
|
taken = false;
|
||||||
parked->clock_out(id);
|
parked->clock_out(id);
|
||||||
parked = nullptr;
|
parked = nullptr;
|
||||||
|
update_db();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// --------------------- db functs
|
||||||
|
|
||||||
|
void Park_spot::update_db() {
|
||||||
|
string statement = "UPDATE Park_spot SET taken = '', customer_id = '' where id = '';";
|
||||||
|
// 29, 48, 62
|
||||||
|
statement.insert(63, to_string(id));
|
||||||
|
if (taken){
|
||||||
|
statement.insert(49, to_string(parked->id));
|
||||||
|
statement.insert(30, "true");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
statement.insert(49, "NULL");
|
||||||
|
statement.insert(30, "false");
|
||||||
|
}
|
||||||
|
data::db.exec(statement);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Park_spot::save_db() {
|
||||||
|
//(int id, bool taken, int customer_id)
|
||||||
|
string statement{"insert into Park_spot values ( , , );"};
|
||||||
|
// after ( = 28)
|
||||||
|
statement.insert(34, "NULL");
|
||||||
|
statement.insert(32, "false");
|
||||||
|
statement.insert(30, to_string(id));
|
||||||
|
SQLite::Transaction transaction(data::db);
|
||||||
|
data::db.exec(statement);
|
||||||
|
transaction.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Park_spot::delete_db() {
|
||||||
|
string statement = "delete from Park_spot where id= ;";
|
||||||
|
statement.insert(statement.length() - 2, std::to_string(id));
|
||||||
|
// std::cout << statement;
|
||||||
|
SQLite::Transaction transaction(data::db);
|
||||||
|
data::db.exec(statement);
|
||||||
|
transaction.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
int Park_spot::auto_increment_db() {
|
||||||
|
SQLite::Statement max_id(data::db, "select max(id) from Park_spot;");
|
||||||
|
int id = 0;
|
||||||
|
max_id.executeStep();
|
||||||
|
id = max_id.getColumn(0);
|
||||||
|
max_id.reset();
|
||||||
|
return id;
|
||||||
|
}
|
@ -77,7 +77,6 @@ void Park_time::update_db() {
|
|||||||
statement.insert(53, std::to_string(id));
|
statement.insert(53, std::to_string(id));
|
||||||
statement.insert(40, to_string(duration));
|
statement.insert(40, to_string(duration));
|
||||||
statement.insert(27, to_string(start_to_int() + duration));
|
statement.insert(27, to_string(start_to_int() + duration));
|
||||||
std::cout << statement; // TODO: set some logging here
|
|
||||||
data::db.exec(statement);
|
data::db.exec(statement);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,12 +12,12 @@
|
|||||||
using std::string;
|
using std::string;
|
||||||
using std::vector;
|
using std::vector;
|
||||||
|
|
||||||
// enum type is basically een manier om categories te representen als een integer in the background, maar om t in code
|
// will make it easy to represent it in the database while making it easy to use while programming
|
||||||
// aan te geven als de actual category.
|
|
||||||
enum class Verhicle_type {
|
enum class Verhicle_type {
|
||||||
small = 1,
|
bike = 1,
|
||||||
medium = 2,
|
small_car = 2,
|
||||||
large = 3,
|
suv = 3,
|
||||||
|
pickup = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -43,15 +43,13 @@ class Customer {
|
|||||||
void update_db();
|
void update_db();
|
||||||
void delete_db();
|
void delete_db();
|
||||||
|
|
||||||
// void gen_weekly(); TODO: this
|
void gen_monthly(); // remove, make it a function in data
|
||||||
void gen_monthly();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Verhicle_type verhicle;
|
Verhicle_type verhicle;
|
||||||
vector<Park_time> park_instances;
|
vector<Park_time> park_instances;
|
||||||
|
|
||||||
string gen_cardcode();
|
string gen_cardcode();
|
||||||
|
|
||||||
void save_db();
|
void save_db();
|
||||||
int auto_increment_db();
|
int auto_increment_db();
|
||||||
};
|
};
|
||||||
|
@ -15,7 +15,11 @@ class Park_spot {
|
|||||||
int id;
|
int id;
|
||||||
bool taken;
|
bool taken;
|
||||||
Customer* parked; //TODO: think about memory management
|
Customer* parked; //TODO: think about memory management
|
||||||
Park_spot(int id_);
|
Park_spot();
|
||||||
void clock(Customer* c_customer);
|
void clock(Customer* c_customer);
|
||||||
private:
|
private:
|
||||||
|
void save_db();
|
||||||
|
void update_db();
|
||||||
|
void delete_db();
|
||||||
|
int auto_increment_db();
|
||||||
};
|
};
|
@ -12,26 +12,20 @@ using namespace std::chrono;
|
|||||||
using std::string;
|
using std::string;
|
||||||
using std::to_string;
|
using std::to_string;
|
||||||
/*
|
/*
|
||||||
db repr of Park_time
|
|
||||||
int id (not null, auto increment)
|
|
||||||
int customer_id (not null) (many to one or something like that)
|
|
||||||
int spot_id (not null, many to one or something like that)
|
|
||||||
int duration
|
|
||||||
datetime start (not null)
|
|
||||||
datetime end
|
|
||||||
|
|
||||||
Dit is gewoon een record van hoe lang, wie en waar iemand parkeert. Basically, een component van
|
|
||||||
de internal state van customer.
|
Record of who parked at what park_spot and at what time.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class Park_time {
|
class Park_time {
|
||||||
public:
|
public:
|
||||||
|
Park_time(int c_id, int s_id);
|
||||||
|
// Park_time(int c_id, int s_id );
|
||||||
int id;
|
int id;
|
||||||
int customer_id;
|
int customer_id;
|
||||||
int spot_id;
|
int spot_id;
|
||||||
int duration;
|
int duration;
|
||||||
Park_time(int c_id, int s_id);
|
|
||||||
// Park_time(int c_id, int s_id );
|
|
||||||
void clock_out(int c_id, int s_id);
|
void clock_out(int c_id, int s_id);
|
||||||
friend std::ostream& operator<<(std::ostream& os, const Park_time & pt);
|
friend std::ostream& operator<<(std::ostream& os, const Park_time & pt);
|
||||||
|
|
||||||
|
21
main.cpp
21
main.cpp
@ -5,6 +5,8 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#include <thread>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Code strucure like this:
|
Code strucure like this:
|
||||||
class declarations zijn in /headers/class_naam.h, en definitions van de member
|
class declarations zijn in /headers/class_naam.h, en definitions van de member
|
||||||
@ -20,16 +22,25 @@ record die zegt dat een customer voor x tijd geparkeert heeft bij spot x, enz.
|
|||||||
De client clockt in en uit bij een spot.
|
De client clockt in en uit bij een spot.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
void Wait(int sec)
|
||||||
|
/*
|
||||||
|
a wait function where 1 sec represents 1 hour irl.
|
||||||
|
*/
|
||||||
|
{
|
||||||
|
std::this_thread::sleep_for(seconds{sec});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
using std::cout;
|
using std::cout;
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
class Customer sagar{"nonsense", Verhicle_type::medium};
|
class Customer sagar{"Sagar Ramsaransing", Verhicle_type::bike};
|
||||||
sagar.update_db();
|
sagar.update_db();
|
||||||
|
Park_spot p1;
|
||||||
|
p1.clock(&sagar);
|
||||||
|
Wait(2);
|
||||||
|
p1.clock(&sagar);
|
||||||
|
|
||||||
Park_spot p1{1};
|
|
||||||
p1.clock(&sagar);
|
|
||||||
p1.clock(&sagar);
|
|
||||||
sagar.gen_monthly();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user