]> git.cworth.org Git - wordgame/blobdiff - rack-fancy.c
rack-fancy: Ignore any blank tiles drawn from the bag
[wordgame] / rack-fancy.c
index 8aae0f8b2e58233c620b00f0136e2dc5d495d122..21c2953064307af7a78a69b0fcbcd3a670500427 100644 (file)
@@ -83,6 +83,9 @@ dict_paint_action (void *closure, char *word, dict_entry_t *entry)
     cairo_t *cr = cursor->cr;
     double new_x, new_y;
 
+    if (strlen (word) < 3)
+       return;
+
     cairo_move_to (cr, cursor->x, cursor->y);
     if (*entry & RACK_DICT_ENTRY_FOUND) {
        cairo_show_text (cr, word);
@@ -101,6 +104,9 @@ dict_paint_action (void *closure, char *word, dict_entry_t *entry)
     }
 }
 
+#define SOLUTION_FONT_SIZE     12
+#define SOLUTION_LINE_HEIGHT   (1.5 * SOLUTION_FONT_SIZE)
+
 static void
 dict_paint (cairo_t *cr, void *closure, double width, double height)
 {
@@ -112,8 +118,9 @@ dict_paint (cairo_t *cr, void *closure, double width, double height)
 
     cursor.cr = cr;
 
-    cairo_set_font_size (cr, 12);
-    cursor.line_height = 14;
+    cairo_select_font_face (cr, "mono", 0, 0);
+    cairo_set_font_size (cr, SOLUTION_FONT_SIZE);
+    cursor.line_height = SOLUTION_LINE_HEIGHT;
     
     cursor.x = 0;
     cursor.y = 0;
@@ -333,10 +340,12 @@ on_key_press_event (GtkWidget     *widget,
 
     if (event->keyval == GDK_Return) {
        dict_entry_t *entry;
-       entry = dict_lookup (rack->solution, rack->guess);
-       if (DICT_ENTRY_IS_WORD (entry)) {
-           *entry = *entry | RACK_DICT_ENTRY_FOUND;
-           goo_canvas_item_simple_changed (GOO_CANVAS_ITEM_SIMPLE (rack->solution_item), FALSE);
+       if (rack->guess_length >= 3) {
+           entry = dict_lookup (rack->solution, rack->guess);
+           if (DICT_ENTRY_IS_WORD (entry)) {
+               *entry = *entry | RACK_DICT_ENTRY_FOUND;
+               goo_canvas_item_simple_changed (GOO_CANVAS_ITEM_SIMPLE (rack->solution_item), FALSE);
+           }
        }
        rack_return_all (rack);
        return TRUE;
@@ -431,7 +440,7 @@ create_canvas (GtkWidget *parent, rack_t *rack)
     root = goo_canvas_get_root_item (GOO_CANVAS (canvas));
 
     rack->solution_item = goo_demo_item_new (root,
-                                            LETTER_PAD,
+                                            LETTER_PAD + SOLUTION_LINE_HEIGHT,
                                             LETTER_PAD + 2 * (LETTER_SIZE + 2 * LETTER_PAD),
                                             400, 400 - (2 * (LETTER_SIZE + 2 * LETTER_PAD)),
                                             dict_paint, rack->solution,
@@ -449,6 +458,7 @@ main (int argc, char *argv[])
     rack_t rack;
     char word[8];
     int i;
+    char *draw;
     GtkWidget *window;
     GooCanvas *canvas;
 
@@ -458,11 +468,14 @@ main (int argc, char *argv[])
     bag_init (&bag);
     bag_shuffle (&bag);
 
-    memcpy (word, bag.tiles, 7);
-    word[7] = '\0';
-
-    for (i = 0; i < 7; i++)
-       word[i] = toupper (word[i]);
+    /* Keep drawing until we get 7 non-blank tiles */
+    i = 0;
+    draw = bag.tiles;
+    while (i < 7) {
+       if (*draw != '?')
+           word[i++] = toupper (*draw);
+       draw++;
+    }
 
     dict_init (&dict);
     dict_add_words_from_file (&dict, "words.txt");