#include "pch.hpp" #include "io.h" #include "table.h" #include #include #include #include "utils.h" #include char* gbuf = nullptr; void setgbuf(char* buf) { static char* b = 0; if (buf == 0) gbuf = b; else { gbuf = buf; b = buf; } } #ifdef __AQ__HAS__INT128__ template <> void print<__int128_t>(const __int128_t& v, const char* delimiter){ char s[41]; s[40] = 0; std::cout<< get_int128str(v, s+40)<< delimiter; } template <> void print<__uint128_t>(const __uint128_t&v, const char* delimiter){ char s[41]; s[40] = 0; std::cout<< get_uint128str(v, s+40) << delimiter; } std::ostream& operator<<(std::ostream& os, __int128 & v) { print(v); return os; } std::ostream& operator<<(std::ostream& os, __uint128_t & v) { print(v); return os; } #endif template <> void print(const bool&v, const char* delimiter){ std::cout<< (v?"true":"false") << delimiter; } template T getInt(const char*& buf){ T ret = 0; while(*buf >= '0' and *buf <= '9'){ ret = ret*10 + *buf - '0'; buf++; } return ret; } template char* intToString(T val, char* buf){ while (val > 0){ *--buf = val%10 + '0'; val /= 10; } return buf; } void skip(const char*& buf){ while(*buf && (*buf >'9' || *buf < '0')) buf++; } namespace types { using namespace std; using namespace chrono; date_t::date_t(const char* str) { fromString(str); } date_t& date_t::fromString(const char* str) { if(str) { skip(str); year = getInt(str); skip(str); month = getInt(str); skip(str); day = getInt(str); } else{ day = month = year = 0; } return *this; } bool date_t::validate() const{ return year <= 9999 && month <= 12 && day <= 31; } char* date_t::toString(char* buf) const { // if (!validate()) return "(invalid date)"; *--buf = 0; buf = intToString(day, buf); *--buf = '-'; buf = intToString(month, buf); *--buf = '-'; buf = intToString(year, buf); return buf; } bool date_t::operator > (const date_t& other) const { return year > other.year || (year == other.year && (month > other.month || (month == other.month && day > other.day))); } bool date_t::operator < (const date_t& other) const { return year < other.year || (year == other.year && (month < other.month || (month == other.month && day < other.day))); } bool date_t::operator >= (const date_t& other) const { return year >= other.year || (year == other.year && (month >= other.month || (month == other.month && day >= other.day))); } bool date_t::operator <= (const date_t& other) const { return year <= other.year || (year == other.year && (month <= other.month || (month == other.month && day <= other.day))); } bool date_t::operator == (const date_t& other) const { return year == other.year && month == other.month && day == other.day; } bool date_t::operator != (const date_t& other) const { return !operator==(other); } time_t::time_t(const char* str) { fromString(str); } time_t& time_t::fromString(const char* str) { if(str) { skip(str); hours = getInt(str); skip(str); minutes = getInt(str); skip(str); seconds = getInt(str); skip(str); ms = getInt (str); } else { hours = minutes = seconds = ms = 0; } return *this; } char* time_t::toString(char* buf) const { // if (!validate()) return "(invalid date)"; *--buf = 0; buf = intToString(ms, buf); *--buf = ':'; buf = intToString(seconds, buf); *--buf = ':'; buf = intToString(minutes, buf); *--buf = ':'; buf = intToString(hours, buf); return buf; } bool time_t::operator > (const time_t& other) const { return hours > other.hours || (hours == other.hours && (minutes > other.minutes || (minutes == other.minutes && (seconds > other.seconds || (seconds == other.seconds && ms > other.ms))))); } bool time_t::operator< (const time_t& other) const { return hours < other.hours || (hours == other.hours && (minutes < other.minutes || (minutes == other.minutes && (seconds < other.seconds || (seconds == other.seconds && ms < other.ms))))); } bool time_t::operator>= (const time_t& other) const { return hours >= other.hours || (hours == other.hours && (minutes >= other.minutes || (minutes == other.minutes && (seconds >= other.seconds || (seconds == other.seconds && ms >= other.ms))))); } bool time_t::operator<= (const time_t& other) const{ return hours <= other.hours || (hours == other.hours && (minutes <= other.minutes || (minutes == other.minutes && (seconds <= other.seconds || (seconds == other.seconds && ms <= other.ms))))); } bool time_t::operator==(const time_t& other) const { return hours == other.hours && minutes == other.minutes && seconds == other.seconds && ms == other.ms; } bool time_t::operator!= (const time_t& other) const { return !operator==(other); } bool time_t::validate() const{ return hours < 24 && minutes < 60 && seconds < 60 && ms < 1000000; } timestamp_t::timestamp_t(const char* str) { fromString(str); } timestamp_t& timestamp_t::fromString(const char* str) { date.fromString(str); time.fromString(str); return *this; } bool timestamp_t::validate() const { return date.validate() && time.validate(); } char* timestamp_t::toString(char* buf) const { buf = time.toString(buf); auto ret = date.toString(buf); *(buf-1) = ' '; return ret; } bool timestamp_t::operator > (const timestamp_t& other) const { return date > other.date || (date == other.date && time > other.time); } bool timestamp_t::operator < (const timestamp_t& other) const { return date < other.date || (date == other.date && time < other.time); } bool timestamp_t::operator >= (const timestamp_t& other) const { return date >= other.date || (date == other.date && time >= other.time); } bool timestamp_t::operator <= (const timestamp_t& other) const { return date <= other.date || (date == other.date && time <= other.time); } bool timestamp_t::operator == (const timestamp_t& other) const { return date == other.date && time == other.time; } bool timestamp_t::operator!= (const timestamp_t & other) const { return !operator==(other); } } template void print_datetime(const T&v){ char buf[T::string_length()]; std::cout< u(0x10000, 0xfffff); uint64_t uuid = (u(engine) << 32ull) + (chrono::system_clock::now().time_since_epoch().count() & 0xffffffff); //printf("%llu\n", uuid); string ret; while (uuid && l-- >= 0) { ret = string("") + base62alp[uuid % 62] + ret; uuid /= 62; } return ret; } template inline void vector_type<_Ty>::out(uint32_t n, const char* sep) const { n = n > size ? size : n; std::cout << '('; { uint32_t i = 0; for (; i < n - 1; ++i) std::cout << this->operator[](i) << sep; std::cout << this->operator[](i); } std::cout << ')'; }