summaryrefslogtreecommitdiffabout
path: root/lib/hypnodata.cc
Unidiff
Diffstat (limited to 'lib/hypnodata.cc') (more/less context) (ignore whitespace changes)
-rw-r--r--lib/hypnodata.cc2
1 files changed, 2 insertions, 0 deletions
diff --git a/lib/hypnodata.cc b/lib/hypnodata.cc
index 977fb76..a64b7d7 100644
--- a/lib/hypnodata.cc
+++ b/lib/hypnodata.cc
@@ -1,92 +1,94 @@
1#include <stdlib.h>
2#include <string.h>
1#include <napkin/exception.h> 3#include <napkin/exception.h>
2#include <napkin/util.h> 4#include <napkin/util.h>
3#include <napkin/types.h> 5#include <napkin/types.h>
4 6
5namespace napkin { 7namespace napkin {
6 8
7 void hypnodata_t::clear() { 9 void hypnodata_t::clear() {
8 to_bed = alarm = 0; 10 to_bed = alarm = 0;
9 data_a = window = 0; 11 data_a = window = 0;
10 almost_awakes.clear(); 12 almost_awakes.clear();
11 } 13 }
12 14
13 static time_t from_minute_w3c(const string& w3c) { 15 static time_t from_minute_w3c(const string& w3c) {
14 struct tm t; memset(&t,0,sizeof(t)); t.tm_isdst=-1; 16 struct tm t; memset(&t,0,sizeof(t)); t.tm_isdst=-1;
15 if(sscanf(w3c.c_str(),"%04d-%02d-%02dT%02d:%02d", 17 if(sscanf(w3c.c_str(),"%04d-%02d-%02dT%02d:%02d",
16 &t.tm_year,&t.tm_mon,&t.tm_mday,&t.tm_hour,&t.tm_min)!=5) 18 &t.tm_year,&t.tm_mon,&t.tm_mday,&t.tm_hour,&t.tm_min)!=5)
17 throw exception("failed to parse w3c time"); 19 throw exception("failed to parse w3c time");
18 --t.tm_mon;t.tm_year-=1900; 20 --t.tm_mon;t.tm_year-=1900;
19 time_t rv = mktime(&t); 21 time_t rv = mktime(&t);
20 if(rv==(time_t)-1) 22 if(rv==(time_t)-1)
21 throw exception("failed to mktime()"); 23 throw exception("failed to mktime()");
22 return rv; 24 return rv;
23 } 25 }
24 26
25 void hypnodata_t::set_to_bed(const string& w3c) { 27 void hypnodata_t::set_to_bed(const string& w3c) {
26 to_bed = from_minute_w3c(w3c); } 28 to_bed = from_minute_w3c(w3c); }
27 void hypnodata_t::set_alarm(const string& w3c) { 29 void hypnodata_t::set_alarm(const string& w3c) {
28 alarm = from_minute_w3c(w3c); } 30 alarm = from_minute_w3c(w3c); }
29 void hypnodata_t::set_window(const string& str) { 31 void hypnodata_t::set_window(const string& str) {
30 window = strtol(str.c_str(),0,10); /* TODO: check for error */ 32 window = strtol(str.c_str(),0,10); /* TODO: check for error */
31 } 33 }
32 void hypnodata_t::set_data_a(const string& str) { 34 void hypnodata_t::set_data_a(const string& str) {
33 data_a = strtol(str.c_str(),0,10); /* TODO: check for error */ 35 data_a = strtol(str.c_str(),0,10); /* TODO: check for error */
34 } 36 }
35 void hypnodata_t::set_almost_awakes(const string& str) { 37 void hypnodata_t::set_almost_awakes(const string& str) {
36 almost_awakes.clear(); 38 almost_awakes.clear();
37 static const char *significants = "0123456789-T:Z"; 39 static const char *significants = "0123456789-T:Z";
38 string::size_type p = str.find_first_of(significants); 40 string::size_type p = str.find_first_of(significants);
39 struct tm t; memset(&t,0,sizeof(t)); t.tm_isdst=-1; 41 struct tm t; memset(&t,0,sizeof(t)); t.tm_isdst=-1;
40 while(p!=string::npos) { 42 while(p!=string::npos) {
41 string::size_type ns = str.find_first_not_of(significants,p); 43 string::size_type ns = str.find_first_not_of(significants,p);
42 string w3c; 44 string w3c;
43 if(ns==string::npos) { 45 if(ns==string::npos) {
44 w3c = str.substr(p); 46 w3c = str.substr(p);
45 p = string::npos; 47 p = string::npos;
46 }else{ 48 }else{
47 w3c = str.substr(p,ns-p); 49 w3c = str.substr(p,ns-p);
48 p = str.find_first_of(significants,ns); 50 p = str.find_first_of(significants,ns);
49 } 51 }
50 if(w3c.empty()) continue; 52 if(w3c.empty()) continue;
51 if(sscanf(w3c.c_str(),"%04d-%02d-%02dT%02d:%02d:%02d", 53 if(sscanf(w3c.c_str(),"%04d-%02d-%02dT%02d:%02d:%02d",
52 &t.tm_year,&t.tm_mon,&t.tm_mday,&t.tm_hour,&t.tm_min,&t.tm_sec)!=6) 54 &t.tm_year,&t.tm_mon,&t.tm_mday,&t.tm_hour,&t.tm_min,&t.tm_sec)!=6)
53 throw exception("failed to parse w3c time"); 55 throw exception("failed to parse w3c time");
54 --t.tm_mon;t.tm_year-=1900; 56 --t.tm_mon;t.tm_year-=1900;
55 time_t aa = mktime(&t); 57 time_t aa = mktime(&t);
56 if(aa==(time_t)-1) 58 if(aa==(time_t)-1)
57 throw exception("failed to mktime()"); 59 throw exception("failed to mktime()");
58 almost_awakes.push_back(aa); 60 almost_awakes.push_back(aa);
59 } 61 }
60 } 62 }
61 63
62 const string hypnodata_t::w3c_to_bed() const { 64 const string hypnodata_t::w3c_to_bed() const {
63 return strftime("%Y-%m-%dT%H:%M",to_bed); } 65 return strftime("%Y-%m-%dT%H:%M",to_bed); }
64 const string hypnodata_t::w3c_alarm() const { 66 const string hypnodata_t::w3c_alarm() const {
65 return strftime("%Y-%m-%dT%H:%M",alarm); } 67 return strftime("%Y-%m-%dT%H:%M",alarm); }
66 const string hypnodata_t::w3c_almostawakes() const { 68 const string hypnodata_t::w3c_almostawakes() const {
67 string rv; 69 string rv;
68 for(vector<time_t>::const_iterator i=almost_awakes.begin();i!=almost_awakes.end();++i) { 70 for(vector<time_t>::const_iterator i=almost_awakes.begin();i!=almost_awakes.end();++i) {
69 if(!rv.empty()) 71 if(!rv.empty())
70 rv += ','; 72 rv += ',';
71 rv += strftime("%Y-%m-%dT%H:%M:%S",*i); 73 rv += strftime("%Y-%m-%dT%H:%M:%S",*i);
72 } 74 }
73 return rv; 75 return rv;
74 } 76 }
75 77
76 const string hypnodata_t::str_to_bed() const { 78 const string hypnodata_t::str_to_bed() const {
77 return strftime("%H:%M",to_bed); } 79 return strftime("%H:%M",to_bed); }
78 const string hypnodata_t::str_alarm() const { 80 const string hypnodata_t::str_alarm() const {
79 return strftime("%H:%M",alarm); } 81 return strftime("%H:%M",alarm); }
80 const string hypnodata_t::str_date() const { 82 const string hypnodata_t::str_date() const {
81 return strftime("%Y-%m-%d, %a",alarm); } 83 return strftime("%Y-%m-%d, %a",alarm); }
82 const string hypnodata_t::str_data_a() const { 84 const string hypnodata_t::str_data_a() const {
83 char tmp[16]; 85 char tmp[16];
84 snprintf(tmp,sizeof(tmp),"%d:%02d:%02d", 86 snprintf(tmp,sizeof(tmp),"%d:%02d:%02d",
85 data_a/3600, (data_a%3600)/60, 87 data_a/3600, (data_a%3600)/60,
86 data_a % 60 ); 88 data_a % 60 );
87 return tmp; } 89 return tmp; }
88 90
89 time_t hypnodata_t::aligned_start() const { 91 time_t hypnodata_t::aligned_start() const {
90 return alarm - (alarm % (24*60*60)) - 24*60*60; } 92 return alarm - (alarm % (24*60*60)) - 24*60*60; }
91 93
92} 94}