ncurses 5.6 - patch 20070714
[ncurses.git] / Ada95 / src / terminal_interface-curses-forms-field_types-user.adb
1 ------------------------------------------------------------------------------
2 --                                                                          --
3 --                           GNAT ncurses Binding                           --
4 --                                                                          --
5 --              Terminal_Interface.Curses.Forms.Field_Types.User            --
6 --                                                                          --
7 --                                 B O D Y                                  --
8 --                                                                          --
9 ------------------------------------------------------------------------------
10 -- Copyright (c) 1998-2004,2006 Free Software Foundation, Inc.              --
11 --                                                                          --
12 -- Permission is hereby granted, free of charge, to any person obtaining a  --
13 -- copy of this software and associated documentation files (the            --
14 -- "Software"), to deal in the Software without restriction, including      --
15 -- without limitation the rights to use, copy, modify, merge, publish,      --
16 -- distribute, distribute with modifications, sublicense, and/or sell       --
17 -- copies of the Software, and to permit persons to whom the Software is    --
18 -- furnished to do so, subject to the following conditions:                 --
19 --                                                                          --
20 -- The above copyright notice and this permission notice shall be included  --
21 -- in all copies or substantial portions of the Software.                   --
22 --                                                                          --
23 -- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  --
24 -- OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               --
25 -- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   --
26 -- IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   --
27 -- DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    --
28 -- OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    --
29 -- THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               --
30 --                                                                          --
31 -- Except as contained in this notice, the name(s) of the above copyright   --
32 -- holders shall not be used in advertising or otherwise to promote the     --
33 -- sale, use or other dealings in this Software without prior written       --
34 -- authorization.                                                           --
35 ------------------------------------------------------------------------------
36 --  Author:  Juergen Pfeifer, 1996
37 --  Version Control:
38 --  $Revision: 1.14 $
39 --  $Date: 2006/06/25 14:24:40 $
40 --  Binding Version 01.00
41 ------------------------------------------------------------------------------
42 with Ada.Unchecked_Conversion;
43 with Interfaces.C;
44 with Terminal_Interface.Curses.Aux; use Terminal_Interface.Curses.Aux;
45
46 package body Terminal_Interface.Curses.Forms.Field_Types.User is
47
48    use type Interfaces.C.int;
49
50    procedure Set_Field_Type (Fld : in Field;
51                              Typ : in User_Defined_Field_Type)
52    is
53       function Allocate_Arg (T : User_Defined_Field_Type'Class)
54                              return Argument_Access;
55
56       function Set_Fld_Type (F    : Field := Fld;
57                              Cft  : C_Field_Type := C_Generic_Type;
58                              Arg1 : Argument_Access)
59                              return C_Int;
60       pragma Import (C, Set_Fld_Type, "set_field_type");
61
62       Res : Eti_Error;
63
64       function Allocate_Arg (T : User_Defined_Field_Type'Class)
65                              return Argument_Access
66       is
67          Ptr : constant Field_Type_Access
68              := new User_Defined_Field_Type'Class'(T);
69       begin
70          return new Argument'(Usr => System.Null_Address,
71                               Typ => Ptr,
72                               Cft => Null_Field_Type);
73       end Allocate_Arg;
74
75    begin
76       Res := Set_Fld_Type (Arg1 => Allocate_Arg (Typ));
77       if Res /= E_Ok then
78          Eti_Exception (Res);
79       end if;
80    end Set_Field_Type;
81
82    pragma Warnings (Off);
83    function To_Argument_Access is new Ada.Unchecked_Conversion
84      (System.Address, Argument_Access);
85    pragma Warnings (On);
86
87    function Generic_Field_Check (Fld : Field;
88                                  Usr : System.Address) return C_Int
89    is
90       Result : Boolean;
91       Udf    : constant User_Defined_Field_Type_Access :=
92         User_Defined_Field_Type_Access (To_Argument_Access (Usr).Typ);
93    begin
94       Result := Field_Check (Fld, Udf.all);
95       return C_Int (Boolean'Pos (Result));
96    end Generic_Field_Check;
97
98    function Generic_Char_Check (Ch  : C_Int;
99                                 Usr : System.Address) return C_Int
100    is
101       Result : Boolean;
102       Udf    : constant User_Defined_Field_Type_Access :=
103         User_Defined_Field_Type_Access (To_Argument_Access (Usr).Typ);
104    begin
105       Result := Character_Check (Character'Val (Ch), Udf.all);
106       return C_Int (Boolean'Pos (Result));
107    end Generic_Char_Check;
108
109    --  -----------------------------------------------------------------------
110    --
111    function C_Generic_Type return C_Field_Type
112    is
113       Res : Eti_Error;
114       T   : C_Field_Type;
115    begin
116       if M_Generic_Type = Null_Field_Type then
117          T := New_Fieldtype (Generic_Field_Check'Access,
118                              Generic_Char_Check'Access);
119          if T = Null_Field_Type then
120             raise Form_Exception;
121          else
122             Res := Set_Fieldtype_Arg (T,
123                                       Make_Arg'Access,
124                                       Copy_Arg'Access,
125                                       Free_Arg'Access);
126             if Res /= E_Ok then
127                Eti_Exception (Res);
128             end if;
129          end if;
130          M_Generic_Type := T;
131       end if;
132       pragma Assert (M_Generic_Type /= Null_Field_Type);
133       return M_Generic_Type;
134    end C_Generic_Type;
135
136 end Terminal_Interface.Curses.Forms.Field_Types.User;