]> Pileus Git - lackey/blobdiff - src/util.c
Add day and week view
[lackey] / src / util.c
index 55cd265a14b45812ea66a743f39ff139f83303f5..9f7bdfaf7cf5bb034d541ca42f1d0774985e6f96 100644 (file)
@@ -1,31 +1,18 @@
 /* Time Keeping Bugs Abound! */
 
 #include <stdio.h>
+#include <time.h>
 
 #include "util.h"
 
-/* Helper functions */
-static int is_leap_year(year_t year)
+/* Time functions */
+int is_leap_year(year_t year)
 {
        return (year % 400 == 0) ? 1 :
               (year % 100 == 0) ? 0 :
               (year % 4   == 0) ? 1 : 0;
 }
 
-static wday_t day_of_week(year_t year, month_t month, day_t day)
-{
-       static int tmp[] = {0, 3, 2, 5, 0, 3,
-                           5, 1, 4, 6, 2, 4};
-       if (month < 3)
-               year--;
-       int start = year + year / 4
-                        - year / 100
-                        + year / 400
-                        + tmp[month];
-       return (start + day) % 7;
-}
-
-/* Time functions */
 int days_in_year(year_t year)
 {
        return 365 + is_leap_year(year);
@@ -47,18 +34,45 @@ int weeks_in_month(year_t year, month_t month)
        return ((start + days)-1) / 7 + 1;
 }
 
+wday_t day_of_week(year_t year, month_t month, day_t day)
+{
+       static int tmp[] = {0, 3, 2, 5, 0, 3,
+                           5, 1, 4, 6, 2, 4};
+       if (month < 3)
+               year--;
+       int start = year + year / 4
+                        - year / 100
+                        + year / 400
+                        + tmp[month];
+       return (start + day) % 7;
+}
+
 wday_t start_of_month(year_t year, month_t month)
 {
        return day_of_week(year, month, 1);
 }
 
+void add_days(year_t *year, month_t *month, day_t *day, int days)
+{
+       time_t time = mktime(&(struct tm){
+                       .tm_year = *year-1900,
+                       .tm_mon  = *month,
+                       .tm_mday = *day+1,
+                       .tm_hour = 12});
+       time  += days*24*60*60;
+       struct tm *tm = localtime(&time);
+       *year  = tm->tm_year+1900;
+       *month = tm->tm_mon;
+       *day   = tm->tm_mday-1;
+}
+
 /* Debug functions */
 const char *month_to_str(month_t month)
 {
        static const char *map[] =
                { "Jan", "Feb", "Mar", "Apr", "May", "Jun",
                  "Jul", "Aug", "Sep", "Oct", "Nov", "Dec", };
-       return map[month];
+       return map[month%12];
 }
 const char *month_to_string(month_t month)
 {
@@ -66,27 +80,27 @@ const char *month_to_string(month_t month)
                { "January",   "February", "March",    "April",
                  "May",       "June",     "July",     "August",
                  "September", "October",  "November", "December" };
-       return map[month];
+       return map[month%12];
 }
 
 const char *day_to_st(wday_t day)
 {
        static const char *map[] =
                { "Su","Mo", "Tu", "We", "Th", "Fr", "Sa" };
-       return map[day];
+       return map[day%7];
 }
 const char *day_to_str(wday_t day)
 {
        static const char *map[] =
                { "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat" };
-       return map[day];
+       return map[day%7];
 }
 const char *day_to_string(wday_t day)
 {
        static const char *map[] =
                { "Sunday",   "Monday", "Tuesday", "Wednesday",
                  "Thursday", "Friday", "Saturday" };
-       return map[day];
+       return map[day%7];
 }
 
 /* Test functions */