#define BOOL(x) COLUMN("bool", int, x, 0, 0) #define BOOL_ARRAY(x, items) COLUMN_ARRAY("bool", int, x, 0, 0, items) #define BOOL_(x) COLUMN_("bool", int, x, 0, 0) #define BOOL_ARRAY_(x, items) COLUMN_ARRAY_("bool", int, x, 0, 0, items) #define INT(x) COLUMN("integer", int, x, 0, 0) #define INT_ARRAY(x, items) COLUMN_ARRAY("integer", int, x, 0, 0, items) #define INT_(x) COLUMN_("integer", int, x, 0, 0) #define INT_ARRAY_(x, items) COLUMN_ARRAY_("integer", int, x, 0, 0, items) #define DOUBLE(x) COLUMN("real", double, x, 0, 0) #define DOUBLE_ARRAY(x, items) COLUMN_ARRAY("real", double, x, 0, 0, items) #define DOUBLE_(x) COLUMN_("real", double, x, 0, 0) #define DOUBLE_ARRAY_(x, items) COLUMN_ARRAY_("real", double, x, 0, 0, items) #define DATE(x) COLUMN("date", Date, x, 0, 0) #define DATE_ARRAY(x, items) COLUMN_ARRAY("date", Date, x, 0, 0, items) #define DATE_(x) COLUMN_("date", Date, x, 0, 0) #define DATE_ARRAY_(x, items) COLUMN_ARRAY_("date", Date, x, 0, 0, items) #define TIME(x) COLUMN("datetime", Time, x, 0, 0) #define TIME_ARRAY(x, items) COLUMN_ARRAY("datetime", Time, x, 0, 0, items) #define TIME_(x) COLUMN_("datetime", Time, x, 0, 0) #define TIME_ARRAY_(x, items) COLUMN_ARRAY_("datetime", Time, x, 0, 0, items) #define STRING(x, n) COLUMN(MySqlTextType(n), String, x, n, 0) #define STRING_ARRAY(x, n, items) COLUMN_ARRAY(MySqlTextType(n), String, x, n, 0, items) #define STRING_(x, n) COLUMN_(MySqlTextType(n), String, x, n, 0) #define STRING_ARRAY_(x, n, items) COLUMN_ARRAY_(MySqlTextType(n), String, x, n, 0, items) #define PRIMARY_KEY INLINE_ATTRIBUTE("primary key") #define AUTO_INCREMENT INLINE_ATTRIBUTE("auto_increment") #define KEY INLINE_ATTRIBUTE("key") #define NOT_NULL INLINE_ATTRIBUTE("not null") #define INDEX ATTRIBUTE("alter table @t add index IDX_@x (@c);", \ "alter table @t drop index IDX_@x;") #define UNIQUE ATTRIBUTE("alter table @t add unique UNQ_@x (@c);", \ "alter table @t drop index UNQ_@x;") #define REFERENCES(x) ATTRIBUTE("alter table @t add (constraint FK_@x foreign key "\ "(@c) references " #x ");",\ "alter table @t drop constraint FK_@x;") #define TIMESTAMP(ts) SCHEMA("-- " ts "\n\n", NULL) #define COMMENT(txt) SCHEMA("-- " #txt "\n", NULL) #define INNODB TABLE_SUFFIX(" type=InnoDB") #include #undef INT #undef INT_ARRAY #undef INT_ #undef INT_ARRAY_ #undef DOUBLE #undef DOUBLE_ARRAY #undef DOUBLE_ #undef DOUBLE_ARRAY_ #undef DATE #undef DATE_ARRAY #undef DATE_ #undef DATE_ARRAY_ #undef DATETIME #undef DATETIME_ARRAY #undef DATETIME_ #undef DATETIME_ARRAY_ #undef STRING #undef STRING_ARRAY #undef STRING_ #undef STRING_ARRAY_ #undef PRIMARY_KEY #undef AUTO_INCREMENT #undef KEY #undef NOT_NULL #undef INDEX #undef UNIQUE #undef TIMESTAMP #undef COMMENT