#include <stdbool.h>
#include <string.h>
#include <ctype.h>
+#include <unistd.h>
#include "wordblox.h"
#include "constantstrings.h"
/* set the password for the puzzle */
void do_set_password (Puzzle *p)
{
- printf (INPUT_PASSWORD);
- char password[256];
- fgets (password, 256, stdin);
+ char* password;
+ password = getpass (INPUT_PASSWORD);
/* if empty reset the password to nothing */
- if (strlen (password) == 1)
+ if (strlen(password) == 0)
{
set_puzzle_password (p, "\0");
printf (PASSWORD_RESET);
/* set the password */
else
{
- char *passwd = strtok (password, "\n");
-
- set_puzzle_password (p, (const char* )passwd);
+ set_puzzle_password (p, (const char* )password);
printf (PASSWORD_SET);
char ch = getchar ();
}
bool loop = true;
while (loop)
{
- print_menu (WHITE, BLUE, PUZZLE_MENU_TITLE, PUZZLE_EDIT_MENU, 14, 50);
+ char puzzle_title[60];
+ sprintf (puzzle_title, "%s - %s", PUZZLE_MENU_TITLE, filename);
+ print_menu (WHITE, BLUE, puzzle_title, PUZZLE_EDIT_MENU, 14, 50);
printf (INPUT_CHOICE);
int ch = get_num ();
switch (ch)
if (strcmp (p.hashed_password, "\0") != 0)
{
- char passwd[256];
- printf (INPUT_PASSWORD);
- fgets (passwd, 256, stdin);
- if (strlen (passwd) == 1)
+ char *passwd;
+ passwd = getpass (INPUT_PASSWORD);
+ if (strlen (passwd) == 0)
return;
- char *pwd = strtok (passwd, "\n");
-
- if (verify_password (&p, (const char*) pwd))
+
+ if (verify_password (&p, (const char*) passwd))
puzzle_editor_loop (&p, filename);
else
{