summaryrefslogtreecommitdiff
path: root/src/gui_kde.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui_kde.cc')
-rw-r--r--src/gui_kde.cc464
1 files changed, 252 insertions, 212 deletions
diff --git a/src/gui_kde.cc b/src/gui_kde.cc
index 499db7754..1ac8db990 100644
--- a/src/gui_kde.cc
+++ b/src/gui_kde.cc
@@ -40,8 +40,8 @@ extern "C" {
#undef mputs
#if 1
-#define dbf( format, args... ) { printf( "%s" " : " format "\n" , __FUNCTION__ , ## args ); fflush(stdout); }
-#define db() { printf( "%s\n", __FUNCTION__ );fflush(stdout); }
+#define dbf(format, args...) { printf("%s" " : " format "\n" , __FUNCTION__ , ## args ); fflush(stdout); }
+#define db() { printf("%s\n", __FUNCTION__ );fflush(stdout); }
#else
#define dbf(format, args... )
#define db()
@@ -165,163 +165,184 @@ const char *kdeicons[] = {
/*
* creates a blank pixmap using tb_blank
*/
- QPixmap
+ QPixmap
pixmap_create_from_xpm(char **xpm)//{{{
{
- return(QPixmap((const char **)xpm));
+ return (QPixmap((const char **)xpm));
}//}}}
/*
* creates a pixmap by using a built-in number
*/
- QPixmap
+ QPixmap
pixmap_create_by_num(int pixmap_num)//{{{
{
#ifdef FEAT_KDETOOLBAR
- if (pixmap_num >= 0 && (unsigned)pixmap_num < (sizeof(kdeicons)
- / sizeof(kdeicons[0])) - 1) {
-
- KIconLoader *il = kapp->iconLoader(); //new KIconLoader();
- QString icon;
- icon=QString(kdeicons[pixmap_num]);
- return il->loadIcon(icon,KIcon::MainToolbar);
- }
- return QPixmap();
+ if (pixmap_num >= 0 && (unsigned)pixmap_num < (sizeof(kdeicons)
+ / sizeof(kdeicons[0])) - 1)
+ {
+
+ KIconLoader *il = kapp->iconLoader(); //new KIconLoader();
+ QString icon;
+ icon = QString(kdeicons[pixmap_num]);
+ return il->loadIcon(icon, KIcon::MainToolbar);
+ }
+ return QPixmap();
#else
- if (pixmap_num >= 0 && (unsigned)pixmap_num < (sizeof(built_in_pixmaps)
- / sizeof(built_in_pixmaps[0])) - 1)
- return pixmap_create_from_xpm(built_in_pixmaps[pixmap_num]);
- else return QPixmap();
+ if (pixmap_num >= 0 && (unsigned)pixmap_num < (sizeof(built_in_pixmaps)
+ / sizeof(built_in_pixmaps[0])) - 1)
+ return pixmap_create_from_xpm(built_in_pixmaps[pixmap_num]);
+ else
+ return QPixmap();
#endif
}//}}}
/*
* Creates a pixmap by using the pixmap "name" found in 'runtimepath'/bitmaps/
*/
- QPixmap
+ QPixmap
pixmap_create_by_dir(char_u *name)//{{{
{
- char_u full_pathname[MAXPATHL + 1];
+ char_u full_pathname[MAXPATHL + 1];
- if (gui_find_bitmap(name, full_pathname, "xpm") == OK) {
- return QPixmap((const char *)full_pathname);
- }
- else return QPixmap();
+ if (gui_find_bitmap(name, full_pathname, "xpm") == OK)
+ {
+ return QPixmap((const char *)full_pathname);
+ }
+ else
+ return QPixmap();
}//}}}
- QPixmap
+ QPixmap
pixmap_create_from_file(char_u *file)
{
- return QPixmap((const char*)file);
+ return QPixmap((const char *)file);
}
#endif
- void
+ void
gui_mch_add_menu(vimmenu_T * menu, int idx)//{{{
{
#ifdef FEAT_MENU
- QPopupMenu *me;
- vimmenu_T *parent = menu->parent;
-
- if (menu_is_popup(menu->name)) {
- menu->widget = new QPopupMenu(vmw , (const char *) menu->name);
- QObject::connect( menu->widget, SIGNAL(activated(int)), vmw, SLOT(menu_activated(int)) );
- return;
- }
-
- if (!menu_is_menubar(menu->name))
- return;
-
- if (parent) {
- idx++; // for tearoffs to be first in menus
- me = new QPopupMenu(parent->widget, (const char *) menu->name);
- parent->widget->insertItem( QString((const char *)menu->name), me, (int)me, idx);
- } else {
- me = new QPopupMenu(vmw->menuBar() , (const char *) menu->name);
- vmw->menuBar()->insertItem( QString((const char *)menu->name), me , (int) me, idx);
- }
-
- me->setCaption((const char*)( menu->dname ));
- if (vmw->have_tearoff) me->insertTearOffHandle(0,0);
- QObject::connect( me, SIGNAL(activated(int)), vmw, SLOT(menu_activated(int)) );
- menu->widget = me;
+ QPopupMenu *me;
+ vimmenu_T *parent = menu->parent;
+
+ if (menu_is_popup(menu->name))
+ {
+ menu->widget = new QPopupMenu(vmw , (const char *)menu->name);
+ QObject::connect(menu->widget, SIGNAL(activated(int)), vmw,
+ SLOT(menu_activated(int)));
+ return;
+ }
+
+ if (!menu_is_menubar(menu->name))
+ return;
+
+ if (parent)
+ {
+ idx++; // for tearoffs to be first in menus
+ me = new QPopupMenu(parent->widget, (const char *)menu->name);
+ parent->widget->insertItem(QString((const char *)menu->name), me,
+ (int)me, idx);
+ }
+ else
+ {
+ me = new QPopupMenu(vmw->menuBar() , (const char *)menu->name);
+ vmw->menuBar()->insertItem(QString((const char *)menu->name), me,
+ (int)me, idx);
+ }
+
+ me->setCaption((const char *)(menu->dname));
+ if (vmw->have_tearoff)
+ me->insertTearOffHandle(0, 0);
+ QObject::connect(me, SIGNAL(activated(int)), vmw,
+ SLOT(menu_activated(int)));
+ menu->widget = me;
#endif
}//}}}
- void
+ void
gui_mch_add_menu_item(vimmenu_T * menu, int idx)//{{{
{
#ifdef FEAT_MENU
- vimmenu_T *parent = menu->parent;
+ vimmenu_T *parent = menu->parent;
#ifdef FEAT_TOOLBAR
- if (menu_is_toolbar(parent->name)) {
- QPixmap pix;
- if ( menu_is_separator(menu->name) )
- {
- vmw->toolBar()->insertSeparator();
- return;
- }
- if (menu->iconfile != NULL) {
- pix = pixmap_create_from_file(menu->iconfile);
- }
- if (!menu->icon_builtin) {
- pix = pixmap_create_by_dir(menu->name);
- }
- if (pix.isNull() && menu->iconidx >= 0) {
- pix = pixmap_create_by_num(menu->iconidx);
- }
+ if (menu_is_toolbar(parent->name))
+ {
+ QPixmap pix;
+
+ if (menu_is_separator(menu->name))
+ {
+ vmw->toolBar()->insertSeparator();
+ return;
+ }
+ if (menu->iconfile != NULL)
+ {
+ pix = pixmap_create_from_file(menu->iconfile);
+ }
+ if (!menu->icon_builtin)
+ {
+ pix = pixmap_create_by_dir(menu->name);
+ }
+ if (pix.isNull() && menu->iconidx >= 0)
+ {
+ pix = pixmap_create_by_num(menu->iconidx);
+ }
#ifndef FEAT_KDETOOLBAR
- if (pix.isNull()) {
- pix = pixmap_create_from_xpm(tb_blank_xpm);
- }
-#endif
- if (pix.isNull()) return; // failed
- vmw->toolBar()->insertButton (
- pix,
- (int) menu , // id
- true,
- (char *) (menu->strings[MENU_INDEX_TIP]) , // tooltip or text
- idx
- );
- menu->parent=parent;
- return;
+ if (pix.isNull())
+ {
+ pix = pixmap_create_from_xpm(tb_blank_xpm);
}
+#endif
+ if (pix.isNull())
+ return; // failed
+ vmw->toolBar()->insertButton(
+ pix,
+ (int)menu, // id
+ true,
+ (char *)(menu->strings[MENU_INDEX_TIP]), // tooltip or text
+ idx);
+ menu->parent=parent;
+ return;
+ }
#endif // FEAT_TOOLBAR
- idx++;
- if ( menu_is_separator(menu->name) ) {
- parent->widget->insertSeparator();
- return;
- }
- parent->widget->insertItem(QString((const char *)menu->name), (int)menu, idx );
+ idx++;
+ if (menu_is_separator(menu->name))
+ {
+ parent->widget->insertSeparator();
+ return;
+ }
+ parent->widget->insertItem(QString((const char *)menu->name), (int)menu, idx);
#endif
}//}}}
- void
+ void
gui_mch_set_text_area_pos(int x, int y, int w, int h)//{{{
{
- int X = 0;
- int Y = 0;
- if (vmw->menuBar()->isVisible() && vmw->menuBar()->isEnabled()
+ int X = 0;
+ int Y = 0;
+
+ if (vmw->menuBar()->isVisible() && vmw->menuBar()->isEnabled()
#if QT_VERSION>=300
- && !vmw->menuBar()->isTopLevelMenu()
+ && !vmw->menuBar()->isTopLevelMenu()
#endif
- )
- Y += vmw->menuBar()->height();
+ )
+ Y += vmw->menuBar()->height();
#ifdef FEAT_TOOLBAR
- if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled() &&
- vmw->toolBar()->barPos()==KToolBar::Top)
- Y += vmw->toolBar()->height();
+ if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled()
+ && vmw->toolBar()->barPos()==KToolBar::Top)
+ Y += vmw->toolBar()->height();
- if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled() &&
- vmw->toolBar()->barPos()==KToolBar::Left)
- X += vmw->toolBar()->width();
+ if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled()
+ && vmw->toolBar()->barPos()==KToolBar::Left)
+ X += vmw->toolBar()->width();
#endif // FEAT_TOOLBAR
- gui.w->setGeometry(x+X,y+Y,w,h);
+ gui.w->setGeometry(x + X, y + Y, w, h);
}//}}}
@@ -329,24 +350,29 @@ gui_mch_set_text_area_pos(int x, int y, int w, int h)//{{{
/*
* Enable or disable mnemonics for the toplevel menus.
*/
- void
+ void
gui_gtk_set_mnemonics(int enable)//{{{ // TO BE REMOVED
{
}//}}}
- void
+ void
toggle_tearoffs(vimmenu_T *menu, int enable)//{{{
{
- while (menu != NULL) {
- if (!menu_is_popup(menu->name)) {
- if (menu->widget != 0) {
- if (enable) menu->widget->insertTearOffHandle(0,0);
- else menu->widget->removeItem(0);
- }
- toggle_tearoffs(menu->children, enable);
- }
- menu = menu->next;
+ while (menu != NULL)
+ {
+ if (!menu_is_popup(menu->name))
+ {
+ if (menu->widget != 0)
+ {
+ if (enable)
+ menu->widget->insertTearOffHandle(0,0);
+ else
+ menu->widget->removeItem(0);
+ }
+ toggle_tearoffs(menu->children, enable);
}
+ menu = menu->next;
+ }
}//}}}
void
@@ -362,20 +388,21 @@ gui_mch_toggle_tearoffs(int enable)//{{{
/*
* Destroy the machine specific menu widget.
*/
- void
+ void
gui_mch_destroy_menu(vimmenu_T * menu)//{{{
{
#ifdef FEAT_TOOLBAR
- if (menu->parent && menu_is_toolbar(menu->parent->name)) {
- vmw->toolBar()->removeItem( (int) menu );
- return;
- }
+ if (menu->parent && menu_is_toolbar(menu->parent->name))
+ {
+ vmw->toolBar()->removeItem((int)menu);
+ return;
+ }
#endif
- if (menu->parent)
- menu->parent->widget->removeItem((int)menu);
- if (menu->widget)
- delete menu->widget;
- menu->widget = 0;
+ if (menu->parent)
+ menu->parent->widget->removeItem((int)menu);
+ if (menu->widget)
+ delete menu->widget;
+ menu->widget = 0;
}//}}}
#endif /* FEAT_MENU */
@@ -384,68 +411,78 @@ gui_mch_destroy_menu(vimmenu_T * menu)//{{{
* Scrollbar stuff.
*/
- void
-gui_mch_set_scrollbar_thumb(scrollbar_T * sb, long val, long size, long max)//{{{
+ void
+gui_mch_set_scrollbar_thumb(scrollbar_T *sb, long val, long size, long max)//{{{
{
- if (!sb->w) return;
+ if (!sb->w)
+ return;
- sb->w->setRange(0, max+1-size);
- sb->w->setValue(val);
+ sb->w->setRange(0, max + 1 - size);
+ sb->w->setValue(val);
- sb->w->setLineStep(1);
- sb->w->setPageStep(size);
+ sb->w->setLineStep(1);
+ sb->w->setPageStep(size);
}//}}}
- void
-gui_mch_set_scrollbar_pos(scrollbar_T * sb, int x, int y, int w, int h)//{{{
+ void
+gui_mch_set_scrollbar_pos(scrollbar_T *sb, int x, int y, int w, int h)//{{{
{
- if (!sb->w) return;
- //we add the menubar and toolbar height/width
- int X = 0;
- int Y = 0;
+ if (!sb->w)
+ return;
+ //we add the menubar and toolbar height/width
+ int X = 0;
+ int Y = 0;
- if (vmw->menuBar()->isVisible() && vmw->menuBar()->isEnabled()
+ if (vmw->menuBar()->isVisible() && vmw->menuBar()->isEnabled()
#if QT_VERSION>=300
- && !vmw->menuBar()->isTopLevelMenu()
+ && !vmw->menuBar()->isTopLevelMenu()
#endif
- )
- Y += vmw->menuBar()->height();
+ )
+ Y += vmw->menuBar()->height();
#ifdef FEAT_TOOLBAR
- if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled() &&
- vmw->toolBar()->barPos()==KToolBar::Top)
- Y += vmw->toolBar()->height();
+ if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled()
+ && vmw->toolBar()->barPos()==KToolBar::Top)
+ Y += vmw->toolBar()->height();
- if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled() &&
- vmw->toolBar()->barPos()==KToolBar::Left)
- X += vmw->toolBar()->width();
+ if (vmw->toolBar()->isVisible() && vmw->toolBar()->isEnabled()
+ && vmw->toolBar()->barPos()==KToolBar::Left)
+ X += vmw->toolBar()->width();
#endif //FEAT_TOOLBAR
- if (sb->w->orientation() == Qt::Vertical) {
- bool leftscroll=gui.which_scrollbars[SBAR_LEFT];
- bool rightscroll=gui.which_scrollbars[SBAR_RIGHT];
- if (x<20) leftscroll=true;
- else rightscroll=true;
- if (x<20) sb->w->setGeometry(X,y+Y,w,h);
- else sb->w->setGeometry(vmw->width()-w-1+X, y+Y,w,h);
- } else {
- sb->w->setGeometry(x+X,y+Y,w,h);
- }
+ if (sb->w->orientation() == Qt::Vertical)
+ {
+ bool leftscroll=gui.which_scrollbars[SBAR_LEFT];
+ bool rightscroll=gui.which_scrollbars[SBAR_RIGHT];
+
+ if (x < 20)
+ leftscroll = true;
+ else
+ rightscroll = true;
+ if (x < 20)
+ sb->w->setGeometry(X, y+Y, w, h);
+ else
+ sb->w->setGeometry(vmw->width() - w - 1 + X, y + Y, w, h);
+ }
+ else
+ {
+ sb->w->setGeometry(x + X, y + Y, w, h);
+ }
}//}}}
/* SBAR_VERT or SBAR_HORIZ */
- void
-gui_mch_create_scrollbar(scrollbar_T * sb, int orient)//{{{
+ void
+gui_mch_create_scrollbar(scrollbar_T *sb, int orient)//{{{
{
- sbpool->create(sb,orient);
- if (orient==SBAR_VERT)
- gui.scrollbar_width = sb->w->sizeHint().width();
- else
- gui.scrollbar_height = sb->w->sizeHint().height();
+ sbpool->create(sb,orient);
+ if (orient == SBAR_VERT)
+ gui.scrollbar_width = sb->w->sizeHint().width();
+ else
+ gui.scrollbar_height = sb->w->sizeHint().height();
}//}}}
- void
+ void
gui_mch_destroy_scrollbar(scrollbar_T * sb)//{{{
{
- sbpool->destroy(sb);
+ sbpool->destroy(sb);
}//}}}
#if defined(FEAT_BROWSE) || defined(PROTO)
@@ -464,7 +501,7 @@ gui_mch_destroy_scrollbar(scrollbar_T * sb)//{{{
* filter not used (file name filter)
*/
/*ARGSUSED*/
-char_u *
+ char_u *
gui_mch_browse(int saving,//{{{
char_u * title,
char_u * dflt,
@@ -472,36 +509,37 @@ gui_mch_browse(int saving,//{{{
char_u * initdir,
char_u * filter)
{
- char * filt_glob;
+ char *filt_glob;
- if (filter != (char_u *) 0x0 )
- {
- filter = vim_strsave(filter);
- strtok((char *) filter, "(");
- filt_glob = strtok(0L, ")");
- }
- else
- filt_glob = (char *) filter;
+ if (filter != (char_u *)0x0)
+ {
+ filter = vim_strsave(filter);
+ strtok((char *)filter, "(");
+ filt_glob = strtok(0L, ")");
+ }
+ else
+ filt_glob = (char *)filter;
- gui_mch_mousehide(FALSE);
+ gui_mch_mousehide(FALSE);
- QString s;
- if (!saving)
- s = KFileDialog::getOpenFileName( (char *) initdir, (char *) filt_glob, vmw, (char *) title );
- else
- s = KFileDialog::getSaveFileName( );
+ QString s;
+ if (!saving)
+ s = KFileDialog::getOpenFileName((char *)initdir, (char *)filt_glob,
+ vmw, (char *)title);
+ else
+ s = KFileDialog::getSaveFileName();
- if (filter)
- vim_free(filter);
+ if (filter)
+ vim_free(filter);
- if (s.isNull())
- return NULL;
- QCString unistring = vmw->codec->fromUnicode(s);
- char_u * s2 = (char_u *)(const char*)unistring;
- if (s2)
- s2 = vim_strsave( s2 );
+ if (s.isNull())
+ return NULL;
+ QCString unistring = vmw->codec->fromUnicode(s);
+ char_u *s2 = (char_u *)(const char *)unistring;
+ if (s2)
+ s2 = vim_strsave(s2);
- return s2;
+ return s2;
}//}}}
#endif /* FEAT_BROWSE */
@@ -511,9 +549,9 @@ gui_mch_browse(int saving,//{{{
/* ARGSUSED */
int
gui_mch_dialog(int type, /* type of dialog *///{{{
- char_u * title, /* title of dialog */
- char_u * message, /* message text */
- char_u * buttons, /* names of buttons */
+ char_u *title, /* title of dialog */
+ char_u *message, /* message text */
+ char_u *buttons, /* names of buttons */
int def_but, /* default button */
char_u *textfield)
{
@@ -546,8 +584,8 @@ gui_make_popup (char_u *pathname)//{{{
/* Find and Replace implementations */
- void
-gui_mch_find_dialog(exarg_T * eap)//{{{
+ void
+gui_mch_find_dialog(exarg_T *eap)//{{{
{
// char_u* entry_text;
//int exact_word=FALSE;
@@ -555,8 +593,9 @@ gui_mch_find_dialog(exarg_T * eap)//{{{
vmw->finddlg->setCaseSensitive(true);
- /* if (entry_text!=NULL) {
- vmw->finddlg->setText(QString((char*)entry_text));
+ /* if (entry_text!=NULL)
+ * {
+ vmw->finddlg->setText(QString((char *)entry_text));
// exact match should go there, hopefully KDE old KEdFind/KEdReplace will be replaced in KDE 4 as pple wanted KDE 3's Find/Replace to be kept
}*/ // Don't use it, KDE keeps old search in memory and vim give \\Csearch, which is difficult to handle
// vim_free(entry_text);
@@ -564,25 +603,26 @@ gui_mch_find_dialog(exarg_T * eap)//{{{
vmw->finddlg->show();
}//}}}
- void
-gui_mch_replace_dialog(exarg_T * eap)//{{{
+ void
+gui_mch_replace_dialog(exarg_T *eap)//{{{
{
- // char_u* entry_text;
- //int exact_word=FALSE;
+ // char_u* entry_text;
+ //int exact_word=FALSE;
- // entry_text = get_find_dialog_text(eap->arg,&exact_word);
+ // entry_text = get_find_dialog_text(eap->arg,&exact_word);
- /* if (entry_text!=NULL) {
- vmw->repldlg->setText(QString((char*)entry_text));
- // exact match should go there, hopefully KDE old KEdFind/KEdReplace will be replaced in KDE 4 as pple wanted KDE 3's Find/Replace to be kept
- }*/
- //vim_free(entry_text);
+ /* if (entry_text!=NULL)
+ * {
+ vmw->repldlg->setText(QString((char *)entry_text));
+ // exact match should go there, hopefully KDE old KEdFind/KEdReplace will be replaced in KDE 4 as pple wanted KDE 3's Find/Replace to be kept
+ }*/
+ //vim_free(entry_text);
- vmw->repldlg->show();
+ vmw->repldlg->show();
}//}}}
- void
+ void
ex_helpfind(exarg_T *eap)//{{{
{
- do_cmdline_cmd((char_u *)"emenu ToolBar.FindHelp");
+ do_cmdline_cmd((char_u *)"emenu ToolBar.FindHelp");
}//}}}