Skip to content

Commit

Permalink
Check val.netloc instead of self.absolute internally
Browse files Browse the repository at this point in the history
val.netloc is accessed on a namedtuple, which is much faster
  • Loading branch information
bdraco committed Oct 13, 2024
1 parent a5de0c0 commit 2e560d0
Showing 1 changed file with 22 additions and 22 deletions.
44 changes: 22 additions & 22 deletions yarl/_url.py
Original file line number Diff line number Diff line change
Expand Up @@ -418,7 +418,7 @@ def __init_subclass__(cls):
def __str__(self) -> str:
val = self._val
scheme, netloc, path, query, fragment = val
if not val.path and self.absolute and (val.query or val.fragment):
if not val.path and val.netloc and (val.query or val.fragment):
path = "/"
if (port := self.explicit_port) is not None and port == self._default_port:
# port normalization - using None for default ports to remove from rendering
Expand Down Expand Up @@ -454,11 +454,11 @@ def __eq__(self, other: object) -> bool:
return NotImplemented

val1 = self._val
if not val1.path and self.absolute:
if not val1.path and val1.netloc:
val1 = val1._replace(path="/")

val2 = other._val
if not val2.path and other.absolute:
if not val2.path and val2.netloc:
val2 = val2._replace(path="/")

return val1 == val2
Expand All @@ -467,7 +467,7 @@ def __hash__(self) -> int:
ret = self._cache.get("hash")
if ret is None:
val = self._val
if not val.path and self.absolute:
if not val.path and val.netloc:
val = val._replace(path="/")
ret = self._cache["hash"] = hash(val)
return ret
Expand Down Expand Up @@ -501,9 +501,8 @@ def __mod__(self, query: Query) -> "URL":
return self.update_query(query)

def __bool__(self) -> bool:
return bool(
self._val.netloc or self._val.path or self._val.query or self._val.fragment
)
val = self._val
return bool(val.netloc or val.path or val.query or val.fragment)

def __getstate__(self) -> Tuple[SplitResult]:
return (self._val,)
Expand Down Expand Up @@ -551,7 +550,7 @@ def is_default_port(self) -> bool:
# If the explicit port is None, then the URL must be
# using the default port unless its a relative URL
# which does not have an implicit port / default port
return self.absolute
return self._val.netloc != ""
return explicit == self._default_port

def origin(self) -> "URL":
Expand Down Expand Up @@ -588,7 +587,7 @@ def relative(self) -> "URL":
scheme, user, password, host and port are removed.
"""
if not self.absolute:
if not self._val.netloc:
raise ValueError("URL should be absolute")
val = self._val._replace(scheme="", netloc="")
return self._from_val(val)
Expand Down Expand Up @@ -762,7 +761,7 @@ def raw_path(self) -> str:
"""
ret = self._val.path
if not ret and self.absolute:
if not ret and self._val.netloc:
ret = "/"
return ret

Expand Down Expand Up @@ -859,7 +858,7 @@ def raw_parts(self) -> Tuple[str, ...]:
"""
path = self._val.path
if self.absolute:
if self._val.netloc:
return ("/", *path[1:].split("/")) if path else ("/",)
if path and path[0] == "/":
return ("/", *path[1:].split("/"))
Expand Down Expand Up @@ -893,7 +892,7 @@ def parent(self) -> "URL":
def raw_name(self) -> str:
"""The last part of raw_parts."""
parts = self.raw_parts
if self.absolute:
if self._val.netloc:
parts = parts[1:]
if not parts:
return ""
Expand Down Expand Up @@ -970,7 +969,7 @@ def _make_child(self, paths: "Sequence[str]", encoded: bool = False) -> "URL":
old_path_cutoff = -1 if old_path_segments[-1] == "" else None
parsed = [*old_path_segments[:old_path_cutoff], *parsed]

if self.absolute:
if self._val.netloc:
parsed = _normalize_path_segments(parsed) if needs_normalize else parsed
if parsed and parsed[0] != "":
# inject a leading slash when adding a path to an absolute URL
Expand Down Expand Up @@ -1148,7 +1147,7 @@ def with_scheme(self, scheme: str) -> "URL":
if not isinstance(scheme, str):
raise TypeError("Invalid scheme type")
lower_scheme = scheme.lower()
if not self.absolute and lower_scheme in SCHEME_REQUIRES_HOST:
if not self._val.netloc and lower_scheme in SCHEME_REQUIRES_HOST:
msg = (
"scheme replacement is not allowed for "
f"relative URLs for the {lower_scheme} scheme"
Expand All @@ -1173,7 +1172,7 @@ def with_user(self, user: Union[str, None]) -> "URL":
password = self.raw_password
else:
raise TypeError("Invalid user type")
if not self.absolute:
if not val.netloc:
raise ValueError("user replacement is not allowed for relative URLs")
encoded_host = self.host_subcomponent or ""
netloc = self._make_netloc(user, password, encoded_host, self.explicit_port)
Expand All @@ -1194,7 +1193,7 @@ def with_password(self, password: Union[str, None]) -> "URL":
password = self._QUOTER(password)
else:
raise TypeError("Invalid password type")
if not self.absolute:
if not self._val.netloc:
raise ValueError("password replacement is not allowed for relative URLs")
encoded_host = self.host_subcomponent or ""
port = self.explicit_port
Expand All @@ -1213,14 +1212,15 @@ def with_host(self, host: str) -> "URL":
# N.B. doesn't cleanup query/fragment
if not isinstance(host, str):
raise TypeError("Invalid host type")
if not self.absolute:
val = self._val
if not val.netloc:
raise ValueError("host replacement is not allowed for relative URLs")
if not host:
raise ValueError("host removing is not allowed")
encoded_host = self._encode_host(host) if host else ""
port = self.explicit_port
netloc = self._make_netloc(self.raw_user, self.raw_password, encoded_host, port)
return self._from_val(self._val._replace(netloc=netloc))
return self._from_val(val._replace(netloc=netloc))

def with_port(self, port: Union[int, None]) -> "URL":
"""Return a new URL with port replaced.
Expand All @@ -1234,9 +1234,9 @@ def with_port(self, port: Union[int, None]) -> "URL":
raise TypeError(f"port should be int or None, got {type(port)}")
if not (0 <= port <= 65535):
raise ValueError(f"port must be between 0 and 65535, got {port}")
if not self.absolute:
raise ValueError("port replacement is not allowed for relative URLs")
val = self._val
if not val.netloc:
raise ValueError("port replacement is not allowed for relative URLs")
encoded_host = self.host_subcomponent or ""
netloc = self._make_netloc(self.raw_user, self.raw_password, encoded_host, port)
return self._from_val(val._replace(netloc=netloc))
Expand All @@ -1245,7 +1245,7 @@ def with_path(self, path: str, *, encoded: bool = False) -> "URL":
"""Return a new URL with path replaced."""
if not encoded:
path = self._PATH_QUOTER(path)
if self.absolute:
if self._val.netloc:
path = self._normalize_path(path) if "." in path else path
if len(path) > 0 and path[0] != "/":
path = "/" + path
Expand Down Expand Up @@ -1470,7 +1470,7 @@ def with_name(self, name: str) -> "URL":
if name in (".", ".."):
raise ValueError(". and .. values are forbidden")
parts = list(self.raw_parts)
if self.absolute:
if self._val.netloc:
if len(parts) == 1:
parts.append(name)
else:
Expand Down

0 comments on commit 2e560d0

Please sign in to comment.