[fixes #666] Find SymmetricComponent.PreviousSymmetricComponent now handles PodSets correctly.

This commit is contained in:
Daniel_M_Williams 2020-05-16 11:23:27 -04:00
parent e400c8aeac
commit ce6a6fa2e3

View File

@ -570,21 +570,21 @@ public abstract class SymmetricComponent extends BodyComponent implements Radial
return null; return null;
} }
// might be: (a) Rocket -- for centerline stages final ComponentAssembly assembly = this.getAssembly();
// (b) BodyTube -- for Parallel Stages // might be: (a) Rocket -- for Centerline/Axial stages
final AxialStage stage = this.getStage(); // (b) BodyTube -- for Parallel Stages & PodSets
final RocketComponent stageParent = stage.getParent(); final RocketComponent assemblyParent = assembly.getParent();
// note: this is not guaranteed to _contain_ a stage... but that we're _searching_ for one. // note: this is not guaranteed to _contain_ a stage... but that we're _searching_ for one.
int stageIndex = stageParent.getChildPosition(stage); int assemblyIndex = assemblyParent.getChildPosition(assembly); // position of stage w/in parent
int symmetricIndex = this.parent.getChildPosition(this)-1; int symmetricIndex = this.parent.getChildPosition(this)-1; // guess at index of previous stage
while( 0 <= stageIndex ) { while( 0 <= assemblyIndex ) {
final RocketComponent prevStage = stageParent.getChild(stageIndex); final RocketComponent searchAssembly = assemblyParent.getChild(assemblyIndex);
if(prevStage instanceof AxialStage){ if(searchAssembly instanceof ComponentAssembly){
while (0 <= symmetricIndex) { while (0 <= symmetricIndex) {
final RocketComponent previousSymmetric = prevStage.getChild(symmetricIndex); final RocketComponent previousSymmetric = searchAssembly.getChild(symmetricIndex);
if (previousSymmetric instanceof SymmetricComponent) { if (previousSymmetric instanceof SymmetricComponent) {
return (SymmetricComponent) previousSymmetric; return (SymmetricComponent) previousSymmetric;
@ -592,8 +592,8 @@ public abstract class SymmetricComponent extends BodyComponent implements Radial
--symmetricIndex; --symmetricIndex;
} }
} }
--stageIndex; --assemblyIndex;
symmetricIndex = prevStage.getChildCount() - 1; symmetricIndex = searchAssembly.getChildCount() - 1;
} }
return null; return null;
} }