source: trunk/Lucide/SOURCE/gui/lucide.cpp @ 211

Last change on this file since 211 was 211, checked in by Eugene Romanenko, 14 years ago

TAB key switch between navigation pane and document (closes #112, #123)

File size: 40.2 KB
Line 
1/* ***** BEGIN LICENSE BLOCK *****
2 * Version: CDDL 1.0/LGPL 2.1
3 *
4 * The contents of this file are subject to the COMMON DEVELOPMENT AND
5 * DISTRIBUTION LICENSE (CDDL) Version 1.0 (the "License"); you may not use
6 * this file except in compliance with the License. You may obtain a copy of
7 * the License at http://www.sun.com/cddl/
8 *
9 * Software distributed under the License is distributed on an "AS IS" basis,
10 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
11 * for the specific language governing rights and limitations under the
12 * License.
13 *
14 * The Initial Developer of the Original Code is
15 * Eugene Romanenko, netlabs.org.
16 * Portions created by the Initial Developer are Copyright (C) 2006
17 * the Initial Developer. All Rights Reserved.
18 *
19 * Contributor(s):
20 *
21 * Alternatively, the contents of this file may be used under the terms of
22 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
23 * in which case the provisions of the LGPL are applicable instead of those
24 * above. If you wish to allow use of your version of this file only under the
25 * terms of the LGPL, and not to allow others to use your version of this file
26 * under the terms of the CDDL, indicate your decision by deleting the
27 * provisions above and replace them with the notice and other provisions
28 * required by the LGPL. If you do not delete the provisions above, a recipient
29 * may use your version of this file under the terms of any one of the CDDL
30 * or the LGPL.
31 *
32 * ***** END LICENSE BLOCK ***** */
33
34
35#define INCL_WIN
36#define INCL_DOS
37#define INCL_SPL
38#define INCL_SPLDOSPRINT
39#define INCL_DEV
40#include <os2.h>
41
42#include <string>
43#include <stdio.h>
44#include <process.h>
45
46#include <ludoc.xh>
47
48#include "Lucide.h"
49#include "pluginman.h"
50#include "pluginViewDlg.h"
51#include "fontsInfoDlg.h"
52#include "docInfoDlg.h"
53#include "findDlg.h"
54#include "printDlg.h"
55#include "progressDlg.h"
56#include "settingsDlg.h"
57#include "passwordDlg.h"
58#include "docViewer.h"
59#include "indexWindow.h"
60#include "lusettings.h"
61#include "luutils.h"
62#include "tb_spl.h"
63#include "Lucide_res.h"
64#include "messages.h"
65
66
67#define ID_SPLITTER 1
68
69const char *appName    = "Lucide";
70const char *appVersion = VERSION;
71const char *fwp        = "FrameWindowPos";
72const char *lvd        = "LastViewedDir";
73const char *splpos     = "SplitterPos";
74const char *showind    = "ShowIndex";
75
76HWND createToolbar( HWND hwnd );
77void AboutBox( HWND hWndFrame );
78void initPipeMon( HWND hWndFrame );
79void unInitPipeMon();
80
81HAB   hab            = NULLHANDLE;
82HWND  hWndFrame      = NULLHANDLE;
83HWND  hWndMenu       = NULLHANDLE;
84HWND  hToolBar       = NULLHANDLE;
85HWND  hVertSplitter  = NULLHANDLE;
86HWND  hFrameSysmenu  = NULLHANDLE;
87HWND  hFrameTitlebar = NULLHANDLE;
88HWND  hFrameMinMax   = NULLHANDLE;
89
90Environment    *ev        = somGetGlobalEnvironment();
91LuDocument     *doc       = NULL;
92PluginManager  *pluginMan = NULL;
93DocumentViewer *docViewer = NULL;
94IndexWindow    *indexWin  = NULL;
95FindDlg        *findDlg   = NULL;
96LuSettings     *settings  = NULL;
97char           *title     = NULL;
98
99
100bool         Lucide::dontSwitchPage                = false;
101SHORT        Lucide::splitterPos                   = 100;
102bool         Lucide::showIndex                     = true;
103bool         Lucide::isMaxview                     = false;
104bool         Lucide::isFullscreen                  = false;
105LuWindowPos  Lucide::winPos                        = {0};
106char         Lucide::docFullName[ CCHMAXPATH ]     = "";
107char         Lucide::docFileName[ CCHMAXPATHCOMP ] = "";
108char        *Lucide::password                      = NULL;
109ActiveWindow Lucide::activeWindow                  = AwView;
110// static data for asynch loading document
111ProgressDlg *Lucide::loadProgressDlg               = NULL;
112bool         Lucide::docLoaded                     = false;;
113char        *Lucide::loadError                     = NULL;
114long         Lucide::loadErrorCode                 = LU_LDERR_NO_ERROR;
115void        *Lucide::thumbnailData                 = NULL;
116int          Lucide::thumbnailDataLen              = 0;
117
118
119HMODULE _hmod = NULLHANDLE;
120
121unsigned APIENTRY LibMain( unsigned hmod, unsigned termination )
122{
123    if ( termination ) {
124        // DLL is detaching from process
125    } else {
126        // DLL is attaching to process
127        _hmod = hmod;
128    }
129    return( 1 );
130}
131
132
133PFNWP pOldSplProc;
134
135void Lucide::enableCopy( bool enable )
136{
137    WinEnableMenuItem( hWndMenu, CM_COPY, enable );
138}
139
140void Lucide::setOfPages( long pages )
141{
142    char *pgfrm = newstrdupL( TB_PAGENUM );
143    char pgnum[ 32 ];
144    snprintf( pgnum, sizeof( pgnum ), pgfrm, pages );
145    delete pgfrm;
146    WinSetDlgItemText( hToolBar, TBID_OFPAGES, pgnum );
147    WinSendDlgItemMsg( hToolBar, TBID_PAGENUM, SPBM_SETLIMITS,
148                       MPFROMLONG( pages ), MPFROMLONG( 1 ) );
149}
150
151void Lucide::checkNavigationMenus()
152{
153    WinEnableMenuItem( hWndMenu, CM_GOTOPAGE, TRUE );
154    BOOL enfirst = ( docViewer->getCurrentPage() != 0 );
155    BOOL enlast = ( docViewer->getCurrentPage() != ( doc->getPageCount( ev ) - 1 ) );
156    WinEnableMenuItem( hWndMenu, CM_FIRSTPAGE, enfirst );
157    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FIRSTPAGE), (MPARAM)enfirst );
158    WinEnableMenuItem( hWndMenu, CM_PREVPAGE, enfirst );
159    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_PREVPAGE), (MPARAM)enfirst );
160    WinEnableMenuItem( hWndMenu, CM_NEXTPAGE, enlast );
161    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_NEXTPAGE), (MPARAM)enlast );
162    WinEnableMenuItem( hWndMenu, CM_LASTPAGE, enlast );
163    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_LASTPAGE), (MPARAM)enlast );
164
165    bool tmp = dontSwitchPage;
166    dontSwitchPage = true;
167    WinSendDlgItemMsg( hToolBar, TBID_PAGENUM, SPBM_SETCURRENTVALUE,
168                       MPFROMLONG( docViewer->getCurrentPage() + 1 ), MPVOID );
169    dontSwitchPage = tmp;
170    indexWin->goToPage( NULL, docViewer->getCurrentPage() );
171}
172
173void Lucide::enableZoomMenus()
174{
175    BOOL scalable = doc->isScalable( ev );
176    WinEnableMenuItem( hWndMenu, CM_FITWINDOW, scalable );
177    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FITWINDOW), (MPARAM)scalable );
178    WinEnableMenuItem( hWndMenu, CM_ACTSIZE, scalable );
179    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_ACTSIZE), (MPARAM)scalable );
180    WinEnableMenuItem( hWndMenu, CM_FITWIDTH, scalable );
181    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FITWIDTH), (MPARAM)scalable );
182    WinEnableMenuItem( hWndMenu, CM_ZOOM_IN_OUT, scalable );
183    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_ZOOM_IN_OUT), (MPARAM)scalable );
184    WinEnableControl( hToolBar, TBID_ZOOM, scalable );
185    BOOL rotable = doc->isRotable( ev );
186    WinEnableMenuItem( hWndMenu, CM_ROTATE90CW, rotable );
187    WinEnableMenuItem( hWndMenu, CM_ROTATE90CCW, rotable );
188}
189
190
191void Lucide::setZoomChecks( SHORT cmd, SHORT cbind, double zoom )
192{
193    if ( cmd != -1 )
194    {
195        WinCheckMenuItem( hWndMenu, cmd, TRUE );
196        WinSendMsg( hToolBar, TBM_SETCHECK, MPFROMSHORT( cmd ), (MPARAM)TRUE );
197    }
198
199    if ( cbind != -1 )
200    {
201        char buf[ 255 ] = "";
202        WinSendDlgItemMsg( hToolBar, TBID_ZOOM, LM_QUERYITEMTEXT,
203                           MPFROM2SHORT( cbind, sizeof( buf ) ), MPFROMP( buf ) );
204        WinSetDlgItemText( hToolBar, TBID_ZOOM, buf );
205    }
206
207    if ( zoom != 0 )
208    {
209        std::string z = str( zoom * 100.0 ) + "%";
210        WinSetDlgItemText( hToolBar, TBID_ZOOM, z.c_str() );
211    }
212}
213
214void Lucide::checkZoomMenus()
215{
216    double zoom = docViewer->getZoom();
217
218    WinCheckMenuItem( hWndMenu, CM_FITWINDOW, FALSE );
219    WinSendMsg( hToolBar, TBM_SETCHECK, MPFROMSHORT(CM_FITWINDOW), (MPARAM)FALSE );
220    WinCheckMenuItem( hWndMenu, CM_ACTSIZE, FALSE );
221    WinSendMsg( hToolBar, TBM_SETCHECK, MPFROMSHORT(CM_ACTSIZE), (MPARAM)FALSE );
222    WinCheckMenuItem( hWndMenu, CM_FITWIDTH, FALSE );
223    WinSendMsg( hToolBar, TBM_SETCHECK, MPFROMSHORT(CM_FITWIDTH), (MPARAM)FALSE );
224
225    if ( zoom == -2 ) {
226        setZoomChecks( CM_FITWINDOW, 1, 0 );
227    } else if ( zoom == -1 ) {
228        setZoomChecks( CM_FITWIDTH, 2, 0 );
229    } else if ( zoom == 1 ) {
230        setZoomChecks( CM_ACTSIZE, 0, 0 );
231    } else {
232        setZoomChecks( -1, -1, zoom );
233    }
234}
235
236void Lucide::checkMenus()
237{
238    // pre-set "Actual size"
239    setZoomChecks( CM_ACTSIZE, 0, 0 );
240
241    if ( doc == NULL )
242    {
243        // "single page" mode by default
244        WinCheckMenuItem( hWndMenu, CM_SINGLEPAGE, TRUE );
245
246        WinEnableMenuItem( hWndMenu, CM_SAVEAS, FALSE );
247        WinEnableMenuItem( hWndMenu, CM_PRINT, FALSE );
248        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_PRINT), (MPARAM)FALSE );
249        WinEnableMenuItem( hWndMenu, CM_DOCINFO, FALSE );
250        WinEnableMenuItem( hWndMenu, CM_FONTSINFO, FALSE );
251
252        WinEnableMenuItem( hWndMenu, CM_COPY, FALSE );
253        WinEnableMenuItem( hWndMenu, CM_SELECTALL, FALSE );
254        WinEnableMenuItem( hWndMenu, CM_FIND, FALSE );
255        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FIND), (MPARAM)FALSE );
256        WinEnableMenuItem( hWndMenu, CM_FINDAGAIN, FALSE );
257        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FINDAGAIN), (MPARAM)FALSE );
258
259        WinEnableMenuItem( hWndMenu, CM_FIRSTPAGE, FALSE );
260        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FIRSTPAGE), (MPARAM)FALSE );
261        WinEnableMenuItem( hWndMenu, CM_PREVPAGE, FALSE );
262        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_PREVPAGE), (MPARAM)FALSE );
263        WinEnableMenuItem( hWndMenu, CM_NEXTPAGE, FALSE );
264        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_NEXTPAGE), (MPARAM)FALSE );
265        WinEnableMenuItem( hWndMenu, CM_LASTPAGE, FALSE );
266        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_LASTPAGE), (MPARAM)FALSE );
267        WinEnableMenuItem( hWndMenu, CM_GOTOPAGE, FALSE );
268
269        WinEnableMenuItem( hWndMenu, CM_FITWINDOW, FALSE );
270        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FITWINDOW), (MPARAM)FALSE );
271        WinEnableMenuItem( hWndMenu, CM_ACTSIZE, FALSE );
272        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_ACTSIZE), (MPARAM)FALSE );
273        WinEnableMenuItem( hWndMenu, CM_FITWIDTH, FALSE );
274        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FITWIDTH), (MPARAM)FALSE );
275        WinEnableMenuItem( hWndMenu, CM_ZOOM_IN_OUT, FALSE );
276        WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_ZOOM_IN_OUT), (MPARAM)FALSE );
277        WinEnableControl( hToolBar, TBID_ZOOM, FALSE );
278
279        WinEnableMenuItem( hWndMenu, CM_ROTATE90CW, FALSE );
280        WinEnableMenuItem( hWndMenu, CM_ROTATE90CCW, FALSE );
281        WinEnableMenuItem( hWndMenu, CM_SINGLEPAGE, FALSE );
282        WinEnableMenuItem( hWndMenu, CM_CONTINUOUS, FALSE );
283
284        setOfPages( 0 );
285        return;
286    }
287
288
289    checkNavigationMenus();
290    enableZoomMenus();
291    checkZoomMenus();
292
293    WinEnableMenuItem( hWndMenu, CM_PRINT, TRUE );
294    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_PRINT), (MPARAM)TRUE );
295    WinEnableMenuItem( hWndMenu, CM_SAVEAS, doc->isSaveable( ev ) );
296    setOfPages( doc->getPageCount( ev ) );
297    WinEnableMenuItem( hWndMenu, CM_FONTSINFO, doc->isHaveFontInfo( ev ) );
298    WinEnableMenuItem( hWndMenu, CM_DOCINFO, TRUE );
299
300    BOOL haveText = doc->isHaveText( ev );
301    WinEnableMenuItem( hWndMenu, CM_FIND, haveText );
302    WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FIND), (MPARAM)haveText );
303    WinEnableMenuItem( hWndMenu, CM_SELECTALL, haveText );
304
305    WinEnableMenuItem( hWndMenu, CM_SINGLEPAGE, TRUE );
306    WinEnableMenuItem( hWndMenu, CM_CONTINUOUS, TRUE );
307}
308
309void Lucide::goToPage( long page )
310{
311    if ( docViewer != NULL ) {
312        docViewer->goToPage( page );
313    }
314}
315
316void Lucide::setZoom( double zoom )
317{
318    if ( docViewer != NULL ) {
319        docViewer->setZoom( zoom );
320        checkZoomMenus();
321    }
322}
323
324void Lucide::setDocument( LuDocument *_doc )
325{
326    docViewer->setDocument( _doc );
327    indexWin->setDocument( _doc );
328    checkMenus();
329}
330
331void Lucide::setPageLayout( PgLayout layout )
332{
333    if ( layout == SinglePage ) {
334        WinCheckMenuItem( hWndMenu, CM_SINGLEPAGE, TRUE );
335        WinCheckMenuItem( hWndMenu, CM_CONTINUOUS, FALSE );
336    }
337    else {
338        WinCheckMenuItem( hWndMenu, CM_SINGLEPAGE, FALSE );
339        WinCheckMenuItem( hWndMenu, CM_CONTINUOUS, TRUE );
340    }
341
342    docViewer->setPageLayout( layout );
343}
344
345
346void Lucide::closeDocument()
347{
348    docViewer->close();
349    delete doc;
350    doc = NULL;
351    WinSetWindowText( hWndFrame, title );
352
353    if ( thumbnailData != NULL ) {
354        writeThumbnail( docFullName );
355        delete thumbnailData;
356        thumbnailData = NULL;
357        thumbnailDataLen = 0;
358    }
359}
360
361void Lucide::loadthread( void* )
362{
363    HAB thab = WinInitialize( 0 );
364    HMQ thmq = WinCreateMsgQueue( thab, 0 );
365
366    docLoaded = doc->loadFile( ev, docFullName, password, &loadErrorCode, &loadError );
367    if ( docLoaded ) {
368        if ( doc->isCreateFileThumbnail( ev ) && isThumbNeeded( docFullName ) ) {
369            loadProgressDlg->setText( getLocalizedString( MSGS_CREATING_THUMBNAIL ).c_str() );
370            createThumbnail( doc );
371        }
372    }
373    loadProgressDlg->hide();
374
375    WinDestroyMsgQueue( thmq );
376    WinTerminate( thab );
377    _endthread();
378}
379
380void Lucide::loadDocument( const char *fn )
381{
382    char *msg = newstrdupL( MSGS_NO_SUIT_PLUG );
383
384    // find extension
385    char *ext = strrchr( fn, '.' );
386    if ( ext == NULL )
387    {
388        WinMessageBox( HWND_DESKTOP, hWndFrame, msg,
389                       NULL, 0, MB_OK | MB_ICONEXCLAMATION | MB_MOVEABLE );
390    }
391    else
392    {
393        // test if extension supported and then close previous opened document
394        if ( pluginMan->createDocumentForExt( ext + 1, true ) == NULL )
395        {
396            WinMessageBox( HWND_DESKTOP, hWndFrame, msg,
397                           NULL, 0, MB_OK | MB_ICONEXCLAMATION | MB_MOVEABLE );
398        }
399        else
400        {
401            closeDocument();
402
403            doc = pluginMan->createDocumentForExt( ext + 1, false );
404            if ( doc == NULL )
405            {
406                WinMessageBox( HWND_DESKTOP, hWndFrame, msg,
407                               NULL, 0, MB_OK | MB_ICONEXCLAMATION | MB_MOVEABLE );
408            }
409            else
410            {
411                strcpy( docFullName, fn );
412                if ( password != NULL ) {
413                    delete password;
414                    password = NULL;
415                }
416                bool once = true;
417                while ( once || ( password != NULL ) )
418                {
419                    once = false;
420                    docLoaded = false;
421                    loadError = NULL;
422
423                    // Load document asynchronously
424                    loadProgressDlg = new ProgressDlg( hWndFrame );
425                    char *ldmsg = newstrdupL( MSGS_LOADING_DOCUMENT );
426                    loadProgressDlg->setText( ldmsg );
427                    delete ldmsg;
428                    loadProgressDlg->show( loadthread, NULL ); // doc will be loaded
429                    delete loadProgressDlg;
430
431                    if ( password != NULL ) {
432                        delete password;
433                        password = NULL;
434                    }
435
436                    if ( docLoaded )
437                    {
438                        char *t = new char[ 2048 ];
439                        char _fn[ _MAX_FNAME ];
440                        char _ex[ _MAX_EXT ];
441                        _splitpath( fn, NULL, NULL, _fn, _ex );
442                        strcpy( docFileName, _fn );
443                        strcat( docFileName, _ex );
444                        snprintf( t, 2048, "%s - %s", docFileName, title );
445                        WinSetWindowText( hWndFrame, t );
446                        delete t;
447                        setDocument( doc );
448                    }
449                    else
450                    {
451                        if ( loadErrorCode == LU_LDERR_NO_ERROR )
452                        {
453                            char *m = newstrdupL( MSGS_FILE_LOAD_ERROR );
454                            WinMessageBox( HWND_DESKTOP, hWndFrame, m,
455                                           NULL, 0, MB_OK | MB_ICONEXCLAMATION | MB_MOVEABLE );
456                            delete m;
457                        }
458                        else
459                        {
460                            std::string msgTempl = getLocalizedString( MSGS_LDERR );
461
462                            const int errmsgLen = 1024;
463                            char *errmsg = new char[ errmsgLen ];
464                            memset( errmsg, 0, errmsgLen );
465
466                            if ( loadErrorCode == LU_LDERR_CUSTOM )
467                            {
468                                snprintf( errmsg, errmsgLen, msgTempl.c_str(), loadError );
469                                SOMFree( loadError );
470                            }
471                            else
472                            {
473                                const char *lmsg = NULL;
474                                switch ( loadErrorCode )
475                                {
476                                    case LU_LDERR_OUT_OF_MEMORY:
477                                        lmsg = MSGS_LDERR_OUT_OF_MEMORY;
478                                        break;
479                                    case LU_LDERR_OPEN_ERROR:
480                                        lmsg = MSGS_LDERR_OPEN_ERROR;
481                                        break;
482                                    case LU_LDERR_READ_ERROR:
483                                        lmsg = MSGS_LDERR_READ_ERROR;
484                                        break;
485                                    case LU_LDERR_DAMAGED:
486                                        lmsg = MSGS_LDERR_DAMAGED;
487                                        break;
488                                    case LU_LDERR_WRONG_FORMAT:
489                                        lmsg = MSGS_LDERR_WRONG_FORMAT;
490                                        break;
491                                    case LU_LDERR_ENCRYPTED:
492                                        {
493                                            lmsg = MSGS_LDERR_ENCRYPTED;
494
495                                            PasswordDlg *pd = new PasswordDlg( hWndFrame );
496                                            if ( pd->showDialog() == DID_OK ) {
497                                                password = newstrdup( pd->getPassword() );
498                                            }
499                                            delete pd;
500                                        }
501                                        break;
502                                }
503
504                                if ( lmsg != NULL ) {
505                                    snprintf( errmsg, errmsgLen, msgTempl.c_str(),
506                                              getLocalizedString( lmsg ).c_str() );
507                                }
508                            }
509
510                            if ( password == NULL )
511                            {
512                                WinMessageBox( HWND_DESKTOP, hWndFrame, errmsg, NULL, 0,
513                                               MB_OK | MB_ICONEXCLAMATION | MB_MOVEABLE );
514                            }
515                            delete errmsg;
516                        } // ( loadErrorCode == LU_LDERR_NO_ERROR )
517
518                        if ( password == NULL ) {
519                            delete doc;
520                            doc = NULL;
521                        }
522                    } // ( docLoaded )
523                } // while ( once || ( password != NULL ) )
524            } // ( doc == NULL )
525        } // ( pluginMan->createDocumentForExt( ext + 1, true ) == NULL )
526    } // ( ext == NULL )
527    delete msg;
528}
529
530void Lucide::openDocument()
531{
532    char dirbuf[ CCHMAXPATH ];
533    PFILEDLG fd = new FILEDLG;
534    memset( fd, 0, sizeof( FILEDLG ) );
535    fd->cbSize = sizeof( FILEDLG );
536    fd->fl = FDS_CENTER | FDS_OPEN_DIALOG;
537    PrfQueryProfileString( HINI_USERPROFILE, appName, lvd, "",
538                           dirbuf, sizeof( dirbuf ) );
539    snprintf( fd->szFullFile, sizeof( fd->szFullFile ),
540              "%s%s", dirbuf, pluginMan->getExtsMask().c_str() );
541    WinFileDlg( HWND_DESKTOP, hWndFrame, fd );
542    if ( fd->lReturn == DID_OK )
543    {
544        char drv[ _MAX_DRIVE ] = "";
545        char dir[ _MAX_PATH ] = "";
546        char buf[ _MAX_PATH ] = "";
547        _splitpath( fd->szFullFile, drv, dir, NULL, NULL );
548        _makepath( buf, drv, dir, NULL, NULL );
549        PrfWriteProfileString( HINI_USERPROFILE, appName, lvd, buf );
550
551        loadDocument( fd->szFullFile );
552    }
553    delete fd;
554}
555
556void Lucide::saveDocumentAs()
557{
558    char dirbuf[ CCHMAXPATH ];
559    PFILEDLG fd = new FILEDLG;
560    memset( fd, 0, sizeof( FILEDLG ) );
561    fd->cbSize = sizeof( FILEDLG );
562    fd->fl = FDS_CENTER | FDS_SAVEAS_DIALOG;
563    PrfQueryProfileString( HINI_USERPROFILE, appName, lvd, "",
564                           dirbuf, sizeof( dirbuf ) );
565    char fil[ _MAX_FNAME ] = "";
566    char ext[ _MAX_EXT ] = "";
567    _splitpath( docFullName, NULL, NULL, fil, ext );
568    snprintf( fd->szFullFile, sizeof( fd->szFullFile ),
569                "%s%s%s", dirbuf, fil, ext );
570    WinFileDlg( HWND_DESKTOP, hWndFrame, fd );
571    if ( fd->lReturn == DID_OK )
572    {
573        bool doSave = true;
574        if ( access( fd->szFullFile, F_OK ) == 0 )
575        {
576            char *t = newstrdupL( MSGS_WARNING );
577            char *m = newstrdupL( MSGS_OVERWRITE_FILE );
578            ULONG response = WinMessageBox( HWND_DESKTOP, hWndFrame, m, t,
579                                            0, MB_YESNO | MB_WARNING | MB_MOVEABLE );
580            delete m;
581            delete t;
582
583            doSave = ( response == MBID_YES );
584        }
585        if ( doSave )
586        {
587            if ( !doc->saveAs( ev, fd->szFullFile ) )
588            {
589                char *m = newstrdupL( MSGS_FILE_SAVE_ERROR );
590                WinMessageBox( HWND_DESKTOP, hWndFrame, m, NULL,
591                               0, MB_OK | MB_ERROR | MB_MOVEABLE );
592                delete m;
593            }
594        }
595    }
596    delete fd;
597}
598
599void Lucide::checkNavpane()
600{
601    if ( Lucide::showIndex ) {
602        WinCheckMenuItem( hWndMenu, CM_NAVPANE, TRUE );
603        WinSendMsg( hToolBar, TBM_SETCHECK, MPFROMSHORT( CM_NAVPANE ), (MPARAM)TRUE );
604    }
605    else {
606        WinCheckMenuItem( hWndMenu, CM_NAVPANE, FALSE );
607        WinSendMsg( hToolBar, TBM_SETCHECK, MPFROMSHORT( CM_NAVPANE ), (MPARAM)FALSE );
608    }
609}
610
611
612void Lucide::toggleMaxview()
613{
614    ULONG ulFrameStyle = WinQueryWindowULong( hWndFrame, QWL_STYLE );
615
616    if ( isMaxview )
617    {
618        WinSetParent( hFrameSysmenu,  hWndFrame, FALSE );
619        WinSetParent( hFrameTitlebar, hWndFrame, FALSE );
620        WinSetParent( hFrameMinMax,   hWndFrame, FALSE );
621        ulFrameStyle |= FS_SIZEBORDER;
622    }
623    else
624    {
625        WinQueryWindowPos( hWndFrame, &winPos.Swp );
626        winPos.XRestore  = WinQueryWindowUShort( hWndFrame, QWS_XRESTORE );
627        winPos.YRestore  = WinQueryWindowUShort( hWndFrame, QWS_YRESTORE );
628        winPos.CXRestore = WinQueryWindowUShort( hWndFrame, QWS_CXRESTORE );
629        winPos.CYRestore = WinQueryWindowUShort( hWndFrame, QWS_CYRESTORE );
630        winPos.XMinimize = WinQueryWindowUShort( hWndFrame, QWS_XMINIMIZE );
631        winPos.YMinimize = WinQueryWindowUShort( hWndFrame, QWS_YMINIMIZE );
632
633        WinSetParent( hFrameSysmenu,  HWND_OBJECT, FALSE );
634        WinSetParent( hFrameTitlebar, HWND_OBJECT, FALSE );
635        WinSetParent( hFrameMinMax,   HWND_OBJECT, FALSE );
636        ulFrameStyle &= ~FS_SIZEBORDER;
637    }
638
639    WinSetWindowULong( hWndFrame, QWL_STYLE, ulFrameStyle );
640    WinSendMsg( hWndFrame, WM_UPDATEFRAME,
641                MPFROMLONG( FCF_TITLEBAR | FCF_SIZEBORDER | FCF_SYSMENU | FCF_MINMAX ),
642                MPVOID );
643
644    if ( isMaxview )
645    {
646        WinSetWindowUShort( hWndFrame, QWS_XRESTORE,  winPos.XRestore );
647        WinSetWindowUShort( hWndFrame, QWS_YRESTORE,  winPos.YRestore );
648        WinSetWindowUShort( hWndFrame, QWS_CXRESTORE, winPos.CXRestore );
649        WinSetWindowUShort( hWndFrame, QWS_CYRESTORE, winPos.CYRestore );
650        WinSetWindowUShort( hWndFrame, QWS_XMINIMIZE, winPos.XMinimize );
651        WinSetWindowUShort( hWndFrame, QWS_YMINIMIZE, winPos.YMinimize );
652        ULONG swpopt = SWP_MOVE | SWP_SIZE | SWP_SHOW;
653        WinSetWindowPos( hWndFrame, NULLHANDLE,
654                         winPos.Swp.x, winPos.Swp.y, winPos.Swp.cx, winPos.Swp.cy,
655                         swpopt );
656    }
657    else
658    {
659        WinSetWindowPos( hWndFrame, HWND_TOP, 0, 0,
660                         WinQuerySysValue( HWND_DESKTOP, SV_CXSCREEN ),
661                         WinQuerySysValue( HWND_DESKTOP, SV_CYSCREEN ),
662                         SWP_SIZE | SWP_MOVE | SWP_ZORDER );
663    }
664
665    isMaxview = !isMaxview;
666}
667
668
669void Lucide::toggleFullscreen()
670{
671    if ( isFullscreen )
672    {
673        docViewer->setFullscreen( false );
674        WinSetParent( docViewer->getFrameHWND(), hWndFrame, TRUE );
675        WinSendMsg( hVertSplitter, SBM_SETWINDOWS,
676                    MPFROMHWND( indexWin->getHWND() ),
677                    MPFROMHWND( docViewer->getFrameHWND() ) );
678    }
679    else
680    {
681        docViewer->setFullscreen( true );
682        WinSendMsg( hVertSplitter, SBM_SETWINDOWS,
683                    MPFROMHWND( indexWin->getHWND() ),
684                    MPFROMHWND( NULLHANDLE ) );
685        WinSetParent( docViewer->getFrameHWND(), HWND_DESKTOP, FALSE );
686        WinSetWindowPos( docViewer->getFrameHWND(), HWND_TOP, 0, 0,
687                         WinQuerySysValue( HWND_DESKTOP, SV_CXSCREEN ),
688                         WinQuerySysValue( HWND_DESKTOP, SV_CYSCREEN ),
689                         SWP_SIZE | SWP_MOVE | SWP_ZORDER );
690    }
691
692    isFullscreen = !isFullscreen;
693}
694
695void Lucide::focusDocview()
696{
697    WinSetFocus( HWND_DESKTOP, docViewer->getViewHWND() );
698}
699
700void Lucide::focusIndex()
701{
702    WinSetFocus( HWND_DESKTOP, indexWin->getIndexHWND() );
703}
704
705void Lucide::cmdSwitchWindow()
706{
707    if ( activeWindow == AwIndex ) {
708        focusDocview();
709    } else {
710        focusIndex();
711    }
712}
713
714void Lucide::toggleZoom()
715{
716    if ( ( doc != NULL ) && doc->isScalable( ev ) )
717    {
718        bool isZoom = !docViewer->isZoomMode();
719
720        WinCheckMenuItem( hWndMenu, CM_ZOOM_IN_OUT, isZoom );
721        WinSendMsg( hToolBar, TBM_SETCHECK, MPFROMSHORT( CM_ZOOM_IN_OUT ), (MPARAM)isZoom );
722        docViewer->setZoomMode( isZoom );
723    }
724}
725
726void Lucide::cmdMinimize()
727{
728    if ( isFullscreen ) {
729        toggleFullscreen();
730    }
731    WinSetWindowPos( hWndFrame, HWND_TOP, 0, 0, 0, 0, SWP_MINIMIZE );
732}
733
734void Lucide::cmdSwitchToFullscreen()
735{
736    if ( !isFullscreen )
737    {
738        SWP pos = {0};
739        WinQueryWindowPos( hWndFrame, &pos );
740
741        if ( pos.fl & SWP_MINIMIZE ) {
742            WinSetWindowPos( hWndFrame, HWND_TOP, 0, 0, 0, 0,
743                    SWP_SHOW | SWP_ACTIVATE | SWP_RESTORE | SWP_ZORDER );
744        }
745        toggleFullscreen();
746    }
747}
748
749void Lucide::newWindow()
750{
751    PROGDETAILS pd;
752    pd.Length                      = sizeof( PROGDETAILS );
753    pd.progt.progc                 = PROG_DEFAULT;
754    pd.progt.fbVisible             = SHE_VISIBLE;
755    pd.pszTitle                    = NULL;
756    pd.pszExecutable               = __argv[0];
757    pd.pszParameters               = NULL;
758    pd.pszStartupDir               = NULL;
759    pd.pszIcon                     = NULL;
760    pd.pszEnvironment              = NULL;
761    pd.swpInitial.fl               = SWP_ACTIVATE;
762    pd.swpInitial.cy               = 0;
763    pd.swpInitial.cx               = 0;
764    pd.swpInitial.y                = 0;
765    pd.swpInitial.x                = 0;
766    pd.swpInitial.hwndInsertBehind = HWND_TOP;
767    pd.swpInitial.hwnd             = NULLHANDLE;
768    pd.swpInitial.ulReserved1      = 0;
769    pd.swpInitial.ulReserved2      = 0;
770
771    WinStartApp( NULLHANDLE, &pd, NULL, NULL, 0 );
772}
773
774static MRESULT EXPENTRY splProc( HWND hwnd, ULONG msg, MPARAM mp1, MPARAM mp2 )
775{
776    switch ( msg )
777    {
778        case WM_CONTROL:
779        {
780            if ( ( SHORT1FROMMP( mp1 ) == ID_SPLITTER ) &&
781                 ( SHORT2FROMMP( mp1 ) == SBN_POSITIONCHANGED ) )
782            {
783                SHORT pos = SHORT1FROMMP( mp2 );
784                if ( pos > 0 ) {
785                    Lucide::splitterPos = pos;
786                    Lucide::showIndex = true;
787                }
788                else {
789                    Lucide::showIndex = false;
790                }
791                Lucide::checkNavpane();
792            }
793        }
794        break;
795
796        case WM_COMMAND:
797        {
798            switch ( SHORT1FROMMP(mp1) )
799            {
800                case CM_NEW_WINDOW:
801                    Lucide::newWindow();
802                    return (MRESULT)FALSE;
803
804                case CM_OPEN:
805                    Lucide::openDocument();
806                    return (MRESULT)FALSE;
807
808                case CM_SAVEAS:
809                    Lucide::saveDocumentAs();
810                    return (MRESULT)FALSE;
811
812                case CM_PRINT:
813                {
814                    PrintDlg *d = new PrintDlg( hWndFrame, doc, Lucide::docFileName, docViewer->getCurrentPage() + 1 );
815                    if ( d->showDialog() == DID_OK )
816                    {
817                        // print
818                        PrintSetup *p = new PrintSetup;
819                        memset( p, 0, sizeof( PrintSetup ) );
820                        d->getPrintSetup( p );
821                        printDocument( hWndFrame, doc, Lucide::docFileName, p );
822                        delete p;
823                    }
824                    delete d;
825                    return (MRESULT)FALSE;
826                }
827
828                case CM_EXIT:
829                    WinPostMsg( hWndFrame, WM_CLOSE, NULL, NULL );
830                    return (MRESULT)FALSE;
831
832                case CM_DOCINFO:
833                {
834                    LuDocumentInfo *dinfo = doc->getDocumentInfo( ev );
835                    DocInfoDlg *d = new DocInfoDlg( hWndFrame, dinfo );
836                    d->doDialog();
837                    LuDocument::freeDocumentInfo( ev, dinfo );
838                    return (MRESULT)FALSE;
839                }
840
841                case CM_FONTSINFO:
842                {
843                    FontsInfoDlg *d = new FontsInfoDlg( hWndFrame, doc );
844                    d->doDialog();
845                    return (MRESULT)FALSE;
846                }
847
848                case CM_PLUGINSLIST:
849                {
850                    PluginViewDlg *d = new PluginViewDlg( hWndFrame,
851                                                pluginMan->getPluginsList() );
852                    d->doDialog();
853                    return (MRESULT)FALSE;
854                }
855
856                case CM_COPY:
857                    docViewer->copyToClipbrd();
858                    return (MRESULT)FALSE;
859
860                case CM_SELECTALL:
861                    docViewer->selectAll();
862                    return (MRESULT)FALSE;
863
864                case CM_FIND:
865                    if ( findDlg->showDialog() == DID_OK ) {
866                        if ( strlen( findDlg->getSearchString() ) > 0 )
867                        {
868                            docViewer->searchDocument( findDlg->getSearchString(),
869                                            findDlg->isCaseSensitive(), false );
870
871                            WinEnableMenuItem( hWndMenu, CM_FINDAGAIN, TRUE );
872                            WinSendMsg( hToolBar, TBM_ENABLEITEM, MPFROMSHORT(CM_FINDAGAIN), (MPARAM)TRUE );
873                        }
874                    }
875                    return (MRESULT)FALSE;
876
877                case CM_FINDAGAIN:
878                    docViewer->searchDocument( findDlg->getSearchString(),
879                                               findDlg->isCaseSensitive(), true );
880                    return (MRESULT)FALSE;
881
882                case CM_SETTINGS:
883                {
884                    SettingsDlg *d = new SettingsDlg( hWndFrame, settings );
885                    d->doDialog();
886                    return (MRESULT)FALSE;
887                }
888
889                case CM_FIRSTPAGE:
890                    Lucide::goToPage( 0 );
891                    return (MRESULT)FALSE;
892
893                case CM_NEXTPAGE:
894                    Lucide::goToPage( docViewer->getCurrentPage() + 1 );
895                    return (MRESULT)FALSE;
896
897                case CM_PREVPAGE:
898                    Lucide::goToPage( docViewer->getCurrentPage() - 1 );
899                    return (MRESULT)FALSE;
900
901                case CM_LASTPAGE:
902                    Lucide::goToPage( doc->getPageCount( ev ) - 1 );
903                    return (MRESULT)FALSE;
904
905                case CM_GOTOPAGE:
906                {
907                    GotoDlg *d = new GotoDlg( hWndFrame, doc->getPageCount( ev ),
908                                                docViewer->getCurrentPage() + 1 );
909                    if ( d->showDialog() == DID_OK ) {
910                        long pg = d->getPage();
911                        if ( pg > 0 ) {
912                            Lucide::goToPage( pg - 1 );
913                        }
914                    }
915                    delete d;
916                    return (MRESULT)FALSE;
917                }
918
919                case CM_FITWINDOW:
920                    Lucide::setZoom( -2 );
921                    return (MRESULT)FALSE;
922
923                case CM_ACTSIZE:
924                    Lucide::setZoom( 1 );
925                    return (MRESULT)FALSE;
926
927                case CM_FITWIDTH:
928                    Lucide::setZoom( -1 );
929                    return (MRESULT)FALSE;
930
931                case CM_ZOOM_IN_OUT:
932                    Lucide::toggleZoom();
933                    return (MRESULT)FALSE;
934
935                case CM_SINGLEPAGE:
936                    Lucide::setPageLayout( SinglePage );
937                    return (MRESULT)FALSE;
938
939                case CM_CONTINUOUS:
940                    Lucide::setPageLayout( Continuous );
941                    return (MRESULT)FALSE;
942
943                case CM_ROTATE90CW:
944                    docViewer->setRotation( docViewer->getRotation() + 90 );
945                    return (MRESULT)FALSE;
946
947                case CM_ROTATE90CCW:
948                    docViewer->setRotation( docViewer->getRotation() - 90 );
949                    return (MRESULT)FALSE;
950
951                case CM_NAVPANE:
952                    {
953                        Lucide::showIndex = !Lucide::showIndex;
954                        Lucide::checkNavpane();
955                        WinSendMsg( hVertSplitter, SBM_SETSPLITTERPOS,
956                            MPFROMSHORT( Lucide::showIndex ? Lucide::splitterPos : 0 ), MPVOID );
957                        if ( !Lucide::showIndex ) {
958                            Lucide::focusDocview();
959                        }
960                    }
961                    return (MRESULT)FALSE;
962
963                case CM_MAXVIEW:
964                    Lucide::toggleMaxview();
965                    return (MRESULT)FALSE;
966
967                case CM_FULLSCREEN:
968                    Lucide::toggleFullscreen();
969                    return (MRESULT)FALSE;
970
971                case CM_PRODINFO:
972                    AboutBox( hWndFrame );
973                    return (MRESULT)FALSE;
974
975                case CM_MINIMIZE:
976                    Lucide::cmdMinimize();
977                    return (MRESULT)FALSE;
978
979                case CM_TOFULLSCREEN:
980                    Lucide::cmdSwitchToFullscreen();
981                    return (MRESULT)FALSE;
982
983                case CM_SWITCHWINDOW:
984                    Lucide::cmdSwitchWindow();
985                    return (MRESULT)FALSE;
986            }
987        }
988        break;
989    }
990    return pOldSplProc( hwnd, msg, mp1, mp2 );
991}
992
993
994char deffont[] = "9.WarpSans";
995int deffontlen = sizeof( deffont );
996
997extern "C" APIRET APIENTRY LucideMain( int argc, char *argv[] )
998{
999    HMQ   hmq;
1000    QMSG  qmsg;
1001    hab = WinInitialize( 0 );
1002    hmq = WinCreateMsgQueue( hab, 0 );
1003
1004    loadLang();
1005
1006    settings = new LuSettings;
1007    settings->load();
1008
1009    pluginMan = new PluginManager;
1010
1011    InitPMSplitterClass( hab );
1012    InitPMToolbarClass( hab );
1013
1014    ULONG ulFrameFlags = FCF_TITLEBAR | FCF_SIZEBORDER | FCF_SYSMENU |
1015                         FCF_MINMAX | FCF_TASKLIST | FCF_NOBYTEALIGN | FCF_ICON;
1016    title = newstrdupL( MSGS_MAIN_WIN_TITLE );
1017    hWndFrame = WinCreateStdWindow( HWND_DESKTOP, 0, &ulFrameFlags, NULL, title,
1018                                    WS_SYNCPAINT|WS_VISIBLE, _hmod, IDI_MAIN_ICON, NULL );
1019    hFrameSysmenu  = WinWindowFromID( hWndFrame, FID_SYSMENU );
1020    hFrameTitlebar = WinWindowFromID( hWndFrame, FID_TITLEBAR );
1021    hFrameMinMax   = WinWindowFromID( hWndFrame, FID_MINMAX );
1022    WinSetAccelTable( hab, WinLoadAccelTable( hab, _hmod, IDA_MAINACCEL ), hWndFrame );
1023    hWndMenu = WinLoadMenu( hWndFrame, _hmod, IDM_MAINMENU );
1024    localizeMenu( hWndMenu );
1025    WinSetWindowUShort( hWndMenu, QWS_ID, FID_MENU );
1026
1027    // Vertical splitter and his windows - Index and Document view
1028    hVertSplitter = WinCreateWindow( hWndFrame, WC_ER_SPLITTER, "",
1029                                     WS_VISIBLE | SBS_VSPLIT,
1030                                     0, 0, 0, 0, hWndFrame, HWND_TOP,
1031                                     ID_SPLITTER, NULL, NULL );
1032
1033    indexWin = new IndexWindow( hWndFrame );
1034
1035    DocumentViewer::registerClass();
1036
1037    docViewer = new DocumentViewer( hWndFrame );
1038
1039    WinSendMsg( hVertSplitter, SBM_SETWINDOWS,
1040                MPFROMHWND( indexWin->getHWND() ), MPFROMHWND( docViewer->getFrameHWND() ) );
1041    Lucide::splitterPos = PrfQueryProfileInt( HINI_USERPROFILE, appName, splpos, Lucide::splitterPos );
1042    Lucide::showIndex = PrfQueryProfileInt( HINI_USERPROFILE, appName, showind, Lucide::showIndex );
1043    WinSendMsg( hVertSplitter, SBM_SETSPLITTERPOS,
1044                MPFROMSHORT( Lucide::showIndex ? Lucide::splitterPos : 0 ), MPVOID );
1045
1046    // Horizontal splitter and its windows - Toolbar and Vertical splitter
1047    // Horizontal splitter is client window
1048    HWND hHorizSplitter = WinCreateWindow( hWndFrame, WC_ER_SPLITTER, "",
1049                                           WS_VISIBLE | SBS_HSPLIT | SBS_SECONDFIXED,
1050                                           0, 0, 0, 0, hWndFrame, HWND_TOP,
1051                                           FID_CLIENT, NULL, NULL );
1052    pOldSplProc = WinSubclassWindow( hHorizSplitter, splProc );
1053
1054    hToolBar = createToolbar( hWndFrame );
1055
1056    WinSendMsg( hHorizSplitter, SBM_SETWINDOWS,
1057                MPFROMHWND( hVertSplitter ), MPFROMHWND( hToolBar ) );
1058    // ãáâ ­®¢šâì 䚪ášà®¢ ­­ë© à §¬¥à €«ï âã«¡ à 
1059    WinSendMsg( hHorizSplitter, SBM_SETFIXEDSIZE,
1060                MPFROMSHORT( DEFAULT_PICTSIZE + TOOLBAR_HEIGHT_ADD ), MPVOID );
1061
1062    findDlg = new FindDlg( hWndFrame );
1063    Lucide::checkMenus();
1064    Lucide::setPageLayout( settings->layout );
1065    Lucide::setZoom( settings->zoom );
1066
1067    // ®ª § âì ®ª­® ¯à®£à ¬¬ë
1068    if ( !PMRestoreWindowPos( NULL, appName, fwp, hWndFrame,
1069                              TRUE, TRUE, FALSE, FALSE, FALSE ) ) {
1070        WinSetWindowPos( hWndFrame, HWND_TOP, 100, 100, 630, 400,
1071                         SWP_SIZE | SWP_MOVE | SWP_SHOW | SWP_ACTIVATE );
1072    }
1073
1074    Lucide::focusDocview();
1075
1076    if ( argc > 1 ) {
1077        Lucide::loadDocument( argv[1] );
1078    }
1079
1080    Lucide::checkNavpane();
1081    initPipeMon( hWndFrame );
1082
1083    // Messsage loop
1084    while ( WinGetMsg( hab, &qmsg, 0, 0, 0 ) ) {
1085        WinDispatchMsg( hab, &qmsg );
1086    }
1087
1088    if ( WinIsWindow( hab, hWndFrame ) )
1089    {
1090        char valbuf[ 3 ] = "";
1091        PrfWriteProfileString( HINI_USERPROFILE, appName, splpos,
1092                               itoa( Lucide::splitterPos, valbuf, 10 ) );
1093        PrfWriteProfileString( HINI_USERPROFILE, appName, showind,
1094                               itoa( Lucide::showIndex, valbuf, 10 ) );
1095        PMStoreWindowPos( NULL, appName, fwp, hWndFrame );
1096    }
1097
1098    WinDestroyWindow( hWndFrame );
1099
1100    Lucide::closeDocument();
1101    delete docViewer;
1102    delete indexWin;
1103
1104    // must be freed _after_ document
1105    delete pluginMan;
1106
1107    delete findDlg;
1108    delete title;
1109    delete settings;
1110    unInitPipeMon();
1111
1112    WinDestroyMsgQueue( hmq );
1113    WinTerminate( hab );
1114    return 0;
1115}
1116
Note: See TracBrowser for help on using the repository browser.