rbx.cp 0.16.0__py3-none-any.whl → 0.16.2__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
rbx/__version__.py CHANGED
@@ -1 +1 @@
1
- __version__ = '0.16.0'
1
+ __version__ = '0.16.2'
rbx/box/git_utils.py CHANGED
@@ -48,9 +48,33 @@ def ls_remote_tags(uri: str) -> List[str]:
48
48
  ]
49
49
 
50
50
 
51
- def latest_remote_tag(uri: str) -> str:
51
+ def ls_version_remote_tags(uri: str) -> List[str]:
52
52
  tags = ls_remote_tags(uri)
53
53
  valid_tags = [tag for tag in tags if semver.Version.is_valid(tag)]
54
- if not valid_tags:
54
+ return valid_tags
55
+
56
+
57
+ def latest_remote_tag(
58
+ uri: str, before: Optional[str] = None, after: Optional[str] = None
59
+ ) -> str:
60
+ tags = ls_version_remote_tags(uri)
61
+ if not tags:
55
62
  raise ValueError(f'No valid tags found for {uri}')
56
- return sorted(valid_tags, key=semver.VersionInfo.parse)[-1]
63
+ if before is not None:
64
+ tags = [
65
+ tag
66
+ for tag in tags
67
+ if semver.VersionInfo.parse(tag) <= semver.VersionInfo.parse(before)
68
+ ]
69
+ if after is not None:
70
+ tags = [
71
+ tag
72
+ for tag in tags
73
+ if semver.VersionInfo.parse(tag) >= semver.VersionInfo.parse(after)
74
+ ]
75
+ return sorted(tags, key=semver.VersionInfo.parse)[-1]
76
+
77
+
78
+ def has_remote_tag(uri: str, tag: str) -> bool:
79
+ tags = ls_remote_tags(uri)
80
+ return tag in tags
@@ -27,12 +27,14 @@ class File(BaseXmlModel):
27
27
 
28
28
 
29
29
  class Test(BaseXmlModel):
30
- method: Literal['manual', 'generated'] = attr()
30
+ method: Literal['manual', 'generated'] = attr(default='manual')
31
31
 
32
32
  sample: Optional[bool] = attr(default=None)
33
33
 
34
34
  description: Optional[str] = attr(default=None)
35
35
 
36
+ verdict: Optional[str] = attr(default=None)
37
+
36
38
 
37
39
  class Testset(BaseXmlModel):
38
40
  name: Optional[str] = attr(default=None)
@@ -60,7 +62,7 @@ class Judging(BaseXmlModel):
60
62
 
61
63
  class Checker(BaseXmlModel):
62
64
  name: Optional[str] = attr(default=None)
63
- type: Literal['testlib'] = attr()
65
+ type: Literal['testlib'] = attr(default='testlib')
64
66
  source: File = element()
65
67
  binary: Optional[File] = element(default=None)
66
68
  cpy: Optional[File] = element(tag='copy', default=None)
@@ -11,7 +11,7 @@ import semver
11
11
  import typer
12
12
 
13
13
  from rbx import console, utils
14
- from rbx.box import cd
14
+ from rbx.box import cd, git_utils
15
15
  from rbx.box.git_utils import latest_remote_tag
16
16
  from rbx.box.presets.fetch import (
17
17
  PresetFetchInfo,
@@ -605,7 +605,18 @@ def _install_preset_from_remote(
605
605
  console.console.print(
606
606
  f'Cloning preset from [item]{fetch_info.fetch_uri}[/item]...'
607
607
  )
608
- git.Repo.clone_from(fetch_info.fetch_uri, d)
608
+ repo = git.Repo.clone_from(fetch_info.fetch_uri, d)
609
+ if fetch_info.tool_tag is not None:
610
+ console.console.print(
611
+ f'Checking out tool tag [item]{fetch_info.tool_tag}[/item]...'
612
+ )
613
+ try:
614
+ repo.git.checkout(fetch_info.tool_tag)
615
+ except Exception as e:
616
+ console.console.print(
617
+ f'[error]Could not checkout tool tag [item]{fetch_info.tool_tag}[/item] for preset [item]{fetch_info.name}[/item].[/error]'
618
+ )
619
+ raise typer.Exit(1) from e
609
620
  pd = pathlib.Path(d)
610
621
  if fetch_info.inner_dir:
611
622
  console.console.print(
@@ -719,14 +730,32 @@ def _install_preset_from_fetch_info(
719
730
  update=update,
720
731
  )
721
732
  return
722
- if _install_preset_from_resources(
723
- fetch_info,
724
- dest,
725
- ensure_contest=ensure_contest,
726
- ensure_problem=ensure_problem,
727
- update=update,
728
- ):
733
+ if fetch_info.is_tool():
734
+ # Fallback to the remote tool tag if it exists.
735
+ assert fetch_info.tool_tag is not None
736
+ remote_fetch_info = get_preset_fetch_info(
737
+ get_remote_uri_from_tool_preset(fetch_info.name)
738
+ )
739
+ assert remote_fetch_info is not None
740
+ remote_fetch_info.tool_tag = fetch_info.tool_tag
741
+
742
+ _install_preset_from_remote(
743
+ remote_fetch_info,
744
+ dest,
745
+ ensure_contest=ensure_contest,
746
+ ensure_problem=ensure_problem,
747
+ update=update,
748
+ )
729
749
  return
750
+
751
+ # if _install_preset_from_resources(
752
+ # fetch_info,
753
+ # dest,
754
+ # ensure_contest=ensure_contest,
755
+ # ensure_problem=ensure_problem,
756
+ # update=update,
757
+ # ):
758
+ # return
730
759
  console.console.print(
731
760
  f'[error]Preset [item]{fetch_info.name}[/item] not found.[/error]'
732
761
  )
@@ -895,8 +924,6 @@ def _sync(try_update: bool = False, force: bool = False, symlinks: bool = False)
895
924
  def copy_tree_normalizing_gitdir(
896
925
  src_path: pathlib.Path, dst_path: pathlib.Path, update: bool = False
897
926
  ):
898
- from rbx.box import git_utils
899
-
900
927
  shutil.copytree(str(src_path), str(dst_path), dirs_exist_ok=update, symlinks=True)
901
928
 
902
929
  if not (src_path / '.git').is_file():
@@ -918,8 +945,6 @@ def copy_local_preset(
918
945
  ):
919
946
  copy_tree_normalizing_gitdir(preset_path, dest_path / '.local.rbx')
920
947
 
921
- from rbx.box import git_utils
922
-
923
948
  preset_repo = git_utils.get_repo_or_nil(preset_path)
924
949
  current_repo = git_utils.get_repo_or_nil(
925
950
  pathlib.Path.cwd(), search_parent_directories=True
rbx/box/presets/fetch.py CHANGED
@@ -4,6 +4,8 @@ from typing import Optional
4
4
 
5
5
  from pydantic import BaseModel
6
6
 
7
+ _RBX_REMOTE_URI = 'https://github.com/rsalesc/rbx'
8
+
7
9
 
8
10
  class PresetFetchInfo(BaseModel):
9
11
  # The actual name of this preset.
@@ -18,12 +20,18 @@ class PresetFetchInfo(BaseModel):
18
20
  # Inner directory from where to pull the preset.
19
21
  inner_dir: str = ''
20
22
 
23
+ # Tool tag.
24
+ tool_tag: Optional[str] = None
25
+
21
26
  def is_remote(self) -> bool:
22
27
  return self.fetch_uri is not None
23
28
 
24
29
  def is_local_dir(self) -> bool:
25
30
  return bool(self.inner_dir) and not self.is_remote()
26
31
 
32
+ def is_tool(self) -> bool:
33
+ return self.tool_tag is not None
34
+
27
35
 
28
36
  def get_inner_dir_from_tool_preset(tool_preset: str) -> str:
29
37
  return f'rbx/resources/presets/{tool_preset}'
@@ -78,6 +86,7 @@ def get_preset_fetch_info(uri: Optional[str]) -> Optional[PresetFetchInfo]:
78
86
  match = compiled.match(s)
79
87
  if match is None:
80
88
  return None
89
+ # Treat as a plain local preset name (no implicit tool tag resolution).
81
90
  return PresetFetchInfo(name=s)
82
91
 
83
92
  extractors = [
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  # yaml-language-server: $schema=https://rsalesc.github.io/rbx/schemas/Preset.json
3
3
  name: "default"
4
- min_version: "0.15.0"
4
+ min_version: "0.16.2"
5
5
  uri: "rsalesc/rbx/rbx/resources/presets/default"
6
6
  problem: "problem"
7
7
  contest: "contest"
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: rbx.cp
3
- Version: 0.16.0
3
+ Version: 0.16.2
4
4
  Summary:
5
5
  Author: Roberto Sales
6
6
  Requires-Python: >=3.9.1,<4.0.0
@@ -1,5 +1,5 @@
1
1
  rbx/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
- rbx/__version__.py,sha256=ZkVXSbnNkhhpmMRr5ur6FqBcUYuqHyK0KUV5Je_XFn8,23
2
+ rbx/__version__.py,sha256=zA3Is963yicS_tJKC2SjI8Arr1-HiEa3ICYj1uj8QJ0,23
3
3
  rbx/annotations.py,sha256=_TkLhgZWiUyon3bonHwUo03ls1jY8LwgcR4bVgtgnc0,3519
4
4
  rbx/autoenum.py,sha256=cusv8ClXRlDVvhZ8eDrtYcL_2peXlHugAey_ht8roXk,12025
5
5
  rbx/box/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -25,7 +25,7 @@ rbx/box/extensions.py,sha256=Von8kIeXvNFTkGlMRMTvL2HIHPwlkuiMswr-ydbGV1w,519
25
25
  rbx/box/fields.py,sha256=Gsox7Q1M7I8I2FtKvwiAfYUC6USpwghk8fel2Q9Eyhg,2291
26
26
  rbx/box/formatting.py,sha256=i3vXHpo_L_VpVPxOe4wHlai1WhlDJlfxUexS9DC0Szg,1249
27
27
  rbx/box/generators.py,sha256=trI4i3BFAzIK4wA0hdCjU1rf8QLwSXKWzSFtCZX17SA,17739
28
- rbx/box/git_utils.py,sha256=WTK8lfmkrBtJpSBuFSwjlSXpkdHnKcVYJgGWTr5V1lY,1513
28
+ rbx/box/git_utils.py,sha256=wuM_k5RgCz5lvoiBciSHo5XT1BdNLhXB0hBlGsc08Vs,2140
29
29
  rbx/box/global_package.py,sha256=YfFGw2vxFspF2v3phBEeBCrLe1sfbANrctGqii3I2X4,2106
30
30
  rbx/box/header.py,sha256=OZJD2J0fdIiYyiEAwQ3x3M8TwM1v1J9nhIjnPVz4Zy8,3029
31
31
  rbx/box/lang.py,sha256=CSD-yxFUC3LWdGpv4IVFOLdgONc_JbsI45BEN3bjaFw,888
@@ -52,9 +52,9 @@ rbx/box/packaging/polygon/packager.py,sha256=1ddKbUJ-RgzgolDZTkmDJFF5N3JGTXRYVA8
52
52
  rbx/box/packaging/polygon/polygon_api.py,sha256=mPKEqiwANJ1nr-JhOgzGMaDhnbljsAgzzPHW6kkf7R4,41016
53
53
  rbx/box/packaging/polygon/test.py,sha256=bgEju5PwudgyfwxXJagm8fM6CJVlWM6l_-2q1V-oKaQ,3069
54
54
  rbx/box/packaging/polygon/upload.py,sha256=w7F0ejfEwhXrAyKADkA2FGuOfTCq96nMNi1YJNRyrtU,13801
55
- rbx/box/packaging/polygon/xml_schema.py,sha256=TSl4BWwMWv7V07BKJ56mcLXNr_3zlRgNmqN2q-wnk4M,3128
56
- rbx/box/presets/__init__.py,sha256=6CJpyIpx7wdUqPvRB5hQY5mIPDo6m1NTOSAYrfF3t5Q,36382
57
- rbx/box/presets/fetch.py,sha256=d37Pze32iQK2uWDr5I55cFeKwobZ6aczRNwpBoUJqoM,2755
55
+ rbx/box/packaging/polygon/xml_schema.py,sha256=UbGtW5-SKN3wK952-eoTvcIDVoO0et10IA9bTb7jV8Y,3210
56
+ rbx/box/presets/__init__.py,sha256=YusqU2ewwq3R1MqIXRM2N-i3uFX6s8m8PDbFJDr4zyg,37451
57
+ rbx/box/presets/fetch.py,sha256=IgnRm1KGTQRsSzbXBaCK_J_qs52Yiddz-1YSiOrw-yo,3012
58
58
  rbx/box/presets/lock_schema.py,sha256=8PKL7UMX4dkdVpCPLwYtaNIIrZpAfHGvTfnF8bRFedM,1708
59
59
  rbx/box/presets/schema.py,sha256=5Nw72QrSsA39cUCCLlVfSYMImK_-TfJEGu5TSIDv3W8,2918
60
60
  rbx/box/remote.py,sha256=hCdiZSmh6Y1vnSEwLZ_gtAMYV-WLVlU3iVnvcObRpRc,5274
@@ -201,7 +201,7 @@ rbx/resources/presets/default/contest/statement/info.rbx.tex,sha256=Wz8Tbmi2lPWM
201
201
  rbx/resources/presets/default/contest/statement/instructions.tex,sha256=JG_eR13ukZgEahrrmrbg40H8cUzpoUE8QLocihN-fZ8,2414
202
202
  rbx/resources/presets/default/contest/statement/logo.png,sha256=RLNYmZoc-BR6AZKkmr4UEg3h01YeFzvy604jMAQC7aA,414485
203
203
  rbx/resources/presets/default/env.rbx.yml,sha256=quSPG5Xs9KroYLATNLPNtORLGRWtrLLt2Fx81T1enAM,1692
204
- rbx/resources/presets/default/preset.rbx.yml,sha256=fcpit12HmIjhsfFdeq9mORnYr4J21Ex-7HPJnbuSfWo,520
204
+ rbx/resources/presets/default/preset.rbx.yml,sha256=xGZuTSzEHsXJUSmJLBTw3-VuX-0gw0pIdyIuTEHK56E,520
205
205
  rbx/resources/presets/default/problem/.gitignore,sha256=1rt95y9Q7ZHIQn28JyZQUdD5zkpRosjAl9ZqoQmX2cE,149
206
206
  rbx/resources/presets/default/problem/gens/gen.cpp,sha256=rn6sGRjZ1sFE1Rq02r6488iquY9xTrutcvLv4d1sohA,178
207
207
  rbx/resources/presets/default/problem/manual_tests/samples/000.in,sha256=w66OEtCJGqjUNj8cJrqgImgGVm8W_OlIUtF255ds-ow,4
@@ -223,8 +223,8 @@ rbx/resources/templates/rbx.h,sha256=0AZds9R0PmuPgnlTENb33Y81LW0LlnmOJFaoN8oG3Yo
223
223
  rbx/resources/templates/template.cpp,sha256=xXWpWo7fa7HfmPNqkmHcmv3i46Wm0ZL-gPmkRfGvLn4,317
224
224
  rbx/testing_utils.py,sha256=vNNdaytowJfuopszVHeFzVtHWlPfipPW4zpqCOvdZKU,2908
225
225
  rbx/utils.py,sha256=AUIknhhED-ZIp6w-VcfPkaG1cYjQkovlX5WCvbVLNHg,9930
226
- rbx_cp-0.16.0.dist-info/LICENSE,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
227
- rbx_cp-0.16.0.dist-info/METADATA,sha256=NWiKQeON30wdiUVjK3so6HKwBBN05aJydDUZ1w6svS8,4799
228
- rbx_cp-0.16.0.dist-info/WHEEL,sha256=b4K_helf-jlQoXBBETfwnf4B04YC67LOev0jo4fX5m8,88
229
- rbx_cp-0.16.0.dist-info/entry_points.txt,sha256=Gw2_BZ5Jon61biaH_ETbAQGXy8fR5On9gw2U4A1erpo,40
230
- rbx_cp-0.16.0.dist-info/RECORD,,
226
+ rbx_cp-0.16.2.dist-info/LICENSE,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
227
+ rbx_cp-0.16.2.dist-info/METADATA,sha256=GthHjKApkHasCi0iCMj5iullxXBaazX6FC-RJSO6WvE,4799
228
+ rbx_cp-0.16.2.dist-info/WHEEL,sha256=b4K_helf-jlQoXBBETfwnf4B04YC67LOev0jo4fX5m8,88
229
+ rbx_cp-0.16.2.dist-info/entry_points.txt,sha256=Gw2_BZ5Jon61biaH_ETbAQGXy8fR5On9gw2U4A1erpo,40
230
+ rbx_cp-0.16.2.dist-info/RECORD,,