rbx.cp 0.16.1__py3-none-any.whl → 0.16.4__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.1'
1
+ __version__ = '0.16.4'
rbx/box/cli.py CHANGED
@@ -109,9 +109,7 @@ app.add_typer(
109
109
 
110
110
  def version_callback(value: bool) -> None:
111
111
  if value:
112
- import importlib.metadata
113
-
114
- version = importlib.metadata.version('rbx.cp')
112
+ version = utils.get_version()
115
113
 
116
114
  console.console.print(f'rbx version {version}')
117
115
  raise typer.Exit()
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
@@ -1,7 +1,7 @@
1
1
  import pathlib
2
2
  import shutil
3
3
  from math import fabs
4
- from typing import List
4
+ from typing import List, Optional
5
5
 
6
6
  import typer
7
7
 
@@ -29,19 +29,21 @@ class BocaPackager(BasePackager):
29
29
  def task_types(cls) -> List[TaskType]:
30
30
  return [TaskType.BATCH, TaskType.COMMUNICATION]
31
31
 
32
- def _get_main_statement(self) -> Statement:
32
+ def _get_main_statement(self) -> Optional[Statement]:
33
33
  pkg = package.find_problem_package_or_die()
34
34
 
35
35
  if not pkg.expanded_statements:
36
- console.console.print('[error]No statements found.[/error]')
37
- raise typer.Exit(1)
36
+ return None
38
37
 
39
38
  return pkg.expanded_statements[0]
40
39
 
41
40
  def _get_main_built_statement(
42
41
  self, built_statements: List[BuiltStatement]
43
- ) -> BuiltStatement:
42
+ ) -> Optional[BuiltStatement]:
44
43
  statement = self._get_main_statement()
44
+ if statement is None:
45
+ return None
46
+
45
47
  for built_statement in built_statements:
46
48
  if built_statement.statement == statement:
47
49
  return built_statement
@@ -322,13 +324,15 @@ class BocaPackager(BasePackager):
322
324
  (tests_path / language).write_text('exit 0\n')
323
325
 
324
326
  # Problem statement
325
- description_path = into_path / 'description'
326
- description_path.mkdir(parents=True, exist_ok=True)
327
- (description_path / 'problem.info').write_text(self._get_problem_info())
328
- shutil.copyfile(
329
- self._get_main_built_statement(built_statements).path,
330
- (description_path / self._get_problem_basename()).with_suffix('.pdf'),
331
- )
327
+ main_built_statement = self._get_main_built_statement(built_statements)
328
+ if main_built_statement is not None:
329
+ description_path = into_path / 'description'
330
+ description_path.mkdir(parents=True, exist_ok=True)
331
+ (description_path / 'problem.info').write_text(self._get_problem_info())
332
+ shutil.copyfile(
333
+ self._get_main_built_statement(built_statements).path,
334
+ (description_path / self._get_problem_basename()).with_suffix('.pdf'),
335
+ )
332
336
 
333
337
  # Copy solutions
334
338
  solutions_path = into_path / 'solutions'
rbx/box/packaging/main.py CHANGED
@@ -26,7 +26,8 @@ async def polygon(
26
26
  None,
27
27
  '--language',
28
28
  '-l',
29
- help='If set, will use the given language as the main language.',
29
+ help='If set, will use the given language as the main language. '
30
+ 'Leave unset if your problem has no statements.',
30
31
  ),
31
32
  upload_as_english: bool = typer.Option(
32
33
  False,
@@ -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,11 @@ from typing import Optional
4
4
 
5
5
  from pydantic import BaseModel
6
6
 
7
+ from rbx import utils
8
+ from rbx.box import git_utils
9
+
10
+ _RBX_REMOTE_URI = 'https://github.com/rsalesc/rbx'
11
+
7
12
 
8
13
  class PresetFetchInfo(BaseModel):
9
14
  # The actual name of this preset.
@@ -18,12 +23,18 @@ class PresetFetchInfo(BaseModel):
18
23
  # Inner directory from where to pull the preset.
19
24
  inner_dir: str = ''
20
25
 
26
+ # Tool tag.
27
+ tool_tag: Optional[str] = None
28
+
21
29
  def is_remote(self) -> bool:
22
30
  return self.fetch_uri is not None
23
31
 
24
32
  def is_local_dir(self) -> bool:
25
33
  return bool(self.inner_dir) and not self.is_remote()
26
34
 
35
+ def is_tool(self) -> bool:
36
+ return self.tool_tag is not None
37
+
27
38
 
28
39
  def get_inner_dir_from_tool_preset(tool_preset: str) -> str:
29
40
  return f'rbx/resources/presets/{tool_preset}'
@@ -78,7 +89,10 @@ def get_preset_fetch_info(uri: Optional[str]) -> Optional[PresetFetchInfo]:
78
89
  match = compiled.match(s)
79
90
  if match is None:
80
91
  return None
81
- return PresetFetchInfo(name=s)
92
+ tool_tag = git_utils.latest_remote_tag(
93
+ _RBX_REMOTE_URI, before=utils.get_version()
94
+ )
95
+ return PresetFetchInfo(name=s, tool_tag=tool_tag)
82
96
 
83
97
  extractors = [
84
98
  get_github_fetch_info,
@@ -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.16.1"
4
+ min_version: "0.16.4"
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.1
3
+ Version: 0.16.4
4
4
  Summary:
5
5
  Author: Roberto Sales
6
6
  Requires-Python: >=3.9.1,<4.0.0
@@ -1,12 +1,12 @@
1
1
  rbx/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
- rbx/__version__.py,sha256=_5Udfe3jX_Ju2NuNb0dUgUDu7GADMpIFGMOs0TQl5TI,23
2
+ rbx/__version__.py,sha256=9ZYMANsHpUpRueGC3gdnVjGvLseEK8ywMOkZEQU44Gg,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
6
6
  rbx/box/builder.py,sha256=umrTdVAwvsOosBDVvDZ6kq1yWg3Z2Lxp2o1zK-V7BBk,3594
7
7
  rbx/box/cd.py,sha256=_XAzb3kV1NUaaRs8hc9SGDo10O1yh2_gr1EiAKzfUjI,2711
8
8
  rbx/box/checkers.py,sha256=mRovZyTZdySFEaYFVc3Lc-xgEsu6F9FjVPOxDwub7aY,13226
9
- rbx/box/cli.py,sha256=ybtCWnH0uYhUe95s6ZhBGoPmanMMleaTaWB78tA3kag,29773
9
+ rbx/box/cli.py,sha256=grWUlz5jpcwF2y4eqYBGurOpu4KlB8mRvvs7C92cWAs,29721
10
10
  rbx/box/code.py,sha256=TWF-o8fTh5nAtndKuO9Ti7KL-Ye6mkOoUnRzS4POrfw,25524
11
11
  rbx/box/compile.py,sha256=Kzn5mEQu4vb91W9vjyt0DS6cfPJzFLTUoowFj7uHLUo,2539
12
12
  rbx/box/contest/__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
@@ -40,10 +40,10 @@ rbx/box/packaging/boca/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3
40
40
  rbx/box/packaging/boca/boca_language_utils.py,sha256=bd5-KxN-0h6yg74Jx3NUsgwf_euBU95zC2GLw0MAFS4,1071
41
41
  rbx/box/packaging/boca/boca_outcome_utils.py,sha256=MhO7aKTJ1weCgSJBA9MF_ejK3HFBFwC5dIsiR4wA1Mw,310
42
42
  rbx/box/packaging/boca/extension.py,sha256=EQALNEOv4zVDXSKs_dk11n92y7cBZVn8TogIK683lE0,890
43
- rbx/box/packaging/boca/packager.py,sha256=31fwscJR0JZTr-55i070fOpb6lAXtEGu50xWFTC2U4o,13746
43
+ rbx/box/packaging/boca/packager.py,sha256=W-qCyIe8ZFxtZ-yYPKVVV7ayszIfpL_ZYrmow11fgvA,13903
44
44
  rbx/box/packaging/contest_main.py,sha256=G3CO4RILxGbUhyLsTdeDqPXEJ3sK2pSH9X8piqU61FQ,4486
45
45
  rbx/box/packaging/importer.py,sha256=qcKpDQyf6EvYXorofLs5abteBEWV9AezA8tcihCw5wk,909
46
- rbx/box/packaging/main.py,sha256=hP4UEKjLowRHBzttGKWx0UMAw8_8lVAAhQ9I9Y3khXA,2724
46
+ rbx/box/packaging/main.py,sha256=GRTP7_Ao-8I5F0GrLTAXSOwYbh1DYP_cLPm5jUMKN0U,2782
47
47
  rbx/box/packaging/moj/packager.py,sha256=FjghOe5CPlaF1GqK0NZgWVV_eYWpdTmz88bh04yeAyI,8708
48
48
  rbx/box/packaging/packager.py,sha256=2a2yldbVZzEQLoQnfGc8fHDHasFRdLUwAGlQuxudLBs,7324
49
49
  rbx/box/packaging/pkg/packager.py,sha256=4pt4cZa_MU9gsWNVvh5Um1KEIh_axBHlXmPf6rpFoHg,4904
@@ -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=aom7f5atJ5Vy5Ox7k0aF8FDVMIeTjF0IRCkP_nrt6Ms,3118
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=w6SUps46mrKPAoXCqxFPd8HyNqpHQDOyWIdswpsC6KA,520
204
+ rbx/resources/presets/default/preset.rbx.yml,sha256=Fq2dBpQzcNEVZcES3ThbQadyyGb3WEMkxK6Mggttg7Q,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.1.dist-info/LICENSE,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
227
- rbx_cp-0.16.1.dist-info/METADATA,sha256=CvJPfF8h2IvR_MshkNWC-5TT9m55i3NFYc-P7M5PNHE,4799
228
- rbx_cp-0.16.1.dist-info/WHEEL,sha256=b4K_helf-jlQoXBBETfwnf4B04YC67LOev0jo4fX5m8,88
229
- rbx_cp-0.16.1.dist-info/entry_points.txt,sha256=Gw2_BZ5Jon61biaH_ETbAQGXy8fR5On9gw2U4A1erpo,40
230
- rbx_cp-0.16.1.dist-info/RECORD,,
226
+ rbx_cp-0.16.4.dist-info/LICENSE,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
227
+ rbx_cp-0.16.4.dist-info/METADATA,sha256=I7CFir9kxAZ--hAobuDQLIiFqd7l-xAkxLuzf_MTrNw,4799
228
+ rbx_cp-0.16.4.dist-info/WHEEL,sha256=b4K_helf-jlQoXBBETfwnf4B04YC67LOev0jo4fX5m8,88
229
+ rbx_cp-0.16.4.dist-info/entry_points.txt,sha256=Gw2_BZ5Jon61biaH_ETbAQGXy8fR5On9gw2U4A1erpo,40
230
+ rbx_cp-0.16.4.dist-info/RECORD,,