]> Pileus Git - ~andy/gtk/blob - gtk/gtkeditable.c
Include "." and ".." in the list of entries; they are needed for correct
[~andy/gtk] / gtk / gtkeditable.c
1 /* GTK - The GIMP Toolkit
2  * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with this library; if not, write to the
16  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17  * Boston, MA 02111-1307, USA.
18  */
19
20 /*
21  * Modified by the GTK+ Team and others 1997-2000.  See the AUTHORS
22  * file for a list of people on the GTK+ Team.  See the ChangeLog
23  * files for a list of changes.  These files are distributed with
24  * GTK+ at ftp://ftp.gtk.org/pub/gtk/. 
25  */
26
27 #include <string.h>
28
29 #include "gtkeditable.h"
30 #include "gtkmarshalers.h"
31
32
33 static void   gtk_editable_base_init             (gpointer g_class);
34
35
36 GType
37 gtk_editable_get_type (void)
38 {
39   static GType editable_type = 0;
40
41   if (!editable_type)
42     {
43       static const GTypeInfo editable_info =
44       {
45         sizeof (GtkEditableClass),  /* class_size */
46         gtk_editable_base_init,     /* base_init */
47         NULL,                       /* base_finalize */
48       };
49
50       editable_type = g_type_register_static (G_TYPE_INTERFACE, "GtkEditable",
51                                               &editable_info, 0);
52     }
53
54   return editable_type;
55 }
56
57 static void
58 gtk_editable_base_init (gpointer g_class)
59 {
60   static gboolean initialized = FALSE;
61
62   if (! initialized)
63     {
64       g_signal_new ("insert_text",
65                     GTK_TYPE_EDITABLE,
66                     G_SIGNAL_RUN_LAST,
67                     G_STRUCT_OFFSET (GtkEditableClass, insert_text),
68                     NULL, NULL,
69                     _gtk_marshal_VOID__STRING_INT_POINTER,
70                     G_TYPE_NONE, 3,
71                     G_TYPE_STRING,
72                     G_TYPE_INT,
73                     G_TYPE_POINTER);
74       g_signal_new ("delete_text",
75                     GTK_TYPE_EDITABLE,
76                     G_SIGNAL_RUN_LAST,
77                     G_STRUCT_OFFSET (GtkEditableClass, delete_text),
78                     NULL, NULL,
79                     _gtk_marshal_VOID__INT_INT,
80                     G_TYPE_NONE, 2,
81                     G_TYPE_INT,
82                     G_TYPE_INT);
83       g_signal_new ("changed",
84                     GTK_TYPE_EDITABLE,
85                     G_SIGNAL_RUN_LAST,
86                     G_STRUCT_OFFSET (GtkEditableClass, changed),
87                     NULL, NULL,
88                     _gtk_marshal_VOID__VOID,
89                     G_TYPE_NONE, 0);
90
91       initialized = TRUE;
92     }
93 }
94
95 void
96 gtk_editable_insert_text (GtkEditable *editable,
97                           const gchar *new_text,
98                           gint         new_text_length,
99                           gint        *position)
100 {
101   g_return_if_fail (GTK_IS_EDITABLE (editable));
102   g_return_if_fail (position != NULL);
103
104   if (new_text_length < 0)
105     new_text_length = strlen (new_text);
106   
107   GTK_EDITABLE_GET_CLASS (editable)->do_insert_text (editable, new_text, new_text_length, position);
108 }
109
110 void
111 gtk_editable_delete_text (GtkEditable *editable,
112                           gint         start_pos,
113                           gint         end_pos)
114 {
115   g_return_if_fail (GTK_IS_EDITABLE (editable));
116
117   GTK_EDITABLE_GET_CLASS (editable)->do_delete_text (editable, start_pos, end_pos);
118 }
119
120 gchar *    
121 gtk_editable_get_chars (GtkEditable *editable,
122                         gint         start,
123                         gint         end)
124 {
125   g_return_val_if_fail (GTK_IS_EDITABLE (editable), FALSE);
126
127   return GTK_EDITABLE_GET_CLASS (editable)->get_chars (editable, start, end);
128 }
129
130 void
131 gtk_editable_set_position (GtkEditable      *editable,
132                            gint              position)
133 {
134   g_return_if_fail (GTK_IS_EDITABLE (editable));
135
136   GTK_EDITABLE_GET_CLASS (editable)->set_position (editable, position);
137 }
138
139 gint
140 gtk_editable_get_position (GtkEditable      *editable)
141 {
142   g_return_val_if_fail (GTK_IS_EDITABLE (editable), 0);
143
144   return GTK_EDITABLE_GET_CLASS (editable)->get_position (editable);
145 }
146
147 gboolean
148 gtk_editable_get_selection_bounds (GtkEditable *editable,
149                                    gint        *start_pos,
150                                    gint        *end_pos)
151 {
152   gint tmp_start, tmp_end;
153   gboolean result;
154   
155   g_return_val_if_fail (GTK_IS_EDITABLE (editable), FALSE);
156
157   result = GTK_EDITABLE_GET_CLASS (editable)->get_selection_bounds (editable, &tmp_start, &tmp_end);
158
159   if (start_pos)
160     *start_pos = MIN (tmp_start, tmp_end);
161   if (end_pos)
162     *end_pos = MAX (tmp_start, tmp_end);
163
164   return result;
165 }
166
167 void
168 gtk_editable_delete_selection (GtkEditable *editable)
169 {
170   gint start, end;
171
172   g_return_if_fail (GTK_IS_EDITABLE (editable));
173
174   if (gtk_editable_get_selection_bounds (editable, &start, &end))
175     gtk_editable_delete_text (editable, start, end);
176 }
177
178 void
179 gtk_editable_select_region (GtkEditable *editable,
180                             gint         start,
181                             gint         end)
182 {
183   g_return_if_fail (GTK_IS_EDITABLE (editable));
184   
185   GTK_EDITABLE_GET_CLASS (editable)->set_selection_bounds (editable,  start, end);
186 }
187
188 void
189 gtk_editable_cut_clipboard (GtkEditable *editable)
190 {
191   g_return_if_fail (GTK_IS_EDITABLE (editable));
192   
193   g_signal_emit_by_name (editable, "cut_clipboard");
194 }
195
196 void
197 gtk_editable_copy_clipboard (GtkEditable *editable)
198 {
199   g_return_if_fail (GTK_IS_EDITABLE (editable));
200   
201   g_signal_emit_by_name (editable, "copy_clipboard");
202 }
203
204 void
205 gtk_editable_paste_clipboard (GtkEditable *editable)
206 {
207   g_return_if_fail (GTK_IS_EDITABLE (editable));
208   
209   g_signal_emit_by_name (editable, "paste_clipboard");
210 }
211
212 void
213 gtk_editable_set_editable (GtkEditable    *editable,
214                            gboolean        is_editable)
215 {
216   g_return_if_fail (GTK_IS_EDITABLE (editable));
217
218   g_object_set (G_OBJECT (editable),
219                 "editable", is_editable != FALSE,
220                 NULL);
221 }
222
223 /**
224  * gtk_editable_get_editable:
225  * @editable: a #GtkEditable
226  *
227  * Retrieves whether @editable is editable. See
228  * gtk_editable_set_editable().
229  *
230  * Return value: %TRUE if @editable is editable.
231  **/
232 gboolean
233 gtk_editable_get_editable (GtkEditable *editable)
234 {
235   gboolean value;
236
237   g_return_val_if_fail (GTK_IS_EDITABLE (editable), FALSE);
238
239   g_object_get (G_OBJECT (editable), "editable", &value, NULL);
240
241   return value;
242 }