2 * Copyright (C) 2012 Andy Spencer <andy753421@gmail.com>
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
30 /* Helper functions */
31 static void print_month(month_t month, int y, int x)
33 const char *name = month_to_string(month);
34 const int start = start_of_month(YEAR, month);
35 const char days = days_in_month(YEAR, month);
36 mvwprintw(win, y, x+MW/2-strlen(name)/2, "%s", name);
38 for (int d = 0; d < 7; d++)
39 wprintw(win, "%-3s", day_to_st(d));
40 for (int d = 0; d < days; d++) {
41 int row = (start + d) / 7;
42 int col = (start + d) % 7;
43 if (month == MONTH && d == DAY) wattron(win, A_REVERSE);
44 mvwprintw(win, y+2+row, x+col*3, "%2d", d+1);
45 if (month == MONTH && d == DAY) wattroff(win, A_REVERSE);
50 void year_init(WINDOW *_win)
66 /* Determine heights */
67 for (int m = 0; m < 12; m++) {
68 int weeks = weeks_in_month(YEAR, m);
69 h[m/3] = MAX(h[m/3], weeks+2);
71 int sum = h[0]+h[1]+h[2]+h[3];
74 mvwprintw(win, y++, COLS/2-2, "%d", YEAR);
77 for (int m = 0; m < 12; m++) {
89 mvwvline(win, y, x+(MW+3)*1-2, ACS_VLINE, sum+3);
90 mvwvline(win, y, x+(MW+3)*2-2, ACS_VLINE, sum+3);
91 for (int i = 0; i < 3; i++) {
93 mvwhline(win, y, x, ACS_HLINE, w);
94 mvwaddch(win, y, x+(MW+3)*1-2, ACS_PLUS);
95 mvwaddch(win, y, x+(MW+3)*2-2, ACS_PLUS);
101 int year_run(int key, mmask_t btn, int row, int col)
106 wday_t day = day_of_week(YEAR, MONTH, DAY);
107 int week = (start_of_month(y, m) + d) / 7;
117 if (key == 'h' || key == 'k')
119 if (key == 'j' || key == 'l')
123 if (key == 'j' || key == 'k') {
124 for (int i = 0; i < 90/7; i++) {
125 add_days(&y, &m, &d, dir*7);
126 if (day_of_week(y, m, d) == day &&
127 y == YEAR && m%3 == MONTH%3) {
135 /* Step left/right */
136 if (key == 'h' || key == 'l') {
137 for (int i = 0; i < 90; i++) {
138 add_days(&y, &m, &d, dir);
139 if ((start_of_month(y, m) + d) / 7 == week &&
140 y == YEAR && m/3 == MONTH/3) {