msgbox.c 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * msgbox.c -- implements the message box and info box
  3. *
  4. * ORIGINAL AUTHOR: Savio Lam (lam836@cs.cuhk.hk)
  5. * MODIFIED FOR LINUX KERNEL CONFIG BY: William Roadcap (roadcapw@cfw.com)
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License
  9. * as published by the Free Software Foundation; either version 2
  10. * of the License, or (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20. */
  21. #include "dialog.h"
  22. /*
  23. * Display a message box. Program will pause and display an "OK" button
  24. * if the parameter 'pause' is non-zero.
  25. */
  26. int dialog_msgbox(const char *title, const char *prompt, int height, int width,
  27. int pause)
  28. {
  29. int i, x, y, key = 0;
  30. WINDOW *dialog;
  31. /* center dialog box on screen */
  32. x = (COLS - width) / 2;
  33. y = (LINES - height) / 2;
  34. draw_shadow(stdscr, y, x, height, width);
  35. dialog = newwin(height, width, y, x);
  36. keypad(dialog, TRUE);
  37. draw_box(dialog, 0, 0, height, width, dialog_attr, border_attr);
  38. if (title != NULL && strlen(title) >= width - 2) {
  39. /* truncate long title -- mec */
  40. char *title2 = malloc(width - 2 + 1);
  41. memcpy(title2, title, width - 2);
  42. title2[width - 2] = '\0';
  43. title = title2;
  44. }
  45. if (title != NULL) {
  46. wattrset(dialog, title_attr);
  47. mvwaddch(dialog, 0, (width - strlen(title)) / 2 - 1, ' ');
  48. waddstr(dialog, (char *)title);
  49. waddch(dialog, ' ');
  50. }
  51. wattrset(dialog, dialog_attr);
  52. print_autowrap(dialog, prompt, width - 2, 1, 2);
  53. if (pause) {
  54. wattrset(dialog, border_attr);
  55. mvwaddch(dialog, height - 3, 0, ACS_LTEE);
  56. for (i = 0; i < width - 2; i++)
  57. waddch(dialog, ACS_HLINE);
  58. wattrset(dialog, dialog_attr);
  59. waddch(dialog, ACS_RTEE);
  60. print_button(dialog, " Ok ", height - 2, width / 2 - 4, TRUE);
  61. wrefresh(dialog);
  62. while (key != ESC && key != '\n' && key != ' ' &&
  63. key != 'O' && key != 'o' && key != 'X' && key != 'x')
  64. key = wgetch(dialog);
  65. } else {
  66. key = '\n';
  67. wrefresh(dialog);
  68. }
  69. delwin(dialog);
  70. return key == ESC ? -1 : 0;
  71. }