rbx.cp 0.5.31__py3-none-any.whl → 0.5.33__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/box/code.py CHANGED
@@ -169,7 +169,7 @@ def _check_stack_limit():
169
169
  except Exception:
170
170
  pass
171
171
 
172
- if soft != hard or (soft != resource.RLIM_INFINITY and soft < TARGET):
172
+ if soft != hard and soft != resource.RLIM_INFINITY and soft < TARGET:
173
173
  soft_fmt = _format_stack_limit(soft)
174
174
  hard_fmt = _format_stack_limit(hard)
175
175
  console.console.print(
@@ -186,15 +186,14 @@ def _check_stack_limit():
186
186
  if hard != resource.RLIM_INFINITY:
187
187
  target_text = min(hard, TARGET)
188
188
  console.console.print(
189
- """
189
+ f"""
190
190
  ```
191
- export RBX_BIN_PATH=`which rbx`
192
- function rbx() {
193
- ulimit -s %s && $RBX_BIN_PATH $@
194
- }
191
+ function rbx() {{
192
+ local rbx_bin=`bash -c "type -P rbx"`
193
+ ulimit -s {target_text} && $rbx_bin $@
194
+ }}
195
195
  ```
196
- """
197
- % target_text
196
+ """
198
197
  )
199
198
  console.console.print()
200
199
  console.console.print(
rbx/box/main.py CHANGED
@@ -760,8 +760,3 @@ def clear():
760
760
  console.console.print('Cleaning cache and build directories...')
761
761
  shutil.rmtree('.box', ignore_errors=True)
762
762
  shutil.rmtree('build', ignore_errors=True)
763
-
764
-
765
- @app.callback()
766
- def callback():
767
- pass
rbx/box/solutions.py CHANGED
@@ -911,38 +911,81 @@ class TimingSummary:
911
911
  if self.fastest_slow is None or time < self.fastest_slow:
912
912
  self.fastest_slow = time
913
913
 
914
+ def print(self, console: rich.console.Console, tl: Optional[int] = None):
915
+ if self.slowest_good is not None:
916
+ console.print(
917
+ f'Slowest [success]OK[/success] solution: {self.slowest_good} ms'
918
+ )
919
+ if self.fastest_slow is not None:
920
+ fastest_slow = self.fastest_slow
921
+ if tl is not None and self.fastest_slow > tl:
922
+ fastest_slow = f'>{tl}'
923
+ console.print(f'Fastest [error]slow[/error] solution: {fastest_slow} ms')
924
+
914
925
 
915
926
  async def _print_timing(
916
927
  console: rich.console.Console,
917
928
  skeleton: SolutionReportSkeleton,
918
929
  evaluations: StructuredEvaluation,
930
+ verification: VerificationLevel,
919
931
  ):
932
+ pkg = package.find_problem_package_or_die()
920
933
  summary = TimingSummary()
921
- sumamry_per_language = collections.defaultdict(TimingSummary)
934
+ summary_per_language = collections.defaultdict(TimingSummary)
935
+ tls_per_language = {}
936
+ all_tls = set()
922
937
  for solution in skeleton.solutions:
923
- all_evals = []
938
+ all_evals: List[Evaluation] = []
924
939
  for evals in evaluations[str(solution.path)].values():
925
940
  all_evals.extend([await eval() for eval in evals if eval is not None])
941
+ if not all_evals:
942
+ continue
943
+
944
+ # Get solution TL.
926
945
  solution_time = _get_evals_time_in_ms(all_evals)
946
+ solution_tls = [
947
+ eval.log.metadata.timeLimit
948
+ for eval in all_evals
949
+ if eval.log.metadata is not None and eval.log.metadata.timeLimit is not None
950
+ ]
951
+ solution_tl = 0
952
+ if solution_tls:
953
+ solution_tl = min(solution_tls)
954
+ else:
955
+ solution_tl = pkg.timelimit_for_language(solution.language)
956
+ if verification.value >= VerificationLevel.FULL.value:
957
+ solution_tl = solution_tl * 2
958
+ all_tls.add(solution_tl)
959
+ for eval in all_evals:
960
+ if eval.log.get_run_language() is not None:
961
+ tls_per_language[eval.log.get_run_language()] = solution_tl
962
+
963
+ # Get solution timings.
927
964
  if solution.outcome.match(Outcome.ACCEPTED):
928
965
  summary.add_good(solution_time)
929
- sumamry_per_language[solution.language].add_good(solution_time)
966
+ summary_per_language[solution.language].add_good(solution_time)
930
967
  if solution.outcome.is_slow():
931
968
  summary.add_slow(solution_time)
932
- sumamry_per_language[solution.language].add_slow(solution_time)
969
+ summary_per_language[solution.language].add_slow(solution_time)
933
970
 
934
971
  if summary.slowest_good is None and summary.fastest_slow is None:
935
972
  return
936
973
 
974
+ all_languages = set(summary_per_language)
975
+ all_tl = min(all_tls) if all_tls else None
937
976
  console.print('[status]Timing summary:[/status]')
938
- if summary.slowest_good is not None:
939
- console.print(
940
- f'Slowest [success]OK[/success] solution: {summary.slowest_good} ms'
941
- )
942
- if summary.fastest_slow is not None:
943
- console.print(
944
- f'Fastest [error]slow[/error] solution: {summary.fastest_slow} ms'
977
+
978
+ if len(all_languages) <= 1 or len(all_tls) <= 1:
979
+ summary.print(console, tl=all_tl)
980
+ return
981
+
982
+ # Otherwise, print per language.
983
+ for lang in sorted(all_languages):
984
+ console.print(f'[status]{lang}[/status]')
985
+ summary_per_language[lang].print(
986
+ console, tl=tls_per_language.get(lang) or all_tl
945
987
  )
988
+ console.print()
946
989
 
947
990
 
948
991
  def _length_markup(markup: str) -> int:
@@ -1109,7 +1152,9 @@ async def _print_detailed_run_report(
1109
1152
  console.print()
1110
1153
 
1111
1154
  if timing:
1112
- await _print_timing(console, result.skeleton, structured_evaluations)
1155
+ await _print_timing(
1156
+ console, result.skeleton, structured_evaluations, verification=verification
1157
+ )
1113
1158
  return ok
1114
1159
 
1115
1160
 
@@ -1193,7 +1238,9 @@ async def print_run_report(
1193
1238
  ok = ok and cur_ok
1194
1239
  console.print()
1195
1240
 
1196
- await _print_timing(console, result.skeleton, structured_evaluations)
1241
+ await _print_timing(
1242
+ console, result.skeleton, structured_evaluations, verification=verification
1243
+ )
1197
1244
 
1198
1245
  return ok
1199
1246
 
rbx/box/validators.py CHANGED
@@ -273,6 +273,11 @@ def print_validation_report(infos: List[TestcaseValidationInfo]):
273
273
  if _is_hit_bound_good(v) and k != 'samples'
274
274
  }
275
275
 
276
+ all_groups = set(info.group for info in infos)
277
+ if len(all_groups) == 1 and 'samples' in all_groups:
278
+ # If there's only the samples group, do not check for hit bounds.
279
+ hit_bounds_per_group = {}
280
+
276
281
  if not hit_bounds_per_group:
277
282
  console.console.print('[info]No validation issues found.[/info]')
278
283
  return
@@ -1,6 +1,6 @@
1
- Metadata-Version: 2.1
1
+ Metadata-Version: 2.3
2
2
  Name: rbx.cp
3
- Version: 0.5.31
3
+ Version: 0.5.33
4
4
  Summary:
5
5
  Author: Roberto Sales
6
6
  Requires-Python: >=3.9,<4.0
@@ -9,6 +9,7 @@ Classifier: Programming Language :: Python :: 3.9
9
9
  Classifier: Programming Language :: Python :: 3.10
10
10
  Classifier: Programming Language :: Python :: 3.11
11
11
  Classifier: Programming Language :: Python :: 3.12
12
+ Classifier: Programming Language :: Python :: 3.13
12
13
  Requires-Dist: chardet (>=5.2.0,<6.0.0)
13
14
  Requires-Dist: fastapi (>=0.115.8,<0.116.0)
14
15
  Requires-Dist: filelock (>=3.14.0,<4.0.0)
@@ -5,7 +5,7 @@ rbx/box/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
5
  rbx/box/builder.py,sha256=eynVPyRdpYtSNmr8MP7-8jspNH74lj-DclwtiIcJrvM,3280
6
6
  rbx/box/cd.py,sha256=9a_SOnzoJBXxxffp4Wbf3UKXIwKuN3Hvj7K6SocALwE,1194
7
7
  rbx/box/checkers.py,sha256=VpgDzevOK7hrffG2zJGxquNiu-a9Fl3wquLn7xadcK0,6285
8
- rbx/box/code.py,sha256=_tJExjZxByi_pnxOJkmyr2008lLH8-6rvGE0m85j3L0,13420
8
+ rbx/box/code.py,sha256=lty0K5FGCZVUiqNFdqxTG1mZHmm1aP6PHzN9gXTFRjo,13404
9
9
  rbx/box/compile.py,sha256=OJLthDQ921w9vyoE6Gk1Df54i5RwtRJ2YG-8XEfefcs,2489
10
10
  rbx/box/conftest.py,sha256=sEmciXSeDC-wmrZ1JSxbsUenKNP_VWW32mrCun2pY3I,1070
11
11
  rbx/box/contest/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -23,7 +23,7 @@ rbx/box/extensions.py,sha256=Von8kIeXvNFTkGlMRMTvL2HIHPwlkuiMswr-ydbGV1w,519
23
23
  rbx/box/formatting.py,sha256=3phFRHzqVXj4Ok1yDhCq6Clbw6KlqwJNpMhs--oTWFI,405
24
24
  rbx/box/generators.py,sha256=XJsWXNjtQXUDX2huAUsl-q7OWFyIPc42CyS557jLYxk,20594
25
25
  rbx/box/generators_test.py,sha256=BqWf-A0u0ifZJZlvrMuOHOHQPfMox2Jy6540GmnTnkc,1753
26
- rbx/box/main.py,sha256=qSHoXBsG7nW9cXmnOm9afnGavIOZqvknu691YFACTxQ,23765
26
+ rbx/box/main.py,sha256=9G21yVefrVLwM9NERozTe-w2xeEZROD2tDL82Gpc-AE,23722
27
27
  rbx/box/package.py,sha256=SSckCXo7Zh412_qjYhSNwConjhR0Sk8911qGJU34Hac,11851
28
28
  rbx/box/packaging/boca/extension.py,sha256=hQhcbocNfW2ESv5RalS1wf6uvOoOfOnR_gHvbXUbSzY,852
29
29
  rbx/box/packaging/boca/packager.py,sha256=FOhSRg5K5Y4qNB0WyTR3DKgrpObf9I0JbyGpJHOtxpo,10673
@@ -41,7 +41,7 @@ rbx/box/retries.py,sha256=z7cIh1QmLVUsTr3Attt_28dbwNg6KWTwpulcWCFwMPo,4667
41
41
  rbx/box/sanitizers/warning_stack.py,sha256=RI97_GJgdjTKIXY_r0EKp5h0qQQSDSdNDh5K7zINrqs,2861
42
42
  rbx/box/schema.py,sha256=iu6S2A2d_7SAQNFd34galQHxFAI2CQrIgXnSBlKgBCk,14307
43
43
  rbx/box/setter_config.py,sha256=ZM7_G2tbaixaFr0NvRaXkowwfxSWF2Gb4XHBsr2Prpc,4279
44
- rbx/box/solutions.py,sha256=A-VVxjTrQ2OuBk_2WynoK0kS5BtsEjkRWzBcx92N6Mk,42266
44
+ rbx/box/solutions.py,sha256=oSlKeublgwSeaz_qt79d9OQqKuK6MINxa4kkiavutZo,43974
45
45
  rbx/box/solutions_test.py,sha256=Cx7Goon_0sz_PaUcD8qa8gmjgzOVub6VHss3CB0GaA0,1524
46
46
  rbx/box/state.py,sha256=yTpjfASpnSXkRB3JiDNvCg5b9JNnNxuYT4uMcbdr59s,109
47
47
  rbx/box/statements/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -61,7 +61,7 @@ rbx/box/ui/captured_log.py,sha256=ptICDPViVnz-_2NfrcB0SSBXNW5L74zI-vAZNN7kSok,11
61
61
  rbx/box/ui/css/app.tcss,sha256=apd5PkPEvl5jK3kE2qrxPyVED1VnvSsj08QQwzUPwEA,786
62
62
  rbx/box/ui/main.py,sha256=b0rHcBF42W4AOCv7WhtiGf_rUnY0yxpqO5oj3wfR4R4,984
63
63
  rbx/box/ui/run.py,sha256=wMEXrEFdQvMHz2hRKAFIithTnTtaL0kNQZu0jKmb8jI,7060
64
- rbx/box/validators.py,sha256=SNOzOk2lJdxnU3e6TFPaqaBwz-qisYLR44vbiH1F4Hc,8806
64
+ rbx/box/validators.py,sha256=f6595hPsNSCxp8Q9IiGwWTrSNOBiJlQw63NVo0v1cRQ,9023
65
65
  rbx/box/validators_test.py,sha256=hriR6rD32Ouu64eKYYTPLZVvqMxXj7Q2h1l_JAefL7U,344
66
66
  rbx/checker.py,sha256=pj1jO3my48ru-qugbER5onccANCjoR0-PaFe3H3VGEY,4118
67
67
  rbx/clone.py,sha256=wpHyED0_7ST7LD3vj7HjXhzqEzlwh6dRQvKQVDYhGeU,6744
@@ -165,8 +165,8 @@ rbx/testdata/caching/executable.py,sha256=WKRHNf_fprFJd1Fq1ubmQtR3mZzTYVNwKPLWuZ
165
165
  rbx/testdata/compatible,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
166
166
  rbx/testing_utils.py,sha256=ZZLKMUHlZ4HwsuNY50jqSBJ9HhpnFdba7opjDsvXE1U,2084
167
167
  rbx/utils.py,sha256=q1ZmfVCD6rdKVVZFBqwVetldSgGAbIh_KLHseBTUSiQ,4511
168
- rbx_cp-0.5.31.dist-info/LICENSE,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
169
- rbx_cp-0.5.31.dist-info/METADATA,sha256=RQ-vCGczePo4_Nqvi4XUkF3iRKN7kFpyhOGOOoj-LB0,3212
170
- rbx_cp-0.5.31.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
171
- rbx_cp-0.5.31.dist-info/entry_points.txt,sha256=qBTLBOeifT1F00LWaEewRRE_jQPgvH7BUdJfZ-dYsFU,57
172
- rbx_cp-0.5.31.dist-info/RECORD,,
168
+ rbx_cp-0.5.33.dist-info/LICENSE,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
169
+ rbx_cp-0.5.33.dist-info/METADATA,sha256=KVWJXsloAmLAEI9NyNRHAGrXLwG2JWtz1Wf_zPSDMN8,3263
170
+ rbx_cp-0.5.33.dist-info/WHEEL,sha256=XbeZDeTWKc1w7CSIyre5aMDU_-PohRwTQceYnisIYYY,88
171
+ rbx_cp-0.5.33.dist-info/entry_points.txt,sha256=qBTLBOeifT1F00LWaEewRRE_jQPgvH7BUdJfZ-dYsFU,57
172
+ rbx_cp-0.5.33.dist-info/RECORD,,
@@ -1,4 +1,4 @@
1
1
  Wheel-Version: 1.0
2
- Generator: poetry-core 1.9.0
2
+ Generator: poetry-core 2.1.1
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any