From 693b7801f17acd82aa58b0963042bf1350cc3d51 Mon Sep 17 00:00:00 2001 From: "mjudge%netscape.com" Date: Mon, 8 May 2000 04:01:26 +0000 Subject: [PATCH] we get selection controller not from pres shell. we get it from GetSelectionController --- editor/base/nsEditor.cpp | 34 ++++++++++++++---------------- editor/libeditor/base/nsEditor.cpp | 34 ++++++++++++++---------------- 2 files changed, 32 insertions(+), 36 deletions(-) diff --git a/editor/base/nsEditor.cpp b/editor/base/nsEditor.cpp index 46508dfea127..10d8beedfc1f 100644 --- a/editor/base/nsEditor.cpp +++ b/editor/base/nsEditor.cpp @@ -1280,10 +1280,9 @@ NS_IMETHODIMP nsEditor::SelectAll() ForceCompositionEnd(); nsCOMPtr selection; - if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - nsresult result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + nsresult result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if (NS_SUCCEEDED(result) && selection) { result = SelectEntireDocument(selection); @@ -1297,9 +1296,9 @@ NS_IMETHODIMP nsEditor::BeginningOfDocument() nsCOMPtr selection; if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - nsresult result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + nsresult result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if (NS_SUCCEEDED(result) && selection) { nsCOMPtr nodeList; @@ -1356,9 +1355,9 @@ NS_IMETHODIMP nsEditor::EndOfDocument() nsCOMPtr selection; if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - nsresult result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + nsresult result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if (NS_SUCCEEDED(result) && selection) { nsCOMPtr nodeList; @@ -4926,10 +4925,10 @@ nsresult nsEditor::EndUpdateViewBatch() { NS_PRECONDITION(mUpdateCount>0, "bad state"); - nsCOMPtr selCon; - nsresult rv = GetSelectionController(getter_AddRefs(selCon)); - if (NS_FAILED(rv)) - return rv; + nsresult rv; + nsCOMPtr selCon = do_QueryReferent(mSelConWeak,&rv); + if (NS_FAILED(rv) || !selCon) + return rv?rv:NS_ERROR_FAILURE; StCaretHider caretHider(selCon); @@ -5272,10 +5271,9 @@ nsEditor::CreateTxnForDeleteSelection(nsIEditor::EDirection aAction, nsresult result; nsCOMPtr selection; - if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if ((NS_SUCCEEDED(result)) && selection) { // Check whether the selection is collapsed and we should do nothing: diff --git a/editor/libeditor/base/nsEditor.cpp b/editor/libeditor/base/nsEditor.cpp index 46508dfea127..10d8beedfc1f 100644 --- a/editor/libeditor/base/nsEditor.cpp +++ b/editor/libeditor/base/nsEditor.cpp @@ -1280,10 +1280,9 @@ NS_IMETHODIMP nsEditor::SelectAll() ForceCompositionEnd(); nsCOMPtr selection; - if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - nsresult result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + nsresult result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if (NS_SUCCEEDED(result) && selection) { result = SelectEntireDocument(selection); @@ -1297,9 +1296,9 @@ NS_IMETHODIMP nsEditor::BeginningOfDocument() nsCOMPtr selection; if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - nsresult result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + nsresult result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if (NS_SUCCEEDED(result) && selection) { nsCOMPtr nodeList; @@ -1356,9 +1355,9 @@ NS_IMETHODIMP nsEditor::EndOfDocument() nsCOMPtr selection; if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - nsresult result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + nsresult result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if (NS_SUCCEEDED(result) && selection) { nsCOMPtr nodeList; @@ -4926,10 +4925,10 @@ nsresult nsEditor::EndUpdateViewBatch() { NS_PRECONDITION(mUpdateCount>0, "bad state"); - nsCOMPtr selCon; - nsresult rv = GetSelectionController(getter_AddRefs(selCon)); - if (NS_FAILED(rv)) - return rv; + nsresult rv; + nsCOMPtr selCon = do_QueryReferent(mSelConWeak,&rv); + if (NS_FAILED(rv) || !selCon) + return rv?rv:NS_ERROR_FAILURE; StCaretHider caretHider(selCon); @@ -5272,10 +5271,9 @@ nsEditor::CreateTxnForDeleteSelection(nsIEditor::EDirection aAction, nsresult result; nsCOMPtr selection; - if (!mPresShellWeak) return NS_ERROR_NOT_INITIALIZED; - nsCOMPtr selcon = do_QueryReferent(mPresShellWeak); - if (!selcon) return NS_ERROR_NOT_INITIALIZED; - result = selcon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); + nsCOMPtr selCon = do_QueryReferent(mSelConWeak); + if (!selCon) return NS_ERROR_NOT_INITIALIZED; + result = selCon->GetSelection(nsISelectionController::SELECTION_NORMAL, getter_AddRefs(selection)); if ((NS_SUCCEEDED(result)) && selection) { // Check whether the selection is collapsed and we should do nothing: