1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
2 * This Source Code Form is subject to the terms of the Mozilla Public
3 * License, v. 2.0. If a copy of the MPL was not distributed with this
4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
6 #ifndef MOZILLA_GFX_FONTSRCURI_H
7 #define MOZILLA_GFX_FONTSRCURI_H
10 #include "nsTString.h"
11 #include "PLDHashTable.h"
19 } // namespace mozilla
22 * A wrapper for an nsIURI that can be used OMT, which has cached information
23 * useful for the gfxUserFontSet.
27 explicit gfxFontSrcURI(nsIURI
* aURI
);
29 NS_INLINE_DECL_THREADSAFE_REFCOUNTING(gfxFontSrcURI
)
31 nsIURI
* get() { return mURI
; }
33 bool Equals(gfxFontSrcURI
* aOther
);
34 nsresult
GetSpec(nsACString
& aResult
);
35 nsCString
GetSpecOrDefault();
37 PLDHashNumber
Hash() const { return mHash
; }
38 bool InheritsSecurityContext() const { return mInheritsSecurityContext
; }
39 bool SyncLoadIsOK() const { return mSyncLoadIsOK
; }
45 nsCOMPtr
<nsIURI
> mURI
;
47 // If the nsIURI is an nsSimpleURI for a data: URL, this is a pointer to it.
48 // (Just a weak reference since mURI holds the strong reference.)
50 // We store this so that we don't duplicate the URL spec for data: URLs,
51 // which can be much larger than other URLs.
52 mozilla::net::nsSimpleURI
* mSimpleURI
;
54 // If the nsIURI is not an nsSimpleURI, this is its spec.
57 // Precomputed hash for mURI.
60 // Whether the nsIURI's protocol handler has the URI_INHERITS_SECURITY_CONTEXT
62 bool mInheritsSecurityContext
;
64 // Whether the nsIURI's protocol handler has teh URI_SYNC_LOAD_IS_OK flag.
68 #endif // MOZILLA_GFX_FONTSRCURI_H