diff options
author | San Jacobs | 2022-08-08 10:57:52 +0200 |
---|---|---|
committer | San Jacobs | 2022-08-08 10:58:39 +0200 |
commit | 1f0d52aaddc9d39986724733db265d300bd8f6c8 (patch) | |
tree | 6992f753b9bbe6e53868ec98fc8aacd84559e8b0 | |
parent | e658e00804690c18ea1e44533e9c1385216e04ff (diff) | |
download | satscalc-1f0d52aaddc9d39986724733db265d300bd8f6c8.tar.gz satscalc-1f0d52aaddc9d39986724733db265d300bd8f6c8.tar.bz2 satscalc-1f0d52aaddc9d39986724733db265d300bd8f6c8.zip |
Cleanup
-rw-r--r-- | .gitignore | 3 | ||||
-rw-r--r-- | makefile | 11 | ||||
-rwxr-xr-x | src/main.cpp | 351 | ||||
-rwxr-xr-x | test.sh | 2 |
4 files changed, 186 insertions, 181 deletions
@@ -2,6 +2,9 @@ __pycache__ obj/*.o a.out a.exe +satscalc +satscalc.exe +satscalc32.exe notes.txt a.pdb remedy.rdbg @@ -25,17 +25,17 @@ OBJECTS=$(patsubst src/%.cpp, $(OBJDIR)%.o, $(SOURCES)) # This last line creates an identical list of objects based on the list of .cpp files. a.out: $(OBJECTS) - $(CXX) $(LIBDIR) $(CVERSION) $(CFLAGS) $(LIBS) $(OBJECTS) + $(CXX) $(LIBDIR) $(CVERSION) $(CFLAGS) $(LIBS) $(OBJECTS) -o satscalc $(OBJECTS): obj/%.o : src/%.cpp mkdir -p obj $(CXX) -g $(INCLUDE) $(CVERSION) $(CFLAGS) -c $< -o $@ windows: - zig c++ -target x86_64-windows-gnu src/*.cpp -std=c++17 -g -gcodeview + zig c++ -target x86_64-windows-gnu src/*.cpp $(CVERSION) -g -gcodeview -o satscalc.exe windows32: - zig c++ -target i386-windows-gnu src/*.cpp -std=c++17 -g -gcodeview + zig c++ -target i386-windows-gnu src/*.cpp $(CVERSION) -g -gcodeview -o satscalc32.exe clean: rm obj/*.o @@ -44,5 +44,8 @@ cleanall: rm obj/*.o a.out install: a.out - cp a.out /usr/local/bin/satscalc + cp satscalc /usr/local/bin/satscalc + +test: a.out + ./test.sh diff --git a/src/main.cpp b/src/main.cpp index ce5c8c3..830e737 100755 --- a/src/main.cpp +++ b/src/main.cpp @@ -33,40 +33,109 @@ int main(int argc, char* argv[]) if(argc > 1){ if(std::string(argv[1])=="test") { test(); // Test time-stuff - } - } else { - std::cout << "satscalc (C++ Edition)\n"; - std::cout << "Copyright 2022 Sander J. Skjegstad.\n"; - std::cout << "This is free software with ABSOLUTELY NO WARRENTY.\n"; - std::cout << "It does NOT give financial advice.\n\n"; + return 0; + }} + std::cout << "satscalc (C++ Edition)\n"; + std::cout << "Copyright 2022 Sander J. Skjegstad.\n"; + std::cout << "This is free software with ABSOLUTELY NO WARRENTY.\n"; + std::cout << "It does NOT give financial advice.\n\n"; - std::cout << "-----\nStep 0: Setting the dayrate\n\n"; + std::cout << "-----\nStep 0: Setting the dayrate\n\n"; - int dayrate; - std::cout << "Dayrate: "; - std::cin >> dayrate; - std::cin.ignore(); + int dayrate; + std::cout << "Dayrate: "; + std::cin >> dayrate; + std::cin.ignore(); + + long double hourly_rate = dayrate/7.5; + std::cout << "Hourly rate: " << hourly_rate << "\n\n"; + + std::cout << "How many days do you want to enter? "; + int number_of_days; + std::cin >> number_of_days; + std::cin.ignore(); + delta default_daylength{0, 8, 0}; + long double social_costs = 1.26; + + while(1) { + CLEAR; + std::cout << "\n------------- Setup and defaults -------------\n"; + std::cout << "[d] Dayrate: " << dayrate << " (" << hourly_rate << " hourly)\n"; + std::cout << "[w] Workdays to input: " << number_of_days << "\n"; + std::cout << "[l] Default length of workday: " << default_daylength.hours << "h\n"; + std::cout << "[s] Social costs: " << (social_costs-1)*100 << "%\n"; + //std::cout << "[l] Lunch: " << timeprint((timeblock){lunch_start, lunch_end}) << "\n" << std::endl; - long double hourly_rate = dayrate/7.5; - std::cout << "Hourly rate: " << hourly_rate << "\n\n"; + std::cout << "\nWrite the letter for what you want to change, or 0 to continue." << std::endl; - std::cout << "How many days do you want to enter? "; - int number_of_days; - std::cin >> number_of_days; + char input_char = '5'; + std::cin >> input_char; std::cin.ignore(); - delta default_daylength{0, 8, 0}; - long double social_costs = 1.26; + + std::cout << "\n"; + switch (input_char) { + case '0': + goto setup_done; + case 'd': + std::cout << "Changing dayrate.\nDayrate: "; + std::cin >> dayrate; + std::cin.ignore(); + hourly_rate = dayrate/7.5; + break; + case 'w': + std::cout << "Changing number of workdays.\nDays: "; + std::cin >> number_of_days; + std::cin.ignore(); + break; + case 'l': + std::cout << "Changing default workday length:\nHours: "; + std::cin >> default_daylength.hours; + std::cin.ignore(); + break; + case 's': + { + std::cout << "Changing social cost percentage:\nSocial cost %"; + int social_input = 0; + std::cin >> social_input; + std::cin.ignore(); + social_costs = (social_input+100.0f)/100.0f; + break; + } + default: + std::cout << "ERROR: That's not a valid char, ya doofus." << std::endl; + } + } +setup_done: + CLEAR; + + //number_of_days = 1; // Just here for debugging + workday workdays[number_of_days]; + + moment previous_wrap{0, 16, 20, 11, 1000}; // Set to a long time ago + + for(int day=0; day<number_of_days; day++) { + + // TODO: Inputing the dates should be done with a custom function and layout, + // not std::cin, because it openly allows for invalid input + std::cout << "\n - DAY " << day+1 << "-\nCalltime:\n"; + moment calltime = timeinput(); + + moment wraptime = calltime+default_daylength; + moment planned_wraptime = wraptime; + // TODO: Maybe lunch should be 0000-00-00 00:00 if day is short. + moment lunch_start = calltime+(delta){0,4,0}; + moment lunch_end = lunch_start+(delta){30,0,0}; while(1) { CLEAR; - std::cout << "\n------------- Setup and defaults -------------\n"; - std::cout << "[d] Dayrate: " << dayrate << " (" << hourly_rate << " hourly)\n"; - std::cout << "[w] Workdays to input: " << number_of_days << "\n"; - std::cout << "[l] Default length of workday: " << default_daylength.hours << "h\n"; - std::cout << "[s] Social costs: " << (social_costs-1)*100 << "%\n"; - //std::cout << "[l] Lunch: " << timeprint((timeblock){lunch_start, lunch_end}) << "\n" << std::endl; + std::cout << "\n------------- DAY " << day+1 << " -------------\n"; + std::cout << "[c] Calltime: " << timeprint(calltime) << "\n"; + std::cout << "[w] Wraptime: " << timeprint(wraptime) << "\n"; + std::cout << "[p] Planned wrap: " << timeprint(planned_wraptime) << "\n"; + std::cout << "[l] Lunch: " << timeprint((timeblock){lunch_start, lunch_end}) << "\n"; + // TODO: Add second lunch option - std::cout << "\nWrite the letter for what you want to change, or 0 to continue." << std::endl; + std::cout << "\nWrite the letter for what you want to change, or 0 to go to the next day." << std::endl; char input_char = '5'; std::cin >> input_char; @@ -75,175 +144,105 @@ int main(int argc, char* argv[]) std::cout << "\n"; switch (input_char) { case '0': - goto setup_done; - case 'd': - std::cout << "Changing dayrate.\nDayrate: "; - std::cin >> dayrate; - std::cin.ignore(); - hourly_rate = dayrate/7.5; + goto done; + case 'c': + std::cout << "Changing calltime.\n"; + calltime = timeinput(); break; case 'w': - std::cout << "Changing number of workdays.\nDays: "; - std::cin >> number_of_days; - std::cin.ignore(); + std::cout << "Changing actual wraptime.\n"; + wraptime = timeinput(calltime); break; - case 'l': - std::cout << "Changing default workday length:\nHours: "; - std::cin >> default_daylength.hours; - std::cin.ignore(); + case 'p': + std::cout << "Changing planned wraptime.\n"; + planned_wraptime = timeinput(calltime); break; - case 's': - { - std::cout << "Changing social cost percentage:\nSocial cost %"; - int social_input = 0; - std::cin >> social_input; - std::cin.ignore(); - social_costs = (social_input+100.0f)/100.0f; + case 'l': + std::cout << "Changing lunch-time.\n"; + std::cout << "Lunch start:\n"; + lunch_start = timeinput(calltime); + std::cout << "Lunch end:\n"; + lunch_end = timeinput(calltime); break; - } default: - std::cout << "ERROR: That's not a valid char, ya doofus." << std::endl; + std::cout << "ERROR: That's not a valid number, ya doofus." << std::endl; } } -setup_done: - CLEAR; +done: - //number_of_days = 1; // Just here for debugging - workday workdays[number_of_days]; + workdays[day] = {previous_wrap, + calltime, + wraptime, + planned_wraptime}; - moment previous_wrap{0, 16, 20, 11, 1000}; // Set to a long time ago + if(lunch_start != lunch_end) workdays[day].lunch(lunch_start, lunch_end); - for(int day=0; day<number_of_days; day++) { - - // TODO: Inputing the dates should be done with a custom function and layout, - // not std::cin, because it openly allows for invalid input - std::cout << "\n - DAY " << day+1 << "-\nCalltime:\n"; - moment calltime = timeinput(); - - moment wraptime = calltime+default_daylength; - moment planned_wraptime = wraptime; - // TODO: Maybe lunch should be 0000-00-00 00:00 if day is short. - moment lunch_start = calltime+(delta){0,4,0}; - moment lunch_end = lunch_start+(delta){30,0,0}; - - while(1) { - CLEAR; - std::cout << "\n------------- DAY " << day+1 << " -------------\n"; - std::cout << "[c] Calltime: " << timeprint(calltime) << "\n"; - std::cout << "[w] Wraptime: " << timeprint(wraptime) << "\n"; - std::cout << "[p] Planned wrap: " << timeprint(planned_wraptime) << "\n"; - std::cout << "[l] Lunch: " << timeprint((timeblock){lunch_start, lunch_end}) << "\n"; - // TODO: Add second lunch option - - std::cout << "\nWrite the letter for what you want to change, or 0 to go to the next day." << std::endl; - - char input_char = '5'; - std::cin >> input_char; - std::cin.ignore(); - - std::cout << "\n"; - switch (input_char) { - case '0': - goto done; - case 'c': - std::cout << "Changing calltime.\n"; - calltime = timeinput(); - break; - case 'w': - std::cout << "Changing actual wraptime.\n"; - wraptime = timeinput(calltime); - break; - case 'p': - std::cout << "Changing planned wraptime.\n"; - planned_wraptime = timeinput(calltime); - break; - case 'l': - std::cout << "Changing lunch-time.\n"; - std::cout << "Lunch start:\n"; - lunch_start = timeinput(calltime); - std::cout << "Lunch end:\n"; - lunch_end = timeinput(calltime); - break; - default: - std::cout << "ERROR: That's not a valid number, ya doofus." << std::endl; - } - } -done: - - workdays[day] = {previous_wrap, - calltime, - wraptime, - planned_wraptime}; - - if(lunch_start != lunch_end) workdays[day].lunch(lunch_start, lunch_end); - - std::cout << "\nCalltime: " << timeprint(workdays[day].call) << "\n"; - std::cout << "Wraptime: " << timeprint(workdays[day].wrap) << "\n"; - std::cout << "Planned wrap: " << timeprint(workdays[day].planned_wrap) << "\n\n"; - - for(int i=0; i<workdays[day].total_timeblocks; i++) { - std::cout << "Timeblock " << i << ": " << timeprint(workdays[day].blocks[i]) - << ". Total hours: " << workdays[day].blocks[i].hourcount() - << "\t Valuefactor: " << workdays[day].blocks[i].valuefactor << std::endl; - } - - // This assumes that the user is entering things chronologically, which they may not be - previous_wrap = wraptime; - CLEAR; + std::cout << "\nCalltime: " << timeprint(workdays[day].call) << "\n"; + std::cout << "Wraptime: " << timeprint(workdays[day].wrap) << "\n"; + std::cout << "Planned wrap: " << timeprint(workdays[day].planned_wrap) << "\n\n"; + + for(int i=0; i<workdays[day].total_timeblocks; i++) { + std::cout << "Timeblock " << i << ": " << timeprint(workdays[day].blocks[i]) + << ". Total hours: " << workdays[day].blocks[i].hourcount() + << "\t Valuefactor: " << workdays[day].blocks[i].valuefactor << std::endl; } - std::cout << "\n\n\n -+-+-+-+-+-+-+- CALCULATION -+-+-+-+-+-+-+-\n\n"; - std::cout << "Dayrate: " << dayrate << "\n"; - std::cout << "Hourly rate: " << hourly_rate << "\n"; - std::cout << "Social costs: " << (social_costs-1)*100 << "%\n"; - double total_sum = 0; - for(int ii=0; ii < number_of_days; ii++) { - workday& each_day = workdays[ii]; - double day_price = 0; - std::cout << "\n ----- Day " << ii+1 << ": " << timeprint(each_day.call, false) << " ----- " << "\n"; - - for(int jj=0; jj < each_day.total_timeblocks; jj++) { - timeblock& each_block = each_day.blocks[jj]; - double block_price = each_block.hourcount() * hourly_rate * each_block.valuefactor; - - std::cout << timeprint(each_block, true) << ", " - << each_block.hourcount() << "h\t+" - << (each_block.valuefactor-1)*100 << "%\t= " - << block_price; - //if(each_block.price_reason != "Norm") { - std::cout << " \t[" << each_block.price_reason << "]"; - //} - std::cout << "\n"; - - day_price += block_price; - } + // This assumes that the user is entering things chronologically, which they may not be + previous_wrap = wraptime; + CLEAR; + } + std::cout << "\n\n\n -+-+-+-+-+-+-+- CALCULATION -+-+-+-+-+-+-+-\n\n"; + std::cout << "Dayrate: " << dayrate << "\n"; + std::cout << "Hourly rate: " << hourly_rate << "\n"; + std::cout << "Social costs: " << (social_costs-1)*100 << "%\n"; + + double total_sum = 0; + for(int ii=0; ii < number_of_days; ii++) { + workday& each_day = workdays[ii]; + double day_price = 0; + std::cout << "\n ----- Day " << ii+1 << ": " << timeprint(each_day.call, false) << " ----- " << "\n"; + + for(int jj=0; jj < each_day.total_timeblocks; jj++) { + timeblock& each_block = each_day.blocks[jj]; + double block_price = each_block.hourcount() * hourly_rate * each_block.valuefactor; - double day_length = (timeblock){each_day.call, each_day.wrap}.hourcount(); + std::cout << timeprint(each_block, true) << ", " + << each_block.hourcount() << "h\t+" + << (each_block.valuefactor-1)*100 << "%\t= " + << block_price; + //if(each_block.price_reason != "Norm") { + std::cout << " \t[" << each_block.price_reason << "]"; + //} + std::cout << "\n"; - if((each_day.call.hours < 6 || each_day.call.hours >= 22) && - (each_day.wrap.hours < 6 || each_day.wrap.hours >= 22) && - day_length < 9) - { - std::cout << "Day set entirely between 22:00 and 06:00.\nPrice is dayrate plus 100% for hours worked. [§6.12B]\n"; - day_price = dayrate + (day_length * hourly_rate); - - } else if((each_day.call.hours < 6 || each_day.call.hours >= 10) && - (each_day.wrap.hours > 22 || each_day.wrap.hours <= 10)){ - if(day_price < dayrate){ - day_price = dayrate; - - std::cout << "Offset day at least partially set between 22:00 and 06:00.\nMinimum price is full dayrate. [§6.12A]\n"; - } - } - std::cout << "Price of day " << ii+1 << ": " << day_price << std::endl; - total_sum += day_price; + day_price += block_price; } - std::cout << "\nSum: " << total_sum; - std::cout << "\nTotal: " << total_sum*social_costs << std::endl; - + double day_length = (timeblock){each_day.call, each_day.wrap}.hourcount(); - return 0; + if((each_day.call.hours < 6 || each_day.call.hours >= 22) && + (each_day.wrap.hours < 6 || each_day.wrap.hours >= 22) && + day_length < 9) + { + std::cout << "Day set entirely between 22:00 and 06:00.\nPrice is dayrate plus 100% for hours worked. [§6.12B]\n"; + day_price = dayrate + (day_length * hourly_rate); + + } else if((each_day.call.hours < 6 || each_day.call.hours >= 10) && + (each_day.wrap.hours > 22 || each_day.wrap.hours <= 10)){ + if(day_price < dayrate){ + day_price = dayrate; + + std::cout << "Offset day at least partially set between 22:00 and 06:00.\nMinimum price is full dayrate. [§6.12A]\n"; + } + } + std::cout << "Price of day " << ii+1 << ": " << day_price << std::endl; + total_sum += day_price; } + + std::cout << "\nSum: " << total_sum; + std::cout << "\nTotal: " << total_sum*social_costs << std::endl; + + + return 0; } @@ -1,4 +1,4 @@ -./a.out <<EOF-MARKER +./satscalc <<EOF-MARKER 3462 10 0 |