Merge pull request #5 from dreamstarsky/dev

feat: output limit
This commit is contained in:
xkm
2025-05-02 22:57:33 +08:00
committed by GitHub
5 changed files with 19 additions and 12 deletions

View File

@@ -64,6 +64,7 @@ func compileCpp(ctx context.Context, task *model.Paste, cli *client.Client, tmpD
// Read compilation log
if logData, err := os.ReadFile(filepath.Join(tmpDir, "compile.txt")); err == nil {
logData = logData[:min(len(logData), cfg.Limit.Size)]
task.CompileLog = string(logData)
}
@@ -144,24 +145,26 @@ func runCpp(ctx context.Context, task *model.Paste, cli *client.Client, tmpDir s
usagePath := filepath.Join(tmpDir, "usage.json")
// Read program output
if outData, err := os.ReadFile(stdoutPath); err == nil {
task.Stdout = string(outData)
if stdoutData, err := os.ReadFile(stdoutPath); err == nil {
stdoutData = stdoutData[:min(len(stdoutData), cfg.Limit.Size)]
task.Stdout = string(stdoutData)
}
if outData, err := os.ReadFile(stderrPath); err == nil {
task.Stderr = string(outData)
if stderrData, err := os.ReadFile(stderrPath); err == nil {
stderrData = stderrData[:min(len(stderrData), cfg.Limit.Size)]
task.Stderr = string(stderrData)
}
if usageData, err := os.ReadFile(usagePath); err == nil {
var usage Usage
json.Unmarshal(usageData, &usage)
task.MemoryUsageKb = int(usage.MaxMemory)
task.ExecutionTimeMs = int(usage.RealTime * 1000)
task.ExecutionTimeMs = int(usage.RealTime * 1000)
}
return nil
}
func (w *Worker) RunCppTask(ctx context.Context, task *model.Paste, cli *client.Client) error {
// 临时文件夹
tmpDir, err := os.MkdirTemp("", "cpp_compile_")
tmpDir, err := os.MkdirTemp("/dev/shm/", "cpp_compile_")
if err != nil {
return fmt.Errorf("create temp dir error: %v", err)
}