diff options
Diffstat (limited to 'extra')
-rw-r--r-- | extra/xfe/.md5sum | 2 | ||||
-rw-r--r-- | extra/xfe/Pkgfile | 8 | ||||
-rw-r--r-- | extra/xfe/ViewWindow.cppnew | 751 | ||||
-rw-r--r-- | extra/xfe/xfe-1.04-freetype.patch | 39 | ||||
-rw-r--r-- | extra/xfe/xfe-1.32.1-pos-01.patch | 20 |
5 files changed, 26 insertions, 794 deletions
diff --git a/extra/xfe/.md5sum b/extra/xfe/.md5sum index 99995aaeb..30d610a8f 100644 --- a/extra/xfe/.md5sum +++ b/extra/xfe/.md5sum @@ -1,2 +1,2 @@ -30b5447a11569565e125499441c3270d gcc44.patch +be09eee1dd65d3de31830b9b31c4b823 xfe-1.32.1-pos-01.patch 7ccbc35fc92cf72d2e405d32bfd741bc xfe-1.32.1.tar.gz diff --git a/extra/xfe/Pkgfile b/extra/xfe/Pkgfile index 6399409bd..d792d9940 100644 --- a/extra/xfe/Pkgfile +++ b/extra/xfe/Pkgfile @@ -2,16 +2,18 @@ # URL: http://roland65.free.fr/xfe # Maintainer: NuTyX core team # Packager: thierryn1 at hispeed dot ch -# Depends on: fox +# Depends on: fox, libpng, libjpeg, libtiff name=xfe version=1.32.1 -release=1 -source=(http://downloads.sourceforge.net/$name/$name-$version.tar.gz) +release=2 +source=(http://downloads.sourceforge.net/$name/$name-$version.tar.gz\ + $name-$version-pos-01.patch) build() { cd $name-$version + patch -Np1 -i ../$name-$version-pos-01.patch ./configure --prefix=/usr make make DESTDIR=$PKG install diff --git a/extra/xfe/ViewWindow.cppnew b/extra/xfe/ViewWindow.cppnew deleted file mode 100644 index c2825a66d..000000000 --- a/extra/xfe/ViewWindow.cppnew +++ /dev/null @@ -1,751 +0,0 @@ -// This is adapted from 'textedit', a demo text viewer found -// in the early versions of the FOX library and written -// by Jeroen van der Zijp. - -#include "config.h" -#include "i18n.h" - -#include <stdio.h> -#include <stdlib.h> -#include <sys/stat.h> -#include <string.h> -#include <unistd.h> - -#include <fx.h> -#include <fxkeys.h> -#include <FXPNGIcon.h> - -#include "xfedefs.h" -#include "icons.h" -#include "FontDialog.h" -#include "InputDialog.h" -#include "FileDialog.h" -#include "MessageBox.h" -#include "ViewWindow.h" -#include "XFileView.h" - - -// Map -FXDEFMAP(ViewWindow) ViewWindowMap[]= -{ - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_ABOUT,ViewWindow::onCmdAbout), - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_OPEN,ViewWindow::onCmdOpen), - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_OPEN_RECENT,ViewWindow::onCmdOpenRecent), - FXMAPFUNC(SEL_UPDATE,0,ViewWindow::onUpdTitle), - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_FIND,ViewWindow::onCmdFind), - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_FIND_AGAIN,ViewWindow::onCmdFind), - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_QUIT,ViewWindow::onCmdQuit), - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_PRINT,ViewWindow::onCmdPrint), - FXMAPFUNC(SEL_COMMAND,ViewWindow::ID_FONT,ViewWindow::onCmdFont), - FXMAPFUNC(SEL_UPDATE,ViewWindow::ID_FIND_AGAIN,ViewWindow::onCmdFind), - FXMAPFUNC(SEL_UPDATE,ViewWindow::ID_FIND,ViewWindow::onUpdMenu), - FXMAPFUNC(SEL_UPDATE,ViewWindow::ID_PRINT,ViewWindow::onUpdMenu), - FXMAPFUNCS(SEL_UPDATE,ViewWindow::ID_WINDOW_1,ViewWindow::ID_WINDOW_50,ViewWindow::onUpdWindow), - FXMAPFUNCS(SEL_COMMAND,ViewWindow::ID_WINDOW_1,ViewWindow::ID_WINDOW_50,ViewWindow::onCmdWindow), -}; - - -// Object implementation -FXIMPLEMENT(ViewWindow,FXMainWindow,ViewWindowMap,ARRAYNUMBER(ViewWindowMap)) - - -// Make some windows -ViewWindow::ViewWindow(XFileView* a,const FXString& file):FXMainWindow(a,"XFileView",NULL,NULL,DECOR_ALL),mrufiles(a) -{ - FXHotKey hotkey; - FXButton *btn = NULL; - - // Add to list of windows - getApp()->windowlist.append(this); - - setIcon(xfvicon); - //setMiniIcon(xfvsmallicon); - - // Default font - font=NULL; - - // Make menu bar - menubar=new FXMenuBar(this,LAYOUT_DOCK_NEXT|LAYOUT_SIDE_TOP|LAYOUT_FILL_X|FRAME_RAISED); - - // Sites where to dock - FXDockSite* topdock=new FXDockSite(this,LAYOUT_SIDE_TOP|LAYOUT_FILL_X); - new FXDockSite(this,LAYOUT_SIDE_BOTTOM|LAYOUT_FILL_X); - new FXDockSite(this,LAYOUT_SIDE_LEFT|LAYOUT_FILL_Y); - new FXDockSite(this,LAYOUT_SIDE_RIGHT|LAYOUT_FILL_Y); - - // Tool bar - FXToolBarShell* dragshell1=new FXToolBarShell(this,FRAME_RAISED); - toolbar=new FXToolBar(topdock,dragshell1,LAYOUT_DOCK_NEXT|LAYOUT_SIDE_TOP|LAYOUT_FILL_X|FRAME_RAISED); - new FXToolBarGrip(toolbar,toolbar,FXToolBar::ID_TOOLBARGRIP,TOOLBARGRIP_DOUBLE); - int style=BUTTON_TOOLBAR; - - // Status bar - statusbar=new FXStatusBar(this,FRAME_RAISED|LAYOUT_SIDE_BOTTOM|LAYOUT_FILL_X); - new FXDragCorner(statusbar); - - // File menu - filemenu=new FXMenuPane(this); - new FXMenuTitle(menubar,_("&File"),NULL,filemenu); - - // Edit menu - editmenu=new FXMenuPane(this); - new FXMenuTitle(menubar,_("&Edit"),NULL,editmenu); - - // Search Menu - searchmenu=new FXMenuPane(this); - new FXMenuTitle(menubar,_("&Search"),NULL,searchmenu); - - // Preferences Menu - prefsmenu=new FXMenuPane(this); - new FXMenuTitle(menubar,_("&Preferences"),NULL,prefsmenu); - - // Window menu - windowmenu=new FXMenuPane(this); - new FXMenuTitle(menubar,_("&Window"),NULL,windowmenu); - - // Help menu - helpmenu=new FXMenuPane(this); - new FXMenuTitle(menubar,_("&Help"),NULL,helpmenu); - - // Make contents - contents=new FXHorizontalFrame(this,FRAME_SUNKEN|LAYOUT_FILL_X|LAYOUT_FILL_Y,0,0,0,0, 0,0,0,0, 0,0); - - // Make viewer window - viewer=new FXText(contents,NULL,0,LAYOUT_FILL_X|LAYOUT_FILL_Y); - - // Show column number in status bar - FXTextField* colno=new FXTextField(statusbar,4,viewer,FXText::ID_CURSOR_COLUMN,TEXTFIELD_READONLY|FRAME_SUNKEN|LAYOUT_RIGHT|LAYOUT_CENTER_Y,0,0,0,0,0,0,0,0); - colno->setBackColor(statusbar->getBackColor()); - - // Caption before number - new FXLabel(statusbar,_("Col:"),NULL,LAYOUT_RIGHT|LAYOUT_CENTER_Y); - - // Show line number in status bar - FXTextField* rowno=new FXTextField(statusbar,4,viewer,FXText::ID_CURSOR_ROW,TEXTFIELD_READONLY|FRAME_SUNKEN|LAYOUT_RIGHT|LAYOUT_CENTER_Y,0,0,0,0,0,0,0,0); - rowno->setBackColor(statusbar->getBackColor()); - - // Caption before number - new FXLabel(statusbar,_("Line:"),NULL,LAYOUT_RIGHT|LAYOUT_CENTER_Y); - - // Toolbar button: File open - new FXButton(toolbar,_("\tOpen document (Ctrl-O)\tOpen document file. (Ctrl-O)"),fileopenicon,this,ID_OPEN,style|FRAME_RAISED|LAYOUT_TOP|LAYOUT_LEFT); - - // Toolbar button: Print - new FXButton(toolbar,_("\tPrint document (Ctrl-P)\tPrint document file. (Ctrl-P)"),printicon,this,ID_PRINT,style|BUTTON_TOOLBAR|FRAME_RAISED|LAYOUT_TOP|LAYOUT_LEFT); - - // Toolbar button: Quit - btn=new FXButton(toolbar,_("\tQuit Xfv (Ctrl-Q)\tQuit Xfv. (Ctrl-Q)"),quiticon,this,ID_QUIT,style|FRAME_RAISED|LAYOUT_TOP|LAYOUT_LEFT); - btn->hide(); - hotkey=(CONTROLMASK<<16) | KEY_w; - btn->addHotKey(hotkey); - - // Toolbar button: Copy - new FXSeparator(toolbar,SEPARATOR_GROOVE); - new FXButton(toolbar,_("\tCopy (Ctrl-C)\tCopy selection to clipboard. (Ctrl-C)"),copy_clpicon,viewer,FXText::ID_COPY_SEL,ICON_ABOVE_TEXT|BUTTON_TOOLBAR|FRAME_RAISED|LAYOUT_TOP|LAYOUT_LEFT); - - // Toolbar buttons: Searching - new FXSeparator(toolbar,SEPARATOR_GROOVE); - //new FXFrame(toolbar,LAYOUT_TOP|LAYOUT_LEFT|LAYOUT_FIX_WIDTH|LAYOUT_FIX_HEIGHT,0,0,10,10); - new FXButton(toolbar,_("\tFind a string (Ctrl-F)\tFind string in document. (Ctrl-F)"),searchicon,this,ID_FIND,style|FRAME_RAISED|LAYOUT_TOP|LAYOUT_LEFT); - new FXButton(toolbar,_("\tFind again (Ctrl-G)\tFind again. (Ctrl-G)"),find_againicon,this,ID_FIND_AGAIN,style|FRAME_RAISED|LAYOUT_TOP|LAYOUT_LEFT); - - // File Menu entries - new FXMenuCommand(filemenu,_("&Open file...\tCtrl-O\tOpen document file. (Ctrl-O)"),fileopenicon,this,ID_OPEN); - new FXMenuCommand(filemenu,_("&Print file...\tCtrl-P\tPrint document file. (Ctrl-P)"),printicon,this,ID_PRINT); - - // Recent file menu; this automatically hides if there are no files - FXMenuSeparator* sep1=new FXMenuSeparator(filemenu); - sep1->setTarget(&mrufiles); - sep1->setSelector(FXRecentFiles::ID_ANYFILES); - new FXMenuCommand(filemenu,FXString::null,NULL,&mrufiles,FXRecentFiles::ID_FILE_1); - new FXMenuCommand(filemenu,FXString::null,NULL,&mrufiles,FXRecentFiles::ID_FILE_2); - new FXMenuCommand(filemenu,FXString::null,NULL,&mrufiles,FXRecentFiles::ID_FILE_3); - new FXMenuCommand(filemenu,FXString::null,NULL,&mrufiles,FXRecentFiles::ID_FILE_4); - new FXMenuCommand(filemenu,FXString::null,NULL,&mrufiles,FXRecentFiles::ID_FILE_5); - new FXMenuCommand(filemenu,_("&Clear Recent Files"),NULL,&mrufiles,FXRecentFiles::ID_CLEAR); - FXMenuSeparator* sep2=new FXMenuSeparator(filemenu); - sep2->setTarget(&mrufiles); - sep2->setSelector(FXRecentFiles::ID_ANYFILES); - - new FXMenuCommand(filemenu,_("&Quit\tCtrl-Q\tQuit Xfv. (Ctrl Q)"),quiticon,this,ID_QUIT); - - // Edit menu - new FXMenuCommand(editmenu,_("&Copy\tCtrl-C\tCopy selection to clipboard. (Ctrl-C)"),copy_clpicon,viewer,FXText::ID_COPY_SEL); - - // Search Menu entries - new FXMenuCommand(searchmenu,_("&Find a string...\tCtrl-F\tFind a string in a document. (Ctrl-F)"),searchicon,this,ID_FIND); - new FXMenuCommand(searchmenu,_("Find &again\tCtrl-G\tFind again. (Ctrl-G)"),find_againicon,this,ID_FIND_AGAIN); - - - // Preferences menu - new FXMenuCheck(prefsmenu,_("&Toolbar\t\tDisplay or hide toolbar."),toolbar,FXWindow::ID_TOGGLESHOWN); - new FXMenuCheck(prefsmenu,_("&Status bar\t\tDisplay or hide status bar."),statusbar,FXWindow::ID_TOGGLESHOWN); - new FXMenuCommand(prefsmenu,_("&Font...\t\tChange text font."),fontsicon,this,ID_FONT); - - // Window menu - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_1); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_2); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_3); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_4); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_5); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_6); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_7); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_8); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_9); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_10); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_11); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_12); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_13); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_14); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_15); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_16); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_17); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_18); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_19); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_20); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_21); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_22); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_23); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_24); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_25); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_26); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_27); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_28); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_29); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_30); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_31); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_32); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_33); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_34); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_35); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_36); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_37); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_38); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_39); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_40); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_41); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_42); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_43); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_44); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_45); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_46); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_47); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_48); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_49); - new FXMenuRadio(windowmenu,FXString::null,this,ID_WINDOW_50); - - // Help Menu entries - new FXMenuCommand(helpmenu,_("&About X File View\tF1\tAbout X File View. (F1)"),NULL,this,ID_ABOUT,0); - - // Make a tool tip - new FXToolTip(getApp(),0); - - // Dialogs - printdialog=NULL; - finddialog=NULL; - findtext=NULL; - - // Recent files - mrufiles.setTarget(this); - mrufiles.setSelector(ID_OPEN_RECENT); - - // Initialize file name - filename=file; - filenameset=FALSE; - - // Initialize window position and size - fromreg=TRUE; - ww=0; - hh=0; - xx=0; - yy=0; -} - - -// Create and show window -void ViewWindow::create() -{ - // Read the Xfe registry - FXRegistry* reg_xfe=new FXRegistry(XFEAPPNAME,""); - reg_xfe->read(); - - // Set Xfv text font according to the Xfe registry - FXString fontspec; - fontspec=reg_xfe->readStringEntry("SETTINGS","textfont","Helvetica,100,normal,regular"); - if(!fontspec.empty()) - { - FXFont* font=new FXFont(getApp(),fontspec); - font->create(); - viewer->setFont(font); - } - delete reg_xfe; - - - // Get size and position from registry - if (fromreg) - { - ww=getApp()->reg().readUnsignedEntry("OPTIONS","width",DEFAULT_WINDOW_WIDTH); - hh=getApp()->reg().readUnsignedEntry("OPTIONS","height",DEFAULT_WINDOW_HEIGHT); - xx=getApp()->reg().readIntEntry("OPTIONS","xpos",DEFAULT_WINDOW_XPOS); - yy=getApp()->reg().readIntEntry("OPTIONS","ypos",DEFAULT_WINDOW_YPOS); - } - - // Get toolbar status - if(getApp()->reg().readUnsignedEntry("OPTIONS","showtoolbar",TRUE)==FALSE) - toolbar->hide(); - - // Get status bar status - if(getApp()->reg().readUnsignedEntry("OPTIONS","showstatusbar",TRUE)==FALSE) - statusbar->hide(); - - FXMainWindow::create(); - filemenu->create(); - editmenu->create(); - searchmenu->create(); - prefsmenu->create(); - windowmenu->create(); - helpmenu->create(); - show(PLACEMENT_DEFAULT); - viewer->setFocus(); - viewer->handle(this,FXSEL(SEL_COMMAND,FXText::ID_TOGGLE_EDITABLE),NULL); - - // Reposition window - position(xx,yy,ww,hh); -} - - -// Destructor -ViewWindow::~ViewWindow() -{ - getApp()->windowlist.remove(this); - delete menubar; - delete toolbar; - delete statusbar; - delete font; - delete filemenu; - delete editmenu; - delete searchmenu; - delete prefsmenu; - delete helpmenu; - delete windowmenu; - delete contents; - delete printdialog; - delete finddialog; - delete findtext; -} - - -// About box -long ViewWindow::onCmdAbout(FXObject*,FXSelector,void*) -{ - FXString msg=_("X File View Version "); - msg = msg + VERSION + _(" is a simple text viewer.\n\nCopyright (C) 2002-2008 Roland Baudin (roland65@free.fr)"); - MessageBox about(this,_("About X File View"),msg.text(),xfvicon,BOX_OK|DECOR_TITLE|DECOR_BORDER); - about.execute(PLACEMENT_OWNER); - - return 1; -} - - -// Load file -FXbool ViewWindow::loadFile(const FXString& file) -{ - struct stat info; - char *text; - FILE *fp; - int n; - if(stat(file.text(),&info)!=0) - { - MessageBox::error(this,BOX_OK,_("Error Loading File"),_("Non-existing file: %s"),file.text()); - return FALSE; - } - fp=fopen(file.text(),"r"); - if(!fp) - { - MessageBox::error(this,BOX_OK,_("Error Loading File"),_("Unable to open file: %s"),file.text()); - return FALSE; - } - - // Set wait cursor - getApp()->beginWaitCursor(); - - FXMALLOC(&text,FXchar,info.st_size+1); - n=fread(text,1,info.st_size,fp); - if(n!=info.st_size) - { - MessageBox::error(this,BOX_OK,_("Error Reading File"),_("Unable to load entire file: %s"),file.text()); - getApp()->endWaitCursor(); - return FALSE; - } - else - { - text[info.st_size]='\0'; - viewer->setText(text); - viewer->setModified(FALSE); - } - FXFREE(&text); - fclose(fp); - - // Kill wait cursor - getApp()->endWaitCursor(); - - mrufiles.appendFile(file); - filenameset=TRUE; - filename=file; - return TRUE; -} - - -// Open -long ViewWindow::onCmdOpen(FXObject*,FXSelector,void*) -{ - const FXchar *patterns[]= - { - _("All Files"), "*", - _("Text Files"), "*.txt", - _("C Source Files"), "*.c", - _("C++ Source Files"), "*.cpp", - _("C++ Source Files"), "*.cc", - _("C++ Source Files"), "*.cxx", - _("C/C++ Header Files"), "*.h", - _("HTML Files"), "*.html", - _("HTML Files"), "*.htm", - _("PHP Files"), "*.php",NULL - }; - - FileDialog opendialog(this,_("Open Document")); - - opendialog.setSelectMode(SELECTFILE_MULTIPLE); - opendialog.setPatternList(patterns); - opendialog.setDirectory(FXPath::directory(filename)); - if(opendialog.execute()) - { - FXString* files=opendialog.getFilenames(); - FXuint i=0; - while (files[i]!=FXString::null) - { - ViewWindow *window=findWindow(files[i]); - if(!window) - { - window=findUnused(); - if(!window) - { - // New window - window=new ViewWindow(getApp(),unique()); - - // Smooth scrolling - window->setSmoothScroll(smoothscroll); - - // Set the size and position of the new window - window->fromreg=FALSE; - window->ww=getWidth(); - window->hh=getHeight(); - window->xx=getX(); - window->yy=getY(); - - // Create window - window->create(); - } - window->loadFile(files[i]); - } - window->raise(); - window->setFocus(); - i++; - } - delete[] files; - } - - return 1; -} - - -// Open recent file -long ViewWindow::onCmdOpenRecent(FXObject*,FXSelector,void* ptr) -{ - FXString file=(const char*)ptr; - ViewWindow *window=findWindow(file); - if(!window) - { - window=findUnused(); - if(!window) - { - window=new ViewWindow(getApp(),unique()); - window->create(); - } - window->loadFile(file); - } - window->raise(); - window->setFocus(); - return 1; -} - - -// Print the text -long ViewWindow::onCmdPrint(FXObject*,FXSelector,void*) -{ - // Read the current print command from the registry - FXString printcommand, command; - printcommand=getApp()->reg().readStringEntry("OPTIONS","print_command","lpr -P printer"); - - // Open print dialog filled with the current print command - int rc=1; - if (printdialog==NULL) - printdialog=new InputDialog(this,printcommand,_("Print command: \n(ex: lpr -P <printer>)"),_("Print"),"",printbigicon); - printdialog->setText(printcommand); - printdialog->CursorEnd(); - rc=printdialog->execute(PLACEMENT_CURSOR); - printcommand=printdialog->getText(); - - // If cancel was pressed, exit - if (!rc) - return 0; - - // Write the new print command to the registry - getApp()->reg().writeStringEntry("OPTIONS","print_command",printcommand.text()); - - // Perform the print command - command = "cat " + filename + " |" + printcommand + " &"; - system(command.text()); - - return 1; -} - - -// Change text font -long ViewWindow::onCmdFont(FXObject*,FXSelector,void*) -{ - FontDialog fontdlg(this,_("Change Font"),DECOR_BORDER|DECOR_TITLE); - FXFontDesc fontdesc; - viewer->getFont()->getFontDesc(fontdesc); - fontdlg.setFontSelection(fontdesc); - if(fontdlg.execute()) - { - FXFont *oldfont=font; - fontdlg.getFontSelection(fontdesc); - font=new FXFont(getApp(),fontdesc); - font->create(); - viewer->setFont(font); - delete oldfont; - } - saveConfig(); - return 1; -} - - -// Save configuration when quitting -void ViewWindow::saveConfig() -{ - FXString fontspec; - - // Write new window size and position back to registry - getApp()->reg().writeUnsignedEntry("OPTIONS","width",(FXuint)getWidth()); - getApp()->reg().writeUnsignedEntry("OPTIONS","height",(FXuint)getHeight()); - getApp()->reg().writeIntEntry("OPTIONS","xpos",getX()); - getApp()->reg().writeIntEntry("OPTIONS","ypos",getY()); - - // Toolbar status - if(toolbar->shown()) - getApp()->reg().writeUnsignedEntry("OPTIONS","showtoolbar",TRUE); - else - getApp()->reg().writeUnsignedEntry("OPTIONS","showtoolbar",FALSE); - - // Status bar status - if(statusbar->shown()) - getApp()->reg().writeUnsignedEntry("OPTIONS","showstatusbar",TRUE); - else - getApp()->reg().writeUnsignedEntry("OPTIONS","showstatusbar",FALSE); - - // Font - fontspec=viewer->getFont()->getFont(); - getApp()->reg().writeStringEntry("OPTIONS","textfont",fontspec.text()); - - // Write registry OPTIONS - getApp()->reg().write(); -} - - -// Quit -long ViewWindow::onCmdQuit(FXObject* sender,FXSelector sel,void* ptr) -{ - // Save OPTIONS - saveConfig(); - - // Quit - getApp()->exit(0); - return 1; -} - - -// Update title -long ViewWindow::onUpdTitle(FXObject* sender,FXSelector sel,void* ptr) -{ - FXMainWindow::onUpdate(sender,sel,ptr); - FXString title=FXPath::name(getFilename()); - FXString directory=FXPath::directory(getFilename()); - if(!directory.empty()) - title+=" - " + directory; - setTitle(title); - return 1; -} - - -// Update open, print and find menus -long ViewWindow::onUpdMenu(FXObject* sender,FXSelector,void*) -{ - if (viewer->getLength()==0) - sender->handle(this,FXSEL(SEL_COMMAND,FXWindow::ID_DISABLE),NULL); - else - sender->handle(this,FXSEL(SEL_COMMAND,FXWindow::ID_ENABLE),NULL); - return 1; -} - - -// Open find dialog -long ViewWindow::onCmdFind(FXObject* obj,FXSelector sel,void* ptr) -{ - int loc; - - static FXString str=""; - - if(FXSELTYPE(sel)==SEL_UPDATE) - { - if(str=="") - ((FXWindow*)obj)->disable(); - else - ((FXWindow*)obj)->enable(); - return 1; - } - - if(FXSELID(sel)==ID_FIND) - { - if (finddialog==NULL) - { - finddialog=new DialogBox(this,_("Find"),DECOR_TITLE|DECOR_BORDER); - FXVerticalFrame* content=new FXVerticalFrame(finddialog,LAYOUT_FILL_X|LAYOUT_FILL_Y,0,0,0,0,10,10,10,10,10,10); - findtext=new FXTextField(content,30,NULL,0,FRAME_SUNKEN|LAYOUT_FILL_X); - new FXHorizontalSeparator(content,SEPARATOR_GROOVE|LAYOUT_FILL_X); - FXHorizontalFrame* buttons=new FXHorizontalFrame(content,LAYOUT_FILL_X|PACK_UNIFORM_WIDTH,0,0,0,0,0,0,0,0); - new FXButton(buttons,_("&Cancel"),NULL,finddialog,DialogBox::ID_CANCEL,FRAME_RAISED|FRAME_THICK|LAYOUT_RIGHT,0,0,0,0,20,20); - new FXButton(buttons,_("&Find"),NULL,finddialog,DialogBox::ID_ACCEPT,FRAME_RAISED|FRAME_THICK|LAYOUT_RIGHT); - } - findtext->setText(str); - findtext->setSelection(0,str.length()); - findtext->setFocus(); - - if(!finddialog->execute()) - return 0; - str=findtext->getText(); - } - loc=find(str,viewer->getCursorPos()); - if(loc==-1) - MessageBox::information(this,BOX_OK,_("Not Found"),_("String '%s' not found"),str.text()); - else - { - viewer->setCursorPos(loc+str.length()); - viewer->setTopLine(loc); - viewer->setSelection(loc,str.length()); - viewer->setFocus(); - } - return 1; -} - - -// Find string -FXint ViewWindow::find(FXString str,FXint pos) -{ - FXString buf=viewer->getText(); - const char* text=buf.text(); - const char *p = strstr(&text[pos],str.text()); - if(!p) - return -1; - return (p-text); -} - - -// Close window -FXbool ViewWindow::close(FXbool notify) -{ - // Save OPTIONS - saveConfig(); - - return FXMainWindow::close(notify); -} - - -// User clicks on one of the window menus -long ViewWindow::onCmdWindow(FXObject*,FXSelector sel,void*) -{ - FXint which=FXSELID(sel)-ID_WINDOW_1; - if(which<getApp()->windowlist.no()) - { - getApp()->windowlist[which]->raise(); - getApp()->windowlist[which]->setFocus(); - } - return 1; -} - - -// Update handler for window menus -long ViewWindow::onUpdWindow(FXObject *sender,FXSelector sel,void*) -{ - FXint which=FXSELID(sel)-ID_WINDOW_1; - - if(which<getApp()->windowlist.no()) - { - ViewWindow *window=getApp()->windowlist[which]; - FXString string; - if(which<49) - string.format("&%d %s",which+1,window->getTitle().text()); - else - string.format("5&0 %s",window->getTitle().text()); - - sender->handle(this,FXSEL(SEL_COMMAND,FXWindow::ID_SETSTRINGVALUE),(void*)&string); - - if(window==getApp()->getActiveWindow()) - sender->handle(this,FXSEL(SEL_COMMAND,FXWindow::ID_CHECK),NULL); - else - sender->handle(this,FXSEL(SEL_COMMAND,FXWindow::ID_UNCHECK),NULL); - sender->handle(this,FXSEL(SEL_COMMAND,FXWindow::ID_SHOW),NULL); - } - else - sender->handle(this,FXSEL(SEL_COMMAND,FXWindow::ID_HIDE),NULL); - return 1; -} - - -// Generate unique name for a new window -FXString ViewWindow::unique() const -{ - FXString name=_("untitled"); - for(FXint i=1; i<2147483647; i++) - { - if(!findWindow(name)) - break; - name.format(_("untitled%d"),i); - } - return name; -} - - -// Find an as yet untitled, unedited window -ViewWindow *ViewWindow::findUnused() const -{ - for(FXint w=0; w<getApp()->windowlist.no(); w++) - { - if(!getApp()->windowlist[w]->isFilenameSet()) - return getApp()->windowlist[w]; - } - return NULL; -} - - -// Find window, if any, currently editing the given file -ViewWindow *ViewWindow::findWindow(const FXString& file) const -{ - for(FXint w=0; w<getApp()->windowlist.no(); w++) - { - if(getApp()->windowlist[w]->getFilename()==file) - return getApp()->windowlist[w]; - } - return NULL; -} diff --git a/extra/xfe/xfe-1.04-freetype.patch b/extra/xfe/xfe-1.04-freetype.patch deleted file mode 100644 index 1dfc24311..000000000 --- a/extra/xfe/xfe-1.04-freetype.patch +++ /dev/null @@ -1,39 +0,0 @@ -Submitted By: Hugo Villeneuve <hugo at hugovil dot com> -Date: 2007-11-03 -Initial Package Version: xfe-1.04 -Description: Tries to fix autoconf detection of Xft and FreeType-2 - ---- xfe-1.04-orig/configure.in 2007-08-28 04:45:04.000000000 -0400 -+++ xfe-1.04-patched/configure.in 2007-11-03 16:02:20.000000000 -0400 -@@ -27,9 +27,27 @@ - dnl Internationalisation - AM_GNU_GETTEXT - --dnl Don't work, because /usr/include/freetype2 not in the include path --dnl How to fix this? --dnl AC_CHECK_HEADER(X11/Xft/Xft.h,,AC_MSG_ERROR("Xft.h not found")) -+dnl Checks for FreeType-2 -+freetype_config='' -+AC_CHECK_PROGS(freetype_config,freetype-config,)dnl -+if test -n "$freetype_config"; then -+ freetype_cflags=`$freetype_config --cflags` -+ freetype_libs=`$freetype_config --libs` -+ LDFLAGS="$LDFLAGS $freetype_libs" -+ CPPFLAGS="$freetype_cflags $CPPFLAGS" -+fi -+AC_CHECK_HEADER(freetype/config/ftheader.h,,AC_MSG_ERROR("ftheader.h not found")) -+ -+dnl Checks for Xft -+xft_config='' -+AC_CHECK_PROGS(xft_config,xft-config,)dnl -+if test -n "$xft_config"; then -+ xft_cflags=`$xft_config --cflags` -+ xft_libs=`$xft_config --libs` -+ LDFLAGS="$LDFLAGS $xft_libs" -+ CPPFLAGS="$xft_cflags $CPPFLAGS" -+fi -+AC_CHECK_HEADER(X11/Xft/Xft.h,,AC_MSG_ERROR("Xft.h not found")) - - dnl Check for FOX - AC_CHECK_LIB(FOX-1.6,fxfindfox,,AC_MSG_ERROR("libFOX-1.6 not found")) - diff --git a/extra/xfe/xfe-1.32.1-pos-01.patch b/extra/xfe/xfe-1.32.1-pos-01.patch new file mode 100644 index 000000000..39140843a --- /dev/null +++ b/extra/xfe/xfe-1.32.1-pos-01.patch @@ -0,0 +1,20 @@ +--- xfe-1.32.1/xferc.in.original 2010-01-08 22:04:48.000000000 +0000 ++++ xfe-1.32.1/xferc.in 2010-01-08 22:05:30.000000000 +0000 +@@ -4,13 +4,16 @@ + # + # These settings are overridden in ~/.xfe/xferc + # ++[OPTIONS] ++xpos=50 ++ypos=50 + + [SETTINGS] + # + # Where to search for icons + # + iconpath = @prefix@/share/xfe/icons/gnomeblue-theme +- ++save_win_pos=1 + + [KEYBINDINGS] + # |