Skip to content

Commit

Permalink
AK: Make debugging URLParser easier
Browse files Browse the repository at this point in the history
This patch adds a state_name method to URLParser to convert a state to a
string. With this, the debugging statements now display the state names.

Furthermore, this fixes a bug where non-ASCII code points were
formatted as characters, which fails an assertion in the formatting
system.
  • Loading branch information
MaxWipfli authored and awesomekling committed Jun 5, 2021
1 parent 99d5555 commit 97425c7
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 24 deletions.
8 changes: 5 additions & 3 deletions AK/URLParser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -228,10 +228,12 @@ URL URLParser::parse(Badge<URL>, StringView const& raw_input, URL const* base_ur
code_point = *iterator;

if constexpr (URL_PARSER_DEBUG) {
if (code_point)
dbgln("URLParser::parse: State {:2d} with code point '{:c}' (U+{:04X}).", (int)state, code_point, code_point);
if (!code_point)
dbgln("URLParser::parse: {} state with EOF.", state_name(state));
else if (is_ascii_printable(code_point))
dbgln("URLParser::parse: {} state with code point U+{:04X} ({:c}).", state_name(state), code_point, code_point);
else
dbgln("URLParser::parse: State {:2d} with code point EOF (U+0000).", (int)state);
dbgln("URLParser::parse: {} state with code point U+{:04X}.", state_name(state), code_point);
}

switch (state) {
Expand Down
61 changes: 40 additions & 21 deletions AK/URLParser.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,38 +12,57 @@

namespace AK {

#define ENUMERATE_STATES \
STATE(SchemeStart) \
STATE(Scheme) \
STATE(NoScheme) \
STATE(SpecialRelativeOrAuthority) \
STATE(PathOrAuthority) \
STATE(Relative) \
STATE(RelativeSlash) \
STATE(SpecialAuthoritySlashes) \
STATE(SpecialAuthorityIgnoreSlashes) \
STATE(Authority) \
STATE(Host) \
STATE(Hostname) \
STATE(Port) \
STATE(File) \
STATE(FileSlash) \
STATE(FileHost) \
STATE(PathStart) \
STATE(Path) \
STATE(CannotBeABaseUrlPath) \
STATE(Query) \
STATE(Fragment)

class URLParser {
public:
enum class State {
SchemeStart,
Scheme,
NoScheme,
SpecialRelativeOrAuthority,
PathOrAuthority,
Relative,
RelativeSlash,
SpecialAuthoritySlashes,
SpecialAuthorityIgnoreSlashes,
Authority,
Host,
Hostname,
Port,
File,
FileSlash,
FileHost,
PathStart,
Path,
CannotBeABaseUrlPath,
Query,
Fragment
#define STATE(state) state,
ENUMERATE_STATES
#undef STATE
};

static char const* state_name(State const& state)
{
switch (state) {
#define STATE(state) \
case State::state: \
return #state;
ENUMERATE_STATES
#undef STATE
}
VERIFY_NOT_REACHED();
}

static URL parse(Badge<URL>, StringView const& input, URL const* base_url = nullptr);

private:
static Optional<URL> parse_data_url(StringView const& raw_input);
};

#undef ENUMERATE_STATES

}

using AK::URLParser;

0 comments on commit 97425c7

Please sign in to comment.