From 16438da04a1d2f919eacab39fc2237fd280f9bd2 Mon Sep 17 00:00:00 2001 From: Aofei Sheng Date: Fri, 10 Jan 2025 09:05:10 +0800 Subject: [PATCH] fix(tools/spxls): resolve issues with LS functionality Updates #1199 - https://github.com/goplus/builder/issues/1199#issuecomment-2579274294 - https://github.com/goplus/builder/issues/1199#issuecomment-2579281650 - https://github.com/goplus/builder/issues/1199#issuecomment-2579290223 - https://github.com/goplus/builder/issues/1199#issuecomment-2579313694 Signed-off-by: Aofei Sheng --- tools/ispx/go.mod | 17 +- tools/ispx/go.sum | 69 ++++--- tools/spxls/go.mod | 13 +- tools/spxls/go.sum | 20 +- tools/spxls/internal/server/compile.go | 178 +++++++++--------- .../spxls/internal/server/diagnostic_test.go | 148 ++++----------- tools/spxls/internal/server/document_test.go | 10 +- tools/spxls/internal/server/format.go | 43 +++-- tools/spxls/internal/server/format_test.go | 51 ++++- tools/spxls/internal/server/rename.go | 4 +- tools/spxls/internal/server/rename_test.go | 70 +++++++ tools/spxls/internal/server/spx_definition.go | 8 +- tools/spxls/internal/server/util.go | 9 - 13 files changed, 354 insertions(+), 286 deletions(-) diff --git a/tools/ispx/go.mod b/tools/ispx/go.mod index ae99e3b20..0efba00d2 100644 --- a/tools/ispx/go.mod +++ b/tools/ispx/go.mod @@ -3,7 +3,7 @@ module github.com/goplus/builder/ispx go 1.21 require ( - github.com/goplus/igop v0.27.1 + github.com/goplus/igop v0.28.0 github.com/goplus/reflectx v1.2.2 github.com/goplus/spx v1.0.1-0.20241029011511-845f2c0e2e74 github.com/hajimehoshi/ebiten/v2 v2.8.0-alpha.3 @@ -19,35 +19,34 @@ require ( github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 // indirect github.com/gopherjs/gopherjs v0.0.0-20200217142428-fce0ec30dd00 // indirect github.com/goplus/canvas v0.1.0 // indirect - github.com/goplus/gogen v1.15.2 // indirect + github.com/goplus/gogen v1.16.6-0.20250112152508-dc8cddfd52df // indirect github.com/goplus/gop v1.2.6 // indirect - github.com/goplus/mod v0.13.10 // indirect + github.com/goplus/mod v0.13.15 // indirect github.com/hajimehoshi/go-mp3 v0.3.4 // indirect github.com/jezek/xgb v1.1.1 // indirect github.com/pkg/errors v0.9.1 // indirect github.com/qiniu/audio v0.2.1 // indirect - github.com/qiniu/x v1.13.10 // indirect + github.com/qiniu/x v1.13.11 // indirect github.com/srwiley/oksvg v0.0.0-20210519022825-9fc0c575d5fe // indirect github.com/srwiley/rasterx v0.0.0-20210519020934-456a8d69b780 // indirect - github.com/timandy/routine v1.1.1 // indirect + github.com/timandy/routine v1.1.4 // indirect github.com/visualfc/funcval v0.1.4 // indirect - github.com/visualfc/gid v0.1.0 // indirect + github.com/visualfc/gid v0.2.0 // indirect github.com/visualfc/goembed v0.3.2 // indirect github.com/visualfc/xtype v0.2.0 // indirect golang.org/x/image v0.18.0 // indirect golang.org/x/mobile v0.0.0-20220518205345-8578da9835fd // indirect - golang.org/x/mod v0.19.0 // indirect + golang.org/x/mod v0.20.0 // indirect golang.org/x/sync v0.7.0 // indirect golang.org/x/sys v0.22.0 // indirect golang.org/x/text v0.16.0 // indirect golang.org/x/tools v0.23.0 // indirect - golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 // indirect ) replace ( + github.com/goplus/gop => github.com/goplus/gop v1.2.0-pre.1.0.20250112163018-5fb12b1b2972 github.com/hajimehoshi/oto => github.com/hajimehoshi/oto v1.0.1 github.com/srwiley/oksvg => github.com/qiniu/oksvg v0.2.0-no-charset golang.org/x/image => golang.org/x/image v0.0.0-20210628002857-a66eb6448b8d golang.org/x/mobile => golang.org/x/mobile v0.0.0-20210902104108-5d9a33257ab5 - golang.org/x/mod => golang.org/x/mod v0.5.1 ) diff --git a/tools/ispx/go.sum b/tools/ispx/go.sum index 7bd166585..2e5b09b8f 100644 --- a/tools/ispx/go.sum +++ b/tools/ispx/go.sum @@ -17,24 +17,28 @@ github.com/ebitengine/purego v0.8.0-alpha.3 h1:qoFlpGuVwJ6J85kuj6Qpyp0DBgxsNYfSY github.com/ebitengine/purego v0.8.0-alpha.3/go.mod h1:b94LtM1jUWDZPKDyENVhB0WsLdLWFApjbNw5AyxmKyI= github.com/esimov/stackblur-go v1.0.1-0.20190121110005-00e727e3c7a9 h1:TJdKpA5v3Xu24Vv0yQy1MyRJgpt7vk9AT58fGPfiZcs= github.com/esimov/stackblur-go v1.0.1-0.20190121110005-00e727e3c7a9/go.mod h1:a3zzeKuJKUpCcReHmEsuPaEnq42D2b/bHoCI8UjIuMY= -github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= +github.com/fsnotify/fsnotify v1.8.0/go.mod h1:8jBTzvmWwFyi3Pb8djgCCO5IBqzKJ/Jwo8TRcHyHii0= github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 h1:DACJavvAHhabrF08vX0COfcOBJRhZ8lUbR+ZWIs0Y5g= github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= -github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/gopherjs/gopherjs v0.0.0-20180708170036-38b413be4187/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= github.com/gopherjs/gopherjs v0.0.0-20200217142428-fce0ec30dd00 h1:l5lAOZEym3oK3SQ2HBHWsJUfbNBiTXJDeW2QDxw9AQ0= github.com/gopherjs/gopherjs v0.0.0-20200217142428-fce0ec30dd00/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= -github.com/goplus/c2go v0.7.26/go.mod h1:ePAStubV/ls8mmdPGQo6VfADTVd46rKuBemE4zzBDnA= github.com/goplus/canvas v0.1.0 h1:Vx3f2+U8UANvWf5/01YsQYKNbZDm1GZCjhlEBFrQkeU= github.com/goplus/canvas v0.1.0/go.mod h1:Rhcvo5qkpD9WuXFnvnXtrBSY97l6h7sXQuofrmiLNdM= -github.com/goplus/gogen v1.15.2 h1:Q6XaSx/Zi5tWnjfAziYsQI6Jv6MgODRpFtOYqNkiiqM= github.com/goplus/gogen v1.15.2/go.mod h1:92qEzVgv7y8JEFICWG9GvYI5IzfEkxYdsA1DbmnTkqk= -github.com/goplus/gop v1.2.6 h1:kog3c5Js+8EopqmI4+CwueXsqibnBwYVt5q5N7juRVY= -github.com/goplus/gop v1.2.6/go.mod h1:uREWbR1MrFaviZ4Mbx4ZCcAYDoqzO0iv1Qo6Np0Xx4E= -github.com/goplus/igop v0.27.1 h1:nLfk+2a8TZ1XvMb6XZnD6f1DlJ6Owj5We1gt6BMKqaI= -github.com/goplus/igop v0.27.1/go.mod h1:V8Kf/b4nrw0OPPodwnOYZPCpXvU+hqzuhSAXIToT0ME= -github.com/goplus/mod v0.13.10 h1:5Om6KOvo31daN7N30kWU1vC5zhsJPM+uPbcEN/FnlzE= +github.com/goplus/gogen v1.16.3/go.mod h1:6TQYbabXDF9LCdDkOOzHmfg1R4ENfXQ3XpHa9RhTSD8= +github.com/goplus/gogen v1.16.6-0.20250112152508-dc8cddfd52df h1:YIcLq6a7eGp3niBGF/VQJbSjos2MtnaUu+ysj6Iuhjo= +github.com/goplus/gogen v1.16.6-0.20250112152508-dc8cddfd52df/go.mod h1:6TQYbabXDF9LCdDkOOzHmfg1R4ENfXQ3XpHa9RhTSD8= +github.com/goplus/gop v1.2.0-pre.1.0.20250112163018-5fb12b1b2972 h1:wA4+I+DDfoNwR+zCnaeckt5pxZgLAuaKvVkC+T9GdiQ= +github.com/goplus/gop v1.2.0-pre.1.0.20250112163018-5fb12b1b2972/go.mod h1:lcW75c0a5v361jId1Vxs4lRrsasWsQDH0k3dG3Z7wH0= +github.com/goplus/igop v0.28.0 h1:hbcZR2Z9Ax2y29ndkYZmXx5KE9YQPy/OV7mb9szKGHQ= +github.com/goplus/igop v0.28.0/go.mod h1:ObprI7cQUSZN0LYeUX0+MqzpQ0MmeS5o1/ToDU+jfTg= +github.com/goplus/llgo v0.9.9/go.mod h1:udcq+s6tGOdhJq7I8fXPTv4qT2j17/KrlvtcJrMZAoM= +github.com/goplus/llvm v0.8.0/go.mod h1:PeVK8GgzxwAYCiMiUAJb5wJR6xbhj989tu9oulKLLT4= github.com/goplus/mod v0.13.10/go.mod h1:HDuPZgpWiaTp3PUolFgsiX+Q77cbUWB/mikVHfYND3c= +github.com/goplus/mod v0.13.13/go.mod h1:invR72Rz2+qpOOsXqxz830MX8/aR2GDR2EAow/WgfHI= +github.com/goplus/mod v0.13.15 h1:IyneSjwm1VpwvHGz6hSHnFxZCuO6ULHcu74IAZcW9nw= +github.com/goplus/mod v0.13.15/go.mod h1:invR72Rz2+qpOOsXqxz830MX8/aR2GDR2EAow/WgfHI= github.com/goplus/reflectx v1.2.2 h1:T1p20OIH/HcnAvQQNnDLwl6AZOjU34icsfc6migD6L8= github.com/goplus/reflectx v1.2.2/go.mod h1:wHOS9ilbB4zrecI0W1dMmkW9JMcpXV7VjALVbNU9xfM= github.com/goplus/spx v1.0.1-0.20241029011511-845f2c0e2e74 h1:68g+YDfUceO/iZ+RJUktPxDDaWLzE23QXrm+NuYTLls= @@ -48,10 +52,8 @@ github.com/hajimehoshi/oto v1.0.1/go.mod h1:wovJ8WWMfFKvP587mhHgot/MBr4DnNy9m6Ee github.com/hajimehoshi/oto/v2 v2.3.1/go.mod h1:seWLbgHH7AyUMYKfKYT9pg7PhUu9/SisyJvNTT+ASQo= github.com/jezek/xgb v1.1.1 h1:bE/r8ZZtSv7l9gk6nU0mYx51aXrvnyb44892TwSaqS4= github.com/jezek/xgb v1.1.1/go.mod h1:nrhwO0FX/enq75I7Y7G8iN1ubpSGZEiA3v9e9GyRFlk= -github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/mattn/go-runewidth v0.0.3/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= -github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= github.com/peterh/liner v1.2.2/go.mod h1:xFwJyiKIXJZUKItq5dGHZSTBRAuG/CpeNpWLyiNRNwI= github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= @@ -63,25 +65,27 @@ github.com/qiniu/audio v0.2.1/go.mod h1:APMJRPaS4toviejZnDzzZ8wVyr12jqZhd3xfKr/q github.com/qiniu/oksvg v0.2.0-no-charset h1:KKQg81v52pd5VyaxrF891igoOO50epKfFWkryYgntnE= github.com/qiniu/oksvg v0.2.0-no-charset/go.mod h1:YCAOS1HFo2kMxfcFCjrJMeo93KGFYaBAKl7LvrAkltQ= github.com/qiniu/x v1.11.5/go.mod h1:03Ni9tj+N2h2aKnAz+6N0Xfl8FwMEDRC2PAlxekASDs= -github.com/qiniu/x v1.13.10 h1:J4Z3XugYzAq85SlyAfqlKVrbf05glMbAOh+QncsDQpE= github.com/qiniu/x v1.13.10/go.mod h1:INZ2TSWSJVWO/RuELQROERcslBwVgFG7MkTfEdaQz9E= +github.com/qiniu/x v1.13.11 h1:zlFLY9zFXOwKEjx0SQXRBunhFjDVpEY+pRGL/4shd5U= +github.com/qiniu/x v1.13.11/go.mod h1:INZ2TSWSJVWO/RuELQROERcslBwVgFG7MkTfEdaQz9E= github.com/srwiley/rasterx v0.0.0-20200120212402-85cb7272f5e9/go.mod h1:mvWM0+15UqyrFKqdRjY6LuAVJR0HOVhJlEgZ5JWtSWU= github.com/srwiley/rasterx v0.0.0-20210519020934-456a8d69b780 h1:oDMiXaTMyBEuZMU53atpxqYsSB3U1CHkeAu2zr6wTeY= github.com/srwiley/rasterx v0.0.0-20210519020934-456a8d69b780/go.mod h1:mvWM0+15UqyrFKqdRjY6LuAVJR0HOVhJlEgZ5JWtSWU= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= -github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= +github.com/stretchr/objx v0.5.2/go.mod h1:FRsXN1f5AsAjCGJKqEizvkpNtU+EGNCLh3NxZ/8L+MA= github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= -github.com/stretchr/testify v1.8.1 h1:w7B6lhMri9wdJUVmEZPGGhZzrYTPvgJArz7wNPgYKsk= -github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= -github.com/timandy/routine v1.1.1 h1:6/Z7qLFZj3GrzuRksBFzIG8YGUh8CLhjnnMePBQTrEI= -github.com/timandy/routine v1.1.1/go.mod h1:OZHPOKSvqL/ZvqXFkNZyit0xIVelERptYXdAHH00adQ= +github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= +github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= +github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= +github.com/timandy/routine v1.1.4 h1:L9eAli/ROJcW6LhmwZcusYQcdAqxAXGOQhEXLQSNWOA= +github.com/timandy/routine v1.1.4/go.mod h1:siBcl8iIsGmhLCajRGRcy7Y7FVcicNXkr97JODdt9fc= github.com/visualfc/funcval v0.1.4 h1:lAI88zQYfRzmC7mKF4+swXeCZvb8wb1f3lMSDRAY2mQ= github.com/visualfc/funcval v0.1.4/go.mod h1:3Izv+irhArmrTvy+lmL6pIq16gSOzx73CIka51J9eR0= -github.com/visualfc/gid v0.1.0 h1:sg95vChDrUS5hngkfg4yxN6JAF6qIwwvJ+TC8cuZVto= -github.com/visualfc/gid v0.1.0/go.mod h1:YiRDLgdRp89d4OduAkhv5AAtc6XjUlx74IRLYofu3+E= +github.com/visualfc/gid v0.2.0 h1:afcecoaa0GejCYlDBCUQZn4VUB3RsTXhxawNg7rAEto= +github.com/visualfc/gid v0.2.0/go.mod h1:srMMe/ps7zr2aZ1XP1jzPiaidjiM+w+c6olVnFcNjpw= github.com/visualfc/goembed v0.3.2 h1:a9m6o9VTzNk3mEF98C8cHp8f8P8BblyjsjajXGfTp8w= github.com/visualfc/goembed v0.3.2/go.mod h1:jCVCz/yTJGyslo6Hta+pYxWWBuq9ADCcIVZBTQ0/iVI= github.com/visualfc/xtype v0.2.0 h1:0ESNXyWHtK01kaOzOyqHsR1ZjEPdNu/IWPZkf0VOHl8= @@ -90,8 +94,11 @@ github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9dec github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= +golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= +golang.org/x/crypto v0.13.0/go.mod h1:y6Z2r+Rw4iayiXXAIxJIDAJ1zMW4yaTpebo8fPOliYc= golang.org/x/crypto v0.19.0/go.mod h1:Iy9bg/ha4yyC70EfRS8jz+B6ybOBKMaSxLj6P6oBDfU= golang.org/x/crypto v0.21.0/go.mod h1:0BP7YvVV9gBbVKyeTG0Gyn+gZm94bibOW5BjDEYAOMs= golang.org/x/exp v0.0.0-20190731235908-ec7cb31e5a56/go.mod h1:JhuoJpWY28nO4Vef9tZUw9qufEGTyX1+7lmHxV5q5G4= @@ -99,16 +106,27 @@ golang.org/x/image v0.0.0-20210628002857-a66eb6448b8d h1:RNPAfi2nHY7C2srAV8A49jp golang.org/x/image v0.0.0-20210628002857-a66eb6448b8d/go.mod h1:023OzeP/+EPmXeapQh35lcL3II3LrY8Ic+EFFKVhULM= golang.org/x/mobile v0.0.0-20210902104108-5d9a33257ab5 h1:peBP2oZO/xVnGMaWMCyFEI0WENsGj71wx5K12mRELHQ= golang.org/x/mobile v0.0.0-20210902104108-5d9a33257ab5/go.mod h1:c4YKU3ZylDmvbw+H/PSvm42vhdWbuxCzbonauEAP9B8= -golang.org/x/mod v0.5.1 h1:OJxoQ/rynoF0dcCdI7cLPktw/hR2cueqYfjm43oqK38= -golang.org/x/mod v0.5.1/go.mod h1:5OXOZSfqPIIbmVBIIKWRFfZjPR0E5r58TLhUjH0a2Ro= +golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY= +golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= +golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.12.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.15.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/mod v0.16.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/mod v0.17.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/mod v0.20.0 h1:utOm6MM3R3dnawAiJgn0y+xvuYRsm1RKM/4giyfDgV0= +golang.org/x/mod v0.20.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= +golang.org/x/net v0.15.0/go.mod h1:idbUs1IY1+zTqbi8yxTbhexhEEk5ur9LInksu6HrEpk= golang.org/x/net v0.21.0/go.mod h1:bIjVDfnllIU7BJ2DNgfnXvpSvtn8VRwhlsaeUTyUS44= golang.org/x/net v0.22.0/go.mod h1:JKghWKKOSdJwpW2GEx0Ja7fmaKnMsbu+MWVZTokSYmg= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -116,6 +134,7 @@ golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJ golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.3.0/go.mod h1:FU7BRWz2tNW+3quACPkgCx/L+uEAv1htQ0V83Z9Rj+Y= golang.org/x/sync v0.6.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M= golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= @@ -132,11 +151,13 @@ golang.org/x/sys v0.0.0-20211117180635-dee7805ff2e1/go.mod h1:oPkhp1MJrh7nUepCBc golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220712014510-0a85c31ab51e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.4.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.17.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/sys v0.18.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.21.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/sys v0.22.0 h1:RI27ohtqKCnwULzJLqkv897zojh5/DwS/ENaMzUOaWI= golang.org/x/sys v0.22.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/telemetry v0.0.0-20240228155512-f48c80bd79b2/go.mod h1:TeRTkGYfJXctD9OcfyVLyj2J3IxLnKwHJR8f4D8a3YE= @@ -144,6 +165,7 @@ golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9sn golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= golang.org/x/term v0.8.0/go.mod h1:xPskH00ivmX89bAKVGSKKtLOWNx2+17Eiy94tnKShWo= +golang.org/x/term v0.12.0/go.mod h1:owVbMEjm3cBLCHdkQu9b1opXd4ETQWc3BhuQGKgXgvU= golang.org/x/term v0.17.0/go.mod h1:lLRBjIVuehSbZlaOtGMbcMncT+aqLLLmKrsjNrUguwk= golang.org/x/term v0.18.0/go.mod h1:ILwASektA3OnRv7amZ1xhE/KTR+u50pbXfZ03+6Nx58= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= @@ -152,6 +174,7 @@ golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= +golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= golang.org/x/text v0.16.0 h1:a94ExnEXNtEwYLGJSIUxnWoxoRz/ZcCsV63ROupILh4= golang.org/x/text v0.16.0/go.mod h1:GhwF1Be+LQoKShO3cGOHzqOgRrGaYc9AvblQOmPVHnI= @@ -162,12 +185,12 @@ golang.org/x/tools v0.1.0/go.mod h1:xkSsbof2nBLbhDlRMhhhyNLN/zl3eTqcnHD5viDpcZ0= golang.org/x/tools v0.1.2/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= +golang.org/x/tools v0.13.0/go.mod h1:HvlwmtVNQAhOuCjW7xxvovg8wbNq7LwfXh/k7wXUl58= golang.org/x/tools v0.19.0/go.mod h1:qoJWxmGSIBmAeriMx19ogtrEPrGtDbPK634QFIcLAhc= golang.org/x/tools v0.23.0 h1:SGsXPZ+2l4JsgaCKkx+FQ9YZ5XEtA1GZYuoDjenLjvg= golang.org/x/tools v0.23.0/go.mod h1:pnu6ufv6vQkll6szChhK3C3L/ruaIv5eBeztNG8wtsI= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= diff --git a/tools/spxls/go.mod b/tools/spxls/go.mod index 124022a7a..58dcaab54 100644 --- a/tools/spxls/go.mod +++ b/tools/spxls/go.mod @@ -3,17 +3,14 @@ module github.com/goplus/builder/tools/spxls go 1.23.4 require ( - github.com/goplus/gogen v1.15.2 - github.com/goplus/gop v1.2.6 - github.com/goplus/mod v0.13.10 + github.com/goplus/gogen v1.16.6-0.20250112152508-dc8cddfd52df + github.com/goplus/gop v1.2.0-pre.1.0.20250112163018-5fb12b1b2972 + github.com/goplus/mod v0.13.15 github.com/goplus/spx v1.1.0 github.com/stretchr/testify v1.9.0 golang.org/x/tools v0.23.0 ) -// https://github.com/nighca/mod/tree/web TODO: any better way to fix this? -replace github.com/goplus/mod v0.13.10 => github.com/nighca/mod v0.0.0-20240805065729-b50535825ae2 - require ( github.com/ajstarks/svgo v0.0.0-20210927141636-6d70534b1098 // indirect github.com/davecgh/go-spew v1.1.1 // indirect @@ -30,12 +27,12 @@ require ( github.com/pkg/errors v0.9.1 // indirect github.com/pmezard/go-difflib v1.0.0 // indirect github.com/qiniu/audio v0.2.1 // indirect - github.com/qiniu/x v1.13.10 // indirect + github.com/qiniu/x v1.13.11 // indirect github.com/srwiley/oksvg v0.0.0-20210519022825-9fc0c575d5fe // indirect github.com/srwiley/rasterx v0.0.0-20210519020934-456a8d69b780 // indirect golang.org/x/image v0.18.0 // indirect golang.org/x/mobile v0.0.0-20220518205345-8578da9835fd // indirect - golang.org/x/mod v0.19.0 // indirect + golang.org/x/mod v0.20.0 // indirect golang.org/x/net v0.27.0 // indirect golang.org/x/sync v0.7.0 // indirect golang.org/x/sys v0.22.0 // indirect diff --git a/tools/spxls/go.sum b/tools/spxls/go.sum index 32fd60785..2235eaa0a 100644 --- a/tools/spxls/go.sum +++ b/tools/spxls/go.sum @@ -20,10 +20,12 @@ github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0 h1:DACJavvAHhabrF0 github.com/golang/freetype v0.0.0-20170609003504-e2365dfdc4a0/go.mod h1:E/TSTwGwJL78qG/PmXZO1EjYhfJinVAhrmmHX6Z8B9k= github.com/goplus/canvas v0.1.0 h1:Vx3f2+U8UANvWf5/01YsQYKNbZDm1GZCjhlEBFrQkeU= github.com/goplus/canvas v0.1.0/go.mod h1:Rhcvo5qkpD9WuXFnvnXtrBSY97l6h7sXQuofrmiLNdM= -github.com/goplus/gogen v1.15.2 h1:Q6XaSx/Zi5tWnjfAziYsQI6Jv6MgODRpFtOYqNkiiqM= -github.com/goplus/gogen v1.15.2/go.mod h1:92qEzVgv7y8JEFICWG9GvYI5IzfEkxYdsA1DbmnTkqk= -github.com/goplus/gop v1.2.6 h1:kog3c5Js+8EopqmI4+CwueXsqibnBwYVt5q5N7juRVY= -github.com/goplus/gop v1.2.6/go.mod h1:uREWbR1MrFaviZ4Mbx4ZCcAYDoqzO0iv1Qo6Np0Xx4E= +github.com/goplus/gogen v1.16.6-0.20250112152508-dc8cddfd52df h1:YIcLq6a7eGp3niBGF/VQJbSjos2MtnaUu+ysj6Iuhjo= +github.com/goplus/gogen v1.16.6-0.20250112152508-dc8cddfd52df/go.mod h1:6TQYbabXDF9LCdDkOOzHmfg1R4ENfXQ3XpHa9RhTSD8= +github.com/goplus/gop v1.2.0-pre.1.0.20250112163018-5fb12b1b2972 h1:wA4+I+DDfoNwR+zCnaeckt5pxZgLAuaKvVkC+T9GdiQ= +github.com/goplus/gop v1.2.0-pre.1.0.20250112163018-5fb12b1b2972/go.mod h1:lcW75c0a5v361jId1Vxs4lRrsasWsQDH0k3dG3Z7wH0= +github.com/goplus/mod v0.13.15 h1:IyneSjwm1VpwvHGz6hSHnFxZCuO6ULHcu74IAZcW9nw= +github.com/goplus/mod v0.13.15/go.mod h1:invR72Rz2+qpOOsXqxz830MX8/aR2GDR2EAow/WgfHI= github.com/goplus/spx v1.1.0 h1:rke7F7YpbjeI583HkuNiUGmsbYdrloNT1ABYLfgv9i8= github.com/goplus/spx v1.1.0/go.mod h1:1hkX9vPdDHrsA6LG8itiLMp83KIDJ0KlJI9CmpCoiCA= github.com/hajimehoshi/ebiten/v2 v2.7.9 h1:DYH/usAa9dMHcGkBIIEApJsVqDekrJBxYHmsBuly8Iw= @@ -37,8 +39,6 @@ github.com/hajimehoshi/oto/v2 v2.3.1/go.mod h1:seWLbgHH7AyUMYKfKYT9pg7PhUu9/Sisy github.com/jezek/xgb v1.1.1 h1:bE/r8ZZtSv7l9gk6nU0mYx51aXrvnyb44892TwSaqS4= github.com/jezek/xgb v1.1.1/go.mod h1:nrhwO0FX/enq75I7Y7G8iN1ubpSGZEiA3v9e9GyRFlk= github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= -github.com/nighca/mod v0.0.0-20240805065729-b50535825ae2 h1:Z3kt9W9vV7yx+44TNwl8+Lc0a8zr6ptN/RzswphNlD0= -github.com/nighca/mod v0.0.0-20240805065729-b50535825ae2/go.mod h1:fyCcoiL02uUQK9CWxGK9pQzuJT+rZIvRKaaG+hSa2bk= github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= @@ -46,8 +46,8 @@ github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZN github.com/qiniu/audio v0.2.1 h1:lAc3dWfr7uAfn7mfee2u0/fl/QSQA9oTOqdBtxyFZAM= github.com/qiniu/audio v0.2.1/go.mod h1:APMJRPaS4toviejZnDzzZ8wVyr12jqZhd3xfKr/qYnE= github.com/qiniu/x v1.11.5/go.mod h1:03Ni9tj+N2h2aKnAz+6N0Xfl8FwMEDRC2PAlxekASDs= -github.com/qiniu/x v1.13.10 h1:J4Z3XugYzAq85SlyAfqlKVrbf05glMbAOh+QncsDQpE= -github.com/qiniu/x v1.13.10/go.mod h1:INZ2TSWSJVWO/RuELQROERcslBwVgFG7MkTfEdaQz9E= +github.com/qiniu/x v1.13.11 h1:zlFLY9zFXOwKEjx0SQXRBunhFjDVpEY+pRGL/4shd5U= +github.com/qiniu/x v1.13.11/go.mod h1:INZ2TSWSJVWO/RuELQROERcslBwVgFG7MkTfEdaQz9E= github.com/srwiley/oksvg v0.0.0-20210519022825-9fc0c575d5fe h1:J5Ga/gb+4/WgJBupg9Fp8F6JQnUT3UF+asoTweLi9Jc= github.com/srwiley/oksvg v0.0.0-20210519022825-9fc0c575d5fe/go.mod h1:afMbS0qvv1m5tfENCwnOdZGOF8RGR/FsZ7bvBxQGZG4= github.com/srwiley/rasterx v0.0.0-20210519020934-456a8d69b780 h1:oDMiXaTMyBEuZMU53atpxqYsSB3U1CHkeAu2zr6wTeY= @@ -74,8 +74,8 @@ golang.org/x/mobile v0.0.0-20220518205345-8578da9835fd/go.mod h1:pe2sM7Uk+2Su1y7 golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= -golang.org/x/mod v0.19.0 h1:fEdghXQSo20giMthA7cd28ZC+jts4amQ3YMXiP5oMQ8= -golang.org/x/mod v0.19.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/mod v0.20.0 h1:utOm6MM3R3dnawAiJgn0y+xvuYRsm1RKM/4giyfDgV0= +golang.org/x/mod v0.20.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= diff --git a/tools/spxls/internal/server/compile.go b/tools/spxls/internal/server/compile.go index 34225d1f9..064c9ff09 100644 --- a/tools/spxls/internal/server/compile.go +++ b/tools/spxls/internal/server/compile.go @@ -56,6 +56,12 @@ type compileResult struct { // mainPkg is the main package. mainPkg *types.Package + // mainPkgGameType is the Game type in the main package. + mainPkgGameType *types.Named + + // mainPkgSpriteTypes stores sprite types in the main package. + mainPkgSpriteTypes []*types.Named + // mainASTPkg is the main package AST. mainASTPkg *gopast.Package @@ -80,9 +86,6 @@ type compileResult struct { // process. typeInfo *goptypesutil.Info - // spxSpriteNames stores spx sprite names. - spxSpriteNames []string - // spxResourceSet is the set of spx resources. spxResourceSet SpxResourceSet @@ -342,6 +345,29 @@ func (r *compileResult) selectorTypeNameForIdent(ident *gopast.Ident) string { return "" } +// isGameOrSpriteThisPtr reports whether the given object is the "this" pointer +// of Game or a Sprite type method in the main package. +func (r *compileResult) isGameOrSpriteThisPtr(obj types.Object) bool { + if obj == nil || obj.Pkg() == nil || obj.Pkg().Path() != "main" || obj.Name() != "this" { + return false + } + + v, ok := obj.(*types.Var) + if !ok { + return false + } + ptr, ok := v.Type().(*types.Pointer) + if !ok { + return false + } + + named, ok := ptr.Elem().(*types.Named) + if !ok { + return false + } + return named == r.mainPkgGameType || slices.Contains(r.mainPkgSpriteTypes, named) +} + // isDefinedInFirstVarBlock reports whether the given object is defined in the // first var block of an AST file. func (r *compileResult) isDefinedInFirstVarBlock(obj types.Object) bool { @@ -591,7 +617,10 @@ func (s *Server) compileUncached(snapshot *vfs.MapFS, spxFiles []string) (*compi diagnostics: make(map[DocumentURI][]Diagnostic, len(spxFiles)), } - gpfs := vfs.NewGopParserFS(snapshot) + var ( + gpfs = vfs.NewGopParserFS(snapshot) + spriteNames = make([]string, 0, len(spxFiles)-1) + ) for _, spxFile := range spxFiles { documentURI := s.toDocumentURI(spxFile) result.diagnostics[documentURI] = []Diagnostic{} @@ -644,7 +673,7 @@ func (s *Server) compileUncached(snapshot *vfs.MapFS, spxFiles []string) (*compi if spxFileBaseName := path.Base(spxFile); spxFileBaseName == "main.spx" { result.mainSpxFile = spxFile } else { - result.spxSpriteNames = append(result.spxSpriteNames, strings.TrimSuffix(spxFileBaseName, ".spx")) + spriteNames = append(spriteNames, strings.TrimSuffix(spxFileBaseName, ".spx")) } for _, decl := range astFile.Decls { @@ -707,12 +736,23 @@ func (s *Server) compileUncached(snapshot *vfs.MapFS, spxFiles []string) (*compi }, nil, result.typeInfo, - ).Files(nil, gopASTFileMapToSlice(result.mainASTPkg.Files)); err != nil { + ).Files(nil, slices.Collect(maps.Values(result.mainASTPkg.Files))); err != nil { // Errors should be handled by the type checker. } + if obj := result.mainPkg.Scope().Lookup("Game"); obj != nil { + result.mainPkgGameType = obj.Type().(*types.Named) + } + + result.mainPkgSpriteTypes = make([]*types.Named, 0, len(spriteNames)) + for _, spxSpriteName := range spriteNames { + if obj := result.mainPkg.Scope().Lookup(spxSpriteName); obj != nil { + result.mainPkgSpriteTypes = append(result.mainPkgSpriteTypes, obj.Type().(*types.Named)) + } + } + s.inspectForSpxResourceSet(snapshot, result) - s.inspectForSpxResourceAutoBindingsAndRefsAtDecls(result) + s.inspectForSpxResourceAutoBindings(result) s.inspectForSpxResourceRefs(result) return result, nil @@ -791,99 +831,69 @@ func (s *Server) inspectForSpxResourceSet(snapshot *vfs.MapFS, result *compileRe result.spxResourceSet = *spxResourceSet } -// inspectForSpxResourceAutoBindingsAndRefsAtDecls inspects for spx resource -// auto-bindings and references at variable or constant declarations. -func (s *Server) inspectForSpxResourceAutoBindingsAndRefsAtDecls(result *compileResult) { +// inspectForSpxResourceAutoBindings inspects for spx resource auto-bindings and +// references at variable or constant declarations. +func (s *Server) inspectForSpxResourceAutoBindings(result *compileResult) { + mainSpxFileScope := result.typeInfo.Scopes[result.mainASTPkg.Files[result.mainSpxFile]] for ident, obj := range result.typeInfo.Defs { - objType, ok := obj.Type().(*types.Named) + v, ok := obj.(*types.Var) + if !ok { + continue + } + varType, ok := v.Type().(*types.Named) if !ok { continue } spxFile := result.fset.Position(ident.Pos()).Filename - isInMainSpx := spxFile == result.mainSpxFile - documentURI := s.toDocumentURI(spxFile) - - identRange := Range{ - Start: FromGopTokenPosition(result.fset.Position(ident.Pos())), - End: FromGopTokenPosition(result.fset.Position(ident.End())), + if spxFile != result.mainSpxFile || result.innermostScopeAt(ident.Pos()) != mainSpxFileScope { + continue } var ( isSpxSoundResourceAutoBinding bool isSpxSpriteResourceAutoBinding bool ) - switch objTypeName := objType.String(); objTypeName { + switch varType.String() { case spxSoundTypeFullName: - isSpxSoundResourceAutoBinding = true + isSpxSoundResourceAutoBinding = result.spxResourceSet.Sound(v.Name()) != nil case spxSpriteTypeFullName: - isSpxSpriteResourceAutoBinding = true + isSpxSpriteResourceAutoBinding = result.spxResourceSet.Sprite(v.Name()) != nil default: - for _, spxSpriteName := range result.spxSpriteNames { - if objTypeName != "main."+spxSpriteName { - continue - } - if ident.Name != spxSpriteName { - result.addDiagnostics(documentURI, Diagnostic{ - Severity: SeverityError, - Range: identRange, - Message: "sprite resource name must match type name for explicit auto-binding to work", - }) - continue - } - isSpxSpriteResourceAutoBinding = true - break - } + isSpxSpriteResourceAutoBinding = v.Name() == varType.Obj().Name() && slices.Contains(result.mainPkgSpriteTypes, varType) } - if isSpxSoundResourceAutoBinding || isSpxSpriteResourceAutoBinding { - var diags []Diagnostic - if isInMainSpx { - if result.isDefinedInFirstVarBlock(obj) { - switch { - case isSpxSoundResourceAutoBinding: - result.addSpxResourceRef(SpxResourceRef{ - ID: SpxSoundResourceID{SoundName: ident.Name}, - Kind: SpxResourceRefKindAutoBinding, - Node: ident, - }) - result.spxSoundResourceAutoBindings[obj] = struct{}{} - if result.spxResourceSet.Sound(ident.Name) == nil { - diags = []Diagnostic{{ - Severity: SeverityError, - Range: identRange, - Message: fmt.Sprintf("sound resource %q not found", ident.Name), - }} - } - case isSpxSpriteResourceAutoBinding: - result.addSpxResourceRef(SpxResourceRef{ - ID: SpxSpriteResourceID{SpriteName: ident.Name}, - Kind: SpxResourceRefKindAutoBinding, - Node: ident, - }) - result.spxSpriteResourceAutoBindings[obj] = struct{}{} - if result.spxResourceSet.Sprite(ident.Name) == nil { - diags = []Diagnostic{{ - Severity: SeverityError, - Range: identRange, - Message: fmt.Sprintf("sprite resource %q not found", ident.Name), - }} - } - } - } else { - diags = []Diagnostic{{ - Severity: SeverityWarning, - Range: identRange, - Message: "resources must be defined in the first var block for auto-binding", - }} - } - } else { - diags = []Diagnostic{{ - Severity: SeverityWarning, - Range: identRange, - Message: "auto-binding of resources can only happen in main.spx", - }} - } - result.addDiagnostics(documentURI, diags...) + if !isSpxSoundResourceAutoBinding && !isSpxSpriteResourceAutoBinding { + continue + } + + if !result.isDefinedInFirstVarBlock(obj) { + documentURI := s.toDocumentURI(spxFile) + result.addDiagnostics(documentURI, Diagnostic{ + Severity: SeverityWarning, + Range: Range{ + Start: FromGopTokenPosition(result.fset.Position(ident.Pos())), + End: FromGopTokenPosition(result.fset.Position(ident.End())), + }, + Message: "resources must be defined in the first var block for auto-binding", + }) + continue + } + + switch { + case isSpxSoundResourceAutoBinding: + result.addSpxResourceRef(SpxResourceRef{ + ID: SpxSoundResourceID{SoundName: ident.Name}, + Kind: SpxResourceRefKindAutoBinding, + Node: ident, + }) + result.spxSoundResourceAutoBindings[obj] = struct{}{} + case isSpxSpriteResourceAutoBinding: + result.addSpxResourceRef(SpxResourceRef{ + ID: SpxSpriteResourceID{SpriteName: ident.Name}, + Kind: SpxResourceRefKindAutoBinding, + Node: ident, + }) + result.spxSpriteResourceAutoBindings[obj] = struct{}{} } } } diff --git a/tools/spxls/internal/server/diagnostic_test.go b/tools/spxls/internal/server/diagnostic_test.go index ec519af44..5001a8f03 100644 --- a/tools/spxls/internal/server/diagnostic_test.go +++ b/tools/spxls/internal/server/diagnostic_test.go @@ -180,7 +180,7 @@ var ( for _, item := range report.Items { fullReport := item.Value.(WorkspaceFullDocumentDiagnosticReport) if fullReport.URI == "file:///main.spx" { - require.Len(t, fullReport.Items, 3) + require.Len(t, fullReport.Items, 2) assert.Contains(t, fullReport.Items, Diagnostic{ Severity: SeverityError, Message: "expected ')', found 'EOF'", @@ -197,14 +197,6 @@ var ( End: Position{Line: 3, Character: 23}, }, }) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: `sprite resource "MyAircraft" not found`, - Range: Range{ - Start: Position{Line: 3, Character: 1}, - End: Position{Line: 3, Character: 11}, - }, - }) } else { assert.Empty(t, fullReport.Items) } @@ -223,19 +215,16 @@ var ( s := New(newMapFSWithoutModTime(map[string][]byte{ "main.spx": []byte(` var ( - AutoBindingSoundName Sound -) -play AutoBindingSoundName -var ( - InvalidAutoBindingSoundName Sound + Sound1 Sound ) +play Sound1 run "assets", {Title: "My Game"} `), "MySprite.spx": []byte(` const ConstSoundName = "ConstSoundName" var ( - VarSoundName string - AutoBindingSoundName2 Sound + VarSoundName string + Sound2 Sound ) VarSoundName = "VarSoundName" onStart => { @@ -243,8 +232,8 @@ onStart => { play ConstSoundName play "LiteralSoundName" play VarSoundName - play AutoBindingSoundName - play AutoBindingSoundName2 + play Sound1 + play Sound2 } `), "assets/index.json": []byte(`{}`), @@ -258,42 +247,8 @@ onStart => { fullReport := item.Value.(WorkspaceFullDocumentDiagnosticReport) assert.Equal(t, string(DiagnosticFull), fullReport.Kind) switch fullReport.URI { - case "file:///main.spx": - require.Len(t, fullReport.Items, 3) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: `sound resource "AutoBindingSoundName" not found`, - Range: Range{ - Start: Position{Line: 2, Character: 1}, - End: Position{Line: 2, Character: 21}, - }, - }) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: `sound resource "AutoBindingSoundName" not found`, - Range: Range{ - Start: Position{Line: 4, Character: 5}, - End: Position{Line: 4, Character: 25}, - }, - }) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityWarning, - Message: "resources must be defined in the first var block for auto-binding", - Range: Range{ - Start: Position{Line: 6, Character: 1}, - End: Position{Line: 6, Character: 28}, - }, - }) case "file:///MySprite.spx": - require.Len(t, fullReport.Items, 5) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityWarning, - Message: "auto-binding of resources can only happen in main.spx", - Range: Range{ - Start: Position{Line: 4, Character: 1}, - End: Position{Line: 4, Character: 22}, - }, - }) + require.Len(t, fullReport.Items, 3) assert.Contains(t, fullReport.Items, Diagnostic{ Severity: SeverityError, Message: "sound resource name cannot be empty", @@ -318,14 +273,6 @@ onStart => { End: Position{Line: 10, Character: 24}, }, }) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: `sound resource "AutoBindingSoundName" not found`, - Range: Range{ - Start: Position{Line: 12, Character: 6}, - End: Position{Line: 12, Character: 26}, - }, - }) default: assert.Empty(t, fullReport.Items) } @@ -406,9 +353,8 @@ onStart => { s := New(newMapFSWithoutModTime(map[string][]byte{ "main.spx": []byte(` var ( - MySprite1 Sprite - MySprite2 MySprite2 - MySprite2a MySprite2 + MySprite1 Sprite + MySprite2 MySprite2 ) run "assets", {Title: "My Game"} `), @@ -437,42 +383,7 @@ onStart => { fullReport := item.Value.(WorkspaceFullDocumentDiagnosticReport) assert.Equal(t, string(DiagnosticFull), fullReport.Kind) switch fullReport.URI { - case "file:///main.spx": - require.Len(t, fullReport.Items, 3) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: `sprite resource "MySprite1" not found`, - Range: Range{ - Start: Position{Line: 2, Character: 1}, - End: Position{Line: 2, Character: 10}, - }, - }) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: `sprite resource "MySprite2" not found`, - Range: Range{ - Start: Position{Line: 3, Character: 1}, - End: Position{Line: 3, Character: 10}, - }, - }) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: "sprite resource name must match type name for explicit auto-binding to work", - Range: Range{ - Start: Position{Line: 4, Character: 1}, - End: Position{Line: 4, Character: 11}, - }, - }) case "file:///MySprite1.spx": - require.Len(t, fullReport.Items, 3) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityWarning, - Message: "auto-binding of resources can only happen in main.spx", - Range: Range{ - Start: Position{Line: 1, Character: 4}, - End: Position{Line: 1, Character: 13}, - }, - }) assert.Contains(t, fullReport.Items, Diagnostic{ Severity: SeverityError, Message: `sprite resource "MySprite1" not found`, @@ -490,15 +401,6 @@ onStart => { }, }) case "file:///MySprite2.spx": - require.Len(t, fullReport.Items, 3) - assert.Contains(t, fullReport.Items, Diagnostic{ - Severity: SeverityError, - Message: `sprite resource "MySprite1" not found`, - Range: Range{ - Start: Position{Line: 2, Character: 1}, - End: Position{Line: 2, Character: 10}, - }, - }) assert.Contains(t, fullReport.Items, Diagnostic{ Severity: SeverityError, Message: `sprite resource "MySprite2" not found`, @@ -706,9 +608,7 @@ onStart => { "main.spx": []byte(` onKey KeyLeft, => {} -// FIXME: Multi-key bindings currently fail because goplus/gogen lacks support for types.Alias. -// See https://github.com/goplus/gogen/issues/457 for details. -// onKey [KeyRight, KeyUp, KeyDown], => {} +onKey [KeyRight, KeyUp, KeyDown], => {} run "assets", {Title: "My Game"} `), @@ -725,4 +625,30 @@ run "assets", {Title: "My Game"} assert.Empty(t, fullReport.Items) } }) + + t.Run("NoTypeSpriteVarDeclaration", func(t *testing.T) { + s := New(newMapFSWithoutModTime(map[string][]byte{ + "main.spx": []byte(`// A spx game. + +var ( + MySprite +) + +run "assets", {Title: "My Game"} +`), + "MySprite.spx": []byte(``), + "assets/index.json": []byte(`{}`), + "assets/sprites/MySprite/index.json": []byte(`{}`), + }), nil) + + report, err := s.workspaceDiagnostic(&WorkspaceDiagnosticParams{}) + require.NoError(t, err) + require.NotNil(t, report) + assert.Len(t, report.Items, 2) + for _, item := range report.Items { + fullReport := item.Value.(WorkspaceFullDocumentDiagnosticReport) + assert.Equal(t, string(DiagnosticFull), fullReport.Kind) + assert.Empty(t, fullReport.Items) + } + }) } diff --git a/tools/spxls/internal/server/document_test.go b/tools/spxls/internal/server/document_test.go index 4120e30c5..242e04893 100644 --- a/tools/spxls/internal/server/document_test.go +++ b/tools/spxls/internal/server/document_test.go @@ -19,7 +19,7 @@ run "assets", {Title: "Bullet (by Go+)"} `), "MySprite.spx": []byte(` onStart => { - play "sound1" + play "MySound" onBackdrop "backdrop1", func() {} MySprite.setCostume "costume1" MySprite.animate "anim1" @@ -28,7 +28,7 @@ onStart => { `), "assets/index.json": []byte(`{"backdrops":[{"name":"backdrop1"}],"zorder":[{"name":"widget1","type":"monitor"}]}`), "assets/sprites/MySprite/index.json": []byte(`{"costumes":[{"name":"costume1"}],"fAnimations":{"anim1":{}}}`), - "assets/sounds/sound1/index.json": []byte(`{}`), + "assets/sounds/MySound/index.json": []byte(`{}`), }), nil) paramsForMainSpx := &DocumentLinkParams{ @@ -119,9 +119,9 @@ onStart => { assert.Contains(t, linksForMySpriteSpx, DocumentLink{ Range: Range{ Start: Position{Line: 2, Character: 6}, - End: Position{Line: 2, Character: 14}, + End: Position{Line: 2, Character: 15}, }, - Target: toURI("spx://resources/sounds/sound1"), + Target: toURI("spx://resources/sounds/MySound"), Data: SpxResourceRefDocumentLinkData{ Kind: SpxResourceRefKindStringLiteral, }, @@ -216,6 +216,8 @@ onStart => { var ( MySound Sound `), + "assets/index.json": []byte(`{}`), + "assets/sounds/MySound/index.json": []byte(`{}`), }), nil) params := &DocumentLinkParams{ TextDocument: TextDocumentIdentifier{URI: "file:///main.spx"}, diff --git a/tools/spxls/internal/server/format.go b/tools/spxls/internal/server/format.go index 5dda9d74d..043f8ca0a 100644 --- a/tools/spxls/internal/server/format.go +++ b/tools/spxls/internal/server/format.go @@ -9,6 +9,7 @@ import ( gopast "github.com/goplus/gop/ast" gopfmt "github.com/goplus/gop/format" gopparser "github.com/goplus/gop/parser" + "github.com/goplus/gop/parser/fsx/memfs" goptoken "github.com/goplus/gop/token" ) @@ -58,25 +59,37 @@ func (s *Server) textDocumentFormatting(params *DocumentFormattingParams) ([]Tex func formatSpx(src []byte) ([]byte, error) { // Parse the source into AST. fset := goptoken.NewFileSet() - f, err := gopparser.ParseFile(fset, "main.spx", src, gopparser.ParseComments|gopparser.ParseGoPlusClass) - if err != nil { + astFile, err := gopparser.ParseFSEntry(fset, memfs.SingleFile("", "main.spx", string(src)), "main.spx", nil, gopparser.Config{ + Mode: gopparser.ParseComments | gopparser.ParseGoPlusClass, + }) + if astFile == nil { + // Return error only if parsing completely failed. For partial parsing + // failures, we proceed with formatting. return nil, err } - gopast.SortImports(fset, f) + // Sort import statements first. + gopast.SortImports(fset, astFile) - // Find all var blocks and function declarations. + // Collect all declarations. var ( - varBlocks []*gopast.GenDecl - funcDecls []gopast.Decl - otherDecls []gopast.Decl + importDecls []gopast.Decl + constDecls []gopast.Decl + varBlocks []*gopast.GenDecl + funcDecls []gopast.Decl + otherDecls []gopast.Decl ) - for _, decl := range f.Decls { + for _, decl := range astFile.Decls { switch d := decl.(type) { case *gopast.GenDecl: - if d.Tok == goptoken.VAR { + switch d.Tok { + case goptoken.IMPORT: + importDecls = append(importDecls, d) + case goptoken.CONST: + constDecls = append(constDecls, d) + case goptoken.VAR: varBlocks = append(varBlocks, d) - } else { + default: otherDecls = append(otherDecls, d) } case *gopast.FuncDecl: @@ -86,10 +99,12 @@ func formatSpx(src []byte) ([]byte, error) { } } - // Reorder declarations: vars -> funcs -> others. + // Reorder declarations: imports -> vars -> funcs -> others. // // See https://github.com/goplus/builder/issues/591 and https://github.com/goplus/builder/issues/752. - newDecls := make([]gopast.Decl, 0, len(f.Decls)) + newDecls := make([]gopast.Decl, 0, len(astFile.Decls)) + newDecls = append(newDecls, importDecls...) + newDecls = append(newDecls, constDecls...) if len(varBlocks) > 0 { // Merge multiple var blocks into a single one. firstVarBlock := varBlocks[0] @@ -112,11 +127,11 @@ func formatSpx(src []byte) ([]byte, error) { } newDecls = append(newDecls, funcDecls...) newDecls = append(newDecls, otherDecls...) - f.Decls = newDecls + astFile.Decls = newDecls // Format the modified AST. var buf bytes.Buffer - if err := gopfmt.Node(&buf, fset, f); err != nil { + if err := gopfmt.Node(&buf, fset, astFile); err != nil { return nil, err } return buf.Bytes(), nil diff --git a/tools/spxls/internal/server/format_test.go b/tools/spxls/internal/server/format_test.go index a6820d7a5..2bab7c4ae 100644 --- a/tools/spxls/internal/server/format_test.go +++ b/tools/spxls/internal/server/format_test.go @@ -81,18 +81,35 @@ run "assets", {Title: "Bullet (by Go+)"} require.Nil(t, edits) }) - t.Run("FormatError", func(t *testing.T) { + t.Run("AcceptableFormatError", func(t *testing.T) { s := New(newMapFSWithoutModTime(map[string][]byte{ - "main.spx": []byte("vbr Foobar string"), + "main.spx": []byte(`// A spx game. + +var MyAircraft MyAircraft +!InvalidSyntax +`), }), nil) params := &DocumentFormattingParams{ TextDocument: TextDocumentIdentifier{URI: "file:///main.spx"}, } edits, err := s.textDocumentFormatting(params) - require.Error(t, err) - require.Contains(t, err.Error(), "failed to format spx source file") - require.Nil(t, edits) + require.NoError(t, err) + require.Len(t, edits, 1) + assert.Contains(t, edits, TextEdit{ + Range: Range{ + Start: Position{Line: 0, Character: 0}, + End: Position{Line: 4, Character: 0}, + }, + NewText: `// A spx game. + +var ( + MyAircraft MyAircraft +) + +!InvalidSyntax +`, + }) }) t.Run("WithFormatSpx", func(t *testing.T) { @@ -179,9 +196,27 @@ var ( run "assets", {Title: "My Game"} `), - "MySprite.spx": []byte(``), - "assets/index.json": []byte(`{}`), - "assets/sprites/MySprite/index.json": []byte(`{}`), + }), nil) + params := &DocumentFormattingParams{ + TextDocument: TextDocumentIdentifier{URI: "file:///main.spx"}, + } + + edits, err := s.textDocumentFormatting(params) + require.NoError(t, err) + require.Nil(t, edits) + }) + + t.Run("WithImportStmt", func(t *testing.T) { + s := New(newMapFSWithoutModTime(map[string][]byte{ + "main.spx": []byte(`// A spx game. +import "math" + +onClick => { + println math.floor(2.5) +} + +run "assets", {Title: "My Game"} +`), }), nil) params := &DocumentFormattingParams{ TextDocument: TextDocumentIdentifier{URI: "file:///main.spx"}, diff --git a/tools/spxls/internal/server/rename.go b/tools/spxls/internal/server/rename.go index 1f4e0a4f8..d6f11c93d 100644 --- a/tools/spxls/internal/server/rename.go +++ b/tools/spxls/internal/server/rename.go @@ -27,7 +27,7 @@ func (s *Server) textDocumentPrepareRename(params *PrepareRenameParams) (*Range, return nil, nil } obj := result.typeInfo.ObjectOf(ident) - if !isRenameableObject(obj) { + if !isRenameableObject(obj) || result.isGameOrSpriteThisPtr(obj) { return nil, nil } @@ -60,7 +60,7 @@ func (s *Server) textDocumentRename(params *RenameParams) (*WorkspaceEdit, error } obj := result.typeInfo.ObjectOf(result.identAtASTFilePosition(astFile, params.Position)) - if !isRenameableObject(obj) { + if !isRenameableObject(obj) || result.isGameOrSpriteThisPtr(obj) { return nil, nil } diff --git a/tools/spxls/internal/server/rename_test.go b/tools/spxls/internal/server/rename_test.go index 36730f77a..28e86768f 100644 --- a/tools/spxls/internal/server/rename_test.go +++ b/tools/spxls/internal/server/rename_test.go @@ -61,6 +61,42 @@ onStart => { require.NoError(t, err) require.Nil(t, range3) }) + + t.Run("MainGameAndSpriteThisPtrs", func(t *testing.T) { + s := New(newMapFSWithoutModTime(map[string][]byte{ + "main.spx": []byte(` +onClick => { + _ = this +} +run "assets", {Title: "My Game"} +`), + "MySprite.spx": []byte(` +onClick => { + _ = this +} +`), + "assets/index.json": []byte(`{}`), + "assets/sprites/MySprite/index.json": []byte(`{}`), + }), nil) + + range1, err := s.textDocumentPrepareRename(&PrepareRenameParams{ + TextDocumentPositionParams: TextDocumentPositionParams{ + TextDocument: TextDocumentIdentifier{URI: "file:///main.spx"}, + Position: Position{Line: 2, Character: 5}, + }, + }) + require.NoError(t, err) + require.Nil(t, range1) + + range2, err := s.textDocumentPrepareRename(&PrepareRenameParams{ + TextDocumentPositionParams: TextDocumentPositionParams{ + TextDocument: TextDocumentIdentifier{URI: "file:///MySprite.spx"}, + Position: Position{Line: 2, Character: 5}, + }, + }) + require.NoError(t, err) + require.Nil(t, range2) + }) } func TestServerTextDocumentRename(t *testing.T) { @@ -218,6 +254,40 @@ onStart => { NewText: "NewSprite", }) }) + + t.Run("MainGameAndSpriteThisPtrs", func(t *testing.T) { + s := New(newMapFSWithoutModTime(map[string][]byte{ + "main.spx": []byte(` +onClick => { + _ = this +} +run "assets", {Title: "My Game"} +`), + "MySprite.spx": []byte(` +onClick => { + _ = this +} +`), + "assets/index.json": []byte(`{}`), + "assets/sprites/MySprite/index.json": []byte(`{}`), + }), nil) + + mainSpxWorkspaceEdit, err := s.textDocumentRename(&RenameParams{ + TextDocument: TextDocumentIdentifier{URI: "file:///main.spx"}, + Position: Position{Line: 2, Character: 5}, + NewName: "that", + }) + require.NoError(t, err) + require.Nil(t, mainSpxWorkspaceEdit) + + mySpriteSpxWorkspaceEdit, err := s.textDocumentRename(&RenameParams{ + TextDocument: TextDocumentIdentifier{URI: "file:///MySprite.spx"}, + Position: Position{Line: 2, Character: 5}, + NewName: "that", + }) + require.NoError(t, err) + require.Nil(t, mySpriteSpxWorkspaceEdit) + }) } func TestServerSpxRenameBackdropResource(t *testing.T) { diff --git a/tools/spxls/internal/server/spx_definition.go b/tools/spxls/internal/server/spx_definition.go index c4ad4ede9..af80b6e67 100644 --- a/tools/spxls/internal/server/spx_definition.go +++ b/tools/spxls/internal/server/spx_definition.go @@ -260,15 +260,15 @@ var GetSpxPkg = sync.OnceValue(func() *types.Package { }) // GetSpxGameType returns the [spx.Game] type. -var GetSpxGameType = sync.OnceValue(func() types.Type { +var GetSpxGameType = sync.OnceValue(func() *types.Named { spxPkg := GetSpxPkg() - return spxPkg.Scope().Lookup("Game").Type() + return spxPkg.Scope().Lookup("Game").Type().(*types.Named) }) // GetSpxSpriteImplType returns the [spx.SpriteImpl] type. -var GetSpxSpriteImplType = sync.OnceValue(func() types.Type { +var GetSpxSpriteImplType = sync.OnceValue(func() *types.Named { spxPkg := GetSpxPkg() - return spxPkg.Scope().Lookup("SpriteImpl").Type() + return spxPkg.Scope().Lookup("SpriteImpl").Type().(*types.Named) }) // GetSpxPkgDefinitions returns the spx definitions for the spx package. diff --git a/tools/spxls/internal/server/util.go b/tools/spxls/internal/server/util.go index 3a3ee08fb..2af59d895 100644 --- a/tools/spxls/internal/server/util.go +++ b/tools/spxls/internal/server/util.go @@ -32,15 +32,6 @@ func listSpxFiles(rootFS fs.ReadDirFS) ([]string, error) { return files, nil } -// gopASTFileMapToSlice converts a map of [gopast.File] to a slice of [gopast.File]. -func gopASTFileMapToSlice(fileMap map[string]*gopast.File) []*gopast.File { - files := make([]*gopast.File, 0, len(fileMap)) - for _, file := range fileMap { - files = append(files, file) - } - return files -} - // unwrapPointerType returns the underlying type of t. For pointer types, it // returns the element type that the pointer points to. For non-pointer types, // it returns the type unchanged.