]> Lady’s Gitweb - Shushe/commit
Fix/improve recursive dependency detection
authorLady <redacted>
Wed, 3 Jul 2024 01:42:56 +0000 (21:42 -0400)
committerLady <redacted>
Wed, 3 Jul 2024 01:52:32 +0000 (21:52 -0400)
commit550d6ccc74b1aae2f45947df47245fb57b111c2b
tree585a14ec67280a1007247b4fcd28210eb3625bb8
parentbc1b63801488992c309f0b8bd1d5a772b7e5645e
Fix/improve recursive dependency detection

The old method of detecting recursive dependencies was overcomplicated
and only worked in the simple case of A → B → C → A and not
A → B → C → B. This new method works as follows:

- Given a dependency path…

  - Get all of the links in the last document in the path.

  - If there are no links, return the path.

  - If there are links which point to a file in the path, it is a
    recursive dependency. Return the path ending at the point of
    recursion.

  - Otherwise (there are nonrecursive links), process each path which
    results from appending each link to the end of the current path and
    return all of them.

The algorithm ends with a set of paths to leaf nodes in the dependency
tree, and each nonroot node in this tree (leaf or branch) is a
dependency. This is what the behaviour should have been from the
beginning. (The old method attempted to process the tree in layers,
rather than as a set of paths.)
lib/expandmetadata.xslt
This page took 0.084547 seconds and 4 git commands to generate.