Skip to content

Commit

Permalink
Bug 1774704 - part 7-2: Make `CSSEditUtils::RemoveCSSInlineStyleWithT…
Browse files Browse the repository at this point in the history
…ransaction` stop touching `Selection` directly r=m_kato

Differential Revision: https://phabricator.services.mozilla.com/D152975
  • Loading branch information
masayuki-nakano committed Aug 4, 2022
1 parent 68caf86 commit efd0248
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 25 deletions.
25 changes: 8 additions & 17 deletions editor/libeditor/CSSEditUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -571,38 +571,29 @@ already_AddRefed<nsComputedDOMStyle> CSSEditUtils::GetComputedStyle(

// remove the CSS style "aProperty : aPropertyValue" and possibly remove the
// whole node if it is a span and if its only attribute is _moz_dirty
nsresult CSSEditUtils::RemoveCSSInlineStyleWithTransaction(
Result<EditorDOMPoint, nsresult>
CSSEditUtils::RemoveCSSInlineStyleWithTransaction(
nsStyledElement& aStyledElement, nsAtom* aProperty,
const nsAString& aPropertyValue) {
// remove the property from the style attribute
nsresult rv = RemoveCSSPropertyWithTransaction(aStyledElement, *aProperty,
aPropertyValue);
if (NS_FAILED(rv)) {
NS_WARNING("CSSEditUtils::RemoveCSSPropertyWithTransaction() failed");
return rv;
return Err(rv);
}

if (!aStyledElement.IsHTMLElement(nsGkAtoms::span) ||
HTMLEditor::HasAttributes(&aStyledElement)) {
return NS_OK;
return EditorDOMPoint();
}

OwningNonNull<HTMLEditor> htmlEditor(*mHTMLEditor);
const Result<EditorDOMPoint, nsresult> unwrapStyledElementResult =
Result<EditorDOMPoint, nsresult> unwrapStyledElementResult =
htmlEditor->RemoveContainerWithTransaction(aStyledElement);
if (MOZ_UNLIKELY(unwrapStyledElementResult.isErr())) {
NS_WARNING("HTMLEditor::RemoveContainerWithTransaction() failed");
return unwrapStyledElementResult.inspectErr();
}
const EditorDOMPoint& pointToPutCaret = unwrapStyledElementResult.inspect();
if (!htmlEditor->AllowsTransactionsToChangeSelection() ||
!pointToPutCaret.IsSet()) {
return NS_OK;
}
rv = htmlEditor->CollapseSelectionTo(pointToPutCaret);
NS_WARNING_ASSERTION(NS_SUCCEEDED(rv),
"EditorBase::CollapseSelectionTo() failed");
return rv;
NS_WARNING_ASSERTION(unwrapStyledElementResult.isOk(),
"HTMLEditor::RemoveContainerWithTransaction() failed");
return unwrapStyledElementResult;
}

// Answers true if the property can be removed by setting a "none" CSS value
Expand Down
8 changes: 5 additions & 3 deletions editor/libeditor/CSSEditUtils.h
Original file line number Diff line number Diff line change
Expand Up @@ -134,10 +134,12 @@ class CSSEditUtils final {
* @param aProperty [IN] The CSS property atom to remove.
* @param aPropertyValue [IN] The value of the property we have to remove
* if the property accepts more than one value.
* @return A candidate point to put caret.
*/
[[nodiscard]] MOZ_CAN_RUN_SCRIPT nsresult RemoveCSSInlineStyleWithTransaction(
nsStyledElement& aStyledElement, nsAtom* aProperty,
const nsAString& aPropertyValue);
[[nodiscard]] MOZ_CAN_RUN_SCRIPT Result<EditorDOMPoint, nsresult>
RemoveCSSInlineStyleWithTransaction(nsStyledElement& aStyledElement,
nsAtom* aProperty,
const nsAString& aPropertyValue);

/**
* Answers true is the property can be removed by setting a "none" CSS value
Expand Down
19 changes: 14 additions & 5 deletions editor/libeditor/HTMLEditSubActionHandler.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9720,14 +9720,23 @@ nsresult HTMLEditor::RemoveAlignFromDescendants(Element& aElement,
// MOZ_KnownLive(*styledBlockOrHRElement): It's `blockOrHRElement
// which is OwningNonNull.
nsAutoString dummyCssValue;
nsresult rv = mCSSEditUtils->RemoveCSSInlineStyleWithTransaction(
MOZ_KnownLive(*styledBlockOrHRElement), nsGkAtoms::textAlign,
dummyCssValue);
if (NS_FAILED(rv)) {
Result<EditorDOMPoint, nsresult> pointToPutCaretOrError =
mCSSEditUtils->RemoveCSSInlineStyleWithTransaction(
MOZ_KnownLive(*styledBlockOrHRElement), nsGkAtoms::textAlign,
dummyCssValue);
if (MOZ_UNLIKELY(pointToPutCaretOrError.isErr())) {
NS_WARNING(
"CSSEditUtils::RemoveCSSInlineStyleWithTransaction(nsGkAtoms::"
"textAlign) failed");
return rv;
return pointToPutCaretOrError.unwrapErr();
}
if (AllowsTransactionsToChangeSelection() &&
pointToPutCaretOrError.inspect().IsSet()) {
nsresult rv = CollapseSelectionTo(pointToPutCaretOrError.inspect());
if (NS_FAILED(rv)) {
NS_WARNING("EditorBase::CollapseSelectionTo() failed");
return rv;
}
}
}
}
Expand Down

0 comments on commit efd0248

Please sign in to comment.