I discovered this bug using a much different method than the one shown here, but the result is the same:
- Create a custom block.
- Right click on the definition hat and select "selector..."
- Click the little arrow in the text box and select the primitive of your choice. My example uses "move _ steps".
- Make the definition of your custom block whatever you want. My example uses "turn 15 degrees".
- Take a script picture.
- Import the picture. As you can see, it has replaced the primitive you chose in step 3.
Now, this may not seem like a big problem, but for two things. Firstly, you can accidentally end up having this happen by duplicating a primitive block's definition, because duplicating duplicates the selector. Secondly, primitives aren't supposed to be able to be modified by script pics:
Original post from before I understood the bug
Disclaimer: This bug will not affect 99.99% of users, and requires all four of these steps to occur:
1) Edit a primitive block.
2) Duplicate it in the context menu.
3) Create a script picture of either block.
4) Actually want to be able to reimport the picture into Snap!
How to replicate:
Modify any primitive. I used the "go to" block. Select "duplicate block definition", and modify the duplicated block to help with identification later on. Also modify the primitive to have your own special definition:
Here are the two blocks:
I hope you can see why we need the second block - it is the only way to implement the first (unless you use another go to block, like the go to x,y block, but imagine for now that for this project we need to modify those too).
Try importing the script pic above! The custom block gets replaced with "Undefined!" and the primitive inherits all the modifications of the custom block. Saving the project does not cause any difficulties, however. Thanks!
PS: Why is this in Advanced Topics?
Solved by ego-lay_atman-bay in post #3
The only difference is that they're duplicating the original block, rather than manually creating the custom block.