Skip to content

Commit

Permalink
fix nim-lang#13412 nim now recompiles for stdin input; SuccessX now i…
Browse files Browse the repository at this point in the history
…ndicates whether it recompiled
  • Loading branch information
timotheecour committed Mar 19, 2020
1 parent 15ba765 commit 277a1c0
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 2 deletions.
10 changes: 10 additions & 0 deletions compiler/extccomp.nim
Original file line number Diff line number Diff line change
Expand Up @@ -1064,6 +1064,9 @@ proc writeJsonBuildInstructions*(conf: ConfigRef) =
lit ",\L\"extraCmds\": "
lit $(%* conf.extraCmds)

lit ",\L\"stdinInput\": "
lit $(%* conf.projectIsStdin)

if optRun in conf.globalOptions or isDefined(conf, "nimBetterRun"):
lit ",\L\"cmdline\": "
str conf.commandLine
Expand All @@ -1090,6 +1093,13 @@ proc changeDetectedViaJsonBuildInstructions*(conf: ConfigRef; projectfile: Absol
return true
if hashNimExe() != data["nimexe"].getStr:
return true
if not data.hasKey("stdinInput"): return true
let stdinInput = data["stdinInput"].getBool
if conf.projectIsStdin or stdinInput:
# could optimize by returning false if stdin input was the same,
# but I'm not sure how to get full stding input
return true

let depfilesPairs = data["depfiles"]
doAssert depfilesPairs.kind == JArray
for p in depfilesPairs:
Expand Down
4 changes: 2 additions & 2 deletions compiler/lineinfos.nim
Original file line number Diff line number Diff line change
Expand Up @@ -101,8 +101,8 @@ const
warnCycleCreated: "$1",
warnUser: "$1",
hintSuccess: "operation successful: $#",
# keep in sync with `pegSuccess` see testament.nim
hintSuccessX: "$loc LOC; $sec sec; $mem; $build build; proj: $project; out: $output",
# keep in sync with `testament.isSuccess`
hintSuccessX: "$loc LOC; $sec sec; $mem; $build build; proj: $project; out: $output recompiled: $projectRecompiled",
hintCC: "CC: $1",
hintLineTooLong: "line too long",
hintXDeclaredButNotUsed: "'$1' is declared but not used",
Expand Down
2 changes: 2 additions & 0 deletions compiler/main.nim
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,7 @@ proc commandCompileToC(graph: ModuleGraph) =
graph.config.notes = graph.config.mainPackageNotes
return

graph.config.projectRecompiled = true
compileProject(graph)
if graph.config.errorCounter > 0:
return # issue #9933
Expand Down Expand Up @@ -386,6 +387,7 @@ proc mainCommand*(graph: ModuleGraph) =
"build", build,
"project", project,
"output", output,
"projectRecompiled", $conf.projectRecompiled,
])

when PrintRopeCacheStats:
Expand Down
2 changes: 2 additions & 0 deletions compiler/options.nim
Original file line number Diff line number Diff line change
Expand Up @@ -288,6 +288,7 @@ type
structuredErrorHook*: proc (config: ConfigRef; info: TLineInfo; msg: string;
severity: Severity) {.closure, gcsafe.}
cppCustomNamespace*: string
projectRecompiled*: bool

proc setNoteDefaults*(conf: ConfigRef, note: TNoteKind, enabled = true) =
template fun(op) =
Expand Down Expand Up @@ -405,6 +406,7 @@ proc newConfigRef*(): ConfigRef =
arguments: "",
suggestMaxResults: 10_000,
maxLoopIterationsVM: 10_000_000,
projectRecompiled: false,
)
setTargetFromSystem(result.target)
# enable colors by default on terminals
Expand Down

0 comments on commit 277a1c0

Please sign in to comment.