/* This file is part of the KDevelop Okteta module, part of the KDE project. Copyright 2010-2011 Friedrich W. H. Kossebau This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) version 3, or any later version accepted by the membership of KDE e.V. (or its successor approved by the membership of KDE e.V.), which shall act as a proxy defined in Section 6 of version 3 of the license. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library. If not, see . */ #include "oktetadocument.h" // plugin #include "oktetaplugin.h" #include "oktetaview.h" // Okteta #if KASTEN_VERSION == 2 #include #include #include #include #elif KASTEN_VERSION == 1 #include #include #else #include #include #endif // Kasten #if KASTEN_VERSION == 2 #include #include #include #include #include #elif KASTEN_VERSION == 1 #include #include #include #include #include #else #include #include #include #include #include #endif // KDevelop #include #include #include #include #include // Sublime #include #include #include #include // KDE #include #include // Qt #include namespace KDevelop { OktetaDocument::OktetaDocument( const KUrl& url , ICore* core ) : Sublime::UrlDocument( core->uiController()->controller(), url ), IDocument( core ), mByteArrayDocument( 0 ) { } KUrl OktetaDocument::url() const { return Sublime::UrlDocument::url(); } // TODO: use fromContentAndUrl(ByteArrayIODevice) if document loaded KSharedPtr OktetaDocument::mimeType() const { return KMimeType::findByUrl( url() ); } KParts::Part* OktetaDocument::partForView( QWidget* ) const { return 0; } KTextEditor::Document* OktetaDocument::textDocument() const { return 0; } KTextEditor::Cursor OktetaDocument::cursorPosition() const { return KTextEditor::Cursor(); } IDocument::DocumentState OktetaDocument::state() const { return mByteArrayDocument ? #if KASTEN_VERSION == 2 ( mByteArrayDocument->synchronizer()->localSyncState() == Kasten::LocalHasChanges ? #else ( mByteArrayDocument->localSyncState() == Kasten::LocalHasChanges ? #endif IDocument::Modified : IDocument::Clean ) : IDocument::Clean; } bool OktetaDocument::save( IDocument::DocumentSaveMode mode ) { if( mode & Discard ) return true; if( state() == IDocument::Clean ) return false; Kasten::AbstractModelSynchronizer* synchronizer = mByteArrayDocument->synchronizer(); Kasten::AbstractSyncToRemoteJob* syncJob = synchronizer->startSyncToRemote(); const bool syncSucceeded = #if KASTEN_VERSION == 1 || KASTEN_VERSION == 2 Kasten::JobManager::executeJob( syncJob ); #else Kasten::JobManager::executeJob( syncJob, qApp->activeWindow() ); #endif if( syncSucceeded ) { notifySaved(); notifyStateChanged(); } return syncSucceeded; } void OktetaDocument::reload() { Kasten::AbstractModelSynchronizer* synchronizer = mByteArrayDocument->synchronizer(); Kasten::AbstractSyncFromRemoteJob* syncJob = synchronizer->startSyncFromRemote(); const bool syncSucceeded = #if KASTEN_VERSION == 1 || KASTEN_VERSION == 2 Kasten::JobManager::executeJob( syncJob ); #else Kasten::JobManager::executeJob( syncJob, qApp->activeWindow() ); #endif if( syncSucceeded ) notifyStateChanged(); } bool OktetaDocument::close( IDocument::DocumentSaveMode mode ) { bool isCanceled = false; if( !(mode & Discard) ) { if (mode & Silent) { if (!save(mode)) isCanceled = true; } else { if( state() == IDocument::Modified ) { // TODO: use Kasten::*Manager int code = KMessageBox::warningYesNoCancel( qApp->activeWindow(), i18n("The document \"%1\" has unsaved changes. Would you like to save them?", url().toLocalFile()), i18n("Close Document")); if (code == KMessageBox::Yes) { if (!save(mode)) isCanceled = true; } else if (code == KMessageBox::Cancel) isCanceled = true; } else if( state() == IDocument::DirtyAndModified ) { if( !save(mode) ) isCanceled = true; } } } if( isCanceled ) return false; //close all views and then delete ourself ///@todo test this const QList& allAreas = ICore::self()->uiController()->controller()->allAreas(); foreach( Sublime::Area *area, allAreas ) { const QList areaViews = area->views(); foreach( Sublime::View* view, areaViews ) { if (views().contains(view)) { area->removeView(view); delete view; } } } // The document is deleted automatically when there are no views left return true; } bool OktetaDocument::isActive() const { return Core::self()->uiControllerInternal()->activeSublimeWindow()->activeView()->document() == this; } void OktetaDocument::setCursorPosition( const KTextEditor::Cursor& ) {} void OktetaDocument::setTextSelection( const KTextEditor::Range& ) {} void OktetaDocument::activate( Sublime::View* view, KParts::MainWindow* mainWindow ) { notifyActivated(); } void OktetaDocument::setPlugin( OktetaPlugin* plugin ) { mPlugin = plugin; } Sublime::View* OktetaDocument::newView( Sublime::Document* document ) { if( mByteArrayDocument == 0 ) { Kasten::ByteArrayRawFileSynchronizerFactory* synchronizerFactory = new Kasten::ByteArrayRawFileSynchronizerFactory(); Kasten::AbstractModelSynchronizer* synchronizer = synchronizerFactory->createSynchronizer(); Kasten::AbstractLoadJob* loadJob = synchronizer->startLoad( url() ); #if KASTEN_VERSION == 2 connect( loadJob, SIGNAL(documentLoaded(Kasten2::AbstractDocument*)), SLOT(onByteArrayDocumentLoaded(Kasten2::AbstractDocument*)) ); #elif KASTEN_VERSION == 1 connect( loadJob, SIGNAL(documentLoaded(Kasten1::AbstractDocument*)), SLOT(onByteArrayDocumentLoaded(Kasten1::AbstractDocument*)) ); #else connect( loadJob, SIGNAL(documentLoaded(Kasten::AbstractDocument*)), SLOT(onByteArrayDocumentLoaded(Kasten::AbstractDocument*)) ); #endif const bool syncSucceeded = #if KASTEN_VERSION == 1 || KASTEN_VERSION == 2 Kasten::JobManager::executeJob( loadJob ); #else Kasten::JobManager::executeJob( loadJob, qApp->activeWindow() ); #endif delete synchronizerFactory; } #if KASTEN_VERSION == 2 Kasten::ByteArrayViewProfileManager* const viewProfileManager = mPlugin->viewProfileManager(); Kasten::ByteArrayViewProfileSynchronizer* viewProfileSynchronizer = new Kasten::ByteArrayViewProfileSynchronizer( viewProfileManager ); viewProfileSynchronizer->setViewProfileId( viewProfileManager->defaultViewProfileId() ); return new OktetaView( this, viewProfileSynchronizer ); #else return new OktetaView( this ); #endif } bool OktetaDocument::closeDocument(bool silent) { return close(silent ? Silent : Default); } void OktetaDocument::onByteArrayDocumentLoaded( Kasten::AbstractDocument* document ) { if( document ) { mByteArrayDocument = static_cast( document ); #if KASTEN_VERSION == 2 connect( mByteArrayDocument->synchronizer(), SIGNAL(localSyncStateChanged(Kasten2::LocalSyncState)), #elif KASTEN_VERSION == 1 connect( mByteArrayDocument, SIGNAL(localSyncStateChanged(Kasten1::LocalSyncState)), #else connect( mByteArrayDocument, SIGNAL(localSyncStateChanged(Kasten::LocalSyncState)), #endif SLOT(onByteArrayDocumentChanged()) ); } } void OktetaDocument::onByteArrayDocumentChanged() { notifyStateChanged(); } OktetaDocument::~OktetaDocument() { delete mByteArrayDocument; } }