bc80e3293b9ad2e115af13ab8e35909e2627ad0e
[ncurses.git] / form / fld_newftyp.c
1 /****************************************************************************
2  * Copyright (c) 1998,2000 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 /****************************************************************************
30  *   Author:  Juergen Pfeifer, 1995,1997                                    *
31  *   Contact: http://www.familiepfeifer.de/Contact.aspx?Lang=en             *
32  ****************************************************************************/
33
34 #include "form.priv.h"
35
36 MODULE_ID("$Id: fld_newftyp.c,v 1.7 2002/07/06 15:33:27 juergen Exp $")
37
38 static FIELDTYPE const default_fieldtype = {
39   0,                   /* status                                      */
40   0L,                  /* reference count                             */
41   (FIELDTYPE *)0,      /* pointer to left  operand                    */
42   (FIELDTYPE *)0,      /* pointer to right operand                    */
43   NULL,                /* makearg function                            */
44   NULL,                /* copyarg function                            */
45   NULL,                /* freearg function                            */
46   NULL,                /* field validation function                   */
47   NULL,                /* Character check function                    */
48   NULL,                /* enumerate next function                     */
49   NULL                 /* enumerate previous function                 */
50 };
51
52 NCURSES_EXPORT_VAR(const FIELDTYPE*) _nc_Default_FieldType = &default_fieldtype;
53 \f
54 /*---------------------------------------------------------------------------
55 |   Facility      :  libnform  
56 |   Function      :  FIELDTYPE *new_fieldtype(
57 |                       bool (* const field_check)(FIELD *,const void *),
58 |                       bool (* const char_check) (int, const void *) ) 
59 |   
60 |   Description   :  Create a new fieldtype. The application programmer must
61 |                    write a field_check and a char_check function and give
62 |                    them as input to this call.
63 |                    If an error occurs, errno is set to                    
64 |                       E_BAD_ARGUMENT  - invalid arguments
65 |                       E_SYSTEM_ERROR  - system error (no memory)
66 |
67 |   Return Values :  Fieldtype pointer or NULL if error occured
68 +--------------------------------------------------------------------------*/
69 NCURSES_EXPORT(FIELDTYPE *)
70 new_fieldtype (
71  bool (* const field_check)(FIELD *,const void *),
72  bool (* const char_check) (int,const void *) )
73 {
74   FIELDTYPE *nftyp = (FIELDTYPE *)0;
75   
76   if ( (field_check) || (char_check) )
77     {
78       nftyp = (FIELDTYPE *)malloc(sizeof(FIELDTYPE));
79       if (nftyp)
80         {
81           *nftyp = default_fieldtype;
82           nftyp->fcheck = field_check;
83           nftyp->ccheck = char_check;
84         }
85       else
86         {
87           SET_ERROR( E_SYSTEM_ERROR );
88         }
89     }
90   else
91     {
92       SET_ERROR( E_BAD_ARGUMENT );
93     }
94   return nftyp;
95 }
96
97 /*---------------------------------------------------------------------------
98 |   Facility      :  libnform  
99 |   Function      :  int free_fieldtype(FIELDTYPE *typ)
100 |   
101 |   Description   :  Release the memory associated with this fieldtype.
102 |
103 |   Return Values :  E_OK            - success
104 |                    E_CONNECTED     - there are fields referencing the type
105 |                    E_BAD_ARGUMENT  - invalid fieldtype pointer
106 +--------------------------------------------------------------------------*/
107 NCURSES_EXPORT(int)
108 free_fieldtype (FIELDTYPE *typ)
109 {
110   if (!typ)
111     RETURN(E_BAD_ARGUMENT);
112
113   if (typ->ref!=0)
114     RETURN(E_CONNECTED);
115
116   if (typ->status & _RESIDENT)
117     RETURN(E_CONNECTED);
118
119   if (typ->status & _LINKED_TYPE)
120     {
121       if (typ->left ) typ->left->ref--;
122       if (typ->right) typ->right->ref--;
123     }
124   free(typ);
125   RETURN(E_OK);
126 }
127
128 /* fld_newftyp.c ends here */