Skip to content
Snippets Groups Projects
Commit 9dc6023f authored by Iustin Pop's avatar Iustin Pop
Browse files

Simplify the checkInstanceMove function

This patch flattens the two folds into one, by simply building the whole
list of moves instead  of the double recursion (nodes and the each
node's moves). This has no functional change, but it's much cleaner.
parent 256810de
No related branches found
No related tags found
No related merge requests found
......@@ -397,20 +397,13 @@ checkInstanceMove nodes_idx ini_tbl target =
let
opdx = Instance.pnode target
osdx = Instance.snode target
nodes = filter (\idx -> idx /= opdx && idx /= osdx)
nodes_idx
nodes = filter (\idx -> idx /= opdx && idx /= osdx) nodes_idx
aft_failover = checkSingleStep ini_tbl target ini_tbl Failover
all_moves = concatMap (\idx -> [ReplacePrimary idx,
ReplaceSecondary idx]) nodes
in
-- iterate over the possible nodes for this instance
foldl'
(\ accu_p new_idx ->
let
pmoves = [ReplacePrimary new_idx,
ReplaceSecondary new_idx]
in
foldl' -- while doing both possible moves
(checkSingleStep ini_tbl target) accu_p pmoves
) aft_failover nodes
foldl' (checkSingleStep ini_tbl target) aft_failover all_moves
-- | Compute the best next move.
checkMove :: [Int] -- ^ Allowed target node indices
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment