Compare commits

..

No commits in common. "6e573ab99279503eb8de48afcf564661f4fabf2a" and "4c0abe5464c671f8c3ed6f888c83d1cbe8066af1" have entirely different histories.

3 changed files with 71 additions and 83 deletions

View File

@ -1,7 +1,8 @@
# Compiler and flags # Compiler and flags
CPPC = g++ CPPC = g++
CPPC_FLAGS = -std=c++23 -s -O3 -lncursesw -lcurl -lmenu -lpanel -Wall -Wextra -Wno-write-strings CPPC_FLAGS = -std=c++23 -s -O3 -lncursesw -lcurl -lmenu -lpanel -Wall -Wextra -Wno-write-strings
DEBUG_FLAGS = -ggdb -std=c++23 -lncursesw -lcurl -lmenu -lpanel -Wall -Wextra -Wno-write-strings # Debug flags:
# CPPC_FLAGS = -ggdb -std=c++23 -lncursesw -lcurl -lmenu -lpanel -Wall -Wextra -Wno-write-strings
SRC_PATH := src SRC_PATH := src
@ -10,18 +11,16 @@ BIN_PATH := build/bin
SRC_FILES := $(shell find $(SRC_PATH) -name '*.cpp') SRC_FILES := $(shell find $(SRC_PATH) -name '*.cpp')
# Generate corresponding object file paths by replacing src/ with build/obj/
OBJ_FILES := $(patsubst $(SRC_PATH)/%.cpp,$(OBJ_PATH)/%.o,$(SRC_FILES)) OBJ_FILES := $(patsubst $(SRC_PATH)/%.cpp,$(OBJ_PATH)/%.o,$(SRC_FILES))
all: make-build-dir $(BIN_PATH)/bakatui all: make-build-dir $(BIN_PATH)/bakatui
debug: CPPC_FLAGS = $(DEBUG_FLAGS)
debug: make-build-dir $(BIN_PATH)/bakatui
make-build-dir: make-build-dir:
mkdir -p $(OBJ_PATH) mkdir -p $(OBJ_PATH)
mkdir -p $(OBJ_PATH)/marks
mkdir -p $(BIN_PATH) mkdir -p $(BIN_PATH)
@ -36,4 +35,4 @@ $(OBJ_PATH)/%.o: $(SRC_PATH)/%.cpp
clean: clean:
rm -fr build rm -fr build
.PHONY: all clean install debug .PHONY: all clean install

View File

@ -1,7 +1,7 @@
#include <string_view> #include <string_view>
#ifndef VERSION #ifndef VERSION
#define VERSION "0.7" #define VERSION "0.6"
#define NAME "bakatui" #define NAME "bakatui"
inline constexpr auto hash_djb2a(const std::string_view sv) { inline constexpr auto hash_djb2a(const std::string_view sv) {

View File

@ -23,17 +23,15 @@ using nlohmann::json;
const wchar_t *day_abriviations[] = {nullptr, L"Mo", L"Tu", L"We", const wchar_t *day_abriviations[] = {nullptr, L"Mo", L"Tu", L"We",
L"Th", L"Fr", L"Sa", L"Su"}; L"Th", L"Fr", L"Sa", L"Su"};
void draw_days(WINDOW **&day_windows, uint16_t cell_height, uint8_t num_of_days, void draw_days(WINDOW**& day_windows, uint16_t cell_height,uint8_t num_of_days, json &resp_from_api);
json &resp_from_api);
void draw_lessons(WINDOW **&lesson_windows, uint8_t num_of_columns, void draw_lessons(WINDOW**& lesson_windows, uint8_t num_of_columns, uint16_t cell_width, std::vector<uint8_t> &HourIdLookupTable, json &resp_from_api);
uint16_t cell_width, std::vector<uint8_t> &HourIdLookupTable,
json &resp_from_api);
void draw_cells(uint8_t num_of_columns, uint8_t num_of_days, void draw_cells(uint8_t num_of_columns, uint8_t num_of_days,
uint16_t cell_width, uint16_t cell_height, uint16_t cell_width, uint16_t cell_height,
std::vector<std::vector<WINDOW *>> &cells, std::vector<std::vector<WINDOW *>> &cells,
std::vector<uint8_t> &HourIdLookupTable, json &resp_from_api); std::vector<uint8_t> &HourIdLookupTable,
json &resp_from_api);
uint8_t hour_id_to_index(const std::vector<uint8_t> &HourIdLookupTable, uint8_t hour_id_to_index(const std::vector<uint8_t> &HourIdLookupTable,
uint8_t id) { uint8_t id) {
@ -81,8 +79,7 @@ json *find_atom_by_indexes(json &resp_from_api, uint8_t day_index,
void timetable_page() { void timetable_page() {
// DONT FORGET TO UNCOMMENT // DONT FORGET TO UNCOMMENT
json resp_from_api = json resp_from_api = bakaapi::get_data_from_endpoint("api/3/timetable/actual");
bakaapi::get_data_from_endpoint("api/3/timetable/actual");
/*std::ifstream f("test-data/timetable.json"); /*std::ifstream f("test-data/timetable.json");
json resp_from_api = json::parse(f);*/ json resp_from_api = json::parse(f);*/
@ -187,17 +184,14 @@ void timetable_page() {
day_windows[i] = newwin(cell_height, DEFAULT_OFFSET, day_windows[i] = newwin(cell_height, DEFAULT_OFFSET,
i * cell_height + DEFAULT_OFFSET, 0); i * cell_height + DEFAULT_OFFSET, 0);
} }
draw_days(day_windows, cell_height,num_of_days, resp_from_api);
// init cell windows
for (uint8_t i = 0; i < num_of_columns; i++) { for (uint8_t i = 0; i < num_of_columns; i++) {
lesson_windows[i] = lesson_windows[i] =
newwin(DEFAULT_OFFSET, cell_width, 0, i * cell_width + DEFAULT_OFFSET); newwin(DEFAULT_OFFSET, cell_width, 0, i * cell_width + DEFAULT_OFFSET);
} }
draw_lessons(lesson_windows, num_of_columns, cell_width, HourIdLookupTable, draw_lessons(lesson_windows, num_of_columns, cell_width, HourIdLookupTable, resp_from_api);
resp_from_api);
// days have to be drawn after lessons for some reason i actualy have no idea
// why
draw_days(day_windows, cell_height, num_of_days, resp_from_api);
// init the cell windows // init the cell windows
for (uint8_t i = 0; i < num_of_days; i++) { for (uint8_t i = 0; i < num_of_days; i++) {
@ -208,7 +202,7 @@ void timetable_page() {
} }
} }
draw_cells(num_of_columns, num_of_days, cell_width, cell_height, cells, draw_cells(num_of_columns, num_of_days, cell_width, cell_height, cells,
HourIdLookupTable, resp_from_api); HourIdLookupTable, resp_from_api);
refresh(); refresh();
@ -267,21 +261,20 @@ void timetable_page() {
refresh(); refresh();
// Redraw everithing // Redraw everithing
draw_days(day_windows, cell_height, num_of_days, resp_from_api); draw_days(day_windows, cell_height,num_of_days, resp_from_api);
draw_lessons(lesson_windows, num_of_columns, cell_width, draw_lessons(lesson_windows, num_of_columns, cell_width, HourIdLookupTable, resp_from_api);
HourIdLookupTable, resp_from_api);
draw_cells(num_of_columns, num_of_days, cell_width, cell_height, cells, draw_cells(num_of_columns, num_of_days, cell_width, cell_height, cells,
HourIdLookupTable, resp_from_api); HourIdLookupTable, resp_from_api);
for (uint8_t i = 0; i < selector_panels.size(); i++) { for (uint8_t i = 0; i < selector_panels.size(); i++) {
top_panel(selector_panels[i]); top_panel(selector_panels[i]);
} }
update_panels(); update_panels();
doupdate(); doupdate();
is_info_box_open = false; is_info_box_open = false;
continue; continue;
} }
run_loop_again: run_loop_again:
switch (ch) { switch (ch) {
case KEY_UP: case KEY_UP:
@ -336,14 +329,14 @@ void timetable_page() {
} }
} }
std::wstring Teacher = L""; std::wstring Teacher= L"";
try { try {
Teacher = get_data_for_atom(resp_from_api, atom, "Teachers", Teacher = get_data_for_atom(resp_from_api, atom, "Teachers",
"TeacherId", "Name"); "TeacherId", "Name");
} catch (...) { } catch(...) {
__asm__("nop"); __asm__("nop");
} }
Teacher.insert(0, L"Teacher: "); Teacher.insert(0,L"Teacher: ");
std::wstring Groups = L""; std::wstring Groups = L"";
try { try {
@ -365,31 +358,28 @@ void timetable_page() {
Groups = wrm_tr_le_whitespace(Groups); Groups = wrm_tr_le_whitespace(Groups);
Groups.insert(0, L"Groups: "); Groups.insert(0, L"Groups: ");
std::wstring Room = L""; std::wstring Room= L"";
try { try {
Room = Room = get_data_for_atom(resp_from_api, atom, "Rooms", "RoomId", "Name");
get_data_for_atom(resp_from_api, atom, "Rooms", "RoomId", "Name"); if(Room.empty()) {
if (Room.empty()) { Room = get_data_for_atom(resp_from_api, atom, "Rooms", "RoomId", "Abbrev");;
Room = get_data_for_atom(resp_from_api, atom, "Rooms", "RoomId",
"Abbrev");
;
} }
} catch (...) { } catch (...) {
__asm__("nop"); __asm__("nop");
} }
Room.insert(0, L"Room: "); Room.insert(0, L"Room: ");
std::wstring Theme = L""; std::wstring Theme= L"";
try { try {
Theme = wrm_tr_le_whitespace( Theme = wrm_tr_le_whitespace(string_to_wstring(atom->at("Theme").get<std::string>()));
string_to_wstring(atom->at("Theme").get<std::string>()));
} catch (...) { } catch (...) {
__asm__("nop"); __asm__("nop");
} }
Theme.insert(0, L"Theme: "); Theme.insert(0, L"Theme: ");
wprint_in_middle(infobox_window, 1, 0, getmaxx(infobox_window), wprint_in_middle(
Caption.c_str(), COLOR_PAIR(COLOR_CYAN)); infobox_window, 1, 0, getmaxx(infobox_window), Caption.c_str(),
COLOR_PAIR(COLOR_CYAN));
// printing out of order to reduce wattro* directives // printing out of order to reduce wattro* directives
wattron(infobox_window, COLOR_PAIR(COLOR_YELLOW)); wattron(infobox_window, COLOR_PAIR(COLOR_YELLOW));
@ -402,6 +392,8 @@ void timetable_page() {
mvwaddwstr(infobox_window, 6, 1, Theme.c_str()); mvwaddwstr(infobox_window, 6, 1, Theme.c_str());
wattroff(infobox_window, COLOR_PAIR(COLOR_CYAN)); wattroff(infobox_window, COLOR_PAIR(COLOR_CYAN));
top_panel(infobox_panel); top_panel(infobox_panel);
update_panels(); update_panels();
doupdate(); doupdate();
@ -430,8 +422,8 @@ void timetable_page() {
DEFAULT_OFFSET + y_offset + selected_cell.y * cell_height, DEFAULT_OFFSET + y_offset + selected_cell.y * cell_height,
DEFAULT_OFFSET + x_offset + selected_cell.x * cell_width); DEFAULT_OFFSET + x_offset + selected_cell.x * cell_width);
} }
draw_cells(num_of_columns, num_of_days, cell_width, cell_height, cells, draw_cells(num_of_columns, num_of_days, cell_width, cell_height,
HourIdLookupTable, resp_from_api); cells, HourIdLookupTable, resp_from_api);
update_panels(); update_panels();
doupdate(); doupdate();
@ -446,25 +438,20 @@ void timetable_page() {
endwin(); endwin();
} }
void draw_days(WINDOW **&day_windows, uint16_t cell_height, uint8_t num_of_days, void draw_days(WINDOW**& day_windows, uint16_t cell_height,uint8_t num_of_days, json &resp_from_api) {
json &resp_from_api) {
for (uint8_t i = 0; i < num_of_days; i++) { for (uint8_t i = 0; i < num_of_days; i++) {
// this wont draw left boarder window making it so it looks partially // this wont draw left boarder window making it so it looks partially
// offscreen // offscreen
wborder(day_windows[i], ' ', 0, 0, 0, ACS_HLINE, 0, ACS_HLINE, 0); wborder(day_windows[i], ' ', 0, 0, 0, ACS_HLINE, 0, ACS_HLINE, 0);
mvwaddwstr( mvwaddwstr(day_windows[i], cell_height / 2, 0,day_abriviations[resp_from_api["Days"][i]["DayOfWeek"].get<uint8_t>()]);
day_windows[i], cell_height / 2, 0,
day_abriviations[resp_from_api["Days"][i]["DayOfWeek"].get<uint8_t>()]);
wrefresh(day_windows[i]); wrefresh(day_windows[i]);
} }
} }
void draw_lessons(WINDOW **&lesson_windows, uint8_t num_of_columns, void draw_lessons(WINDOW**& lesson_windows, uint8_t num_of_columns, uint16_t cell_width, std::vector<uint8_t> &HourIdLookupTable, json &resp_from_api) {
uint16_t cell_width, std::vector<uint8_t> &HourIdLookupTable, for (uint8_t i = 0; i < num_of_columns; i++) {
json &resp_from_api) { wborder(lesson_windows[i], 0, 0, ' ', 0, ACS_VLINE, ACS_VLINE, 0, 0);
for (uint8_t i = 0; i < num_of_columns; i++) {
wborder(lesson_windows[i], 0, 0, ' ', 0, ACS_VLINE, ACS_VLINE, 0, 0);
std::wstring caption; std::wstring caption;
std::wstring start_time; std::wstring start_time;
std::wstring end_time; std::wstring end_time;
@ -493,20 +480,21 @@ void draw_lessons(WINDOW **&lesson_windows, uint8_t num_of_columns,
hour_id_found: hour_id_found:
wprint_in_middle(lesson_windows[i], 0, 0, cell_width, caption.c_str(), wprint_in_middle(lesson_windows[i], 0, 0, cell_width,
COLOR_PAIR(0)); caption.c_str(), COLOR_PAIR(0));
mvwaddwstr(lesson_windows[i], 1, 1, start_time.c_str()); mvwaddwstr(lesson_windows[i], 1, 1, start_time.c_str());
print_in_middle(lesson_windows[i], 1, 0, cell_width, "-", COLOR_PAIR(0)); print_in_middle(lesson_windows[i], 1, 0, cell_width, "-",
mvwaddwstr(lesson_windows[i], 1, cell_width - end_time.length() - 1, COLOR_PAIR(0));
end_time.c_str()); mvwaddwstr(lesson_windows[i], 1, cell_width - end_time.length() - 1, end_time.c_str());
wrefresh(lesson_windows[i]); wrefresh(lesson_windows[i]);
} }
} }
void draw_cells(uint8_t num_of_columns, uint8_t num_of_days, void draw_cells(uint8_t num_of_columns, uint8_t num_of_days,
uint16_t cell_width, uint16_t cell_height, uint16_t cell_width, uint16_t cell_height,
std::vector<std::vector<WINDOW *>> &cells, std::vector<std::vector<WINDOW *>> &cells,
std::vector<uint8_t> &HourIdLookupTable, json &resp_from_api) { std::vector<uint8_t> &HourIdLookupTable,
json &resp_from_api) {
for (uint8_t i = 0; i < num_of_days; i++) { for (uint8_t i = 0; i < num_of_days; i++) {
for (uint8_t j = 0; j < num_of_columns; j++) { for (uint8_t j = 0; j < num_of_columns; j++) {
@ -574,11 +562,12 @@ void draw_cells(uint8_t num_of_columns, uint8_t num_of_days,
__asm__("nop"); __asm__("nop");
} }
wprint_in_middle(cells[i][j], cell_height / 2, 0, cell_width, wprint_in_middle(cells[i][j], cell_height / 2,
Subject_Abbrev.c_str(), COLOR_PAIR(0)); 0,
cell_width, Subject_Abbrev.c_str(),
COLOR_PAIR(0));
mvwaddwstr(cells[i][j], cell_height - 2, mvwaddwstr(cells[i][j], cell_height - 2,
cell_width - wcslen(Room_Abbrev.c_str()) - 1, cell_width - wcslen(Room_Abbrev.c_str()) - 1, Room_Abbrev.c_str());
Room_Abbrev.c_str());
mvwaddwstr(cells[i][j], cell_height - 2, 1, Teacher_Abbrev.c_str()); mvwaddwstr(cells[i][j], cell_height - 2, 1, Teacher_Abbrev.c_str());
wrefresh(cells[i][j]); wrefresh(cells[i][j]);