/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 2003 Match Grun
+ * Copyright (C) 2003-2012 Match Grun and the Claws Mail team
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
+ * the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
*/
/*
#ifdef HAVE_CONFIG_H
# include "config.h"
+#include "claws-features.h"
#endif
#ifdef USE_LDAP
#include "defs.h"
#include <glib.h>
+#include <glib/gi18n.h>
#include <gdk/gdkkeysyms.h>
-#include <gtk/gtkwindow.h>
-#include <gtk/gtksignal.h>
-#include <gtk/gtkhbox.h>
-#include <gtk/gtklabel.h>
-#include <gtk/gtkentry.h>
-#include <gtk/gtkhbbox.h>
-#include <gtk/gtkbutton.h>
+#include <gtk/gtk.h>
#include <pthread.h>
-#include "intl.h"
#include "gtkutils.h"
#include "stock_pixmap.h"
#include "prefs_common.h"
GtkWidget *label_address;
GtkWidget *list_entry;
GtkWidget *close_btn;
- GtkWidget *statusbar;
- gint status_cid;
} browseldap_dlg;
/**
GList *node;
NameValuePair *nvp;
- /* printf( "browse_callback_entry...\n" ); */
+ debug_print("browse_callback_entry...\n");
pthread_mutex_lock( & _browseMutex_ );
/* Append contents to end of display queue */
node = listValues;
while( node ) {
nvp = ( NameValuePair * ) node->data;
- /* ldapqry_print_name_value( nvp, stdout ); */
+ debug_print("adding to list: %s->%s\n",
+ nvp->name?nvp->name:"null",
+ nvp->value?nvp->value:"null");
_displayQueue_ = g_list_append( _displayQueue_, nvp );
node->data = NULL;
node = g_list_next( node );
}
pthread_mutex_unlock( & _browseMutex_ );
- /* printf( "browse_callback_entry...done\n" ); */
+ /* g_print( "browse_callback_entry...done\n" ); */
return 0;
}
static gint browse_callback_end(
LdapQuery *qry, gint queryID, gint status, gpointer data )
{
+ debug_print("search completed\n");
_searchComplete_ = TRUE;
+ return 0;
}
/**
pthread_mutex_unlock( & _browseMutex_ );
}
-/**
- * Clear message in status bar.
- * \param msg Message.
- */
-static void browse_status_show( gchar *msg ) {
- if( browseldap_dlg.statusbar != NULL ) {
- gtk_statusbar_pop( GTK_STATUSBAR(browseldap_dlg.statusbar),
- browseldap_dlg.status_cid );
- if( msg ) {
- gtk_statusbar_push(
- GTK_STATUSBAR(browseldap_dlg.statusbar),
- browseldap_dlg.status_cid, msg );
- }
- }
-}
-
/**
* Close window callback.
* \param widget Widget.
static void browse_key_pressed(
GtkWidget *widget, GdkEventKey *event, gboolean *cancelled )
{
- if (event && event->keyval == GDK_Escape) {
+ if (event && event->keyval == GDK_KEY_Escape) {
gtk_main_quit();
}
}
GtkWidget *tree_win;
GtkWidget *hbbox;
GtkWidget *close_btn;
- GtkWidget *hsbox;
- GtkWidget *statusbar;
gint top;
- window = gtk_window_new(GTK_WINDOW_DIALOG);
- gtk_widget_set_usize( window, BROWSELDAP_WIDTH, BROWSELDAP_HEIGHT );
+ debug_print("creating browse widget\n");
+ window = gtk_dialog_new();
+ gtk_widget_set_size_request( window, BROWSELDAP_WIDTH, BROWSELDAP_HEIGHT );
gtk_container_set_border_width( GTK_CONTAINER(window), 0 );
gtk_window_set_title( GTK_WINDOW(window), _("Browse Directory Entry") );
gtk_window_set_position( GTK_WINDOW(window), GTK_WIN_POS_MOUSE );
- gtk_window_set_modal( GTK_WINDOW(window), TRUE );
g_signal_connect(G_OBJECT(window), "delete_event",
G_CALLBACK(browse_delete_event), NULL);
g_signal_connect(G_OBJECT(window), "key_press_event",
G_CALLBACK(browse_key_pressed), NULL);
vbox = gtk_vbox_new(FALSE, 8);
- gtk_container_add(GTK_CONTAINER(window), vbox);
+ gtk_box_pack_start(GTK_BOX(GTK_DIALOG(window)->vbox), vbox, TRUE, TRUE, 0);
gtk_container_set_border_width( GTK_CONTAINER(vbox), 8 );
table = gtk_table_new(2, 2, FALSE);
/* First row */
top = 0;
- label = gtk_label_new(_("Server Name :"));
+ label = gtk_label_new(_("Server Name:"));
gtk_table_attach(GTK_TABLE(table), label, 0, 1, top, (top + 1), GTK_FILL, 0, 0, 0);
gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
/* Second row */
top++;
- label = gtk_label_new(_("Distinguished Name (dn) :"));
+ label = gtk_label_new(_("Distinguished Name (dn):"));
gtk_table_attach(GTK_TABLE(table), label, 0, 1, top, (top + 1), GTK_FILL, 0, 0, 0);
gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
tree_win = gtk_scrolled_window_new( NULL, NULL );
gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW(tree_win),
GTK_POLICY_AUTOMATIC,
- GTK_POLICY_ALWAYS );
+ GTK_POLICY_AUTOMATIC );
gtk_box_pack_start( GTK_BOX(vlbox), tree_win, TRUE, TRUE, 0 );
- list_entry = gtk_clist_new( N_COLS );
+ list_entry = gtk_cmclist_new( N_COLS );
gtk_container_add( GTK_CONTAINER(tree_win), list_entry );
- gtk_clist_column_titles_show( GTK_CLIST(list_entry) );
- gtk_clist_set_column_title(
- GTK_CLIST(list_entry), COL_NAME, _( "LDAP Name" ) );
- gtk_clist_set_column_title(
- GTK_CLIST(list_entry), COL_VALUE, _( "Attribute Value" ) );
- gtk_clist_set_selection_mode(
- GTK_CLIST(list_entry), GTK_SELECTION_BROWSE );
- gtk_clist_set_column_width( GTK_CLIST(list_entry),
+ gtk_cmclist_column_titles_show( GTK_CMCLIST(list_entry) );
+ gtk_cmclist_set_column_title(
+ GTK_CMCLIST(list_entry), COL_NAME, _( "LDAP Name" ) );
+ gtk_cmclist_set_column_title(
+ GTK_CMCLIST(list_entry), COL_VALUE, _( "Attribute Value" ) );
+ gtk_cmclist_set_selection_mode(
+ GTK_CMCLIST(list_entry), GTK_SELECTION_BROWSE );
+ gtk_cmclist_set_column_width( GTK_CMCLIST(list_entry),
COL_NAME, COL_WIDTH_NAME );
- gtk_clist_set_auto_sort( GTK_CLIST(list_entry), TRUE );
-
- /* Status line */
- hsbox = gtk_hbox_new(FALSE, 0);
- gtk_box_pack_end(GTK_BOX(vbox), hsbox, FALSE, FALSE, BORDER_WIDTH);
- statusbar = gtk_statusbar_new();
- gtk_box_pack_start(GTK_BOX(hsbox), statusbar, TRUE, TRUE, BORDER_WIDTH);
+ gtk_cmclist_set_auto_sort( GTK_CMCLIST(list_entry), TRUE );
/* Button panel */
- gtkut_button_set_create(&hbbox, &close_btn, _( "Close" ),
- NULL, NULL, NULL, NULL);
+ gtkut_stock_button_set_create(&hbbox, &close_btn, GTK_STOCK_CLOSE,
+ NULL, NULL, NULL, NULL);
gtk_box_pack_end(GTK_BOX(vbox), hbbox, FALSE, FALSE, 0);
gtk_container_set_border_width( GTK_CONTAINER(hbbox), 0 );
browseldap_dlg.label_address = label_addr;
browseldap_dlg.list_entry = list_entry;
browseldap_dlg.close_btn = close_btn;
- browseldap_dlg.statusbar = statusbar;
- browseldap_dlg.status_cid =
- gtk_statusbar_get_context_id(
- GTK_STATUSBAR(statusbar), "Browse LDAP" );
gtk_widget_show_all( window );
nvp = ( NameValuePair * ) node->data;
text[COL_NAME] = nvp->name;
text[COL_VALUE] = nvp->value;
- gtk_clist_append(
- GTK_CLIST(browseldap_dlg.list_entry), text );
+ debug_print("Adding row to list: %s->%s\n",
+ nvp->name?nvp->name:"null",
+ nvp->value?nvp->value:"null");
+ gtk_cmclist_append(
+ GTK_CMCLIST(browseldap_dlg.list_entry), text );
/* Free up entry */
ldapqry_free_name_value( nvp );
if( _searchComplete_ ) {
/* Remove idler */
if( _browseIdleID_ != 0 ) {
- gtk_idle_remove( _browseIdleID_ );
+ g_source_remove( _browseIdleID_ );
_browseIdleID_ = 0;
- gtk_clist_select_row(
- GTK_CLIST( browseldap_dlg.list_entry ), 0, 0 );
+ gtk_cmclist_select_row(
+ GTK_CMCLIST( browseldap_dlg.list_entry ), 0, 0 );
}
}
gtk_widget_grab_focus(browseldap_dlg.close_btn);
gtk_widget_show(browseldap_dlg.window);
manage_window_set_transient(GTK_WINDOW(browseldap_dlg.window));
-
- browse_status_show( "" );
- gtk_clist_select_row( GTK_CLIST( browseldap_dlg.list_entry ), 0, 0 );
+ gtk_window_set_modal(GTK_WINDOW(browseldap_dlg.window), TRUE);
+ gtk_cmclist_select_row( GTK_CMCLIST( browseldap_dlg.list_entry ), 0, 0 );
gtk_widget_show(browseldap_dlg.window);
gtk_label_set_text( GTK_LABEL(browseldap_dlg.label_address ), "" );
GTK_LABEL(browseldap_dlg.label_server ),
ldapsvr_get_name( server ) );
+ debug_print("browsing server: %s\n", ldapsvr_get_name(server));
/* Setup search */
_searchComplete_ = FALSE;
_queryID_ = ldaplocate_search_setup(
server, dn, browse_callback_entry, browse_callback_end );
- _browseIdleID_ = gtk_idle_add( ( GtkFunction ) browse_idle, NULL );
+ debug_print("query id: %d\n", _queryID_);
+ _browseIdleID_ = g_idle_add( (GSourceFunc) browse_idle, NULL );
/* Start search */
+ debug_print("starting search\n");
ldaplocate_search_start( _queryID_ );
/* Display dialog */
gtk_main();
gtk_widget_hide( browseldap_dlg.window );
-
+ gtk_window_set_modal(GTK_WINDOW(browseldap_dlg.window), FALSE);
/* Stop query */
+ debug_print("stopping search\n");
ldaplocate_search_stop( _queryID_ );
if( _browseIdleID_ != 0 ) {
- gtk_idle_remove( _browseIdleID_ );
+ g_source_remove( _browseIdleID_ );
_browseIdleID_ = 0;
}
browse_clear_queue();
- gtk_clist_clear( GTK_CLIST( browseldap_dlg.list_entry ) );
+ gtk_cmclist_clear( GTK_CMCLIST( browseldap_dlg.list_entry ) );
return TRUE;
}