aseprite/tests/cli/sheet.sh
David Capello 86a50e2e9a [lua] Add native API to decode/encode JSON text (fix #3233)
New json.decode(jsonText) and json.encode(luaTable) functions.

In this way we don't depend on third-party libraries to decode/encode
JSON text which is a quite common task (in tests and export scripts).
2023-07-17 09:25:13 -03:00

419 lines
15 KiB
Bash

#! /bin/bash
# Copyright (C) 2019-2022 Igara Studio S.A.
# $1 = first sprite sheet json file
# $2 = second sprite sheet json file
function compare_sheet_data() {
cat $1 | grep -v "\"image\"" > $1-tmp
cat $2 | grep -v "\"image\"" > $2-tmp
diff -u $1-tmp $2-tmp
}
# --sheet and STDOUT
d=$t/sheet
mkdir $d # we need to create the directory because the >STDOUT redirection
if ! $ASEPRITE -b sprites/1empty3.aseprite --sheet "$d/sheet.png" > "$d/stdout.json" ; then
exit 1
fi
cat >$d/compare.lua <<EOF
local data = json.decode(io.open('$d/stdout.json'):read('a'))
local frames = { data.frames['1empty3 0.aseprite'],
data.frames['1empty3 1.aseprite'],
data.frames['1empty3 2.aseprite'] }
assert(frames[1].frame.x == 0)
assert(frames[2].frame.x == 32)
assert(frames[3].frame.x == 64)
for i,v in ipairs(frames) do
assert(v.frame.y == 0)
assert(v.frame.w == 32)
assert(v.frame.h == 32)
end
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1
# --sheet --data
d0=$d
d=$t/sheet-data
$ASEPRITE -b sprites/1empty3.aseprite --sheet "$d/sheet.png" --data "$d/sheet.json" || exit 1
compare_sheet_data $d0/stdout.json $d/sheet.json || exit 1
cat >$d/compare.lua <<EOF
local orig = app.open("sprites/1empty3.aseprite")
local sheet = app.open("$d/sheet.png")
local expected = Image(orig.width*3, orig.height, orig.colorMode)
expected:clear()
for f = 1,3 do
expected:drawSprite(orig, f, (f-1)*orig.width, 0)
end
assert(expected:isEqual(sheet.cels[1].image))
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1
# vertical sprite sheet
d=$t/vertical-sheet
mkdir $d
# TODO this should be possible in a future
# $ASEPRITE -b sprites/1empty3.aseprite -sheet-type vertical --sheet "$d/sheet.png" --data "$d/sheet.json" || exit 1
cat >$d/create.lua <<EOF
local sprite = app.open("sprites/1empty3.aseprite")
app.command.ExportSpriteSheet {
type="vertical",
textureFilename="$d/sheet1.png",
dataFilename="$d/sheet1.json"
}
app.command.ExportSpriteSheet {
type=SpriteSheetType.VERTICAL,
textureFilename="$d/sheet2.png",
dataFilename="$d/sheet2.json"
}
EOF
$ASEPRITE -b -script "$d/create.lua" || exit 1
compare_sheet_data "$d/sheet1.json" "$d/sheet2.json" || exit 1
cmp "$d/sheet1.png" "$d/sheet2.png" || exit 1
cat >$d/compare.lua <<EOF
local orig = app.open("sprites/1empty3.aseprite")
local sheet = app.open("$d/sheet1.png")
local expected = Image(orig.width, orig.height*3, orig.colorMode)
expected:clear()
for f = 1,3 do
expected:drawSprite(orig, f, 0, (f-1)*orig.height)
end
assert(expected:isEqual(sheet.cels[1].image))
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1
# --split-layers --sheet --data
d=$t/split-layers-sheet-data
$ASEPRITE -b --split-layers sprites/1empty3.aseprite \
--filename-format "{layer}-{frame}" \
--sheet "$d/sheet.png" \
--data "$d/sheet.json" || exit 1
cat >$d/compare.lua <<EOF
local data = json.decode(io.open('$d/sheet.json'):read('a'))
assert(data.meta.size.w == 96)
assert(data.meta.size.h == 64)
local orig = app.open("sprites/1empty3.aseprite")
local sheet = app.open("$d/sheet.png")
local expected = Image(orig.width*3, orig.height*2, orig.colorMode)
expected:clear()
for lay = 1,2 do
orig.layers[1].isVisible = (lay == 1)
orig.layers[2].isVisible = (lay == 2)
for frm = 1,3 do
local x, y = (frm-1)*orig.width, (lay-1)*orig.height
expected:drawSprite(orig, frm, x, y)
local frmData = data.frames[orig.layers[lay].name .. '-' .. (frm-1)]
assert(frmData.frame.x == x)
assert(frmData.frame.y == y)
assert(frmData.frame.w == 32)
assert(frmData.frame.h == 32)
end
end
assert(expected:isEqual(sheet.cels[1].image))
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1
# Test that the transparent color persists in the output sheet
d=$t/sheet-custom-transparent-index
if ! $ASEPRITE -b sprites/bg-index-3.aseprite -sheet "$d/sheet.aseprite" -data "$d/sheet.json" ; then
exit 1
fi
cat >$d/compare.lua <<EOF
local original = Sprite{ fromFile='sprites/bg-index-3.aseprite' }
assert(original.transparentColor == 3)
local sheet = Sprite{ fromFile='$d/sheet.aseprite' }
assert(sheet.transparentColor == 3)
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1
# Don't discard empty frames if -ignore-empty is not used (even if -trim is used)
# https://github.com/aseprite/aseprite/issues/2116
# -layer -trim -ignore-empty -list-tags -sheet -data
d=$t/sheet-trim-without-ignore-empty
$ASEPRITE -b \
-list-tags \
-layer "c" \
"sprites/tags3.aseprite" \
-trim \
-sheet-pack \
-sheet "$d/sheet1.png" \
-format json-array \
-data "$d/sheet1.json" || exit 1
$ASEPRITE -b \
-list-tags \
-layer "c" \
"sprites/tags3.aseprite" \
-trim -ignore-empty \
-sheet-pack \
-sheet "$d/sheet2.png" \
-format json-array \
-data "$d/sheet2.json" || exit 1
cat >$d/check.lua <<EOF
local sheet1 = json.decode(io.open('$d/sheet1.json'):read('a'))
local sheet2 = json.decode(io.open('$d/sheet2.json'):read('a'))
assert(#sheet1.frames == 12)
assert(#sheet2.frames == 4)
EOF
$ASEPRITE -b -script "$d/check.lua" || exit 1
# -sheet -sheet-columns vs -sheet-rows
d=$t/sheet-columns-and-rows
$ASEPRITE -b -split-layers sprites/1empty3.aseprite \
-filename-format "{layer}{frame}" \
-sheet "$d/sheet1.png" \
-sheet-type rows \
-sheet-columns 3 \
-data "$d/sheet1.json" || exit $?
$ASEPRITE -b -split-layers sprites/1empty3.aseprite \
-filename-format "{layer}{frame}" \
-sheet "$d/sheet2.png" \
-sheet-type columns \
-sheet-rows 3 \
-data "$d/sheet2.json" || exit $?
$ASEPRITE -b \
-script-param file1=$d/sheet1.json \
-script-param file2=$d/sheet2.json \
-script scripts/compare_sprite_sheets.lua || exit $?
# -sheet -trim vs -trim-sprite
d=$t/sheet-columns-and-rows
$ASEPRITE -b -split-layers sprites/1empty3.aseprite \
-trim \
-filename-format "{layer}{frame}" \
-sheet "$d/sheet1.png" \
-data "$d/sheet1.json" || exit $?
$ASEPRITE -b -split-layers sprites/1empty3.aseprite \
-trim-sprite \
-filename-format "{layer}{frame}" \
-sheet "$d/sheet2.png" \
-data "$d/sheet2.json" || exit $?
$ASEPRITE -b \
-script-param file1=$d/sheet1.json \
-script-param file2=$d/sheet2.json \
-script scripts/compare_sprite_sheets.lua || exit $?
# Test all sprite sheet types
# -sheet horizontal/vertical/rows/columns/packed
d=$t/sheet-all-types
for type in horizontal vertical rows columns packed ; do
$ASEPRITE -b "sprites/tags3.aseprite" \
-sheet-type $type -sheet "$d/$type.png" \
-format json-array -data "$d/$type.json" || exit $?
$ASEPRITE -b -split-layers "sprites/tags3.aseprite" \
-sheet-type $type -sheet "$d/$type-layers.png" \
-format json-array -data "$d/$type-layers.json" || exit $?
$ASEPRITE -b -split-layers -merge-duplicates "sprites/tags3.aseprite" \
-sheet-type $type -sheet "$d/$type-layers-merge-duplicates.png" \
-format json-array -data "$d/$type-layers-merge-duplicates.json" || exit $?
$ASEPRITE -b -split-tags "sprites/tags3.aseprite" \
-sheet-type $type -sheet "$d/$type-tags.png" \
-format json-array -data "$d/$type-tags.json" || exit $?
$ASEPRITE -b -split-tags -trim "sprites/tags3.aseprite" \
-sheet-type $type -sheet "$d/$type-tags-trim.png" \
-format json-array -data "$d/$type-tags-trim.json" || exit $?
$ASEPRITE -b -split-layers -split-tags "sprites/tags3.aseprite" \
-sheet-type $type -sheet "$d/$type-layer-tags.png" \
-format json-array -data "$d/$type-layer-tags.json" || exit $?
done
for type in horizontal vertical rows columns ; do
for subtype in "" "-layers" "-layers-merge-duplicates" "-tags" "-tags-trim" "-layer-tags" ; do
$ASEPRITE -b \
-script-param file1=$d/packed$subtype.json \
-script-param file2=$d/$type$subtype.json \
-script scripts/compare_sprite_sheets.lua || exit $?
done
done
# "Trim Cels" (-trim) with -merge-duplicates didn't generate the
# correct "spriteSourceSize" for each frame.
# https://igarastudio.zendesk.com/agent/tickets/407
d=$t/ticket-407
for layer in a b ; do
$ASEPRITE -b -layer "$layer" "sprites/point4frames.aseprite" \
-trim \
-data "$d/data1-$layer.json" \
-format json-array -sheet "$d/sheet1-$layer.png" || exit 1
$ASEPRITE -b -layer "$layer" "sprites/point4frames.aseprite" \
-trim -merge-duplicates \
-data "$d/data2-$layer.json" \
-format json-array -sheet "$d/sheet2-$layer.png" || exit 1
cat >$d/compare.lua <<EOF
local data1 = json.decode(io.open('$d/data1-$layer.json'):read('a'))
local data2 = json.decode(io.open('$d/data2-$layer.json'):read('a'))
assert(#data1.frames == #data2.frames)
for i = 1,#data1.frames do
local a = data1.frames[i].spriteSourceSize
local b = data2.frames[i].spriteSourceSize
assert(a.x == b.x)
assert(a.y == b.y)
assert(a.w == b.w)
assert(a.h == b.h)
end
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1
done
# Same problem as in ticket 407 but with "sourceSize" field and
# different sprites in the same texture atlas.
d=$t/ticket-407-w-atlas
$ASEPRITE -b \
-layer a "sprites/point4frames.aseprite" \
"sprites/point2frames.aseprite" \
-data "$d/data1.json" \
-format json-array -sheet "$d/sheet1.png" || exit 1
$ASEPRITE -b \
-layer a "sprites/point4frames.aseprite" \
"sprites/point2frames.aseprite" \
-trim \
-data "$d/data2.json" \
-format json-array -sheet-pack -sheet "$d/sheet2.png" || exit 1
cat >$d/compare.lua <<EOF
local data1 = json.decode(io.open('$d/data1.json'):read('a'))
local data2 = json.decode(io.open('$d/data2.json'):read('a'))
assert(#data1.frames == #data2.frames)
for i = 1,#data1.frames do
local a = data1.frames[i].sourceSize
local b = data2.frames[i].sourceSize
assert(a.w == b.w)
assert(a.h == b.h)
end
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1
# https://github.com/aseprite/aseprite/issues/2380
# Check that -split-layers and -list-layers include group information
d=$t/issue-2380
$ASEPRITE -b -trim -all-layers "sprites/groups3abc.aseprite" -data "$d/sheet1.json" -format json-array -sheet "$d/sheet1.png" -list-layers
$ASEPRITE -b -trim -all-layers -split-layers "sprites/groups3abc.aseprite" -data "$d/sheet2.json" -format json-array -sheet "$d/sheet2.png" -list-layers
cat >$d/check.lua <<EOF
local sheet1 = json.decode(io.open('$d/sheet1.json'):read('a'))
local sheet2 = json.decode(io.open('$d/sheet2.json'):read('a'))
assert(#sheet1.meta.layers == 12)
assert(#sheet2.meta.layers == 12)
assert(json.encode(sheet1.meta.layers) == json.encode(sheet2.meta.layers))
EOF
$ASEPRITE -b -script "$d/check.lua" || exit 1
# https://github.com/aseprite/aseprite/issues/2432
# -ignore-layer is ignoring extra layers when -split-layers is used
d=$t/issue-2432
$ASEPRITE -b -trim -ignore-layer "c" -all-layers "sprites/groups3abc.aseprite" -data "$d/sheet1.json" -format json-array -sheet "$d/sheet1.png" -list-layers
$ASEPRITE -b -trim -ignore-layer "c" -all-layers -split-layers "sprites/groups3abc.aseprite" -data "$d/sheet2.json" -format json-array -sheet "$d/sheet2.png" -list-layers
cat >$d/check.lua <<EOF
local sheet1 = json.decode(io.open('$d/sheet1.json'):read('a'))
local sheet2 = json.decode(io.open('$d/sheet2.json'):read('a'))
assert(#sheet1.meta.layers == 8)
assert(#sheet2.meta.layers == 8)
assert(json.encode(sheet1.meta.layers) == json.encode(sheet2.meta.layers))
EOF
$ASEPRITE -b -script "$d/check.lua" || exit 1
# https://github.com/aseprite/aseprite/issues/2600
# -merge-duplicates -split-layers -trim give incorrect 'frame' coordinates on linked cels
d=$t/issue-2600
$ASEPRITE -b -list-layers -format json-array -trim -merge-duplicates -split-layers -all-layers "sprites/link.aseprite" -data "$d/sheet.json" -sheet "$d/sheet.png"
cat >$d/check.lua <<EOF
local sheet = json.decode(io.open('$d/sheet.json'):read('a'))
local restoredSprite = Sprite(sheet.frames[1].sourceSize.w, sheet.frames[1].sourceSize.h, ColorMode.RGB)
local spriteSheet = Image{ fromFile="$d/sheet.png" }
local lay = 1
repeat
local layerName = sheet.meta.layers[lay].name
local layer = restoredSprite.layers[lay]
for i=1, #sheet.frames do
if string.find(sheet.frames[i].filename, layerName) ~= nil then
local sample = sheet.frames[i]
local dotAseIndex = string.find(sample.filename, ".ase")
local frame = (string.sub(sample.filename, dotAseIndex - 2, dotAseIndex - 1)) + 1
for f=#restoredSprite.frames, frame-1 do
restoredSprite:newEmptyFrame()
end
local image = Image(sample.frame.w, sample.frame.h)
for y=0,image.height-1 do
for x=0,image.width-1 do
image:drawPixel(x, y, spriteSheet:getPixel(sample.frame.x + x, sample.frame.y + y))
end
end
restoredSprite:newCel(layer, frame, image, Point(sample.spriteSourceSize.x, sample.spriteSourceSize.y))
end
end
if lay < #sheet.meta.layers then
restoredSprite:newLayer()
end
lay = lay + 1
until(lay > #sheet.meta.layers)
app.activeSprite = restoredSprite
app.activeLayer = restoredSprite.layers[#restoredSprite.layers]
for i=1,#restoredSprite.layers-1 do
app.command.MergeDownLayer()
end
local orig = app.open("sprites/link.aseprite")
app.activeSprite = orig
app.activeLayer = orig.layers[#orig.layers]
for i=1,#orig.layers-1 do
app.command.MergeDownLayer()
end
assert(orig.width == restoredSprite.width)
assert(orig.height == restoredSprite.height)
assert(#orig.frames == #restoredSprite.frames)
for fr=1,#restoredSprite.frames do
for celIndex1=1,#restoredSprite.cels do
if restoredSprite.cels[celIndex1].frameNumber == fr then
for celIndex2=1,#orig.cels do
if orig.cels[celIndex2].frameNumber == fr then
assert(orig.cels[celIndex2].position == restoredSprite.cels[celIndex1].position)
if orig.cels[celIndex2].image ~= nil and restoredSprite.cels[celIndex1].image ~= nil then
assert(orig.cels[celIndex2].image:isEqual(restoredSprite.cels[celIndex1].image))
end
end
end
end
end
end
EOF
$ASEPRITE -b -script "$d/check.lua" || exit 1
# Test solution to #1514 using new --tagname-format
d=$t/issue-1514
$ASEPRITE -b "sprites/1empty3.aseprite" "sprites/tags3.aseprite" \
-data "$d/atlas.json" \
-format json-array \
-sheet "$d/atlas.png" \
-list-tags -tagname-format="{title}-{tag}" || exit 1
cat >$d/compare.lua <<EOF
local data = json.decode(io.open('$d/atlas.json'):read('a'))
assert(#data.meta.frameTags == 5)
local tags = {}
for i,t in ipairs(data.meta.frameTags) do
tags[t.name] = t
end
t = tags["1empty3-a"] assert(t.from == 0 and t.to == 1)
t = tags["1empty3-b"] assert(t.from == 2 and t.to == 2)
t = tags["tags3-forward"] assert(t.from == 0 and t.to == 3)
t = tags["tags3-reverse"] assert(t.from == 4 and t.to == 7)
t = tags["tags3-pingpong"] assert(t.from == 8 and t.to == 11)
EOF
$ASEPRITE -b -script "$d/compare.lua" || exit 1