1*2e2212a7SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*2e2212a7SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*2e2212a7SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*2e2212a7SAndrew Rist * distributed with this work for additional information 6*2e2212a7SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*2e2212a7SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*2e2212a7SAndrew Rist * "License"); you may not use this file except in compliance 9*2e2212a7SAndrew Rist * with the License. You may obtain a copy of the License at 10*2e2212a7SAndrew Rist * 11*2e2212a7SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*2e2212a7SAndrew Rist * 13*2e2212a7SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*2e2212a7SAndrew Rist * software distributed under the License is distributed on an 15*2e2212a7SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*2e2212a7SAndrew Rist * KIND, either express or implied. See the License for the 17*2e2212a7SAndrew Rist * specific language governing permissions and limitations 18*2e2212a7SAndrew Rist * under the License. 19*2e2212a7SAndrew Rist * 20*2e2212a7SAndrew Rist *************************************************************/ 21*2e2212a7SAndrew Rist 22*2e2212a7SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir #ifndef DBACCESS_MIGRATIONLOG_HXX 25cdf0e10cSrcweir #define DBACCESS_MIGRATIONLOG_HXX 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include "dbmm_types.hxx" 28cdf0e10cSrcweir 29cdf0e10cSrcweir /** === begin UNO includes === **/ 30cdf0e10cSrcweir /** === end UNO includes === **/ 31cdf0e10cSrcweir 32cdf0e10cSrcweir #include <rtl/ustring.hxx> 33cdf0e10cSrcweir 34cdf0e10cSrcweir #include <memory> 35cdf0e10cSrcweir 36cdf0e10cSrcweir //........................................................................ 37cdf0e10cSrcweir namespace dbmm 38cdf0e10cSrcweir { 39cdf0e10cSrcweir //........................................................................ 40cdf0e10cSrcweir 41cdf0e10cSrcweir typedef sal_Int16 DocumentID; 42cdf0e10cSrcweir struct MigrationError; 43cdf0e10cSrcweir 44cdf0e10cSrcweir //==================================================================== 45cdf0e10cSrcweir //= MigrationLog 46cdf0e10cSrcweir //==================================================================== 47cdf0e10cSrcweir struct MigrationLog_Data; 48cdf0e10cSrcweir class MigrationLog 49cdf0e10cSrcweir { 50cdf0e10cSrcweir public: 51cdf0e10cSrcweir MigrationLog(); 52cdf0e10cSrcweir ~MigrationLog(); 53cdf0e10cSrcweir 54cdf0e10cSrcweir //---------------------------------------------------------------- 55cdf0e10cSrcweir //- event logging 56cdf0e10cSrcweir 57cdf0e10cSrcweir /** logs an unrecoverable error during the migration process 58cdf0e10cSrcweir */ 59cdf0e10cSrcweir void logFailure( const MigrationError& _rError ); 60cdf0e10cSrcweir 61cdf0e10cSrcweir /** logs a recoverable (or at least ignorable) error during the migration process 62cdf0e10cSrcweir */ 63cdf0e10cSrcweir void logRecoverable( const MigrationError& _rError ); 64cdf0e10cSrcweir 65cdf0e10cSrcweir /// checks whether logFailure has been called 66cdf0e10cSrcweir bool hadFailure() const; 67cdf0e10cSrcweir 68cdf0e10cSrcweir /// logs the fact that the database document has been backed up 69cdf0e10cSrcweir void backedUpDocument( const ::rtl::OUString& _rNewDocumentLocation ); 70cdf0e10cSrcweir 71cdf0e10cSrcweir /** logs that the migration for a certain sub document has been started, returns 72cdf0e10cSrcweir a unique ID for this sub document which is to be used in later calls 73cdf0e10cSrcweir */ 74cdf0e10cSrcweir DocumentID startedDocument( const SubDocumentType _eType, const ::rtl::OUString& _rName ); 75cdf0e10cSrcweir 76cdf0e10cSrcweir /** logs the event that a macro or script library has been moved from within a 77cdf0e10cSrcweir sub document to the database document 78cdf0e10cSrcweir */ 79cdf0e10cSrcweir void movedLibrary( 80cdf0e10cSrcweir const DocumentID _nDocID, 81cdf0e10cSrcweir const ScriptType _eScriptType, 82cdf0e10cSrcweir const ::rtl::OUString& _rOriginalLibName, 83cdf0e10cSrcweir const ::rtl::OUString& _rNewLibName 84cdf0e10cSrcweir ); 85cdf0e10cSrcweir 86cdf0e10cSrcweir /** logs that the migration for a certain document has been finished 87cdf0e10cSrcweir */ 88cdf0e10cSrcweir void finishedDocument( const DocumentID _nDocID ); 89cdf0e10cSrcweir 90cdf0e10cSrcweir //---------------------------------------------------------------- 91cdf0e10cSrcweir //- information retrieval 92cdf0e10cSrcweir 93cdf0e10cSrcweir /** retrieves the new name of a library 94cdf0e10cSrcweir 95cdf0e10cSrcweir The new library name must previously have been logger by calling 96cdf0e10cSrcweir <member>movedLibrary</member>. If not, an assertion will be raised in 97cdf0e10cSrcweir the non-product builds, and an empty string will be returned. 98cdf0e10cSrcweir */ 99cdf0e10cSrcweir const ::rtl::OUString& 100cdf0e10cSrcweir getNewLibraryName( 101cdf0e10cSrcweir DocumentID _nDocID, 102cdf0e10cSrcweir ScriptType _eScriptType, 103cdf0e10cSrcweir const ::rtl::OUString& _rOriginalLibName 104cdf0e10cSrcweir ) const; 105cdf0e10cSrcweir 106cdf0e10cSrcweir /** determines whether for the given document, any library needed to be (and was) moved 107cdf0e10cSrcweir */ 108cdf0e10cSrcweir bool movedAnyLibrary( const DocumentID ); 109cdf0e10cSrcweir 110cdf0e10cSrcweir /** provides a human-readable version of the log, explaining a user what happened during 111cdf0e10cSrcweir the migration. 112cdf0e10cSrcweir */ 113cdf0e10cSrcweir ::rtl::OUString 114cdf0e10cSrcweir getCompleteLog() const; 115cdf0e10cSrcweir 116cdf0e10cSrcweir private: 117cdf0e10cSrcweir ::std::auto_ptr< MigrationLog_Data > m_pData; 118cdf0e10cSrcweir }; 119cdf0e10cSrcweir 120cdf0e10cSrcweir //........................................................................ 121cdf0e10cSrcweir } // namespace dbmm 122cdf0e10cSrcweir //........................................................................ 123cdf0e10cSrcweir 124cdf0e10cSrcweir #endif // DBACCESS_MIGRATIONLOG_HXX 125