Strongly simplified example:
convert logo: ( -clone 0 -bordercolor green -border 10x10 ) +append test.png
data:image/s3,"s3://crabby-images/168c9/168c9c2935b339dc92146dc861d396a9651b3f54" alt="Image"
As far as i understand, the operation
( +clone +clone -compose subtract -composite +delete )
may be pointless, but should not change the result.
The last image in the stack is cloned twice, both copies are combined in one composite, and this composite is deleted, resulting in no new image on the stack
However:
convert logo: ( +clone +clone -compose subtract -composite +delete ) ( -clone 0 -bordercolor green -border 10x10 ) +append test.png
data:image/s3,"s3://crabby-images/b4c3d/b4c3d750e130da97c118f3d7496937be701ca2d5" alt="Image"
The exact result depends on the last -compose operation:
convert logo: ( +clone +clone -compose multiply -composite +delete ) ( -clone 0 -bordercolor green -border 10x10 ) +append test.png
data:image/s3,"s3://crabby-images/00988/0098889e720e17d42142610fa60fa4c8d9b68359" alt="Image"
Update: -respect-parenthesis prevents this weird behaviour, so I am not sure if it is a bug after all.