1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* 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/. */
#ifndef mozilla_dom_DOMParser_h_
#define mozilla_dom_DOMParser_h_
#include "nsCOMPtr.h"
#include "mozilla/dom/Document.h"
#include "nsWrapperCache.h"
#include "mozilla/Span.h"
#include "mozilla/dom/DOMParserBinding.h"
#include "mozilla/dom/TypedArray.h"
class nsIGlobalObject;
namespace mozilla {
class ErrorResult;
namespace dom {
class DOMParser final : public nsISupports, public nsWrapperCache {
typedef mozilla::dom::GlobalObject GlobalObject;
virtual ~DOMParser();
public:
NS_DECL_CYCLE_COLLECTING_ISUPPORTS
NS_DECL_CYCLE_COLLECTION_WRAPPERCACHE_CLASS(DOMParser)
// WebIDL API
static already_AddRefed<DOMParser> Constructor(const GlobalObject& aOwner,
mozilla::ErrorResult& rv);
already_AddRefed<Document> ParseFromString(const nsAString& aStr,
SupportedType aType,
ErrorResult& aRv);
// ChromeOnly API
already_AddRefed<Document> ParseFromSafeString(const nsAString& aStr,
SupportedType aType,
ErrorResult& aRv);
// Sequence converts to Span, so we can use this overload for both
// the Sequence case and our internal uses.
already_AddRefed<Document> ParseFromBuffer(Span<const uint8_t> aBuf,
SupportedType aType,
ErrorResult& aRv);
already_AddRefed<Document> ParseFromBuffer(const Uint8Array& aBuf,
SupportedType aType,
ErrorResult& aRv);
already_AddRefed<Document> ParseFromStream(nsIInputStream* aStream,
const nsAString& aCharset,
int32_t aContentLength,
SupportedType aType,
ErrorResult& aRv);
void ForceEnableXULXBL() {
mForceEnableXULXBL = true;
ForceEnableDTD();
}
void ForceEnableDTD() { mForceEnableDTD = true; }
nsIGlobalObject* GetParentObject() const { return mOwner; }
virtual JSObject* WrapObject(JSContext* aCx,
JS::Handle<JSObject*> aGivenProto) override {
return mozilla::dom::DOMParser_Binding::Wrap(aCx, this, aGivenProto);
}
// A way to create a non-global-associated DOMParser from C++.
static already_AddRefed<DOMParser> CreateWithoutGlobal(ErrorResult& aRv);
private:
DOMParser(nsIGlobalObject* aOwner, nsIPrincipal* aDocPrincipal,
nsIURI* aDocumentURI, nsIURI* aBaseURI);
already_AddRefed<Document> SetUpDocument(DocumentFlavor aFlavor,
ErrorResult& aRv);
nsCOMPtr<nsIGlobalObject> mOwner;
nsCOMPtr<nsIPrincipal> mPrincipal;
nsCOMPtr<nsIURI> mDocumentURI;
nsCOMPtr<nsIURI> mBaseURI;
bool mForceEnableXULXBL;
bool mForceEnableDTD;
};
} // namespace dom
} // namespace mozilla
#endif
|