/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* ***** BEGIN LICENSE BLOCK ***** * Version: NPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Netscape Public License * Version 1.1 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * http://www.mozilla.org/NPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is mozilla.org code. * * The Initial Developer of the Original Code is * Netscape Communications Corporation. * Portions created by the Initial Developer are Copyright (C) 1998 * the Initial Developer. All Rights Reserved. * * Contributor(s): * Pierre Phaneuf * * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the NPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the NPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ #include #include "nsHTMLEditorLog.h" #include "nsEditorTxnLog.h" #include "nsPIEditorTransaction.h" #define LOCK_LOG(doc) #define UNLOCK_LOG(doc) static NS_DEFINE_IID(kISupportsIID, NS_ISUPPORTS_IID); nsEditorTxnLog::nsEditorTxnLog(nsHTMLEditorLog *aEditorLog) { mRefCnt = 0; mIndentLevel = 0; mBatchCount = 0; mEditorLog = aEditorLog; } nsEditorTxnLog::~nsEditorTxnLog() { } // #define DEBUG_EDITOR_TXN_LOG_REFCNT 1 #ifdef DEBUG_EDITOR_TXN_LOG_REFCNT nsrefcnt nsEditorTxnLog::AddRef(void) { return ++mRefCnt; } nsrefcnt nsEditorTxnLog::Release(void) { NS_PRECONDITION(0 != mRefCnt, "dup release"); if (--mRefCnt == 0) { NS_DELETEXPCOM(this); return 0; } return mRefCnt; } #else NS_IMPL_ADDREF(nsEditorTxnLog) NS_IMPL_RELEASE(nsEditorTxnLog) #endif NS_IMETHODIMP nsEditorTxnLog::QueryInterface(REFNSIID aIID, void** aInstancePtr) { if (nsnull == aInstancePtr) { return NS_ERROR_NULL_POINTER; } if (aIID.Equals(kISupportsIID)) { *aInstancePtr = (void*)(nsISupports*)this; NS_ADDREF_THIS(); return NS_OK; } if (aIID.Equals(NS_GET_IID(nsITransactionListener))) { *aInstancePtr = (void*)(nsITransactionListener*)this; NS_ADDREF_THIS(); return NS_OK; } *aInstancePtr = 0; return NS_NOINTERFACE; } NS_IMETHODIMP nsEditorTxnLog::WillDo(nsITransactionManager *aTxMgr, nsITransaction *aTransaction, PRBool *aInterrupt) { LOCK_LOG(this); PrintIndent(mIndentLevel++); Write("WillDo: "); WriteTransaction(aTransaction); Write("\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::DidDo(nsITransactionManager *aTxMgr, nsITransaction *aTransaction, nsresult aDoResult) { LOCK_LOG(this); PrintIndent(--mIndentLevel); Write("DidDo: "); WriteTransaction(aTransaction); Write("("); WriteInt("%d", aDoResult); Write(")\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::WillUndo(nsITransactionManager *aTxMgr, nsITransaction *aTransaction, PRBool *aInterrupt) { LOCK_LOG(this); PrintIndent(mIndentLevel++); if (aTransaction) { Write("WillUndo: "); WriteTransaction(aTransaction); Write("\n"); } else Write("WillUndoBatch\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::DidUndo(nsITransactionManager *aTxMgr, nsITransaction *aTransaction, nsresult aUndoResult) { LOCK_LOG(this); PrintIndent(--mIndentLevel); if (aTransaction) { Write("DidUndo: "); WriteTransaction(aTransaction); Write("("); WriteInt("%d", aUndoResult); Write(")\n"); } else { Write("EndUndoBatch ("); WriteInt("%d", aUndoResult); Write(")\n"); } Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::WillRedo(nsITransactionManager *aTxMgr, nsITransaction *aTransaction, PRBool *aInterrupt) { LOCK_LOG(this); PrintIndent(mIndentLevel++); if (aTransaction) { Write("WillRedo: "); WriteTransaction(aTransaction); Write("\n"); } else Write("WillRedoBatch\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::DidRedo(nsITransactionManager *aTxMgr, nsITransaction *aTransaction, nsresult aRedoResult) { LOCK_LOG(this); PrintIndent(--mIndentLevel); if (aTransaction) { Write("DidRedo: "); WriteTransaction(aTransaction); Write(" ("); WriteInt("%d", aRedoResult); Write(")\n"); } else { Write("DidRedoBatch ("); WriteInt("%d", aRedoResult); Write(")\n"); } Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::WillBeginBatch(nsITransactionManager *aTxMgr, PRBool *aInterrupt) { LOCK_LOG(this); PrintIndent(mIndentLevel); Write("WillBeginBatch: "); WriteInt("%d", mBatchCount); Write("\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::DidBeginBatch(nsITransactionManager *aTxMgr, nsresult aResult) { LOCK_LOG(this); PrintIndent(mIndentLevel++); Write("DidBeginBatch: "); WriteInt("%d", mBatchCount++); Write(" ("); WriteInt("%d", aResult); Write(")\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::WillEndBatch(nsITransactionManager *aTxMgr, PRBool *aInterrupt) { LOCK_LOG(this); PrintIndent(--mIndentLevel); Write("WillEndBatch: "); WriteInt("%d", --mBatchCount); Write("\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::DidEndBatch(nsITransactionManager *aTxMgr, nsresult aResult) { LOCK_LOG(this); PrintIndent(mIndentLevel); Write("DidEndBatch: "); WriteInt("%d", mBatchCount); Write(" ("); WriteInt("%d", aResult); Write(")\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::WillMerge(nsITransactionManager *aTxMgr, nsITransaction *aTopTransaction, nsITransaction *aTransaction, PRBool *aInterrupt) { LOCK_LOG(this); PrintIndent(mIndentLevel); Write("WillMerge: "); WriteTransaction(aTopTransaction); Write(" <-- "); WriteTransaction(aTransaction); Write("\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } NS_IMETHODIMP nsEditorTxnLog::DidMerge(nsITransactionManager *aTxMgr, nsITransaction *aTopTransaction, nsITransaction *aTransaction, PRBool aDidMerge, nsresult aMergeResult) { LOCK_LOG(this); PrintIndent(mIndentLevel); Write("DidMerge: "); WriteTransaction(aTopTransaction); Write(" <-- "); WriteTransaction(aTransaction); Write(" ("); Write(aDidMerge ? "TRUE" : "FALSE"); Write(", "); WriteInt("%d", aMergeResult); Write(")\n"); Flush(); UNLOCK_LOG(this); return NS_OK; } nsresult nsEditorTxnLog::WriteTransaction(nsITransaction *aTransaction) { nsString str; nsCOMPtr txn = do_QueryInterface(aTransaction); if (txn) { txn->GetTxnDescription(str); if (str.IsEmpty()) str.Assign(NS_LITERAL_STRING("")); } return Write(NS_LossyConvertUCS2toASCII(str).get()); } nsresult nsEditorTxnLog::PrintIndent(PRInt32 aIndentLevel) { PRInt32 i; Write(" // "); for (i = 0; i < aIndentLevel; i++) Write(" "); return NS_OK; } nsresult nsEditorTxnLog::Write(const char *aBuffer) { if (!aBuffer) return NS_ERROR_NULL_POINTER; if (mEditorLog) mEditorLog->Write(aBuffer); else printf(aBuffer); return NS_OK; } nsresult nsEditorTxnLog::WriteInt(const char *aFormat, PRInt32 aInt) { if (!aFormat) return NS_ERROR_NULL_POINTER; if (mEditorLog) mEditorLog->WriteInt(aFormat, aInt); else printf(aFormat, aInt); return NS_OK; } nsresult nsEditorTxnLog::Flush() { nsresult result = NS_OK; #ifdef SLOWS_THINGS_WAY_DOWN if (mEditorLog) result = mEditorLog->Flush(); else fflush(stdout); #endif // SLOWS_THINGS_WAY_DOWN return result; }