WHITE=7
};
+enum ATTR {
+ NORMAL = 23,
+ BOLD=1
+};
+
+enum ORIENTATION {
+ ACROSS=1,
+ DOWN=2
+};
+
typedef char String[MAX_CLUE_LENGTH];
/* The main puzzle struct type */
}
/* Set the terminal colour */
-void set_color (enum COLOR fg, enum COLOR bg) {
- printf ("\x1B[%d;%dm", fg+30, bg+40);
+void set_color (enum COLOR fg, enum COLOR bg, enum ATTR at) {
+ printf ("\x1B[%d;%d;%dm", fg+30, bg+40, at);
}
/* Reset the terminal colour */
void print_puzzle (Puzzle *p)
{
printf ("\n");
- set_color (WHITE, CYAN);
+ set_color (WHITE, CYAN, NORMAL);
printf (" ");
for (int i = 0; i < p->grid_size; i ++)
printf ("%3d", i);
printf("\n");
for (int i = 0; i < p->grid_size; i ++)
{
- set_color (WHITE, CYAN);
+ set_color (WHITE, CYAN, NORMAL);
printf ("%3d ", i);
for (int j = 0; j < p->grid_size; j ++)
{
if (p->chars[i][j] == '#') {
- set_color (WHITE, BLACK);
+ set_color (WHITE, BLACK, NORMAL);
printf (" ");
}
else
if (p->start_across_word[i][j] != -1 ||
p->start_down_word[i][j] != -1)
{
- set_color (BLUE, WHITE);
+ set_color (BLUE, WHITE, NORMAL);
if (p->start_across_word[i][j] != -1)
printf ("%-2d", p->start_across_word[i][j]);
else
}
else
{
- set_color (BLACK, WHITE);
+ set_color (BLACK, WHITE,NORMAL);
printf (" ");
}
- set_color (BLACK, WHITE);
+ set_color (BLACK, WHITE, BOLD);
printf ("%c", p->chars[i][j]);
}
reset_color ();
/* print the clues if set */
if (p->grid_frozen == true)
{
- printf ("ACROSS - CLUES\n");
+ printf ("\x1B[1mACROSS - CLUES\x1B[0m\n");
for (int i = 0; i < p->grid_size; i ++)
{
for (int j = 0; j < p->grid_size; j ++)
}
}
}
- printf ("\nDOWN - CLUES\n");
+ printf ("\n\x1B[1mDOWN - CLUES\x1B[0m\n");
for (int i = 0; i < p->grid_size; i ++)
{
for (int j = 0; j < p->grid_size; j ++)
return true;
}
-/* function set a clue for an across word */
-bool set_across_clue (Puzzle *p, String clue, int index)
+
+/* function to set a clue for an across word */
+bool set_clue (Puzzle *p, String clue, int index, enum ORIENTATION order)
{
for (int i = 0; i < p->grid_size; i ++)
{
for (int j = 0; j < p->grid_size; j ++)
{
- if (p->start_across_word[i][j] == index)
+ if (order == ACROSS)
{
- strcpy (p->clue_across[i][j], clue);
- return true;
- }
+ if (p->start_across_word[i][j] == index)
+ {
+ strcpy (p->clue_across[i][j], clue);
+ return true;
+ }
+ }
+ else if (order == DOWN)
+ {
+ if (p->start_down_word[i][j] == index)
+ {
+ strcpy (p->clue_down[i][j], clue);
+ return true;
+ }
+ }
}
}
return false;
{
/* clear screen */
printf ("\e[1;1H\e[2J");
- set_color (fg, bg);
+ set_color (fg, bg, NORMAL);
printf ("\u2554");
for (int i = 0; i < padding; i ++)
printf ("\u2550");
printf ("\u2557");
reset_color (); printf ("\n");
- set_color (fg, bg);
+ set_color (fg, bg, BOLD);
printf ("\u2551%-*s\u2551", padding, title);
reset_color (); printf ("\n");
- set_color (fg, bg);
+ set_color (fg, bg, NORMAL);
printf ("\u2560");
for (int i = 0; i < padding; i ++)
printf ("\u2550");
reset_color (); printf ("\n");
for (int i = 0; i < num_items; i ++)
{
- set_color (fg, bg);
+ set_color (fg, bg, NORMAL);
printf ("\u2551%-*s\u2551", padding, items[i]);
reset_color (); printf ("\n");
}
- set_color (fg, bg);
+ set_color (fg, bg, NORMAL);
printf ("\u255A");
for (int i = 0; i < padding; i ++)
printf ("\u2550");