1999-06-11 Federico Mena Quintero <federico@nuclecu.unam.mx>
* complete.c (complete_engine): Put an #ifndef HAVE_GNOME around the completion/query engine. Make the Gnome version just beep instead. We do not have the completion/query engine for Gtk. 1999-06-11 Federico Mena Quintero <federico@nuclecu.unam.mx> * gwidget.c (x_update_input): Unblock the changed signal *after* we call gtk_editable_changed().
Этот коммит содержится в:
родитель
3ed2dc2a8d
Коммит
85b9ee430a
@ -1,3 +1,8 @@
|
|||||||
|
1999-06-11 Federico Mena Quintero <federico@nuclecu.unam.mx>
|
||||||
|
|
||||||
|
* gwidget.c (x_update_input): Unblock the changed signal *after*
|
||||||
|
we call gtk_editable_changed().
|
||||||
|
|
||||||
1999-06-09 Federico Mena Quintero <federico@nuclecu.unam.mx>
|
1999-06-09 Federico Mena Quintero <federico@nuclecu.unam.mx>
|
||||||
|
|
||||||
* gdesktop-icon.[ch]: Removed the background hack for desktop
|
* gdesktop-icon.[ch]: Removed the background hack for desktop
|
||||||
|
@ -23,7 +23,7 @@ get_gtk_widget (Widget_Item *p)
|
|||||||
|
|
||||||
if (GNOME_IS_ENTRY (w))
|
if (GNOME_IS_ENTRY (w))
|
||||||
return (gnome_entry_gtk_entry ((GnomeEntry *)(w)));
|
return (gnome_entry_gtk_entry ((GnomeEntry *)(w)));
|
||||||
else
|
else
|
||||||
return (GTK_WIDGET (p->widget->wdata));
|
return (GTK_WIDGET (p->widget->wdata));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -75,7 +75,7 @@ gbutton_callback (GtkWidget *w, void *data)
|
|||||||
|
|
||||||
if (b->callback)
|
if (b->callback)
|
||||||
stop = (*b->callback)(b->action, b->callback_data);
|
stop = (*b->callback)(b->action, b->callback_data);
|
||||||
|
|
||||||
if (!b->callback || stop){
|
if (!b->callback || stop){
|
||||||
h->ret_value = b->action;
|
h->ret_value = b->action;
|
||||||
dlg_stop (h);
|
dlg_stop (h);
|
||||||
@ -86,7 +86,7 @@ char *
|
|||||||
stock_from_text (char *text)
|
stock_from_text (char *text)
|
||||||
{
|
{
|
||||||
char *stock;
|
char *stock;
|
||||||
|
|
||||||
if ( g_strcasecmp (text, _("ok")) == 0)
|
if ( g_strcasecmp (text, _("ok")) == 0)
|
||||||
stock = GNOME_STOCK_BUTTON_OK;
|
stock = GNOME_STOCK_BUTTON_OK;
|
||||||
else if ( g_strcasecmp (text, _("cancel")) == 0)
|
else if ( g_strcasecmp (text, _("cancel")) == 0)
|
||||||
@ -118,7 +118,7 @@ x_create_button (Dlg_head *h, widget_data parent, WButton *b)
|
|||||||
|
|
||||||
if (stock){
|
if (stock){
|
||||||
button = gnome_stock_button (stock);
|
button = gnome_stock_button (stock);
|
||||||
} else
|
} else
|
||||||
button = gtk_button_new_with_label (b->text);
|
button = gtk_button_new_with_label (b->text);
|
||||||
|
|
||||||
if (b->flags == DEFPUSH_BUTTON){
|
if (b->flags == DEFPUSH_BUTTON){
|
||||||
@ -129,7 +129,7 @@ x_create_button (Dlg_head *h, widget_data parent, WButton *b)
|
|||||||
tag = gtk_signal_connect (GTK_OBJECT(button), "clicked", (GtkSignalFunc) gbutton_callback, b);
|
tag = gtk_signal_connect (GTK_OBJECT(button), "clicked", (GtkSignalFunc) gbutton_callback, b);
|
||||||
gtk_object_set_data (GTK_OBJECT (button), "click-signal-tag", (void *) tag);
|
gtk_object_set_data (GTK_OBJECT (button), "click-signal-tag", (void *) tag);
|
||||||
b->widget.wdata = (widget_data) button;
|
b->widget.wdata = (widget_data) button;
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -156,11 +156,11 @@ x_radio_focus_item (WRadio *radio)
|
|||||||
{
|
{
|
||||||
GList *children = GTK_BOX (radio->widget.wdata)->children;
|
GList *children = GTK_BOX (radio->widget.wdata)->children;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < radio->count; i++){
|
for (i = 0; i < radio->count; i++){
|
||||||
if (i == radio->pos){
|
if (i == radio->pos){
|
||||||
GtkBoxChild *bc = (GtkBoxChild *) children->data;
|
GtkBoxChild *bc = (GtkBoxChild *) children->data;
|
||||||
|
|
||||||
gtk_widget_grab_focus (GTK_WIDGET (bc->widget));
|
gtk_widget_grab_focus (GTK_WIDGET (bc->widget));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -173,7 +173,7 @@ x_radio_toggle (WRadio *radio)
|
|||||||
{
|
{
|
||||||
GList *children = GTK_BOX (radio->widget.wdata)->children;
|
GList *children = GTK_BOX (radio->widget.wdata)->children;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < radio->count; i++){
|
for (i = 0; i < radio->count; i++){
|
||||||
GtkBoxChild *bc = (GtkBoxChild *) children->data;
|
GtkBoxChild *bc = (GtkBoxChild *) children->data;
|
||||||
|
|
||||||
@ -216,7 +216,7 @@ x_create_radio (Dlg_head *h, widget_data parent, WRadio *r)
|
|||||||
vbox = gtk_vbox_new (0, 0);
|
vbox = gtk_vbox_new (0, 0);
|
||||||
for (i = 0; i < r->count; i++){
|
for (i = 0; i < r->count; i++){
|
||||||
char *text = remove_hotkey (_(r->texts [i]));
|
char *text = remove_hotkey (_(r->texts [i]));
|
||||||
|
|
||||||
if (i == 0){
|
if (i == 0){
|
||||||
w = gtk_radio_button_new_with_label (NULL, text);
|
w = gtk_radio_button_new_with_label (NULL, text);
|
||||||
r->first_gtk_radio = w;
|
r->first_gtk_radio = w;
|
||||||
@ -230,7 +230,7 @@ x_create_radio (Dlg_head *h, widget_data parent, WRadio *r)
|
|||||||
gtk_box_pack_start_defaults (GTK_BOX (vbox), w);
|
gtk_box_pack_start_defaults (GTK_BOX (vbox), w);
|
||||||
}
|
}
|
||||||
gtk_widget_show_all (vbox);
|
gtk_widget_show_all (vbox);
|
||||||
|
|
||||||
r->widget.wdata = (widget_data) vbox;
|
r->widget.wdata = (widget_data) vbox;
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
@ -311,13 +311,13 @@ x_create_input (Dlg_head *h, widget_data parent, WInput *in)
|
|||||||
gtk_entry_set_text (entry, in->buffer);
|
gtk_entry_set_text (entry, in->buffer);
|
||||||
gtk_editable_select_region (GTK_EDITABLE (entry), 0, -1);
|
gtk_editable_select_region (GTK_EDITABLE (entry), 0, -1);
|
||||||
gtk_entry_set_position (entry, in->point);
|
gtk_entry_set_position (entry, in->point);
|
||||||
|
|
||||||
gtk_signal_connect (GTK_OBJECT (entry), "button_press_event",
|
gtk_signal_connect (GTK_OBJECT (entry), "button_press_event",
|
||||||
GTK_SIGNAL_FUNC (entry_click), in);
|
GTK_SIGNAL_FUNC (entry_click), in);
|
||||||
|
|
||||||
gtk_signal_connect (GTK_OBJECT (entry), "button_release_event",
|
gtk_signal_connect (GTK_OBJECT (entry), "button_release_event",
|
||||||
GTK_SIGNAL_FUNC (entry_release), in);
|
GTK_SIGNAL_FUNC (entry_release), in);
|
||||||
|
|
||||||
gtk_signal_connect (GTK_OBJECT (entry), "changed",
|
gtk_signal_connect (GTK_OBJECT (entry), "changed",
|
||||||
GTK_SIGNAL_FUNC (wentry_changed), in);
|
GTK_SIGNAL_FUNC (wentry_changed), in);
|
||||||
return 1;
|
return 1;
|
||||||
@ -332,7 +332,7 @@ x_update_input (WInput *in)
|
|||||||
GtkEntry *entry;
|
GtkEntry *entry;
|
||||||
char *text;
|
char *text;
|
||||||
int draw = 0;
|
int draw = 0;
|
||||||
|
|
||||||
/* If the widget has not been initialized yet (done by WIDGET_INIT) */
|
/* If the widget has not been initialized yet (done by WIDGET_INIT) */
|
||||||
if (!in->widget.wdata)
|
if (!in->widget.wdata)
|
||||||
return;
|
return;
|
||||||
@ -360,19 +360,13 @@ x_update_input (WInput *in)
|
|||||||
if (text && strcmp (text, in->buffer)){
|
if (text && strcmp (text, in->buffer)){
|
||||||
gtk_entry_set_text (entry, in->buffer);
|
gtk_entry_set_text (entry, in->buffer);
|
||||||
draw = 1;
|
draw = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (GTK_EDITABLE (entry)->current_pos != in->point){
|
if (GTK_EDITABLE (entry)->current_pos != in->point){
|
||||||
gtk_entry_set_position (entry, in->point);
|
gtk_entry_set_position (entry, in->point);
|
||||||
draw = 1;
|
draw = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Unblock the signal handler */
|
|
||||||
gtk_signal_handler_unblock_by_func (
|
|
||||||
GTK_OBJECT (entry),
|
|
||||||
GTK_SIGNAL_FUNC(wentry_changed), in);
|
|
||||||
|
|
||||||
|
|
||||||
if (draw){
|
if (draw){
|
||||||
#ifdef USE_GNOME_ENTRY
|
#ifdef USE_GNOME_ENTRY
|
||||||
gtk_widget_draw (GTK_WIDGET (gnome_entry), NULL);
|
gtk_widget_draw (GTK_WIDGET (gnome_entry), NULL);
|
||||||
@ -382,6 +376,11 @@ x_update_input (WInput *in)
|
|||||||
gtk_editable_changed (GTK_EDITABLE (entry));
|
gtk_editable_changed (GTK_EDITABLE (entry));
|
||||||
gtk_widget_queue_draw (GTK_WIDGET (entry));
|
gtk_widget_queue_draw (GTK_WIDGET (entry));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Unblock the signal handler */
|
||||||
|
gtk_signal_handler_unblock_by_func (
|
||||||
|
GTK_OBJECT (entry),
|
||||||
|
GTK_SIGNAL_FUNC(wentry_changed), in);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Listboxes */
|
/* Listboxes */
|
||||||
@ -396,20 +395,20 @@ x_listbox_select_nth (WListbox *l, int nth)
|
|||||||
{
|
{
|
||||||
static int inside;
|
static int inside;
|
||||||
GtkCList *clist;
|
GtkCList *clist;
|
||||||
|
|
||||||
if (inside)
|
if (inside)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!l->widget.wdata)
|
if (!l->widget.wdata)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
inside = 1;
|
inside = 1;
|
||||||
clist = GTK_CLIST (listbox_pull (l->widget.wdata));
|
clist = GTK_CLIST (listbox_pull (l->widget.wdata));
|
||||||
|
|
||||||
gtk_clist_select_row (clist, nth, 0);
|
gtk_clist_select_row (clist, nth, 0);
|
||||||
if (gtk_clist_row_is_visible (clist, nth) != GTK_VISIBILITY_FULL)
|
if (gtk_clist_row_is_visible (clist, nth) != GTK_VISIBILITY_FULL)
|
||||||
gtk_clist_moveto (clist, nth, 0, 0.5, 0.0);
|
gtk_clist_moveto (clist, nth, 0, 0.5, 0.0);
|
||||||
|
|
||||||
inside = 0;
|
inside = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -430,24 +429,24 @@ listbox_select (GtkWidget *widget, int row, int column, GdkEvent *event, WListbo
|
|||||||
inside = 1;
|
inside = 1;
|
||||||
|
|
||||||
listbox_select_by_number (l, row);
|
listbox_select_by_number (l, row);
|
||||||
|
|
||||||
if (!event){
|
if (!event){
|
||||||
inside = 0;
|
inside = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (event->type == GDK_2BUTTON_PRESS){
|
if (event->type == GDK_2BUTTON_PRESS){
|
||||||
switch (l->action){
|
switch (l->action){
|
||||||
case listbox_nothing:
|
case listbox_nothing:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case listbox_finish:
|
case listbox_finish:
|
||||||
h->running = 0;
|
h->running = 0;
|
||||||
h->ret_value = B_ENTER;
|
h->ret_value = B_ENTER;
|
||||||
gtk_main_quit ();
|
gtk_main_quit ();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case listbox_cback:
|
case listbox_cback:
|
||||||
if ((*l->cback)(l) == listbox_finish){
|
if ((*l->cback)(l) == listbox_finish){
|
||||||
gtk_main_quit ();
|
gtk_main_quit ();
|
||||||
@ -470,11 +469,11 @@ x_create_listbox (Dlg_head *h, widget_data parent, WListbox *l)
|
|||||||
GtkRequisition req;
|
GtkRequisition req;
|
||||||
WLEntry *p;
|
WLEntry *p;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
listbox = gtk_clist_new (1);
|
listbox = gtk_clist_new (1);
|
||||||
sw = gtk_scrolled_window_new (NULL, NULL);
|
sw = gtk_scrolled_window_new (NULL, NULL);
|
||||||
gtk_container_add (GTK_CONTAINER (sw), listbox);
|
gtk_container_add (GTK_CONTAINER (sw), listbox);
|
||||||
|
|
||||||
gtk_clist_set_selection_mode (GTK_CLIST (listbox), GTK_SELECTION_BROWSE);
|
gtk_clist_set_selection_mode (GTK_CLIST (listbox), GTK_SELECTION_BROWSE);
|
||||||
gtk_widget_size_request (listbox, &req);
|
gtk_widget_size_request (listbox, &req);
|
||||||
gtk_widget_set_usize (listbox, req.width, req.height + 20*8);
|
gtk_widget_set_usize (listbox, req.width, req.height + 20*8);
|
||||||
@ -485,7 +484,7 @@ x_create_listbox (Dlg_head *h, widget_data parent, WListbox *l)
|
|||||||
|
|
||||||
g_warning ("FIXME: actually compute the real size of the listbox");
|
g_warning ("FIXME: actually compute the real size of the listbox");
|
||||||
l->height = 8;
|
l->height = 8;
|
||||||
|
|
||||||
for (p = l->list, i = 0; i < l->count; i++, p = p->next){
|
for (p = l->list, i = 0; i < l->count; i++, p = p->next){
|
||||||
char *text [1];
|
char *text [1];
|
||||||
|
|
||||||
@ -510,7 +509,7 @@ x_list_insert (WListbox *l, WLEntry *p, WLEntry *e)
|
|||||||
break;
|
break;
|
||||||
p = p->next;
|
p = p->next;
|
||||||
pos++;
|
pos++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p != e){
|
if (p != e){
|
||||||
printf ("x_list_insert: should not happen!\n");
|
printf ("x_list_insert: should not happen!\n");
|
||||||
@ -555,7 +554,7 @@ buttonbar_clicked (GtkWidget *widget, WButtonBar *bb)
|
|||||||
GtkBox *box = GTK_BOX (widget->parent);
|
GtkBox *box = GTK_BOX (widget->parent);
|
||||||
GList *children = box->children;
|
GList *children = box->children;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Find out which button we are (number) */
|
/* Find out which button we are (number) */
|
||||||
for (i = 0; children; children = children->next, i++){
|
for (i = 0; children; children = children->next, i++){
|
||||||
if (((GtkBoxChild *)children->data)->widget == widget){
|
if (((GtkBoxChild *)children->data)->widget == widget){
|
||||||
@ -575,7 +574,7 @@ x_create_buttonbar (Dlg_head *h, widget_data parent, WButtonBar *bb)
|
|||||||
#if 0
|
#if 0
|
||||||
int i;
|
int i;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
hbox = gtk_hbox_new (0, 0);
|
hbox = gtk_hbox_new (0, 0);
|
||||||
#if 0
|
#if 0
|
||||||
for (i = 0; i < 10; i++){
|
for (i = 0; i < 10; i++){
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
1999-06-11 Federico Mena Quintero <federico@nuclecu.unam.mx>
|
||||||
|
|
||||||
|
* complete.c (complete_engine): Put an #ifndef HAVE_GNOME around
|
||||||
|
the completion/query engine. Make the Gnome version just beep
|
||||||
|
instead. We do not have the completion/query engine for Gtk.
|
||||||
|
|
||||||
1999-06-09 Pavel Machek <pavel@artax.karlin.mff.cuni.cz>
|
1999-06-09 Pavel Machek <pavel@artax.karlin.mff.cuni.cz>
|
||||||
|
|
||||||
* cmd.c (configure_panel_listing): no more code duplication
|
* cmd.c (configure_panel_listing): no more code duplication
|
||||||
|
@ -994,6 +994,11 @@ complete_engine (WInput *in, int what_to_do)
|
|||||||
} else
|
} else
|
||||||
beep ();
|
beep ();
|
||||||
}
|
}
|
||||||
|
/* FIXME: evil evil evil. We do not go into the query completion engine
|
||||||
|
* because we do not have a Gtk dialog for it. Gtk-ted does not like
|
||||||
|
* this; if we enable this code, it will crash.
|
||||||
|
*/
|
||||||
|
#ifndef HAVE_GNOME
|
||||||
if ((what_to_do & DO_QUERY) && in->completions [1]) {
|
if ((what_to_do & DO_QUERY) && in->completions [1]) {
|
||||||
int maxlen = 0, i, count = 0;
|
int maxlen = 0, i, count = 0;
|
||||||
int x, y, w, h;
|
int x, y, w, h;
|
||||||
@ -1052,6 +1057,10 @@ complete_engine (WInput *in, int what_to_do)
|
|||||||
if (i == B_USER)
|
if (i == B_USER)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
if (what_to_do & DO_QUERY)
|
||||||
|
beep ();
|
||||||
|
#endif
|
||||||
} else
|
} else
|
||||||
beep ();
|
beep ();
|
||||||
return 0;
|
return 0;
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user