2001-09-29 03:09:51 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
2012-05-21 15:12:37 +04:00
|
|
|
* 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/. */
|
2001-09-29 03:09:51 +04:00
|
|
|
#ifndef NS_PARSERSERVICE_H__
|
|
|
|
#define NS_PARSERSERVICE_H__
|
|
|
|
|
|
|
|
#include "nsIParserService.h"
|
|
|
|
|
2004-02-09 17:15:57 +03:00
|
|
|
extern "C" int MOZ_XMLIsLetter(const char* ptr);
|
|
|
|
extern "C" int MOZ_XMLIsNCNameChar(const char* ptr);
|
2016-05-19 20:48:11 +03:00
|
|
|
/**
|
|
|
|
* Decodes an entity into the UTF-16 encoding of a Unicode character. If a ';'
|
|
|
|
* is found between `ptr` and `end` it will try to decode the entity and set
|
|
|
|
* `*next` to point to the character after the ;. The resulting UTF-16 code
|
|
|
|
* units will be written in `*result`, so if the entity is a valid numeric
|
|
|
|
* entity there needs to be space for at least two char16_t at the location
|
|
|
|
* `result` points to.
|
|
|
|
*
|
|
|
|
* @param ptr pointer to the ampersand.
|
|
|
|
* @param end pointer to the position after the last character of the
|
|
|
|
* string.
|
|
|
|
* @param next [out] will be set to the character after the ';' or null if
|
|
|
|
* the decoding was unsuccessful.
|
|
|
|
* @param result the buffer to write the resulting UTF-16 character in.
|
|
|
|
* @return the number of char16_t written to `*result`.
|
|
|
|
*/
|
2006-03-17 17:38:57 +03:00
|
|
|
extern "C" int MOZ_XMLTranslateEntity(const char* ptr, const char* end,
|
2014-01-04 19:02:17 +04:00
|
|
|
const char** next, char16_t* result);
|
2004-02-09 17:15:57 +03:00
|
|
|
|
2001-09-29 03:09:51 +04:00
|
|
|
class nsParserService : public nsIParserService {
|
2014-06-27 22:41:03 +04:00
|
|
|
virtual ~nsParserService();
|
|
|
|
|
2001-09-29 03:09:51 +04:00
|
|
|
public:
|
|
|
|
nsParserService();
|
|
|
|
|
|
|
|
NS_DECL_ISUPPORTS
|
|
|
|
|
2015-03-21 19:28:04 +03:00
|
|
|
int32_t HTMLAtomTagToId(nsIAtom* aAtom) const override;
|
2001-09-29 03:09:51 +04:00
|
|
|
|
2015-03-21 19:28:04 +03:00
|
|
|
int32_t HTMLCaseSensitiveAtomTagToId(nsIAtom* aAtom) const override;
|
2001-09-29 03:09:51 +04:00
|
|
|
|
2015-03-21 19:28:04 +03:00
|
|
|
int32_t HTMLStringTagToId(const nsAString& aTag) const override;
|
2001-11-28 09:13:11 +03:00
|
|
|
|
2015-03-21 19:28:04 +03:00
|
|
|
const char16_t *HTMLIdToStringTag(int32_t aId) const override;
|
2001-09-29 03:09:51 +04:00
|
|
|
|
2015-03-21 19:28:04 +03:00
|
|
|
nsIAtom *HTMLIdToAtomTag(int32_t aId) const override;
|
2005-06-16 17:10:58 +04:00
|
|
|
|
2002-03-24 03:16:18 +03:00
|
|
|
NS_IMETHOD HTMLConvertEntityToUnicode(const nsAString& aEntity,
|
2015-03-21 19:28:04 +03:00
|
|
|
int32_t* aUnicode) const override;
|
2012-08-22 19:56:38 +04:00
|
|
|
NS_IMETHOD HTMLConvertUnicodeToEntity(int32_t aUnicode,
|
2015-03-21 19:28:04 +03:00
|
|
|
nsCString& aEntity) const override;
|
|
|
|
NS_IMETHOD IsContainer(int32_t aId, bool& aIsContainer) const override;
|
|
|
|
NS_IMETHOD IsBlock(int32_t aId, bool& aIsBlock) const override;
|
2001-09-29 03:09:51 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|