Skip to content

Commit

Permalink
Don't evaluate @reached_if unless the goal is required #104
Browse files Browse the repository at this point in the history
  • Loading branch information
xonixx committed Feb 8, 2022
1 parent 1b85844 commit a285436
Showing 1 changed file with 37 additions and 25 deletions.
62 changes: 37 additions & 25 deletions makesure_candidate
Original file line number Diff line number Diff line change
Expand Up @@ -296,8 +296,13 @@ function checkBeforeRun( i,j,dep,depCnt,goalName,visited) {
}
}
}
function getPreludeCode( a) {
addLine(a, MyDirScript)
addLine(a, DefinesCode)
return a[0]
}
function doWork(\
i,j,goalName,gnLen,gnMaxLen,depCnt,dep,reachedIf,reachedGoals,emptyGoals,definesLine,
i,j,goalName,gnLen,gnMaxLen,depCnt,dep,reachedGoals,emptyGoals,preludeCode,
body,goalBody,goalBodies,resolvedGoals,exitCode, t0,t1,t2, goalTimed, list) {
started("end")
checkBeforeRun()
Expand Down Expand Up @@ -326,30 +331,27 @@ body,goalBody,goalBodies,resolvedGoals,exitCode, t0,t1,t2, goalTimed, list) {
} else {
if (timingOn())
t0 = currentTimeMillis()
addLine(definesLine, MyDirScript)
addLine(definesLine, DefinesCode)
for (i = 0; i in GoalNames; i++) {
goalName = GoalNames[i]
body = trim(Code[goalName])
reachedIf = ReachedIf[goalName]
reachedGoals[goalName] = reachedIf ? checkConditionReached(goalName, definesLine[0], reachedIf) : 0
emptyGoals[goalName] = length(body) == 0
depCnt = DependenciesCnt[goalName]
depCnt = DependenciesCnt[goalName = GoalNames[i]]
for (j=0; j < depCnt; j++) {
dep = Dependencies[goalName, j]
if (!reachedGoals[goalName]) {
topologicalSortAddConnection(goalName, dep)
} else {
}
topologicalSortAddConnection(goalName, dep)
}
}
topologicalSort(0,GoalNames)
topologicalSort(1,ArgGoals,resolvedGoals,reachedGoals)
preludeCode = getPreludeCode()
for (i = 0; i in GoalNames; i++) {
goalName = GoalNames[i]
body = trim(Code[goalName])
emptyGoals[goalName] = length(body) == 0
goalBody[0] = ""
addLine(goalBody, definesLine[0])
addLine(goalBody, preludeCode)
if (goalName in GoalToLib)
addLine(goalBody, Lib[GoalToLib[goalName]])
addLine(goalBody, body)
goalBodies[goalName] = goalBody[0]
}
resolveGoalsToRun(resolvedGoals)
if ("-d" in Args || "--resolved" in Args) {
printf "Resolved goals to reach for"
for (i = 0; i in ArgGoals; i++)
Expand Down Expand Up @@ -382,15 +384,16 @@ body,goalBody,goalBodies,resolvedGoals,exitCode, t0,t1,t2, goalTimed, list) {
}
}
}
function resolveGoalsToRun(result, i, goalName, loop) {
if (arrLen(ArgGoals) == 0)
arrPush(ArgGoals, "default")
for (i = 0; i in ArgGoals; i++) {
goalName = ArgGoals[i]
function topologicalSort(includeReachedIf,requestedGoals,result,reachedGoals, i,goalName,loop) {
topologicalSortReset()
if (arrLen(requestedGoals) == 0)
arrPush(requestedGoals, "default")
for (i = 0; i in requestedGoals; i++) {
goalName = requestedGoals[i]
if (!(goalName in GoalsByName)) {
die("Goal not found: " goalName)
}
topologicalSortPerform(goalName, result, loop)
topologicalSortPerform(includeReachedIf,reachedGoals, goalName, result, loop)
}
if (loop[0] == 1) {
die("There is a loop in goal dependencies via " loop[1] " -> " loop[2])
Expand All @@ -412,8 +415,8 @@ function die(msg, out) {
close(out)
realExit(1)
}
function checkConditionReached(goalName, definesLine, conditionStr, script) {
script = definesLine
function checkConditionReached(goalName, conditionStr, script) {
script = getPreludeCode()
if (goalName in GoalToLib)
script = script "\n" Lib[GoalToLib[goalName]]
script = script "\n" conditionStr
Expand Down Expand Up @@ -455,16 +458,25 @@ function addCodeLine(line, goalName, name, i) {
function addCodeLineToGoal(name, line) {
Code[name] = addL(Code[name], line)
}
function topologicalSortReset() {
split("",Visited)
}
function topologicalSortAddConnection(from, to) {
Slist[from, ++Scnt[from]] = to
}
function topologicalSortPerform(node, result, loop, i, s) {
function topologicalSortPerform(includeReachedIf,reachedGoals, node, result, loop, i, s) {
if (Visited[node] == 2)
return
if (includeReachedIf && node in ReachedIf && checkConditionReached(node, ReachedIf[node])){
Visited[node] = 2
arrPush(result, node)
reachedGoals[node] = 1
return
}
Visited[node] = 1
for (i = 1; i <= Scnt[node]; i++) {
if (Visited[s = Slist[node, i]] == 0)
topologicalSortPerform(s, result, loop)
topologicalSortPerform(includeReachedIf,reachedGoals, s, result, loop)
else if (Visited[s] == 1) {
loop[0] = 1
loop[1] = s
Expand Down

0 comments on commit a285436

Please sign in to comment.