author | zautrix <zautrix> | 2004-09-12 00:04:54 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-09-12 00:04:54 (UTC) |
commit | d03369e14779dcbedb1e6a8882859664f818f588 (patch) (unidiff) | |
tree | dbd76c26ae1b134ebb3497b6b4bdb695ec867be2 | |
parent | 0a2900e71fd3d80393d67c81aab3aae19d2d680c (diff) | |
download | kdepimpi-d03369e14779dcbedb1e6a8882859664f818f588.zip kdepimpi-d03369e14779dcbedb1e6a8882859664f818f588.tar.gz kdepimpi-d03369e14779dcbedb1e6a8882859664f818f588.tar.bz2 |
Fixed seqfault after sync config
-rw-r--r-- | korganizer/mainwindow.cpp | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/korganizer/mainwindow.cpp b/korganizer/mainwindow.cpp index 9e326a1..d8aa43a 100644 --- a/korganizer/mainwindow.cpp +++ b/korganizer/mainwindow.cpp | |||
@@ -830,49 +830,50 @@ void MainWindow::initActions() | |||
830 | configureToolBarMenu->setItemChecked( 230, true ); | 830 | configureToolBarMenu->setItemChecked( 230, true ); |
831 | if (p-> mShowIconNextDays) | 831 | if (p-> mShowIconNextDays) |
832 | configureToolBarMenu->setItemChecked( 100, true ); | 832 | configureToolBarMenu->setItemChecked( 100, true ); |
833 | if (p-> mShowIconNext) | 833 | if (p-> mShowIconNext) |
834 | configureToolBarMenu->setItemChecked( 110, true ); | 834 | configureToolBarMenu->setItemChecked( 110, true ); |
835 | if (p-> mShowIconJournal) | 835 | if (p-> mShowIconJournal) |
836 | configureToolBarMenu->setItemChecked( 90, true ); | 836 | configureToolBarMenu->setItemChecked( 90, true ); |
837 | if (p-> mShowIconWhatsThis) | 837 | if (p-> mShowIconWhatsThis) |
838 | configureToolBarMenu->setItemChecked( 300, true ); | 838 | configureToolBarMenu->setItemChecked( 300, true ); |
839 | 839 | ||
840 | QLabel* dummy = new QLabel( iconToolBar ); | 840 | QLabel* dummy = new QLabel( iconToolBar ); |
841 | dummy->setBackgroundColor( iconToolBar->backgroundColor() ); | 841 | dummy->setBackgroundColor( iconToolBar->backgroundColor() ); |
842 | if (!p-> mShowIconStretch) | 842 | if (!p-> mShowIconStretch) |
843 | iconToolBar->setStretchableWidget ( dummy ) ; | 843 | iconToolBar->setStretchableWidget ( dummy ) ; |
844 | else | 844 | else |
845 | configureToolBarMenu->setItemChecked( 5, true ); | 845 | configureToolBarMenu->setItemChecked( 5, true ); |
846 | if (p-> mShowIconWhatsThis) | 846 | if (p-> mShowIconWhatsThis) |
847 | QWhatsThis::whatsThisButton ( iconToolBar ); | 847 | QWhatsThis::whatsThisButton ( iconToolBar ); |
848 | connect( configureToolBarMenu, SIGNAL( activated( int ) ),this, SLOT(configureToolBar( int ) ) ); | 848 | connect( configureToolBarMenu, SIGNAL( activated( int ) ),this, SLOT(configureToolBar( int ) ) ); |
849 | configureAgenda( p->mHourSize ); | 849 | configureAgenda( p->mHourSize ); |
850 | connect( configureAgendaMenu, SIGNAL( activated( int ) ),this, SLOT(configureAgenda( int ) ) ); | 850 | connect( configureAgendaMenu, SIGNAL( activated( int ) ),this, SLOT(configureAgenda( int ) ) ); |
851 | } | 851 | } |
852 | void MainWindow::fillSyncMenu() | 852 | void MainWindow::fillSyncMenu() |
853 | { | 853 | { |
854 | syncMenu->clear(); | 854 | if ( syncMenu->count() ) |
855 | syncMenu->clear(); | ||
855 | syncMenu->insertItem( i18n("Configure..."), 0 ); | 856 | syncMenu->insertItem( i18n("Configure..."), 0 ); |
856 | syncMenu->insertSeparator(); | 857 | syncMenu->insertSeparator(); |
857 | syncMenu->insertItem( i18n("Multiple sync"), 1 ); | 858 | syncMenu->insertItem( i18n("Multiple sync"), 1 ); |
858 | syncMenu->insertSeparator(); | 859 | syncMenu->insertSeparator(); |
859 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); | 860 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); |
860 | config.setGroup("General"); | 861 | config.setGroup("General"); |
861 | QStringList prof = config.readListEntry("SyncProfileNames"); | 862 | QStringList prof = config.readListEntry("SyncProfileNames"); |
862 | KOPrefs::instance()->mLocalMachineName = config.readEntry("LocalMachineName","undefined"); | 863 | KOPrefs::instance()->mLocalMachineName = config.readEntry("LocalMachineName","undefined"); |
863 | if ( prof.count() < 3 ) { | 864 | if ( prof.count() < 3 ) { |
864 | prof.clear(); | 865 | prof.clear(); |
865 | prof << i18n("Sharp_DTM"); | 866 | prof << i18n("Sharp_DTM"); |
866 | prof << i18n("Local_file"); | 867 | prof << i18n("Local_file"); |
867 | prof << i18n("Last_file"); | 868 | prof << i18n("Last_file"); |
868 | KSyncProfile* temp = new KSyncProfile (); | 869 | KSyncProfile* temp = new KSyncProfile (); |
869 | temp->setName( prof[0] ); | 870 | temp->setName( prof[0] ); |
870 | temp->writeConfig(&config); | 871 | temp->writeConfig(&config); |
871 | temp->setName( prof[1] ); | 872 | temp->setName( prof[1] ); |
872 | temp->writeConfig(&config); | 873 | temp->writeConfig(&config); |
873 | temp->setName( prof[2] ); | 874 | temp->setName( prof[2] ); |
874 | temp->writeConfig(&config); | 875 | temp->writeConfig(&config); |
875 | config.setGroup("General"); | 876 | config.setGroup("General"); |
876 | config.writeEntry("SyncProfileNames",prof); | 877 | config.writeEntry("SyncProfileNames",prof); |
877 | config.writeEntry("ExternSyncProfiles","Sharp_DTM"); | 878 | config.writeEntry("ExternSyncProfiles","Sharp_DTM"); |
878 | config.sync(); | 879 | config.sync(); |
@@ -967,49 +968,54 @@ void MainWindow::multiSync( bool askforPrefs ) | |||
967 | KOPrefs::instance()->mSyncAlgoPrefs = KOPrefs::instance()->mRingSyncAlgoPrefs; | 968 | KOPrefs::instance()->mSyncAlgoPrefs = KOPrefs::instance()->mRingSyncAlgoPrefs; |
968 | if ( askforPrefs ) { | 969 | if ( askforPrefs ) { |
969 | mView->edit_sync_options(); | 970 | mView->edit_sync_options(); |
970 | KOPrefs::instance()->mRingSyncAlgoPrefs = KOPrefs::instance()->mSyncAlgoPrefs; | 971 | KOPrefs::instance()->mRingSyncAlgoPrefs = KOPrefs::instance()->mSyncAlgoPrefs; |
971 | } | 972 | } |
972 | setCaption(i18n("Multiple sync started.") ); | 973 | setCaption(i18n("Multiple sync started.") ); |
973 | qApp->processEvents(); | 974 | qApp->processEvents(); |
974 | int num = ringSync() ; | 975 | int num = ringSync() ; |
975 | if ( num > 1 ) | 976 | if ( num > 1 ) |
976 | ringSync(); | 977 | ringSync(); |
977 | mBlockSaveFlag = false; | 978 | mBlockSaveFlag = false; |
978 | if ( num ) | 979 | if ( num ) |
979 | save(); | 980 | save(); |
980 | if ( num ) | 981 | if ( num ) |
981 | setCaption(i18n("%1 profiles synced. Multiple sync completed!").arg(num) ); | 982 | setCaption(i18n("%1 profiles synced. Multiple sync completed!").arg(num) ); |
982 | else | 983 | else |
983 | setCaption(i18n("Nothing synced! No profiles defined for multisync!")); | 984 | setCaption(i18n("Nothing synced! No profiles defined for multisync!")); |
984 | return; | 985 | return; |
985 | } | 986 | } |
986 | void MainWindow::slotSyncMenu( int action ) | 987 | void MainWindow::slotSyncMenu( int action ) |
987 | { | 988 | { |
988 | //qDebug("syncaction %d ", action); | 989 | //qDebug("syncaction %d ", action); |
989 | if ( action == 0 ) { | 990 | if ( action == 0 ) { |
990 | 991 | ||
991 | confSync(); | 992 | // seems to be a Qt2 event handling bug |
993 | // syncmenu.clear causes a segfault at first time | ||
994 | // when we call it after the main event loop, it is ok | ||
995 | // same behaviour when calling OM/Pi via QCOP for the first time | ||
996 | QTimer::singleShot ( 1, this, SLOT ( confSync() ) ); | ||
997 | //confSync(); | ||
992 | 998 | ||
993 | return; | 999 | return; |
994 | } | 1000 | } |
995 | if ( action == 1 ) { | 1001 | if ( action == 1 ) { |
996 | multiSync( true ); | 1002 | multiSync( true ); |
997 | return; | 1003 | return; |
998 | } | 1004 | } |
999 | 1005 | ||
1000 | if (mBlockSaveFlag) | 1006 | if (mBlockSaveFlag) |
1001 | return; | 1007 | return; |
1002 | mBlockSaveFlag = true; | 1008 | mBlockSaveFlag = true; |
1003 | mCurrentSyncProfile = action - 1000 ; | 1009 | mCurrentSyncProfile = action - 1000 ; |
1004 | mView->setSyncDevice(KOPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile] ); | 1010 | mView->setSyncDevice(KOPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile] ); |
1005 | mView->setSyncName( KOPrefs::instance()->mLocalMachineName ); | 1011 | mView->setSyncName( KOPrefs::instance()->mLocalMachineName ); |
1006 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); | 1012 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); |
1007 | KSyncProfile* temp = new KSyncProfile (); | 1013 | KSyncProfile* temp = new KSyncProfile (); |
1008 | temp->setName(KOPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile]); | 1014 | temp->setName(KOPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile]); |
1009 | temp->readConfig(&config); | 1015 | temp->readConfig(&config); |
1010 | KOPrefs::instance()->mAskForPreferences = temp->getAskForPreferences(); | 1016 | KOPrefs::instance()->mAskForPreferences = temp->getAskForPreferences(); |
1011 | KOPrefs::instance()->mSyncAlgoPrefs = temp->getSyncPrefs(); | 1017 | KOPrefs::instance()->mSyncAlgoPrefs = temp->getSyncPrefs(); |
1012 | KOPrefs::instance()->mWriteBackFile = temp->getWriteBackFile(); | 1018 | KOPrefs::instance()->mWriteBackFile = temp->getWriteBackFile(); |
1013 | KOPrefs::instance()->mWriteBackExistingOnly = temp->getWriteBackExisting(); | 1019 | KOPrefs::instance()->mWriteBackExistingOnly = temp->getWriteBackExisting(); |
1014 | KOPrefs::instance()->mShowSyncSummary = temp->getShowSummaryAfterSync(); | 1020 | KOPrefs::instance()->mShowSyncSummary = temp->getShowSummaryAfterSync(); |
1015 | if ( action == 1000 ) { | 1021 | if ( action == 1000 ) { |
@@ -1891,51 +1897,48 @@ bool MainWindow::syncWithFile( QString fn , bool quick ) | |||
1891 | setCaption( i18n("Sync cancelled or failed. Nothing synced.") ); | 1897 | setCaption( i18n("Sync cancelled or failed. Nothing synced.") ); |
1892 | if ( ! quick ) | 1898 | if ( ! quick ) |
1893 | KOPrefs::instance()->mLastSyncedLocalFile = fn; | 1899 | KOPrefs::instance()->mLastSyncedLocalFile = fn; |
1894 | slotModifiedChanged( true ); | 1900 | slotModifiedChanged( true ); |
1895 | } | 1901 | } |
1896 | return ret; | 1902 | return ret; |
1897 | } | 1903 | } |
1898 | void MainWindow::quickSyncLocalFile() | 1904 | void MainWindow::quickSyncLocalFile() |
1899 | { | 1905 | { |
1900 | //mView->setSyncDevice("local-file" ); | 1906 | //mView->setSyncDevice("local-file" ); |
1901 | //qDebug("quickSyncLocalFile() "); | 1907 | //qDebug("quickSyncLocalFile() "); |
1902 | if ( syncWithFile( KOPrefs::instance()->mLastSyncedLocalFile, false ) ) { | 1908 | if ( syncWithFile( KOPrefs::instance()->mLastSyncedLocalFile, false ) ) { |
1903 | // Event* e = mView->getLastSyncEvent(); | 1909 | // Event* e = mView->getLastSyncEvent(); |
1904 | // e->setReadOnly( false ); | 1910 | // e->setReadOnly( false ); |
1905 | // e->setLocation( i18n("Quick with file: ")+ KOPrefs::instance()->mLastSyncedLocalFile); | 1911 | // e->setLocation( i18n("Quick with file: ")+ KOPrefs::instance()->mLastSyncedLocalFile); |
1906 | // e->setReadOnly( true ); | 1912 | // e->setReadOnly( true ); |
1907 | 1913 | ||
1908 | } | 1914 | } |
1909 | } | 1915 | } |
1910 | 1916 | ||
1911 | void MainWindow::confSync() | 1917 | void MainWindow::confSync() |
1912 | { | 1918 | { |
1913 | mView->confSync(); | 1919 | mView->confSync(); |
1914 | fillSyncMenu(); | 1920 | fillSyncMenu(); |
1915 | //mView->writeSettings(); | ||
1916 | |||
1917 | |||
1918 | } | 1921 | } |
1919 | void MainWindow::syncRemote( KSyncProfile* prof, bool ask) | 1922 | void MainWindow::syncRemote( KSyncProfile* prof, bool ask) |
1920 | { | 1923 | { |
1921 | QString question; | 1924 | QString question; |
1922 | if ( ask ) { | 1925 | if ( ask ) { |
1923 | question = i18n("Do you really want\nto remote sync\nwith profile \n")+ prof->getName()+" ?\n"; | 1926 | question = i18n("Do you really want\nto remote sync\nwith profile \n")+ prof->getName()+" ?\n"; |
1924 | if ( QMessageBox::information( this, i18n("KO/Pi Sync"), | 1927 | if ( QMessageBox::information( this, i18n("KO/Pi Sync"), |
1925 | question, | 1928 | question, |
1926 | i18n("Yes"), i18n("No"), | 1929 | i18n("Yes"), i18n("No"), |
1927 | 0, 0 ) != 0 ) | 1930 | 0, 0 ) != 0 ) |
1928 | return; | 1931 | return; |
1929 | } | 1932 | } |
1930 | QString command = prof->getPreSyncCommand(); | 1933 | QString command = prof->getPreSyncCommand(); |
1931 | int fi; | 1934 | int fi; |
1932 | if ( (fi = command.find("$PWD$")) > 0 ) { | 1935 | if ( (fi = command.find("$PWD$")) > 0 ) { |
1933 | QString pwd = getPassword(); | 1936 | QString pwd = getPassword(); |
1934 | command = command.left( fi )+ pwd + command.mid( fi+5 ); | 1937 | command = command.left( fi )+ pwd + command.mid( fi+5 ); |
1935 | 1938 | ||
1936 | } | 1939 | } |
1937 | int maxlen = 30; | 1940 | int maxlen = 30; |
1938 | if ( QApplication::desktop()->width() > 320 ) | 1941 | if ( QApplication::desktop()->width() > 320 ) |
1939 | maxlen += 25; | 1942 | maxlen += 25; |
1940 | setCaption ( i18n( "Copy remote file to local machine..." ) ); | 1943 | setCaption ( i18n( "Copy remote file to local machine..." ) ); |
1941 | int fileSize = 0; | 1944 | int fileSize = 0; |