Skip to content

Commit

Permalink
Bug 1575343, part 1 - Avoid a gratuitous string copy by calling the n…
Browse files Browse the repository at this point in the history
…sAString overload of GetCallingLocation. r=smaug

The nsAString overload of GetCallingLocation directly converts the
original source file name string into an nsAString. A number of
callers that want the source file name in an nsAString are calling the
nsACString overload of GetCallingLocation, then calling
NS_ConvertUTF8toUTF16. This results in an extra intermediate copy of
the original string data.

Differential Revision: https://phabricator.services.mozilla.com/D42727

--HG--
extra : moz-landing-system : lando
  • Loading branch information
amccreight committed Aug 20, 2019
1 parent d6e4ed5 commit 62bd52a
Show file tree
Hide file tree
Showing 5 changed files with 20 additions and 22 deletions.
11 changes: 5 additions & 6 deletions dom/base/nsContentUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3724,7 +3724,7 @@ nsresult nsContentUtils::ReportToConsoleByWindowID(
NS_ENSURE_SUCCESS(rv, rv);
}

nsAutoCString spec;
nsAutoString spec;
if (!aLineNumber && aLocationMode == eUSE_CALLING_LOCATION) {
JSContext* cx = GetCurrentJSContext();
if (cx) {
Expand All @@ -3737,11 +3737,10 @@ nsresult nsContentUtils::ReportToConsoleByWindowID(
NS_ENSURE_SUCCESS(rv, rv);

if (!spec.IsEmpty()) {
rv =
errorObject->InitWithWindowID(aErrorText,
NS_ConvertUTF8toUTF16(spec), // file name
aSourceLine, aLineNumber, aColumnNumber,
aErrorFlags, aCategory, aInnerWindowID);
rv = errorObject->InitWithWindowID(aErrorText,
spec, // file name
aSourceLine, aLineNumber, aColumnNumber,
aErrorFlags, aCategory, aInnerWindowID);
} else {
rv = errorObject->InitWithSourceURI(aErrorText, aURI, aSourceLine,
aLineNumber, aColumnNumber, aErrorFlags,
Expand Down
5 changes: 2 additions & 3 deletions dom/bindings/BindingUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4003,7 +4003,7 @@ void DeprecationWarning(const GlobalObject& aGlobal,
if (window && window->GetExtantDoc()) {
window->GetExtantDoc()->WarnOnceAbout(aOperation);

nsAutoCString fileName;
nsAutoString fileName;
Nullable<uint32_t> lineNumber;
Nullable<uint32_t> columnNumber;
uint32_t line = 0;
Expand All @@ -4014,8 +4014,7 @@ void DeprecationWarning(const GlobalObject& aGlobal,
columnNumber.SetValue(column);
}

MaybeReportDeprecation(window, aOperation,
NS_ConvertUTF8toUTF16(fileName), lineNumber,
MaybeReportDeprecation(window, aOperation, fileName, lineNumber,
columnNumber);
}

Expand Down
8 changes: 4 additions & 4 deletions dom/media/webaudio/WebAudioUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,7 @@ void WebAudioUtils::LogToDeveloperConsole(uint64_t aWindowID,
return;
}

nsAutoCString spec;
nsAutoString spec;
uint32_t aLineNumber, aColumnNumber;
JSContext* cx = nsContentUtils::GetCurrentJSContext();
if (cx) {
Expand All @@ -134,9 +134,9 @@ void WebAudioUtils::LogToDeveloperConsole(uint64_t aWindowID,
return;
}

errorObject->InitWithWindowID(
result, NS_ConvertUTF8toUTF16(spec), EmptyString(), aLineNumber,
aColumnNumber, nsIScriptError::warningFlag, "Web Audio", aWindowID);
errorObject->InitWithWindowID(result, spec, EmptyString(), aLineNumber,
aColumnNumber, nsIScriptError::warningFlag,
"Web Audio", aWindowID);
console->LogMessage(errorObject);
}

Expand Down
8 changes: 4 additions & 4 deletions dom/security/featurepolicy/FeaturePolicyUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -136,7 +136,7 @@ void FeaturePolicyUtils::ReportViolation(Document* aDocument,
return;
}

nsAutoCString fileName;
nsAutoString fileName;
Nullable<int32_t> lineNumber;
Nullable<int32_t> columnNumber;
uint32_t line = 0;
Expand All @@ -152,9 +152,9 @@ void FeaturePolicyUtils::ReportViolation(Document* aDocument,
}

RefPtr<FeaturePolicyViolationReportBody> body =
new FeaturePolicyViolationReportBody(
window, aFeatureName, NS_ConvertUTF8toUTF16(fileName), lineNumber,
columnNumber, NS_LITERAL_STRING("enforce"));
new FeaturePolicyViolationReportBody(window, aFeatureName, fileName,
lineNumber, columnNumber,
NS_LITERAL_STRING("enforce"));

ReportingUtils::Report(window, nsGkAtoms::featurePolicyViolation,
NS_LITERAL_STRING("default"),
Expand Down
10 changes: 5 additions & 5 deletions dom/security/nsCSPContext.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -213,7 +213,7 @@ bool nsCSPContext::permitsInternal(
if (!aIsPreload && aSendViolationReports) {
uint32_t lineNumber = 0;
uint32_t columnNumber = 0;
nsAutoCString spec;
nsAutoString spec;
JSContext* cx = nsContentUtils::GetCurrentJSContext();
if (cx) {
nsJSUtils::GetCallingLocation(cx, spec, &lineNumber, &columnNumber);
Expand All @@ -229,10 +229,10 @@ bool nsCSPContext::permitsInternal(
null */
violatedDirective, p, /* policy index */
EmptyString(), /* no observer subject */
NS_ConvertUTF8toUTF16(spec), /* source file */
EmptyString(), /* no script sample */
lineNumber, /* line number */
columnNumber); /* column number */
spec, /* source file */
EmptyString(), /* no script sample */
lineNumber, /* line number */
columnNumber); /* column number */
}
}
}
Expand Down

0 comments on commit 62bd52a

Please sign in to comment.