]> Pileus Git - ~andy/gtk/blob - gtk/gtkeditable.c
53a40f70cc7a68cf7aa767e528542f2207c08cf7
[~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 <config.h>
28 #include <string.h>
29
30 #include "gtkeditable.h"
31 #include "gtkmarshalers.h"
32 #include "gtkalias.h"
33
34
35 static void   gtk_editable_base_init             (gpointer g_class);
36
37
38 GType
39 gtk_editable_get_type (void)
40 {
41   static GType editable_type = 0;
42
43   if (!editable_type)
44     {
45       static const GTypeInfo editable_info =
46       {
47         sizeof (GtkEditableClass),  /* class_size */
48         gtk_editable_base_init,     /* base_init */
49         NULL,                       /* base_finalize */
50       };
51
52       editable_type = g_type_register_static (G_TYPE_INTERFACE, g_intern_static_string ("GtkEditable"),
53                                               &editable_info, 0);
54     }
55
56   return editable_type;
57 }
58
59 static void
60 gtk_editable_base_init (gpointer g_class)
61 {
62   static gboolean initialized = FALSE;
63
64   if (! initialized)
65     {
66       g_signal_new ("insert_text",
67                     GTK_TYPE_EDITABLE,
68                     G_SIGNAL_RUN_LAST,
69                     G_STRUCT_OFFSET (GtkEditableClass, insert_text),
70                     NULL, NULL,
71                     _gtk_marshal_VOID__STRING_INT_POINTER,
72                     G_TYPE_NONE, 3,
73                     G_TYPE_STRING,
74                     G_TYPE_INT,
75                     G_TYPE_POINTER);
76       g_signal_new ("delete_text",
77                     GTK_TYPE_EDITABLE,
78                     G_SIGNAL_RUN_LAST,
79                     G_STRUCT_OFFSET (GtkEditableClass, delete_text),
80                     NULL, NULL,
81                     _gtk_marshal_VOID__INT_INT,
82                     G_TYPE_NONE, 2,
83                     G_TYPE_INT,
84                     G_TYPE_INT);
85       g_signal_new ("changed",
86                     GTK_TYPE_EDITABLE,
87                     G_SIGNAL_RUN_LAST,
88                     G_STRUCT_OFFSET (GtkEditableClass, changed),
89                     NULL, NULL,
90                     _gtk_marshal_VOID__VOID,
91                     G_TYPE_NONE, 0);
92
93       initialized = TRUE;
94     }
95 }
96
97 void
98 gtk_editable_insert_text (GtkEditable *editable,
99                           const gchar *new_text,
100                           gint         new_text_length,
101                           gint        *position)
102 {
103   g_return_if_fail (GTK_IS_EDITABLE (editable));
104   g_return_if_fail (position != NULL);
105
106   if (new_text_length < 0)
107     new_text_length = strlen (new_text);
108   
109   GTK_EDITABLE_GET_CLASS (editable)->do_insert_text (editable, new_text, new_text_length, position);
110 }
111
112 void
113 gtk_editable_delete_text (GtkEditable *editable,
114                           gint         start_pos,
115                           gint         end_pos)
116 {
117   g_return_if_fail (GTK_IS_EDITABLE (editable));
118
119   GTK_EDITABLE_GET_CLASS (editable)->do_delete_text (editable, start_pos, end_pos);
120 }
121
122 gchar *    
123 gtk_editable_get_chars (GtkEditable *editable,
124                         gint         start,
125                         gint         end)
126 {
127   g_return_val_if_fail (GTK_IS_EDITABLE (editable), NULL);
128
129   return GTK_EDITABLE_GET_CLASS (editable)->get_chars (editable, start, end);
130 }
131
132 void
133 gtk_editable_set_position (GtkEditable      *editable,
134                            gint              position)
135 {
136   g_return_if_fail (GTK_IS_EDITABLE (editable));
137
138   GTK_EDITABLE_GET_CLASS (editable)->set_position (editable, position);
139 }
140
141 gint
142 gtk_editable_get_position (GtkEditable      *editable)
143 {
144   g_return_val_if_fail (GTK_IS_EDITABLE (editable), 0);
145
146   return GTK_EDITABLE_GET_CLASS (editable)->get_position (editable);
147 }
148
149 gboolean
150 gtk_editable_get_selection_bounds (GtkEditable *editable,
151                                    gint        *start_pos,
152                                    gint        *end_pos)
153 {
154   gint tmp_start, tmp_end;
155   gboolean result;
156   
157   g_return_val_if_fail (GTK_IS_EDITABLE (editable), FALSE);
158
159   result = GTK_EDITABLE_GET_CLASS (editable)->get_selection_bounds (editable, &tmp_start, &tmp_end);
160
161   if (start_pos)
162     *start_pos = MIN (tmp_start, tmp_end);
163   if (end_pos)
164     *end_pos = MAX (tmp_start, tmp_end);
165
166   return result;
167 }
168
169 void
170 gtk_editable_delete_selection (GtkEditable *editable)
171 {
172   gint start, end;
173
174   g_return_if_fail (GTK_IS_EDITABLE (editable));
175
176   if (gtk_editable_get_selection_bounds (editable, &start, &end))
177     gtk_editable_delete_text (editable, start, end);
178 }
179
180 void
181 gtk_editable_select_region (GtkEditable *editable,
182                             gint         start,
183                             gint         end)
184 {
185   g_return_if_fail (GTK_IS_EDITABLE (editable));
186   
187   GTK_EDITABLE_GET_CLASS (editable)->set_selection_bounds (editable,  start, end);
188 }
189
190 void
191 gtk_editable_cut_clipboard (GtkEditable *editable)
192 {
193   g_return_if_fail (GTK_IS_EDITABLE (editable));
194   
195   g_signal_emit_by_name (editable, "cut_clipboard");
196 }
197
198 void
199 gtk_editable_copy_clipboard (GtkEditable *editable)
200 {
201   g_return_if_fail (GTK_IS_EDITABLE (editable));
202   
203   g_signal_emit_by_name (editable, "copy_clipboard");
204 }
205
206 void
207 gtk_editable_paste_clipboard (GtkEditable *editable)
208 {
209   g_return_if_fail (GTK_IS_EDITABLE (editable));
210   
211   g_signal_emit_by_name (editable, "paste_clipboard");
212 }
213
214 void
215 gtk_editable_set_editable (GtkEditable    *editable,
216                            gboolean        is_editable)
217 {
218   g_return_if_fail (GTK_IS_EDITABLE (editable));
219
220   g_object_set (editable,
221                 "editable", is_editable != FALSE,
222                 NULL);
223 }
224
225 /**
226  * gtk_editable_get_editable:
227  * @editable: a #GtkEditable
228  *
229  * Retrieves whether @editable is editable. See
230  * gtk_editable_set_editable().
231  *
232  * Return value: %TRUE if @editable is editable.
233  **/
234 gboolean
235 gtk_editable_get_editable (GtkEditable *editable)
236 {
237   gboolean value;
238
239   g_return_val_if_fail (GTK_IS_EDITABLE (editable), FALSE);
240
241   g_object_get (editable, "editable", &value, NULL);
242
243   return value;
244 }
245
246 #define __GTK_EDITABLE_C__
247 #include "gtkaliasdef.c"