Bug 1381851 - Add mIsChrome to URLExtraData for querying on servo side.
MozReview-Commit-ID: HTCmAcKNefG
--- a/layout/style/URLExtraData.h
+++ b/layout/style/URLExtraData.h
@@ -4,16 +4,17 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/* thread-safe container of information for resolving url values */
#ifndef mozilla_URLExtraData_h
#define mozilla_URLExtraData_h
+#include "mozilla/dom/URL.h"
#include "mozilla/Move.h"
#include "mozilla/StaticPtr.h"
#include "nsCOMPtr.h"
#include "nsIPrincipal.h"
#include "nsIURI.h"
namespace mozilla {
@@ -21,16 +22,19 @@ namespace mozilla {
struct URLExtraData
{
URLExtraData(already_AddRefed<nsIURI> aBaseURI,
already_AddRefed<nsIURI> aReferrer,
already_AddRefed<nsIPrincipal> aPrincipal)
: mBaseURI(Move(aBaseURI))
, mReferrer(Move(aReferrer))
, mPrincipal(Move(aPrincipal))
+ // When we hold the URI data of a style sheet, mReferrer is always
+ // equal to the sheet URI.
+ , mIsChrome(mReferrer ? dom::IsChromeURI(mReferrer) : false)
{
MOZ_ASSERT(mBaseURI);
}
URLExtraData(nsIURI* aBaseURI, nsIURI* aReferrer, nsIPrincipal* aPrincipal)
: URLExtraData(do_AddRef(aBaseURI),
do_AddRef(aReferrer),
do_AddRef(aPrincipal)) {}
@@ -50,14 +54,17 @@ struct URLExtraData
private:
~URLExtraData();
nsCOMPtr<nsIURI> mBaseURI;
nsCOMPtr<nsIURI> mReferrer;
nsCOMPtr<nsIPrincipal> mPrincipal;
+ // True if mReferrer is a chrome:// URI.
+ const bool mIsChrome;
+
static StaticRefPtr<URLExtraData> sDummy;
};
} // namespace mozilla
#endif // mozilla_URLExtraData_h