frm_opts.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /****************************************************************************
  2. * Copyright (c) 1998 Free Software Foundation, Inc. *
  3. * *
  4. * Permission is hereby granted, free of charge, to any person obtaining a *
  5. * copy of this software and associated documentation files (the *
  6. * "Software"), to deal in the Software without restriction, including *
  7. * without limitation the rights to use, copy, modify, merge, publish, *
  8. * distribute, distribute with modifications, sublicense, and/or sell *
  9. * copies of the Software, and to permit persons to whom the Software is *
  10. * furnished to do so, subject to the following conditions: *
  11. * *
  12. * The above copyright notice and this permission notice shall be included *
  13. * in all copies or substantial portions of the Software. *
  14. * *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
  16. * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
  17. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
  18. * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
  19. * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
  20. * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
  21. * THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
  22. * *
  23. * Except as contained in this notice, the name(s) of the above copyright *
  24. * holders shall not be used in advertising or otherwise to promote the *
  25. * sale, use or other dealings in this Software without prior written *
  26. * authorization. *
  27. ****************************************************************************/
  28. /****************************************************************************
  29. * Author: Juergen Pfeifer <juergen.pfeifer@gmx.net> 1995,1997 *
  30. ****************************************************************************/
  31. #include "form.priv.h"
  32. MODULE_ID("$Id$")
  33. /*---------------------------------------------------------------------------
  34. | Facility : libnform
  35. | Function : int set_form_opts(FORM *form, Form_Options opts)
  36. |
  37. | Description : Turns on the named options and turns off all the
  38. | remaining options for that form.
  39. |
  40. | Return Values : E_OK - success
  41. | E_BAD_ARGUMENT - invalid options
  42. +--------------------------------------------------------------------------*/
  43. int set_form_opts(FORM * form, Form_Options opts)
  44. {
  45. opts &= ALL_FORM_OPTS;
  46. if (opts & ~ALL_FORM_OPTS)
  47. RETURN(E_BAD_ARGUMENT);
  48. else
  49. {
  50. Normalize_Form( form )->opts = opts;
  51. RETURN(E_OK);
  52. }
  53. }
  54. /*---------------------------------------------------------------------------
  55. | Facility : libnform
  56. | Function : Form_Options form_opts(const FORM *)
  57. |
  58. | Description : Retrieves the current form options.
  59. |
  60. | Return Values : The option flags.
  61. +--------------------------------------------------------------------------*/
  62. Form_Options form_opts(const FORM * form)
  63. {
  64. return (Normalize_Form(form)->opts & ALL_FORM_OPTS);
  65. }
  66. /*---------------------------------------------------------------------------
  67. | Facility : libnform
  68. | Function : int form_opts_on(FORM *form, Form_Options opts)
  69. |
  70. | Description : Turns on the named options; no other options are
  71. | changed.
  72. |
  73. | Return Values : E_OK - success
  74. | E_BAD_ARGUMENT - invalid options
  75. +--------------------------------------------------------------------------*/
  76. int form_opts_on(FORM * form, Form_Options opts)
  77. {
  78. opts &= ALL_FORM_OPTS;
  79. if (opts & ~ALL_FORM_OPTS)
  80. RETURN(E_BAD_ARGUMENT);
  81. else
  82. {
  83. Normalize_Form( form )->opts |= opts;
  84. RETURN(E_OK);
  85. }
  86. }
  87. /*---------------------------------------------------------------------------
  88. | Facility : libnform
  89. | Function : int form_opts_off(FORM *form, Form_Options opts)
  90. |
  91. | Description : Turns off the named options; no other options are
  92. | changed.
  93. |
  94. | Return Values : E_OK - success
  95. | E_BAD_ARGUMENT - invalid options
  96. +--------------------------------------------------------------------------*/
  97. int form_opts_off(FORM * form, Form_Options opts)
  98. {
  99. opts &= ALL_FORM_OPTS;
  100. if (opts & ~ALL_FORM_OPTS)
  101. RETURN(E_BAD_ARGUMENT);
  102. else
  103. {
  104. Normalize_Form(form)->opts &= ~opts;
  105. RETURN(E_OK);
  106. }
  107. }
  108. /* frm_opts.c ends here */