Class CheatsheetReconciler
- All Implemented Interfaces:
Reconciler
GOALS.md and
WS-REFERENCE.md — in lockstep with the goal set the plugin
actually ships (IKE-Network/ike-issues#452).
Before this reconciler, those files were written only by
SubprojectInitializer, which is constructed by exactly one
mojo (ws:scaffold-init). After a plugin upgrade the
cheatsheets stayed stale until someone remembered to re-run
ws:scaffold-init — and ws:scaffold-draft did not
even report the drift. Routing cheatsheet generation through the
reconciler chain restores the "draft reports / publish heals"
contract every other workspace dimension already enjoys.
Source-of-truth lives in
SubprojectInitializer.generateGoalCheatsheet() and
SubprojectInitializer.generateWorkspaceReference() — both
already static so this reconciler can call them without any
additional plumbing. A future iteration of those generators is
planned to iterate WsGoal so the content cannot drift from
the actual goal set.
Opt-out: -DupdateCheatsheets=false. Useful when the user
has intentionally edited the cheatsheets and does not want
ws:scaffold-publish to overwrite them.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidapply(WorkspaceContext ctx) Apply reconciliation.detect(WorkspaceContext ctx) Inspect the workspace and report any drift this reconciler would correct.Human-readable name of the dimension this reconciler owns.The Maven property name (without the-Dprefix) that opts out of this reconciler's apply pass.Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface Reconciler
pinFlag
-
Constructor Details
-
CheatsheetReconciler
public CheatsheetReconciler()
-
-
Method Details
-
dimension
Description copied from interface:ReconcilerHuman-readable name of the dimension this reconciler owns. Used as the heading inscaffold-draftoutput.- Specified by:
dimensionin interfaceReconciler- Returns:
- the dimension label, e.g. "Denormalized YAML fields"
-
optOutFlag
Description copied from interface:ReconcilerThe Maven property name (without the-Dprefix) that opts out of this reconciler's apply pass. Setting the property to"false"skips this dimension on a givenscaffold-publishinvocation.- Specified by:
optOutFlagin interfaceReconciler- Returns:
- the opt-out flag name, e.g.
"updateFields"
-
detect
Description copied from interface:ReconcilerInspect the workspace and report any drift this reconciler would correct. Read-only — must not mutate the workspace.- Specified by:
detectin interfaceReconciler- Parameters:
ctx- the workspace context- Returns:
- drift report;
DriftReport.noDrift(String)if nothing to do
-
apply
Description copied from interface:ReconcilerApply reconciliation. Caller is responsible for checkingReconcilerOptions.isOptedOut(String)before invoking; implementations may also re-check defensively.- Specified by:
applyin interfaceReconciler- Parameters:
ctx- the workspace context
-