From 8525a292b0806d258576c2cfc5363b2c44dcaf22 Mon Sep 17 00:00:00 2001 From: JustOff Date: Wed, 13 Mar 2019 20:07:10 +0200 Subject: Add ConvertJSValueTo*String functions that just take a value and hand out a string, without extra complications --- dom/bindings/BindingUtils.h | 30 ++++++++++++++++++++++++++++-- 1 file changed, 28 insertions(+), 2 deletions(-) (limited to 'dom/bindings/BindingUtils.h') diff --git a/dom/bindings/BindingUtils.h b/dom/bindings/BindingUtils.h index e017b986a..a3ec70f47 100644 --- a/dom/bindings/BindingUtils.h +++ b/dom/bindings/BindingUtils.h @@ -2127,11 +2127,30 @@ ConvertJSValueToString(JSContext* cx, JS::Handle v, return AssignJSString(cx, result, s); } +template +static inline bool +ConvertJSValueToString(JSContext* cx, JS::Handle v, T& result) +{ + return ConvertJSValueToString(cx, v, eStringify, eStringify, result); +} + void -NormalizeUSVString(JSContext* aCx, nsAString& aString); +NormalizeUSVString(nsAString& aString); void -NormalizeUSVString(JSContext* aCx, binding_detail::FakeString& aString); +NormalizeUSVString(binding_detail::FakeString& aString); + +template +static inline bool +ConvertJSValueToUSVString(JSContext* cx, JS::Handle v, T& result) +{ + if (!ConvertJSValueToString(cx, v, eStringify, eStringify, result)) { + return false; + } + + NormalizeUSVString(result); + return true; +} template inline bool @@ -2158,6 +2177,13 @@ bool ConvertJSValueToByteString(JSContext* cx, JS::Handle v, bool nullable, nsACString& result); +inline bool +ConvertJSValueToByteString(JSContext* cx, JS::Handle v, + nsACString& result) +{ + return ConvertJSValueToByteString(cx, v, false, result); +} + template void DoTraceSequence(JSTracer* trc, FallibleTArray& seq); template -- cgit v1.2.3