From a4dce1abefa95ea03b91f563e4ac502c1b810cdf Mon Sep 17 00:00:00 2001 From: Paalui Date: Mon, 8 Jul 2024 17:05:40 +0200 Subject: [PATCH] Multicells got merged if the right side was empty When updating paddle rules, if there is a multicell on the left hand it always gets merged first, even if there is nothing in the right side. I changed it to add a nothing instrution for every minicell instead of merging if the cell shouldn't change. --- the-one-true-todey-file-of-cellpond.js | 41 ++++++++++++++++++-------- 1 file changed, 29 insertions(+), 12 deletions(-) diff --git a/the-one-true-todey-file-of-cellpond.js b/the-one-true-todey-file-of-cellpond.js index 002d041..df09e37 100644 --- a/the-one-true-todey-file-of-cellpond.js +++ b/the-one-true-todey-file-of-cellpond.js @@ -8310,6 +8310,7 @@ registerRule( //======// // LEFT // //======// + let miniCount = 0 if (cellAtom.isLeftSlot) { const red = makeNumber({values: [true, true, true, true, true, true, true, true, true, true], channel: 0}) @@ -8337,6 +8338,7 @@ registerRule( content: miniClone, }) left.push(diagramCell) + miniCount++ } } else { @@ -8352,24 +8354,39 @@ registerRule( //=======// // RIGHT // //=======// + const rightContent = cellAtom.slotted === undefined? undefined : cellAtom.slotted.value // Merge!!! if (!cellAtom.isLeftSlot && cellAtom.value.isDiagram) { - const maxiLeft = makeMaximisedDiagram(cellAtom.value) - const [maxiWidth, maxiHeight] = getDiagramDimensions(maxiLeft) - const mergeCell = makeDiagramCell({ - x, - y, - instruction: DRAGON_INSTRUCTION.merge, - splitX: maxiWidth, - splitY: maxiHeight, - }) - - right.push(mergeCell) + if (rightContent === undefined) { + while(miniCount>1){ + const nothingCell = makeDiagramCell({ + x, + y, + instruction: DRAGON_INSTRUCTION.nothing, + }) + + right.push(nothingCell) + miniCount-- + } + } + else{ + const maxiLeft = makeMaximisedDiagram(cellAtom.value) + const [maxiWidth, maxiHeight] = getDiagramDimensions(maxiLeft) + + const mergeCell = makeDiagramCell({ + x, + y, + instruction: DRAGON_INSTRUCTION.merge, + splitX: maxiWidth, + splitY: maxiHeight, + }) + + right.push(mergeCell) + } } - const rightContent = cellAtom.slotted === undefined? undefined : cellAtom.slotted.value if (rightContent === undefined) { const nothingCell = makeDiagramCell({