ffeat: diff finish
This commit is contained in:
		
							parent
							
								
									ec8dc49f21
								
							
						
					
					
						commit
						91ad7e88a7
					
				|  | @ -20,9 +20,7 @@ from joj3_config_generator.models import ( | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # FIXME: LLM generated convert function, only for demostration |  | ||||||
| def convert(repo_conf: Repo, task_conf: Task) -> ResultConfig: | def convert(repo_conf: Repo, task_conf: Task) -> ResultConfig: | ||||||
|     print(task_conf) |  | ||||||
|     # Create the base ResultConf object |     # Create the base ResultConf object | ||||||
|     # FIXME: wrap things in functions |     # FIXME: wrap things in functions | ||||||
|     result_conf = ResultConfig( |     result_conf = ResultConfig( | ||||||
|  | @ -100,7 +98,6 @@ def convert(repo_conf: Repo, task_conf: Task) -> ResultConfig: | ||||||
|         conf_stage = fix_result_detail(task_stage, conf_stage) |         conf_stage = fix_result_detail(task_stage, conf_stage) | ||||||
|         conf_stage = fix_comment(task_stage, conf_stage) |         conf_stage = fix_comment(task_stage, conf_stage) | ||||||
|         conf_stage = fix_keyword(task_stage, conf_stage) |         conf_stage = fix_keyword(task_stage, conf_stage) | ||||||
|         # TODO: fix diff parser here |  | ||||||
|         conf_stage = fix_diff(task_stage, conf_stage) |         conf_stage = fix_diff(task_stage, conf_stage) | ||||||
|         result_conf.stage.stages.append(conf_stage) |         result_conf.stage.stages.append(conf_stage) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,5 +1,6 @@ | ||||||
| import rtoml | import rtoml | ||||||
| 
 | 
 | ||||||
|  | from joj3_config_generator.models.result import CmdFile, OptionalCmd | ||||||
| from joj3_config_generator.models.result import Stage as ResultStage | from joj3_config_generator.models.result import Stage as ResultStage | ||||||
| from joj3_config_generator.models.task import Stage as TaskStage | from joj3_config_generator.models.task import Stage as TaskStage | ||||||
| 
 | 
 | ||||||
|  | @ -78,5 +79,73 @@ def fix_comment(task_stage: TaskStage, conf_stage: ResultStage) -> ResultStage: | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def fix_diff(task_stage: TaskStage, conf_stage: ResultStage) -> ResultStage: | def fix_diff(task_stage: TaskStage, conf_stage: ResultStage) -> ResultStage: | ||||||
|  |     if task_stage.parsers is not None and "diff" in task_stage.parsers: | ||||||
|  |         diff_parser = next((p for p in conf_stage.parsers if p.name == "diff"), None) | ||||||
|  |         skip = task_stage.skip or [] | ||||||
|  |         cases = task_stage.cases or {} | ||||||
|  |         finalized_cases = [case for case in cases if case not in skip] | ||||||
|  | 
 | ||||||
|  |         stage_cases = [] | ||||||
|  |         parser_cases = [] | ||||||
|  | 
 | ||||||
|  |         for case in finalized_cases: | ||||||
|  |             case_stage = task_stage.cases.get(case) if task_stage.cases else None | ||||||
|  |             if not case_stage: | ||||||
|  |                 continue | ||||||
|  | 
 | ||||||
|  |             # Ensure case_stage.limit is defined before accessing .cpu and .mem | ||||||
|  |             cpu_limit = ( | ||||||
|  |                 case_stage.limit.cpu * 1_000_000_000 | ||||||
|  |                 if case_stage.limit and case_stage.limit.cpu is not None | ||||||
|  |                 else 0 | ||||||
|  |             ) | ||||||
|  |             clock_limit = ( | ||||||
|  |                 2 * case_stage.limit.cpu * 1_000_000_000 | ||||||
|  |                 if case_stage.limit and case_stage.limit.cpu is not None | ||||||
|  |                 else 0 | ||||||
|  |             ) | ||||||
|  |             memory_limit = ( | ||||||
|  |                 case_stage.limit.mem * 1_024 * 1_024 | ||||||
|  |                 if case_stage.limit and case_stage.limit.mem is not None | ||||||
|  |                 else 0 | ||||||
|  |             ) | ||||||
|  | 
 | ||||||
|  |             stage_cases.append( | ||||||
|  |                 OptionalCmd( | ||||||
|  |                     stdin=CmdFile( | ||||||
|  |                         src=f"/home/tt/.config/joj/{conf_stage.name}/{case}.in" | ||||||
|  |                     ), | ||||||
|  |                     cpu_limit=cpu_limit, | ||||||
|  |                     clock_limit=clock_limit, | ||||||
|  |                     memory_limit=memory_limit, | ||||||
|  |                     proc_limit=50, | ||||||
|  |                 ) | ||||||
|  |             ) | ||||||
|  | 
 | ||||||
|  |             # Ensure case_stage.diff and case_stage.diff.output are defined | ||||||
|  |             diff_output = ( | ||||||
|  |                 case_stage.diff.output | ||||||
|  |                 if case_stage.diff and case_stage.diff.output | ||||||
|  |                 else None | ||||||
|  |             ) | ||||||
|  |             if diff_output: | ||||||
|  |                 parser_cases.append( | ||||||
|  |                     { | ||||||
|  |                         "outputs": [ | ||||||
|  |                             { | ||||||
|  |                                 "score": diff_output.score, | ||||||
|  |                                 "fileName": "stdout", | ||||||
|  |                                 "answerPath": f"/home/tt/.config/joj/{conf_stage.name}/{case}.out", | ||||||
|  |                                 "forceQuitOnDiff": diff_output.forcequit, | ||||||
|  |                                 "alwaysHide": diff_output.hide, | ||||||
|  |                                 "compareSpace": not diff_output.ignorespaces, | ||||||
|  |                             } | ||||||
|  |                         ] | ||||||
|  |                     } | ||||||
|  |                 ) | ||||||
|  | 
 | ||||||
|  |         if diff_parser and task_stage.diff is not None: | ||||||
|  |             diff_parser.with_.update({"name": "diff", "cases": parser_cases}) | ||||||
|  |             conf_stage.executor.with_.cases = stage_cases | ||||||
| 
 | 
 | ||||||
|     return conf_stage |     return conf_stage | ||||||
|  |  | ||||||
|  | @ -50,7 +50,7 @@ class Stage(BaseModel): | ||||||
|     files: Optional[Files] = None |     files: Optional[Files] = None | ||||||
|     score: Optional[int] = 0 |     score: Optional[int] = 0 | ||||||
|     parsers: Optional[list[str]] = []  # list of parsers |     parsers: Optional[list[str]] = []  # list of parsers | ||||||
|     limit: Optional[Limit] = None |     limit: Optional[Limit] = Limit() | ||||||
|     dummy: Optional[ParserDummy] = ParserDummy() |     dummy: Optional[ParserDummy] = ParserDummy() | ||||||
|     result_status: Optional[ParserDummy] = Field(ParserDummy(), alias="result-status") |     result_status: Optional[ParserDummy] = Field(ParserDummy(), alias="result-status") | ||||||
|     keyword: Optional[ParserKeyword] = ParserKeyword() |     keyword: Optional[ParserKeyword] = ParserKeyword() | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user