+ if (real_render) {
+ int y;
+ FT_Bitmap *bm = &(slot->bitmap);
+ for (y = 0; y < bm->rows; y++) {
+ int xx;
+ int dsty = ypos - slot->bitmap_top + y;
+ if (dsty < 0 || dsty > 599) continue;
+
+ unsigned char *dst = buf + dsty * 800*4 + (x + xpos + slot->bitmap_left)*4;
+ unsigned char *src = bm->buffer + y * bm->width;
+ for (xx = 0; xx < bm->width; xx++) {
+ *dst = (*dst * (256-*src) + r * *src) >> 8;
+ *dst++;
+ *dst = (*dst * (256-*src) + g * *src) >> 8;
+ *dst++;
+ *dst = (*dst * (256-*src) + b * *src) >> 8;
+ *dst++;
+ *dst++ = 0;
+ src++;
+ }
+ }
+ }
+
+ x += slot->advance.x >> 6;
+ }
+
+ return x;
+}
+
+
+int main(int argc, char **argv)
+{
+ ptc_open("CCBS bigscreen", 800, 600);
+
+ try {
+ init_freetype();
+ pqxx::connection conn("dbname=ccbs host=altersex.samfundet.no user=ccbs password=GeT|>>B_");
+ FlagTrigger tournament_changed(conn, "active_tournament");
+ FlagTrigger rounds_changed(conn, "active_groups");
+
+ // when active_tournament or active_rounds is changed, we destroy everything and start from scratch
+ // (at least currently)
+ for ( ;; ) {
+ tournament_changed.reset_flag();
+ rounds_changed.reset_flag();
+ init(conn);
+ do {
+ main_loop(conn);
+ conn.get_notifs();
+ } while (!tournament_changed.get_flag() && !rounds_changed.get_flag());
+ std::fprintf(stderr, "active_tournament or active_groups changed, resetting...\n");
+ }