Skip to content

Commit

Permalink
Split precompiled data into a sub-project (and wheel)
Browse files Browse the repository at this point in the history
The goal of this is the ability to generate wheels for precompiled
instances of uap-core, at whatever version we want.

1. It resolves ua-parser#146 by splitting the versioning of the API and that of
   the (pre-compiled) data, this is an issue for 1.0 as that detaches
   uap-python's versioning from uap-core's.
2. It allows users to update the API and the precompiled dataset
   separately, something they would otherwise need to do via yaml.
3. It fixes ua-parser#221 by allowing the regular release of "preview"
   precompiled regexes from uap-core snapshots e.g. we could release
   0.19.dev202412 at the start of december with whatever uap-core
   merged between the previous prerelease and then. This should not be
   picked up by pip by default, but would allow users to access those
   prerelases via `pip install --pre`.
4. If done well enough, it might allow users to build bespoke
   precompiled datasets so they don't have to pick between custom
   rules and precompiled (not sure there's any demand for this but it
   seems like it might be useful).
5. If it works well enough it might actually be possible to have 0.x
   use the legacy codegen package meaning it should not need to be
   updated anymore.

This is implemented via hatch build hooks (which seem seem simpler
than doing it via setuptools in the end).

Adding `regexes.yaml` to the sdist via artifacts is a bit strange but
necessary in order to generate a complete sdist which a wheel can be
built from (even though the release script will likely only push the
wheel).
  • Loading branch information
masklinn committed Nov 23, 2024
1 parent 2476d04 commit cbbd1ca
Show file tree
Hide file tree
Showing 22 changed files with 309 additions and 295 deletions.
8 changes: 6 additions & 2 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,16 @@ name: CI
on:
push:
pull_request:
workflow_dispatch:

jobs:
checks:
runs-on: ubuntu-latest
steps:
- name: Checkout working copy
uses: actions/checkout@v4
with:
submodules: true
fetch-depth: 0
- name: ruff check
uses: chartboost/ruff-action@v1
- name: ruff format
Expand All @@ -29,7 +31,7 @@ jobs:
if: ${{ always() && steps.setup_python.conclusion == 'success' }}
run: |
python -mpip install --upgrade pip
python -mpip install mypy types-PyYaml
python -mpip install mypy types-PyYaml ./ua-parser-builtins
- name: mypy
if: ${{ always() && steps.install_mypy.conclusion == 'success' }}
run: mypy
Expand Down Expand Up @@ -101,6 +103,7 @@ jobs:
uses: actions/checkout@v4
with:
submodules: true
fetch-depth: 0
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
Expand All @@ -115,6 +118,7 @@ jobs:
sudo apt install libyaml-dev
fi
- run: python -mpip install pytest pyyaml
- run: python -mpip install ./ua-parser-builtins
# install rs accelerator if available, ignore if not
- run: python -mpip install ua-parser-rs || true
# re2 is basically impossible to install from source so don't
Expand Down
5 changes: 2 additions & 3 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ description = "Python port of Browserscope's user agent parser"
version = "1.0.0a1"
readme = "README.rst"
requires-python = ">=3.9"
dependencies = []
dependencies = ["ua-parser-builtins"]

license = {text = "Apache 2.0"}
urls = {repository = "https://github.com/ua-parser/uap-python"}
Expand Down Expand Up @@ -57,8 +57,7 @@ where = ["src"]

[tool.ruff]
exclude = [
"src/ua_parser/_lazy.py",
"src/ua_parser/_matchers.py",
"src/ua_parser/generate_builtins.py",
]

[tool.ruff.lint]
Expand Down
8 changes: 0 additions & 8 deletions setup.cfg

This file was deleted.

221 changes: 0 additions & 221 deletions setup.py

This file was deleted.

8 changes: 4 additions & 4 deletions src/ua_parser/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,17 +20,17 @@
from __future__ import annotations

__all__ = [
"OS",
"BasicResolver",
"CachingResolver",
"Cache",
"CachingResolver",
"DefaultedResult",
"Device",
"Domain",
"Matchers",
"OS",
"Result",
"Resolver",
"PartialResult",
"Resolver",
"Result",
"UserAgent",
"load_builtins",
"load_lazy_builtins",
Expand Down
11 changes: 0 additions & 11 deletions src/ua_parser/_lazy.pyi

This file was deleted.

11 changes: 0 additions & 11 deletions src/ua_parser/_matchers.pyi

This file was deleted.

7 changes: 0 additions & 7 deletions src/ua_parser/_regexes.pyi

This file was deleted.

4 changes: 2 additions & 2 deletions src/ua_parser/caching.py
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ def __setitem__(self, key: str, value: PartialResult) -> None:

@dataclasses.dataclass
class CacheEntry:
__slots__ = ["key", "value", "freq"]
__slots__ = ["freq", "key", "value"]
key: str
value: PartialResult
freq: int
Expand Down Expand Up @@ -161,7 +161,7 @@ def _evict_small(self) -> None:

@dataclasses.dataclass
class SieveNode:
__slots__ = ("key", "value", "visited", "next")
__slots__ = ("key", "next", "value", "visited")
key: str
value: PartialResult
visited: bool
Expand Down
8 changes: 4 additions & 4 deletions src/ua_parser/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,14 @@
from typing import Generic, List, Optional, Protocol, Tuple, TypeVar

__all__ = [
"OS",
"DefaultedResult",
"Device",
"Domain",
"Matchers",
"OS",
"Result",
"PartialResult",
"Resolver",
"Result",
"UserAgent",
]

Expand Down Expand Up @@ -74,7 +74,7 @@ def __init__(
class Device:
"""Device information parsed from the user agent string."""

__slots__ = ("family", "brand", "model")
__slots__ = ("brand", "family", "model")
family: str
brand: Optional[str]
model: Optional[str]
Expand Down Expand Up @@ -172,7 +172,7 @@ class PartialResult:
"""

__slots__ = ("domains", "user_agent", "os", "device", "string")
__slots__ = ("device", "domains", "os", "string", "user_agent")
domains: Domain
user_agent: Optional[UserAgent]
os: Optional[OS]
Expand Down
Loading

0 comments on commit cbbd1ca

Please sign in to comment.