Completed impelementing the clues across nd down
functionality
#define INVALID_WORD "Word contains illegal characters. Only alphabets allowed!"
#define FILE_SAVED "File saved successfully"
#define NO_WORD_INDEX "No such word with specified index"
#define INVALID_WORD "Word contains illegal characters. Only alphabets allowed!"
#define FILE_SAVED "File saved successfully"
#define NO_WORD_INDEX "No such word with specified index"
+#define INPUT_CONFIRM_EXIT "Are you sure you wish to exit? \
+Unsaved changes will be lost [y/N]"
char *MAIN_MENU[] =
{"1. New puzzle",
char *MAIN_MENU[] =
{"1. New puzzle",
"5. Freeze grid",
"6. Unfreeze grid",
"7. Set Clue - Across Word",
"5. Freeze grid",
"6. Unfreeze grid",
"7. Set Clue - Across Word",
- "8. Save puzzle",
- "9. Return to main menu" };
+ "8. Set Clue - Down Word",
+ "9. Save puzzle",
+ "10.Return to main menu" };
#include "wordblox.h"
#include "constantstrings.h"
#include "wordblox.h"
#include "constantstrings.h"
-void set_clue_across_word (Puzzle *p)
+void set_clue_word (Puzzle *p, enum ORIENTATION orient)
{
print_puzzle (p);
if (p->grid_frozen == false)
{
print_puzzle (p);
if (p->grid_frozen == false)
fgets (clue, MAX_CLUE_LENGTH, stdin);
char* cl = strtok (clue, "\n");
fgets (clue, MAX_CLUE_LENGTH, stdin);
char* cl = strtok (clue, "\n");
- bool res = set_across_clue (p, cl, index);
+ bool res;
+ res = set_clue (p, cl, index, orient);
+
if (res == false)
printf (NO_WORD_INDEX);
}
if (res == false)
printf (NO_WORD_INDEX);
}
print_puzzle (p);
char ch = getchar ();
}
print_puzzle (p);
char ch = getchar ();
}
+/* confirm exit */
+bool confirm_exit ()
+{
+ printf (INPUT_CONFIRM_EXIT);
+ char res[2];
+ fgets (res, 2, stdin);
+ if (toupper(res[0]) == 'Y')
+ return true;
+ else
+ return false;
+}
+/* main loop for the puzzle editor */
void puzzle_editor_loop (Puzzle *p, const char *filename)
{
bool loop = true;
while (loop)
{
void puzzle_editor_loop (Puzzle *p, const char *filename)
{
bool loop = true;
while (loop)
{
- print_menu (WHITE, RED, PUZZLE_MENU_TITLE, PUZZLE_EDIT_MENU, 9, 50);
+ print_menu (WHITE, RED, PUZZLE_MENU_TITLE, PUZZLE_EDIT_MENU, 10, 50);
printf (INPUT_CHOICE);
int ch = get_num ();
switch (ch)
printf (INPUT_CHOICE);
int ch = get_num ();
switch (ch)
print_puzzle (p);
ch = getchar ();
break;
print_puzzle (p);
ch = getchar ();
break;
- case 7: set_clue_across_word (p);
+ case 7: set_clue_word (p, ACROSS);
+ print_puzzle (p);
+ ch = getchar ();
+ break;
+ case 8: set_clue_word (p, DOWN);
print_puzzle (p);
ch = getchar ();
break;
print_puzzle (p);
ch = getchar ();
break;
- case 8: save_puzzle (p, filename);
+ case 9: save_puzzle (p, filename);
printf ("%s\n",FILE_SAVED);
ch = getchar ();
break;
printf ("%s\n",FILE_SAVED);
ch = getchar ();
break;
+ case 10: loop = !confirm_exit ();
+enum ATTR {
+ NORMAL = 23,
+ BOLD=1
+};
+
+enum ORIENTATION {
+ ACROSS=1,
+ DOWN=2
+};
+
typedef char String[MAX_CLUE_LENGTH];
/* The main puzzle struct type */
typedef char String[MAX_CLUE_LENGTH];
/* The main puzzle struct type */
}
/* Set the terminal colour */
}
/* 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 */
}
/* Reset the terminal colour */
void print_puzzle (Puzzle *p)
{
printf ("\n");
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 (" ");
for (int i = 0; i < p->grid_size; i ++)
printf ("%3d", i);
printf("\n");
for (int i = 0; i < p->grid_size; 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] == '#') {
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);
if (p->start_across_word[i][j] != -1 ||
p->start_down_word[i][j] != -1)
{
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
if (p->start_across_word[i][j] != -1)
printf ("%-2d", p->start_across_word[i][j]);
else
- set_color (BLACK, WHITE);
+ set_color (BLACK, WHITE,NORMAL);
- set_color (BLACK, WHITE);
+ set_color (BLACK, WHITE, BOLD);
printf ("%c", p->chars[i][j]);
}
reset_color ();
printf ("%c", p->chars[i][j]);
}
reset_color ();
/* print the clues if set */
if (p->grid_frozen == true)
{
/* 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 ++)
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 ++)
for (int i = 0; i < p->grid_size; i ++)
{
for (int j = 0; j < p->grid_size; j ++)
-/* 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 ++)
{
{
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)
- 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;
+ }
+ }
{
/* clear screen */
printf ("\e[1;1H\e[2J");
{
/* clear screen */
printf ("\e[1;1H\e[2J");
+ set_color (fg, bg, NORMAL);
printf ("\u2554");
for (int i = 0; i < padding; i ++)
printf ("\u2550");
printf ("\u2557");
reset_color (); printf ("\n");
printf ("\u2554");
for (int i = 0; i < padding; i ++)
printf ("\u2550");
printf ("\u2557");
reset_color (); printf ("\n");
+ set_color (fg, bg, BOLD);
printf ("\u2551%-*s\u2551", padding, title);
reset_color (); printf ("\n");
printf ("\u2551%-*s\u2551", padding, title);
reset_color (); printf ("\n");
+ set_color (fg, bg, NORMAL);
printf ("\u2560");
for (int i = 0; i < padding; i ++)
printf ("\u2550");
printf ("\u2560");
for (int i = 0; i < padding; i ++)
printf ("\u2550");
reset_color (); printf ("\n");
for (int i = 0; i < num_items; i ++)
{
reset_color (); printf ("\n");
for (int i = 0; i < num_items; i ++)
{
+ set_color (fg, bg, NORMAL);
printf ("\u2551%-*s\u2551", padding, items[i]);
reset_color (); printf ("\n");
}
printf ("\u2551%-*s\u2551", padding, items[i]);
reset_color (); printf ("\n");
}
+ set_color (fg, bg, NORMAL);
printf ("\u255A");
for (int i = 0; i < padding; i ++)
printf ("\u2550");
printf ("\u255A");
for (int i = 0; i < padding; i ++)
printf ("\u2550");