Skip to content

Commit

Permalink
cleanup array ext
Browse files Browse the repository at this point in the history
  • Loading branch information
jwklong authored Jan 14, 2025
1 parent ab89912 commit c90fe23
Showing 1 changed file with 27 additions and 35 deletions.
62 changes: 27 additions & 35 deletions src/extensions/jwArray/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -140,34 +140,14 @@ class Extension {
return w
}))
);

const regenReporters = ["jwArray_forEachI", "jwArray_forEachV"];
if (window.ScratchBlocks !== undefined) {
ScratchBlocks.BlockSvg.INPUT_SHAPE_SQUARE =
ScratchBlocks.BlockSvg.TOP_LEFT_CORNER_START +
ScratchBlocks.BlockSvg.TOP_LEFT_CORNER +
' h ' + (4 * ScratchBlocks.BlockSvg.GRID_UNIT - 2 * ScratchBlocks.BlockSvg.CORNER_RADIUS) +
ScratchBlocks.BlockSvg.TOP_RIGHT_CORNER +
' v ' + (8 * ScratchBlocks.BlockSvg.GRID_UNIT - 2 * ScratchBlocks.BlockSvg.CORNER_RADIUS) +
ScratchBlocks.BlockSvg.BOTTOM_RIGHT_CORNER +
' h ' + (-4 * ScratchBlocks.BlockSvg.GRID_UNIT + 2 * ScratchBlocks.BlockSvg.CORNER_RADIUS) +
ScratchBlocks.BlockSvg.BOTTOM_LEFT_CORNER +
' z';

const ogCheck = ScratchBlocks.scratchBlocksUtils.isShadowArgumentReporter;
ScratchBlocks.scratchBlocksUtils.isShadowArgumentReporter = function (block) {
const result = ogCheck(block);
if (result) return true;
return block.isShadow() && regenReporters.includes(block.type);
};
}
}

getInfo() {
return {
id: "jwArray",
name: "Arrays",
color1: "#ff513d",
menuIconURI: "",
blocks: [
{
opcode: 'blank',
Expand Down Expand Up @@ -261,40 +241,45 @@ class Extension {
},
...jwArray.Block
},
{
opcode: 'concat',
text: 'merge [ONE] with [TWO]',
arguments: {
ONE: jwArray.Argument,
TWO: jwArray.Argument
},
...jwArray.Block
},
"---",
{
opcode: 'forEachI',
text: 'index',
blockType: BlockType.REPORTER,
hideFromPalette: true,
allowDropAnywhere: true
allowDropAnywhere: true,
canDragDuplicate: true
},
{
opcode: 'forEachV',
text: 'value',
blockType: BlockType.REPORTER,
hideFromPalette: true,
allowDropAnywhere: true
allowDropAnywhere: true,
canDragDuplicate: true
},
{
opcode: 'forEach',
text: 'for [I] [V] of [ARRAY]',
blockType: BlockType.LOOP,
hideFromPalette: true,
arguments: {
ARRAY: jwArray.Argument,
I: {},
V: {}
I: {
fillIn: 'jwArray_forEachI'
},
V: {
fillIn: 'jwArray_forEachV'
}
}
},
{
blockType: BlockType.XML,
xml: `
<block type="jwArray_forEach">
<value name="I"><shadow type="jwArray_forEachI"></shadow></value>
<value name="V"><shadow type="jwArray_forEachV"></shadow></value>
</block>
`
}
],
menus: {
Expand Down Expand Up @@ -362,6 +347,13 @@ class Extension {
return ARRAY
}

concat({ONE, TWO}) {
ONE = jwArray.Type.toArray(ONE)
TWO = jwArray.Type.toArray(TWO)

return new jwArray.Type(ONE.array.concat(TWO.array))
}

forEachI({}, util) {
let arr = util.thread.stackFrames[0].jwArray
return arr ? Cast.toNumber(arr[0]) + 1 : 0
Expand Down

0 comments on commit c90fe23

Please sign in to comment.