Redo how images are handled, more world objects work, custom tailored interner

This commit is contained in:
DBotThePony 2023-09-17 18:27:16 +07:00
parent 57c32beb0d
commit ef52700ff2
Signed by: DBot
GPG Key ID: DCC23B5715498507
43 changed files with 1132 additions and 3655 deletions

View File

@ -1,713 +0,0 @@
#
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x00007ffb7c599920, pid=22156, tid=44476
#
# JRE version: OpenJDK Runtime Environment Temurin-17.0.1+12 (17.0.1+12) (build 17.0.1+12)
# Java VM: OpenJDK 64-Bit Server VM Temurin-17.0.1+12 (17.0.1+12, mixed mode, sharing, tiered, compressed oops, compressed class ptrs, g1 gc, windows-amd64)
# Problematic frame:
# C [atio6axx.dll+0x1fe9920]
#
# No core dump will be written. Minidumps are not enabled by default on client versions of Windows
#
# If you would like to submit a bug report, please visit:
# https://github.com/adoptium/adoptium-support/issues
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
--------------- S U M M A R Y ------------
Command Line: -Xms128m -javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\lib\idea_rt.jar=5828:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin -Dfile.encoding=UTF-8 ru.dbotthepony.kstarbound.MainKt
Host: AMD Ryzen 7 3700X 8-Core Processor , 16 cores, 63G, Windows 10 , 64 bit Build 19041 (10.0.19041.1706)
Time: Sun Sep 10 10:43:10 2023 RTZ 6 (s 10 , 64 bit Build 19041 (10.0.19041.1706) elapsed time: 2.030508 seconds (0d 0h 0m 2s)
--------------- T H R E A D ---------------
Current thread (0x00000216e2a20490): JavaThread "main" [_thread_in_native, id=44476, stack(0x0000004d5c500000,0x0000004d5c600000)]
Stack: [0x0000004d5c500000,0x0000004d5c600000], sp=0x0000004d5c5fef88, free space=1019k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
C [atio6axx.dll+0x1fe9920]
Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
j org.lwjgl.opengl.GL11C.nglTexImage2D(IIIIIIIIJ)V+0
j org.lwjgl.opengl.GL11C.glTexImage2D(IIIIIIIILjava/nio/ByteBuffer;)V+17
j org.lwjgl.opengl.GL11.glTexImage2D(IIIIIIIILjava/nio/ByteBuffer;)V+14
j ru.dbotthepony.kstarbound.client.gl.GLTexture2D.upload(IIIIIILjava/nio/ByteBuffer;)Lru/dbotthepony/kstarbound/client/gl/GLTexture2D;+105
j ru.dbotthepony.kstarbound.client.gl.GLTexture2D.upload(IIIIILjava/nio/ByteBuffer;)Lru/dbotthepony/kstarbound/client/gl/GLTexture2D;+18
j ru.dbotthepony.kstarbound.client.StarboundClient.renderFrame()Z+716
j ru.dbotthepony.kstarbound.MainKt.main()V+253
j ru.dbotthepony.kstarbound.MainKt.main([Ljava/lang/String;)V+0
v ~StubRoutines::call_stub
siginfo: EXCEPTION_ACCESS_VIOLATION (0xc0000005), reading address 0x00000216b3843c70
Register to memory mapping:
RIP=0x00007ffb7c599920 atio6axx.dll
RAX=0x00000216b138ba78 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RBX=0x00000216b138ba40 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RCX=0x00000216b138ba78 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RDX=0x00000216b38412e0 points into unknown readable memory: 0x5400bf0071000500 | 00 05 00 71 00 bf 00 54
RSP=0x0000004d5c5fef88 is pointing into the stack for thread: 0x00000216e2a20490
RBP=0x0000004d5c5ff021 is pointing into the stack for thread: 0x00000216e2a20490
RSI=0x00000216b138ba78 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RDI=0x0000000000001908 is an unknown value
R8 =0x00000000000029b0 is an unknown value
R9 =0x00000000000000b8 is an unknown value
R10=0x00007ffb7a5b0000 atio6axx.dll
R11=0x00000216b08e2690 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
R12=0x00000000000029b0 is an unknown value
R13=0x00000000000029b0 is an unknown value
R14=0x00000216b0820080 points into unknown readable memory: 0x00007ffb7d8691f0 | f0 91 86 7d fb 7f 00 00
R15=0x0 is NULL
Registers:
RAX=0x00000216b138ba78, RBX=0x00000216b138ba40, RCX=0x00000216b138ba78, RDX=0x00000216b38412e0
RSP=0x0000004d5c5fef88, RBP=0x0000004d5c5ff021, RSI=0x00000216b138ba78, RDI=0x0000000000001908
R8 =0x00000000000029b0, R9 =0x00000000000000b8, R10=0x00007ffb7a5b0000, R11=0x00000216b08e2690
R12=0x00000000000029b0, R13=0x00000000000029b0, R14=0x00000216b0820080, R15=0x0000000000000000
RIP=0x00007ffb7c599920, EFLAGS=0x0000000000010246
Top of Stack: (sp=0x0000004d5c5fef88)
0x0000004d5c5fef88: 00007ffb7ad699f3 00000216a5f13e98
0x0000004d5c5fef98: 0000000000000000 0000021600000001
0x0000004d5c5fefa8: 000000003f800000 000000000000003a
0x0000004d5c5fefb8: 00007ffb00000001 0000021600001908
0x0000004d5c5fefc8: 0000000000001401 0000000000000000
0x0000004d5c5fefd8: 000000003f71a9fc 0000000100000000
0x0000004d5c5fefe8: 0000000200000001 0000000000000000
0x0000004d5c5feff8: 00000000000029b0 00000000000029e8
0x0000004d5c5ff008: 0000000000000000 000029f5bbbd2f0a
0x0000004d5c5ff018: 0000000000000001 0000000000000000
0x0000004d5c5ff028: 0000000000001908 0000000000001401
0x0000004d5c5ff038: 000000000000003a 0000000000000000
0x0000004d5c5ff048: 0000000000000000 00000216b383e930
0x0000004d5c5ff058: 00000216b0820080 00000216af85def8
0x0000004d5c5ff068: 00007ffb7ae43bd7 00000216b0820000
0x0000004d5c5ff078: 0000021600000de1 0000021600000000
Instructions: (pc=0x00007ffb7c599920)
0x00007ffb7c599820: 89 40 04 44 88 48 06 c3 4c 8b 02 8b 4a 08 44 0f
0x00007ffb7c599830: b7 4a 0c 4c 89 00 89 48 08 66 44 89 48 0c c3 0f
0x00007ffb7c599840: b7 0a 44 0f b6 42 02 66 89 08 44 88 40 02 c3 90
0x00007ffb7c599850: 4c 8b 02 8b 4a 08 44 0f b6 4a 0c 4c 89 00 89 48
0x00007ffb7c599860: 08 44 88 48 0c c3 4c 8b 02 0f b7 4a 08 4c 89 00
0x00007ffb7c599870: 66 89 48 08 c3 4c 8b 02 0f b6 4a 08 4c 89 00 88
0x00007ffb7c599880: 48 08 c3 4c 8b 02 8b 4a 08 4c 89 00 89 48 08 c3
0x00007ffb7c599890: 8b 0a 44 0f b7 42 04 89 08 66 44 89 40 04 c3 8b
0x00007ffb7c5998a0: 0a 44 0f b6 42 04 89 08 44 88 40 04 c3 48 8b 0a
0x00007ffb7c5998b0: 48 89 08 c3 0f b6 0a 88 08 c3 8b 0a 89 08 c3 90
0x00007ffb7c5998c0: 49 83 f8 20 77 17 f3 0f 6f 0a f3 42 0f 6f 54 02
0x00007ffb7c5998d0: f0 f3 0f 7f 09 f3 42 0f 7f 54 01 f0 c3 48 3b d1
0x00007ffb7c5998e0: 73 0e 4e 8d 0c 02 49 3b c9 0f 82 41 04 00 00 90
0x00007ffb7c5998f0: 83 3d 21 37 8d 01 03 0f 82 e3 02 00 00 49 81 f8
0x00007ffb7c599900: 00 20 00 00 76 16 49 81 f8 00 00 18 00 77 0d f6
0x00007ffb7c599910: 05 be d0 a3 01 02 0f 85 64 fe ff ff c5 fe 6f 02
0x00007ffb7c599920: c4 a1 7e 6f 6c 02 e0 49 81 f8 00 01 00 00 0f 86
0x00007ffb7c599930: c4 00 00 00 4c 8b c9 49 83 e1 1f 49 83 e9 20 49
0x00007ffb7c599940: 2b c9 49 2b d1 4d 03 c1 49 81 f8 00 01 00 00 0f
0x00007ffb7c599950: 86 a3 00 00 00 49 81 f8 00 00 18 00 0f 87 3e 01
0x00007ffb7c599960: 00 00 66 66 66 66 66 66 0f 1f 84 00 00 00 00 00
0x00007ffb7c599970: c5 fe 6f 0a c5 fe 6f 52 20 c5 fe 6f 5a 40 c5 fe
0x00007ffb7c599980: 6f 62 60 c5 fd 7f 09 c5 fd 7f 51 20 c5 fd 7f 59
0x00007ffb7c599990: 40 c5 fd 7f 61 60 c5 fe 6f 8a 80 00 00 00 c5 fe
0x00007ffb7c5999a0: 6f 92 a0 00 00 00 c5 fe 6f 9a c0 00 00 00 c5 fe
0x00007ffb7c5999b0: 6f a2 e0 00 00 00 c5 fd 7f 89 80 00 00 00 c5 fd
0x00007ffb7c5999c0: 7f 91 a0 00 00 00 c5 fd 7f 99 c0 00 00 00 c5 fd
0x00007ffb7c5999d0: 7f a1 e0 00 00 00 48 81 c1 00 01 00 00 48 81 c2
0x00007ffb7c5999e0: 00 01 00 00 49 81 e8 00 01 00 00 49 81 f8 00 01
0x00007ffb7c5999f0: 00 00 0f 83 78 ff ff ff 4d 8d 48 1f 49 83 e1 e0
0x00007ffb7c599a00: 4d 8b d9 49 c1 eb 05 47 8b 9c 9a 40 b0 c1 03 4d
0x00007ffb7c599a10: 03 da 41 ff e3 c4 a1 7e 6f 8c 0a 00 ff ff ff c4
Stack slot to memory mapping:
stack at sp + 0 slots: 0x00007ffb7ad699f3 atio6axx.dll
stack at sp + 1 slots: {method} {0x00000216a5f13ea0} 'access$positiveMod' '(Lkotlin/collections/ArrayDeque;I)I' in 'kotlin/collections/ArrayDeque'
stack at sp + 2 slots: 0x0 is NULL
stack at sp + 3 slots: 0x0000021600000001 is an unknown value
stack at sp + 4 slots: 0x000000003f800000 is an unknown value
stack at sp + 5 slots: 0x000000000000003a is an unknown value
stack at sp + 6 slots: 0x00007ffb00000001 is an unknown value
stack at sp + 7 slots: 0x0000021600001908 is an unknown value
--------------- P R O C E S S ---------------
Threads class SMR info:
_java_thread_list=0x00000216b30e95c0, length=42, elements={
0x00000216e2a20490, 0x00000216a2144690, 0x00000216a21452b0, 0x00000216a215daf0,
0x00000216a21604c0, 0x00000216a2160d80, 0x00000216a2161640, 0x00000216a2162230,
0x00000216a21706c0, 0x00000216a2179790, 0x00000216a212a0e0, 0x00000216a390b930,
0x00000216a390bef0, 0x00000216a3a5abe0, 0x00000216a3a5b0b0, 0x00000216a423ad70,
0x00000216b0230af0, 0x00000216b299aa60, 0x00000216a479be30, 0x00000216b2e101f0,
0x00000216b3245070, 0x00000216b3245540, 0x00000216a4876030, 0x00000216a4876500,
0x00000216a42a3fb0, 0x00000216a42a1e00, 0x00000216a42a22d0, 0x00000216a42a4480,
0x00000216a42a52f0, 0x00000216a42a57c0, 0x00000216a42a4950, 0x00000216a42a27a0,
0x00000216a42a3140, 0x00000216a42a3610, 0x00000216a42a4e20, 0x00000216b2a4a8f0,
0x00000216b2a4c100, 0x00000216b366eaa0, 0x00000216b288f110, 0x00000216b2a0a3a0,
0x00000216b288fe30, 0x00000216b3176c30
}
Java Threads: ( => current thread )
=>0x00000216e2a20490 JavaThread "main" [_thread_in_native, id=44476, stack(0x0000004d5c500000,0x0000004d5c600000)]
0x00000216a2144690 JavaThread "Reference Handler" daemon [_thread_blocked, id=53852, stack(0x0000004d5cc00000,0x0000004d5cd00000)]
0x00000216a21452b0 JavaThread "Finalizer" daemon [_thread_blocked, id=2200, stack(0x0000004d5cd00000,0x0000004d5ce00000)]
0x00000216a215daf0 JavaThread "Signal Dispatcher" daemon [_thread_blocked, id=42548, stack(0x0000004d5ce00000,0x0000004d5cf00000)]
0x00000216a21604c0 JavaThread "Attach Listener" daemon [_thread_blocked, id=34984, stack(0x0000004d5cf00000,0x0000004d5d000000)]
0x00000216a2160d80 JavaThread "Service Thread" daemon [_thread_blocked, id=12136, stack(0x0000004d5d000000,0x0000004d5d100000)]
0x00000216a2161640 JavaThread "Monitor Deflation Thread" daemon [_thread_blocked, id=16316, stack(0x0000004d5d100000,0x0000004d5d200000)]
0x00000216a2162230 JavaThread "C2 CompilerThread0" daemon [_thread_blocked, id=22980, stack(0x0000004d5d200000,0x0000004d5d300000)]
0x00000216a21706c0 JavaThread "C1 CompilerThread0" daemon [_thread_blocked, id=14080, stack(0x0000004d5d300000,0x0000004d5d400000)]
0x00000216a2179790 JavaThread "Sweeper thread" daemon [_thread_in_vm, id=23672, stack(0x0000004d5d400000,0x0000004d5d500000)]
0x00000216a212a0e0 JavaThread "Common-Cleaner" daemon [_thread_blocked, id=46420, stack(0x0000004d5d500000,0x0000004d5d600000)]
0x00000216a390b930 JavaThread "C1 CompilerThread1" daemon [_thread_in_native, id=12960, stack(0x0000004d5d600000,0x0000004d5d700000)]
0x00000216a390bef0 JavaThread "C1 CompilerThread2" daemon [_thread_blocked, id=46320, stack(0x0000004d5d700000,0x0000004d5d800000)]
0x00000216a3a5abe0 JavaThread "Monitor Ctrl-Break" daemon [_thread_in_native, id=52364, stack(0x0000004d5d900000,0x0000004d5da00000)]
0x00000216a3a5b0b0 JavaThread "Notification Thread" daemon [_thread_blocked, id=59672, stack(0x0000004d5da00000,0x0000004d5db00000)]
0x00000216a423ad70 JavaThread "C1 CompilerThread3" daemon [_thread_in_native, id=3032, stack(0x0000004d5df00000,0x0000004d5e000000)]
0x00000216b0230af0 JavaThread "C2 CompilerThread1" daemon [_thread_blocked, id=61288, stack(0x0000004d5d800000,0x0000004d5d900000)]
0x00000216b299aa60 JavaThread "C2 CompilerThread2" daemon [_thread_blocked, id=18836, stack(0x0000004d5e000000,0x0000004d5e100000)]
0x00000216a479be30 JavaThread "JNA Cleaner" daemon [_thread_blocked, id=60872, stack(0x0000004d5e700000,0x0000004d5e800000)]
0x00000216b2e101f0 JavaThread "OpenGL Object Cleaner for ru.dbotthepony.kstarbound.client.gl.GLStateTracker@c7ba306" daemon [_thread_blocked, id=59492, stack(0x0000004d5e800000,0x0000004d5e900000)]
0x00000216b3245070 JavaThread "Starbound Lighting Thread 0" daemon [_thread_blocked, id=62268, stack(0x0000004d5f200000,0x0000004d5f300000)]
0x00000216b3245540 JavaThread "Starbound Lighting Thread 1" daemon [_thread_blocked, id=26384, stack(0x0000004d5f300000,0x0000004d5f400000)]
0x00000216a4876030 JavaThread "Starbound Lighting Thread 2" daemon [_thread_blocked, id=58660, stack(0x0000004d5f400000,0x0000004d5f500000)]
0x00000216a4876500 JavaThread "Starbound Lighting Thread 3" daemon [_thread_blocked, id=28780, stack(0x0000004d5f500000,0x0000004d5f600000)]
0x00000216a42a3fb0 JavaThread "Starbound Lighting Thread 4" daemon [_thread_blocked, id=58196, stack(0x0000004d5f600000,0x0000004d5f700000)]
0x00000216a42a1e00 JavaThread "Starbound Lighting Thread 5" daemon [_thread_blocked, id=55400, stack(0x0000004d5f700000,0x0000004d5f800000)]
0x00000216a42a22d0 JavaThread "Starbound Lighting Thread 6" daemon [_thread_blocked, id=17744, stack(0x0000004d5f800000,0x0000004d5f900000)]
0x00000216a42a4480 JavaThread "Starbound Lighting Thread 7" daemon [_thread_blocked, id=11368, stack(0x0000004d5f900000,0x0000004d5fa00000)]
0x00000216a42a52f0 JavaThread "Starbound Lighting Thread 8" daemon [_thread_blocked, id=39724, stack(0x0000004d5fa00000,0x0000004d5fb00000)]
0x00000216a42a57c0 JavaThread "Starbound Lighting Thread 9" daemon [_thread_blocked, id=42584, stack(0x0000004d5fb00000,0x0000004d5fc00000)]
0x00000216a42a4950 JavaThread "Starbound Lighting Thread 10" daemon [_thread_blocked, id=14760, stack(0x0000004d5fc00000,0x0000004d5fd00000)]
0x00000216a42a27a0 JavaThread "Starbound Lighting Thread 11" daemon [_thread_blocked, id=56672, stack(0x0000004d5fd00000,0x0000004d5fe00000)]
0x00000216a42a3140 JavaThread "Starbound Lighting Thread 12" daemon [_thread_blocked, id=37908, stack(0x0000004d5fe00000,0x0000004d5ff00000)]
0x00000216a42a3610 JavaThread "Starbound Lighting Thread 13" daemon [_thread_blocked, id=30428, stack(0x0000004d5ff00000,0x0000004d60000000)]
0x00000216a42a4e20 JavaThread "Starbound Lighting Thread 14" daemon [_thread_blocked, id=20316, stack(0x0000004d60000000,0x0000004d60100000)]
0x00000216b2a4a8f0 JavaThread "Starbound Lighting Thread 15" daemon [_thread_blocked, id=10956, stack(0x0000004d60100000,0x0000004d60200000)]
0x00000216b2a4c100 JavaThread "Asset Loader" daemon [_thread_in_Java, id=35652, stack(0x0000004d60400000,0x0000004d60500000)]
0x00000216b366eaa0 JavaThread "C2 CompilerThread3" daemon [_thread_blocked, id=49424, stack(0x0000004d60500000,0x0000004d60600000)]
0x00000216b288f110 JavaThread "C2 CompilerThread4" daemon [_thread_blocked, id=59124, stack(0x0000004d60600000,0x0000004d60700000)]
0x00000216b2a0a3a0 JavaThread "C2 CompilerThread5" daemon [_thread_blocked, id=34048, stack(0x0000004d60700000,0x0000004d60800000)]
0x00000216b288fe30 JavaThread "C2 CompilerThread6" daemon [_thread_blocked, id=51652, stack(0x0000004d60800000,0x0000004d60900000)]
0x00000216b3176c30 JavaThread "C2 CompilerThread7" daemon [_thread_blocked, id=30504, stack(0x0000004d60900000,0x0000004d60a00000)]
Other Threads:
0x00000216a213f740 VMThread "VM Thread" [stack: 0x0000004d5cb00000,0x0000004d5cc00000] [id=39668]
0x00000216a3afd4b0 WatcherThread [stack: 0x0000004d5db00000,0x0000004d5dc00000] [id=29464]
0x00000216e2ad6630 GCTaskThread "GC Thread#0" [stack: 0x0000004d5c600000,0x0000004d5c700000] [id=22132]
0x00000216a4121560 GCTaskThread "GC Thread#1" [stack: 0x0000004d5dc00000,0x0000004d5dd00000] [id=31040]
0x00000216a3d7f360 GCTaskThread "GC Thread#2" [stack: 0x0000004d5dd00000,0x0000004d5de00000] [id=62292]
0x00000216a4162f60 GCTaskThread "GC Thread#3" [stack: 0x0000004d5de00000,0x0000004d5df00000] [id=48496]
0x00000216a47a91c0 GCTaskThread "GC Thread#4" [stack: 0x0000004d5e900000,0x0000004d5ea00000] [id=27928]
0x00000216a47a8c60 GCTaskThread "GC Thread#5" [stack: 0x0000004d5ea00000,0x0000004d5eb00000] [id=59704]
0x00000216a47a8f10 GCTaskThread "GC Thread#6" [stack: 0x0000004d5eb00000,0x0000004d5ec00000] [id=58096]
0x00000216a47a9470 GCTaskThread "GC Thread#7" [stack: 0x0000004d5ec00000,0x0000004d5ed00000] [id=39348]
0x00000216a47a7ef0 GCTaskThread "GC Thread#8" [stack: 0x0000004d5ed00000,0x0000004d5ee00000] [id=59488]
0x00000216a47a81a0 GCTaskThread "GC Thread#9" [stack: 0x0000004d5ee00000,0x0000004d5ef00000] [id=55024]
0x00000216a47a9720 GCTaskThread "GC Thread#10" [stack: 0x0000004d5ef00000,0x0000004d5f000000] [id=39988]
0x00000216a47a99d0 GCTaskThread "GC Thread#11" [stack: 0x0000004d5f000000,0x0000004d5f100000] [id=17512]
0x00000216b2e75b80 GCTaskThread "GC Thread#12" [stack: 0x0000004d5f100000,0x0000004d5f200000] [id=55136]
0x00000216e2ae7440 ConcurrentGCThread "G1 Main Marker" [stack: 0x0000004d5c700000,0x0000004d5c800000] [id=43248]
0x00000216e2ae8500 ConcurrentGCThread "G1 Conc#0" [stack: 0x0000004d5c800000,0x0000004d5c900000] [id=63080]
0x00000216b2e72870 ConcurrentGCThread "G1 Conc#1" [stack: 0x0000004d60200000,0x0000004d60300000] [id=52788]
0x00000216b2e72b20 ConcurrentGCThread "G1 Conc#2" [stack: 0x0000004d60300000,0x0000004d60400000] [id=62424]
0x00000216a1ff5860 ConcurrentGCThread "G1 Refine#0" [stack: 0x0000004d5c900000,0x0000004d5ca00000] [id=55476]
0x00000216a1ff71a0 ConcurrentGCThread "G1 Service" [stack: 0x0000004d5ca00000,0x0000004d5cb00000] [id=44096]
Threads with active compile tasks:
C1 CompilerThread3 2087 3337 3 com.google.gson.stream.JsonReader::nextQuotedValue (270 bytes)
VM state: not at safepoint (normal execution)
VM Mutex/Monitor currently owned by a thread: ([mutex/lock_event])
[0x00000216e2a1bf10] CompiledIC_lock - owner thread: 0x00000216a2179790
Heap address: 0x0000000401000000, size: 16368 MB, Compressed Oops mode: Zero based, Oop shift amount: 3
CDS archive(s) mapped at: [0x0000000800000000-0x0000000800bc0000-0x0000000800bc0000), size 12320768, SharedBaseAddress: 0x0000000800000000, ArchiveRelocationMode: 0.
Compressed class space mapped at: 0x0000000800c00000-0x0000000840c00000, reserved size: 1073741824
Narrow klass base: 0x0000000800000000, Narrow klass shift: 0, Narrow klass range: 0x100000000
GC Precious Log:
CPUs: 16 total, 16 available
Memory: 65457M
Large Page Support: Disabled
NUMA Support: Disabled
Compressed Oops: Enabled (Zero based)
Heap Region Size: 8M
Heap Min Capacity: 128M
Heap Initial Capacity: 128M
Heap Max Capacity: 16368M
Pre-touch: Disabled
Parallel Workers: 13
Concurrent Workers: 3
Concurrent Refinement Workers: 13
Periodic GC: Disabled
Heap:
garbage-first heap total 131072K, used 61882K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 6 young (49152K), 2 survivors (16384K)
Metaspace used 28134K, committed 28480K, reserved 1081344K
class space used 2992K, committed 3136K, reserved 1048576K
Heap Regions: E=young(eden), S=young(survivor), O=old, HS=humongous(starts), HC=humongous(continues), CS=collection set, F=free, OA=open archive, CA=closed archive, TAMS=top-at-mark-start (previous, next)
| 0|0x0000000401000000, 0x000000040146ea00, 0x0000000401800000| 55%| O| |TAMS 0x0000000401446e00, 0x0000000401000000| Untracked
| 1|0x0000000401800000, 0x0000000402000000, 0x0000000402000000|100%|HS| |TAMS 0x0000000401800000, 0x0000000401800000| Complete
| 2|0x0000000402000000, 0x0000000402800000, 0x0000000402800000|100%|HC| |TAMS 0x0000000402000000, 0x0000000402000000| Complete
| 3|0x0000000402800000, 0x0000000402800000, 0x0000000403000000| 0%| F| |TAMS 0x0000000402800000, 0x0000000402800000| Untracked
| 4|0x0000000403000000, 0x0000000403000000, 0x0000000403800000| 0%| F| |TAMS 0x0000000403000000, 0x0000000403000000| Untracked
| 5|0x0000000403800000, 0x0000000404000000, 0x0000000404000000|100%| S|CS|TAMS 0x0000000403800000, 0x0000000403800000| Complete
| 6|0x0000000404000000, 0x0000000404800000, 0x0000000404800000|100%| S|CS|TAMS 0x0000000404000000, 0x0000000404000000| Complete
| 7|0x0000000404800000, 0x0000000404800000, 0x0000000405000000| 0%| F| |TAMS 0x0000000404800000, 0x0000000404800000| Untracked
| 8|0x0000000405000000, 0x0000000405000000, 0x0000000405800000| 0%| F| |TAMS 0x0000000405000000, 0x0000000405000000| Untracked
| 9|0x0000000405800000, 0x0000000405800000, 0x0000000406000000| 0%| F| |TAMS 0x0000000405800000, 0x0000000405800000| Untracked
| 10|0x0000000406000000, 0x0000000406000000, 0x0000000406800000| 0%| F| |TAMS 0x0000000406000000, 0x0000000406000000| Untracked
| 11|0x0000000406800000, 0x0000000406800000, 0x0000000407000000| 0%| F| |TAMS 0x0000000406800000, 0x0000000406800000| Untracked
| 12|0x0000000407000000, 0x000000040761a348, 0x0000000407800000| 76%| E| |TAMS 0x0000000407000000, 0x0000000407000000| Complete
| 13|0x0000000407800000, 0x0000000408000000, 0x0000000408000000|100%| E|CS|TAMS 0x0000000407800000, 0x0000000407800000| Complete
| 14|0x0000000408000000, 0x0000000408800000, 0x0000000408800000|100%| E|CS|TAMS 0x0000000408000000, 0x0000000408000000| Complete
| 15|0x0000000408800000, 0x0000000409000000, 0x0000000409000000|100%| E|CS|TAMS 0x0000000408800000, 0x0000000408800000| Complete
Card table byte_map: [0x00000216fbd70000,0x00000216fdd70000] _byte_map_base: 0x00000216f9d68000
Marking Bits (Prev, Next): (CMBitMap*) 0x00000216e2ad6b90, (CMBitMap*) 0x00000216e2ad6b50
Prev Bits: [0x000002168ffc0000, 0x000002169ff80000)
Next Bits: [0x0000021680000000, 0x000002168ffc0000)
Polling page: 0x00000216e21f0000
Metaspace:
Usage:
Non-class: 24.55 MB used.
Class: 2.92 MB used.
Both: 27.48 MB used.
Virtual space:
Non-class space: 32.00 MB reserved, 24.75 MB ( 77%) committed, 4 nodes.
Class space: 1.00 GB reserved, 3.06 MB ( <1%) committed, 1 nodes.
Both: 1.03 GB reserved, 27.81 MB ( 3%) committed.
Chunk freelists:
Non-Class: 2.55 MB
Class: 944.00 KB
Both: 3.47 MB
MaxMetaspaceSize: unlimited
CompressedClassSpaceSize: 1.00 GB
Initial GC threshold: 21.00 MB
Current GC threshold: 35.25 MB
CDS: on
MetaspaceReclaimPolicy: balanced
- commit_granule_bytes: 65536.
- commit_granule_words: 8192.
- virtual_space_node_default_size: 1048576.
- enlarge_chunks_in_place: 1.
- new_chunks_are_fully_committed: 0.
- uncommit_free_chunks: 1.
- use_allocation_guard: 0.
- handle_deallocations: 1.
Internal statistics:
num_allocs_failed_limit: 3.
num_arena_births: 306.
num_arena_deaths: 0.
num_vsnodes_births: 5.
num_vsnodes_deaths: 0.
num_space_committed: 443.
num_space_uncommitted: 0.
num_chunks_returned_to_freelist: 3.
num_chunks_taken_from_freelist: 1157.
num_chunk_merges: 3.
num_chunk_splits: 841.
num_chunks_enlarged: 673.
num_purges: 0.
num_inconsistent_stats: 0.
CodeHeap 'non-profiled nmethods': size=119168Kb used=1947Kb max_used=1947Kb free=117220Kb
bounds [0x00000216f2080000, 0x00000216f22f0000, 0x00000216f94e0000]
CodeHeap 'profiled nmethods': size=119104Kb used=6048Kb max_used=6048Kb free=113055Kb
bounds [0x00000216eac30000, 0x00000216eb220000, 0x00000216f2080000]
CodeHeap 'non-nmethods': size=7488Kb used=3431Kb max_used=3488Kb free=4056Kb
bounds [0x00000216ea4e0000, 0x00000216ea850000, 0x00000216eac30000]
total_blobs=4529 nmethods=3327 adapters=1111
compilation: enabled
stopped_count=0, restarted_count=0
full_count=0
Compilation events (20 events):
Event: 2.013 Thread 0x00000216a390b930 3241 3 kotlin.collections.CollectionsKt___CollectionsKt::joinTo (156 bytes)
Event: 2.013 Thread 0x00000216a423ad70 nmethod 3238 0x00000216eb1d8f90 code [0x00000216eb1d92e0, 0x00000216eb1da578]
Event: 2.014 Thread 0x00000216a390bef0 nmethod 3240 0x00000216eb1dae10 code [0x00000216eb1db280, 0x00000216eb1dcf88]
Event: 2.014 Thread 0x00000216a423ad70 3242 1 kotlin.reflect.jvm.internal.impl.serialization.deserialization.descriptors.DeserializedClassDescriptor::getC (5 bytes)
Event: 2.014 Thread 0x00000216a423ad70 nmethod 3242 0x00000216f224a190 code [0x00000216f224a320, 0x00000216f224a3f8]
Event: 2.014 Thread 0x00000216a390b930 nmethod 3241 0x00000216eb1dd990 code [0x00000216eb1ddea0, 0x00000216eb1e03b8]
Event: 2.014 Thread 0x00000216a390b930 3243 3 kotlin.reflect.jvm.internal.impl.incremental.UtilsKt::record (65 bytes)
Event: 2.014 Thread 0x00000216a423ad70 3244 3 kotlin.reflect.jvm.internal.impl.incremental.UtilsKt::recordPackageLookup (98 bytes)
Event: 2.015 Thread 0x00000216a390bef0 3245 3 kotlin.reflect.jvm.internal.impl.storage.LockBasedStorageManager$MapBasedMemoizedFunctionToNotNull::invoke (56 bytes)
Event: 2.015 Thread 0x00000216a390bef0 nmethod 3245 0x00000216eb1e1090 code [0x00000216eb1e1240, 0x00000216eb1e1418]
Event: 2.015 Thread 0x00000216a423ad70 nmethod 3244 0x00000216eb1e1510 code [0x00000216eb1e18a0, 0x00000216eb1e2d78]
Event: 2.015 Thread 0x00000216a390b930 nmethod 3243 0x00000216eb1e3510 code [0x00000216eb1e3900, 0x00000216eb1e50f8]
Event: 2.015 Thread 0x00000216a390bef0 3246 3 kotlin.reflect.jvm.internal.impl.protobuf.GeneratedMessageLite$ExtendableMessage::verifyExtensionContainingType (22 bytes)
Event: 2.016 Thread 0x00000216a390bef0 nmethod 3246 0x00000216eb1e5990 code [0x00000216eb1e5b60, 0x00000216eb1e5e78]
Event: 2.016 Thread 0x00000216a21706c0 3247 3 kotlin.reflect.jvm.internal.impl.serialization.deserialization.descriptors.DeserializedAnnotations::isEmpty (10 bytes)
Event: 2.016 Thread 0x00000216a423ad70 3248 3 kotlin.reflect.jvm.internal.impl.serialization.deserialization.descriptors.DeserializedAnnotations::getAnnotations (17 bytes)
Event: 2.016 Thread 0x00000216a423ad70 nmethod 3248 0x00000216eb1e5f90 code [0x00000216eb1e6240, 0x00000216eb1e6f08]
Event: 2.016 Thread 0x00000216a21706c0 nmethod 3247 0x00000216eb1e7390 code [0x00000216eb1e7660, 0x00000216eb1e8438]
Event: 2.022 Thread 0x00000216b288fe30 3249 4 kotlin.collections.ArrayDeque::access$positiveMod (6 bytes)
Event: 2.023 Thread 0x00000216b288fe30 nmethod 3249 0x00000216f224a490 code [0x00000216f224a600, 0x00000216f224a698]
GC Heap History (10 events):
Event: 0.190 GC heap before
{Heap before GC invocations=0 (full 0):
garbage-first heap total 131072K, used 16384K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 0 survivors (0K)
Metaspace used 2599K, committed 2752K, reserved 1056768K
class space used 257K, committed 320K, reserved 1048576K
}
Event: 0.192 GC heap after
{Heap after GC invocations=1 (full 0):
garbage-first heap total 131072K, used 4549K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 2599K, committed 2752K, reserved 1056768K
class space used 257K, committed 320K, reserved 1048576K
}
Event: 0.249 GC heap before
{Heap before GC invocations=1 (full 0):
garbage-first heap total 131072K, used 12741K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 1 survivors (8192K)
Metaspace used 3796K, committed 3968K, reserved 1056768K
class space used 424K, committed 512K, reserved 1048576K
}
Event: 0.251 GC heap after
{Heap after GC invocations=2 (full 0):
garbage-first heap total 131072K, used 4732K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 3796K, committed 3968K, reserved 1056768K
class space used 424K, committed 512K, reserved 1048576K
}
Event: 1.057 GC heap before
{Heap before GC invocations=2 (full 0):
garbage-first heap total 131072K, used 37500K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 5 young (40960K), 1 survivors (8192K)
Metaspace used 15475K, committed 15744K, reserved 1064960K
class space used 1617K, committed 1728K, reserved 1048576K
}
Event: 1.062 GC heap after
{Heap after GC invocations=3 (full 0):
garbage-first heap total 131072K, used 8367K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 15475K, committed 15744K, reserved 1064960K
class space used 1617K, committed 1728K, reserved 1048576K
}
Event: 1.343 GC heap before
{Heap before GC invocations=3 (full 0):
garbage-first heap total 131072K, used 32943K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 5 young (40960K), 1 survivors (8192K)
Metaspace used 21306K, committed 21504K, reserved 1073152K
class space used 2247K, committed 2368K, reserved 1048576K
}
Event: 1.347 GC heap after
{Heap after GC invocations=4 (full 0):
garbage-first heap total 131072K, used 9360K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 21306K, committed 21504K, reserved 1073152K
class space used 2247K, committed 2368K, reserved 1048576K
}
Event: 1.675 GC heap before
{Heap before GC invocations=5 (full 0):
garbage-first heap total 131072K, used 91280K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 9 young (73728K), 1 survivors (8192K)
Metaspace used 25311K, committed 25536K, reserved 1073152K
class space used 2674K, committed 2752K, reserved 1048576K
}
Event: 1.688 GC heap after
{Heap after GC invocations=6 (full 0):
garbage-first heap total 131072K, used 37306K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 25311K, committed 25536K, reserved 1073152K
class space used 2674K, committed 2752K, reserved 1048576K
}
Deoptimization events (20 events):
Event: 1.943 Thread 0x00000216e2a20490 Uncommon trap: trap_request=0xfffffff4 fr.pc=0x00000216f221d984 relative=0x0000000000002184
Event: 1.943 Thread 0x00000216e2a20490 Uncommon trap: reason=null_check action=make_not_entrant pc=0x00000216f221d984 method=com.sun.jna.Structure.readField(Lcom/sun/jna/Structure$StructField;)Ljava/lang/Object; @ 32 c2
Event: 1.943 Thread 0x00000216e2a20490 DEOPT PACKING pc=0x00000216f221d984 sp=0x0000004d5c5fec00
Event: 1.943 Thread 0x00000216e2a20490 DEOPT UNPACKING pc=0x00000216ea5323a3 sp=0x0000004d5c5fec00 mode 2
Event: 1.945 Thread 0x00000216b2a4c100 Uncommon trap: trap_request=0xffffffc6 fr.pc=0x00000216f21f6b6c relative=0x000000000000004c
Event: 1.945 Thread 0x00000216b2a4c100 Uncommon trap: reason=bimorphic_or_optimized_type_check action=maybe_recompile pc=0x00000216f21f6b6c method=kotlin.collections.CollectionsKt__CollectionsKt.getLastIndex(Ljava/util/List;)I @ 7 c2
Event: 1.945 Thread 0x00000216b2a4c100 DEOPT PACKING pc=0x00000216f21f6b6c sp=0x0000004d604fda10
Event: 1.945 Thread 0x00000216b2a4c100 DEOPT UNPACKING pc=0x00000216ea5323a3 sp=0x0000004d604fd9b0 mode 2
Event: 1.947 Thread 0x00000216b2a4c100 Uncommon trap: trap_request=0xffffffc6 fr.pc=0x00000216f21f6b6c relative=0x000000000000004c
Event: 1.947 Thread 0x00000216b2a4c100 Uncommon trap: reason=bimorphic_or_optimized_type_check action=maybe_recompile pc=0x00000216f21f6b6c method=kotlin.collections.CollectionsKt__CollectionsKt.getLastIndex(Ljava/util/List;)I @ 7 c2
Event: 1.947 Thread 0x00000216b2a4c100 DEOPT PACKING pc=0x00000216f21f6b6c sp=0x0000004d604fdd30
Event: 1.947 Thread 0x00000216b2a4c100 DEOPT UNPACKING pc=0x00000216ea5323a3 sp=0x0000004d604fdcd0 mode 2
Event: 1.948 Thread 0x00000216b2a4c100 Uncommon trap: trap_request=0xffffffc6 fr.pc=0x00000216f21f6b6c relative=0x000000000000004c
Event: 1.948 Thread 0x00000216b2a4c100 Uncommon trap: reason=bimorphic_or_optimized_type_check action=maybe_recompile pc=0x00000216f21f6b6c method=kotlin.collections.CollectionsKt__CollectionsKt.getLastIndex(Ljava/util/List;)I @ 7 c2
Event: 1.948 Thread 0x00000216b2a4c100 DEOPT PACKING pc=0x00000216f21f6b6c sp=0x0000004d604fda10
Event: 1.948 Thread 0x00000216b2a4c100 DEOPT UNPACKING pc=0x00000216ea5323a3 sp=0x0000004d604fd9b0 mode 2
Event: 1.984 Thread 0x00000216b2a4c100 DEOPT PACKING pc=0x00000216eb16809e sp=0x0000004d604fd970
Event: 1.984 Thread 0x00000216b2a4c100 DEOPT UNPACKING pc=0x00000216ea532b43 sp=0x0000004d604fce80 mode 0
Event: 1.993 Thread 0x00000216b2a4c100 DEOPT PACKING pc=0x00000216eb16809e sp=0x0000004d604f92a0
Event: 1.993 Thread 0x00000216b2a4c100 DEOPT UNPACKING pc=0x00000216ea532b43 sp=0x0000004d604f87b0 mode 0
Classes unloaded (0 events):
No events
Classes redefined (0 events):
No events
Internal exceptions (20 events):
Event: 0.721 Thread 0x00000216e2a20490 Exception <a 'sun/nio/fs/WindowsException'{0x00000004073a3f90}> (0x00000004073a3f90)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 516]
Event: 0.723 Thread 0x00000216e2a20490 Exception <a 'sun/nio/fs/WindowsException'{0x00000004073aea40}> (0x00000004073aea40)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 516]
Event: 0.723 Thread 0x00000216e2a20490 Exception <a 'sun/nio/fs/WindowsException'{0x00000004073aed28}> (0x00000004073aed28)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 516]
Event: 0.813 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x00000004076c2de8}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeStaticInit(java.lang.Object, int, int, int, int)'> (0x00000004076c2de8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 0.871 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000407789a88}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeStaticInit(java.lang.Object, java.lang.Object, int, int, int, int)'> (0x0000000407789a88)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 0.929 Thread 0x00000216e2a20490 Implicit null exception at 0x00000216f20ab1f2 to 0x00000216f20ab7cc
Event: 0.992 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000406cfb3f8}: 'int java.lang.invoke.DirectMethodHandle$Holder.invokeSpecialIFC(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000406cfb3f8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.009 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000406e3e580}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.newInvokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, int)'> (0x0000000406e3e580)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.010 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000406e429b0}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, int)'> (0x0000000406e429b0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.010 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000406e462e8}: 'java.lang.Object java.lang.invoke.Invokers$Holder.invoke_MT(java.lang.Object, java.lang.Object, java.lang.Object, int, java.lang.Object)'> (0x0000000406e462e8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.084 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000408b157c0}: 'int java.lang.invoke.DirectMethodHandle$Holder.invokeVirtual(java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000408b157c0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.116 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000408df10b0}: 'java.lang.Object java.lang.invoke.Invokers$Holder.linkToTargetMethod(java.lang.Object, java.lang.Object, int, java.lang.Object)'> (0x0000000408df10b0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.119 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000408e34098}: 'void java.lang.invoke.DirectMethodHandle$Holder.invokeInterface(java.lang.Object, java.lang.Object)'> (0x0000000408e34098)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.168 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x00000004084191f8}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeVirtual(java.lang.Object, java.lang.Object, java.lang.Object)'> (0x00000004084191f8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.510 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000408491738}: 'int java.lang.invoke.DirectMethodHandle$Holder.invokeStaticInit(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000408491738)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.710 Thread 0x00000216b2a4c100 Exception <a 'java/lang/NoSuchMethodError'{0x0000000408da1c48}: 'void java.lang.invoke.DirectMethodHandle$Holder.invokeInterface(java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000408da1c48)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.798 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000407a7f9c8}: 'void java.lang.invoke.DirectMethodHandle$Holder.invokeStatic(java.lang.Object, java.lang.Object, int)'> (0x0000000407a7f9c8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.807 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000407aa39c0}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeStatic(java.lang.Object, java.lang.Object, int, java.lang.Object)'> (0x0000000407aa39c0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.864 Thread 0x00000216e2a20490 Exception <a 'java/lang/NoSuchMethodError'{0x0000000407c8c148}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, double, double)'> (0x0000000407c8c148)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 1.943 Thread 0x00000216e2a20490 Implicit null exception at 0x00000216f221b86f to 0x00000216f221d968
VM Operations (20 events):
Event: 0.966 Executing VM operation: ICBufferFull
Event: 0.966 Executing VM operation: ICBufferFull done
Event: 1.057 Executing VM operation: G1CollectForAllocation
Event: 1.062 Executing VM operation: G1CollectForAllocation done
Event: 1.121 Executing VM operation: HandshakeAllThreads
Event: 1.121 Executing VM operation: HandshakeAllThreads done
Event: 1.188 Executing VM operation: HandshakeAllThreads
Event: 1.188 Executing VM operation: HandshakeAllThreads done
Event: 1.343 Executing VM operation: CollectForMetadataAllocation
Event: 1.347 Executing VM operation: CollectForMetadataAllocation done
Event: 1.353 Executing VM operation: G1Concurrent
Event: 1.355 Executing VM operation: G1Concurrent done
Event: 1.356 Executing VM operation: G1Concurrent
Event: 1.356 Executing VM operation: G1Concurrent done
Event: 1.608 Executing VM operation: HandshakeAllThreads
Event: 1.608 Executing VM operation: HandshakeAllThreads done
Event: 1.675 Executing VM operation: G1CollectForAllocation
Event: 1.689 Executing VM operation: G1CollectForAllocation done
Event: 1.859 Executing VM operation: ICBufferFull
Event: 1.859 Executing VM operation: ICBufferFull done
Events (20 events):
Event: 1.710 loading class java/util/stream/Streams$2
Event: 1.710 loading class java/util/stream/Streams$2 done
Event: 1.770 loading class java/nio/ByteBufferAsFloatBufferL
Event: 1.770 loading class java/nio/ByteBufferAsFloatBufferL done
Event: 1.771 loading class java/nio/BufferMismatch
Event: 1.771 loading class java/nio/BufferMismatch done
Event: 1.773 loading class java/util/PrimitiveIterator$OfInt
Event: 1.773 loading class java/util/PrimitiveIterator
Event: 1.773 loading class java/util/PrimitiveIterator done
Event: 1.773 loading class java/util/PrimitiveIterator$OfInt done
Event: 1.803 loading class java/io/IOError
Event: 1.803 loading class java/io/IOError done
Event: 1.816 loading class sun/reflect/annotation/AnnotationSupport
Event: 1.817 loading class sun/reflect/annotation/AnnotationSupport done
Event: 1.817 loading class java/lang/annotation/Repeatable
Event: 1.817 loading class java/lang/annotation/Repeatable done
Event: 1.864 loading class jdk/internal/math/FDBigInteger
Event: 1.865 loading class jdk/internal/math/FDBigInteger done
Event: 1.921 loading class java/io/NotSerializableException
Event: 1.921 loading class java/io/NotSerializableException done
Dynamic libraries:
0x00007ff760040000 - 0x00007ff76004e000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\java.exe
0x00007ffbd8050000 - 0x00007ffbd8245000 C:\Windows\SYSTEM32\ntdll.dll
0x00007ffbd7e90000 - 0x00007ffbd7f4d000 C:\Windows\System32\KERNEL32.DLL
0x00007ffbd5990000 - 0x00007ffbd5c5d000 C:\Windows\System32\KERNELBASE.dll
0x00007ffbd5760000 - 0x00007ffbd5860000 C:\Windows\System32\ucrtbase.dll
0x00007ffbc8fe0000 - 0x00007ffbc8ff8000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\jli.dll
0x00007ffbc8eb0000 - 0x00007ffbc8ec9000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\VCRUNTIME140.dll
0x00007ffbd6df0000 - 0x00007ffbd6f90000 C:\Windows\System32\USER32.dll
0x00007ffbd58f0000 - 0x00007ffbd5912000 C:\Windows\System32\win32u.dll
0x00007ffbc2400000 - 0x00007ffbc269a000 C:\Windows\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_6.0.19041.1110_none_60b5254171f9507e\COMCTL32.dll
0x00007ffbd7a20000 - 0x00007ffbd7a4a000 C:\Windows\System32\GDI32.dll
0x00007ffbd6410000 - 0x00007ffbd64ae000 C:\Windows\System32\msvcrt.dll
0x00007ffbd5d00000 - 0x00007ffbd5e0b000 C:\Windows\System32\gdi32full.dll
0x00007ffbd5c60000 - 0x00007ffbd5cfd000 C:\Windows\System32\msvcp_win.dll
0x00007ffbd6dc0000 - 0x00007ffbd6df0000 C:\Windows\System32\IMM32.DLL
0x00007ffbcd340000 - 0x00007ffbcd34c000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\vcruntime140_1.dll
0x00007ffba9ae0000 - 0x00007ffba9b71000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\msvcp140.dll
0x00007ffb54660000 - 0x00007ffb552a6000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\server\jvm.dll
0x00007ffbd70b0000 - 0x00007ffbd715e000 C:\Windows\System32\ADVAPI32.dll
0x00007ffbd7500000 - 0x00007ffbd759c000 C:\Windows\System32\sechost.dll
0x00007ffbd6c90000 - 0x00007ffbd6db5000 C:\Windows\System32\RPCRT4.dll
0x00007ffbd7f50000 - 0x00007ffbd7f58000 C:\Windows\System32\PSAPI.DLL
0x00007ffbc01d0000 - 0x00007ffbc01d9000 C:\Windows\SYSTEM32\WSOCK32.dll
0x00007ffbcbd90000 - 0x00007ffbcbdb7000 C:\Windows\SYSTEM32\WINMM.dll
0x00007ffbcdb10000 - 0x00007ffbcdb1a000 C:\Windows\SYSTEM32\VERSION.dll
0x00007ffbd7270000 - 0x00007ffbd72db000 C:\Windows\System32\WS2_32.dll
0x00007ffbd3680000 - 0x00007ffbd3692000 C:\Windows\SYSTEM32\kernel.appcore.dll
0x00007ffbc9240000 - 0x00007ffbc924a000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\jimage.dll
0x00007ffbcf0e0000 - 0x00007ffbcf2c4000 C:\Windows\SYSTEM32\DBGHELP.DLL
0x00007ffbc23d0000 - 0x00007ffbc23fc000 C:\Windows\SYSTEM32\dbgcore.DLL
0x00007ffbd5860000 - 0x00007ffbd58e2000 C:\Windows\System32\bcryptPrimitives.dll
0x00007ffbcd790000 - 0x00007ffbcd79e000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\instrument.dll
0x00007ffbb98c0000 - 0x00007ffbb98e5000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\java.dll
0x00007ffb99a90000 - 0x00007ffb99b66000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\svml.dll
0x00007ffbd64b0000 - 0x00007ffbd6bf4000 C:\Windows\System32\SHELL32.dll
0x00007ffbd3880000 - 0x00007ffbd4014000 C:\Windows\SYSTEM32\windows.storage.dll
0x00007ffbd7b30000 - 0x00007ffbd7e84000 C:\Windows\System32\combase.dll
0x00007ffbd51c0000 - 0x00007ffbd51ec000 C:\Windows\SYSTEM32\Wldp.dll
0x00007ffbd7f60000 - 0x00007ffbd800d000 C:\Windows\System32\SHCORE.dll
0x00007ffbd7ad0000 - 0x00007ffbd7b25000 C:\Windows\System32\shlwapi.dll
0x00007ffbd56a0000 - 0x00007ffbd56bf000 C:\Windows\SYSTEM32\profapi.dll
0x00007ffbbeea0000 - 0x00007ffbbeeb8000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\zip.dll
0x00007ffbc4a00000 - 0x00007ffbc4a19000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\net.dll
0x00007ffbcd8c0000 - 0x00007ffbcd9ca000 C:\Windows\SYSTEM32\WINHTTP.dll
0x00007ffbd4f20000 - 0x00007ffbd4f8a000 C:\Windows\system32\mswsock.dll
0x00007ffbbf010000 - 0x00007ffbbf025000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\nio.dll
0x00007ffbcd760000 - 0x00007ffbcd77a000 C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin\breakgen64.dll
0x00007ffbc4ae0000 - 0x00007ffbc4ae9000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\management.dll
0x00007ffbc22c0000 - 0x00007ffbc22cb000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\management_ext.dll
0x00007ffbbe0f0000 - 0x00007ffbbe107000 C:\Windows\system32\napinsp.dll
0x00007ffbbdf90000 - 0x00007ffbbdfab000 C:\Windows\system32\pnrpnsp.dll
0x00007ffbb6a30000 - 0x00007ffbb6a45000 C:\Windows\system32\wshbth.dll
0x00007ffbd13f0000 - 0x00007ffbd140d000 C:\Windows\system32\NLAapi.dll
0x00007ffbd4ba0000 - 0x00007ffbd4bdb000 C:\Windows\SYSTEM32\IPHLPAPI.DLL
0x00007ffbd4be0000 - 0x00007ffbd4cab000 C:\Windows\SYSTEM32\DNSAPI.dll
0x00007ffbd6c60000 - 0x00007ffbd6c68000 C:\Windows\System32\NSI.dll
0x00007ffbbc030000 - 0x00007ffbbc042000 C:\Windows\System32\winrnr.dll
0x0000000061af0000 - 0x0000000061b16000 C:\Program Files\Bonjour\mdnsNSP.dll
0x00007ffbccc00000 - 0x00007ffbccc0a000 C:\Windows\System32\rasadhlp.dll
0x00007ffbcc2f0000 - 0x00007ffbcc370000 C:\Windows\System32\fwpuclnt.dll
0x00007ffbd5f10000 - 0x00007ffbd5f37000 C:\Windows\System32\bcrypt.dll
0x00007ffbb8c30000 - 0x00007ffbb8ca1000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl.dll
0x00007ffbb9230000 - 0x00007ffbb9291000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\glfw.dll
0x00007ffbb96a0000 - 0x00007ffbb96e5000 C:\Windows\SYSTEM32\dinput8.dll
0x00007ffbbda60000 - 0x00007ffbbda71000 C:\Windows\SYSTEM32\xinput1_4.dll
0x00007ffbd5e10000 - 0x00007ffbd5e5e000 C:\Windows\System32\cfgmgr32.dll
0x00007ffbd5510000 - 0x00007ffbd553c000 C:\Windows\SYSTEM32\DEVOBJ.dll
0x00007ffbd3390000 - 0x00007ffbd33bf000 C:\Windows\SYSTEM32\dwmapi.dll
0x00007ffbc89f0000 - 0x00007ffbc8b42000 C:\Windows\SYSTEM32\inputhost.dll
0x00007ffbd6340000 - 0x00007ffbd640d000 C:\Windows\System32\OLEAUT32.dll
0x00007ffbd16d0000 - 0x00007ffbd1824000 C:\Windows\SYSTEM32\wintypes.dll
0x00007ffbd2d90000 - 0x00007ffbd2e82000 C:\Windows\SYSTEM32\CoreMessaging.dll
0x00007ffbcfe40000 - 0x00007ffbcff36000 C:\Windows\SYSTEM32\PROPSYS.dll
0x00007ffbd2a30000 - 0x00007ffbd2d8e000 C:\Windows\SYSTEM32\CoreUIComponents.dll
0x00007ffbd4460000 - 0x00007ffbd4493000 C:\Windows\SYSTEM32\ntmarta.dll
0x00007ffbd31a0000 - 0x00007ffbd323e000 C:\Windows\system32\uxtheme.dll
0x00007ffbd6f90000 - 0x00007ffbd70a5000 C:\Windows\System32\MSCTF.dll
0x00007ffb9b170000 - 0x00007ffb9b296000 C:\Windows\SYSTEM32\opengl32.dll
0x00007ffb9bf50000 - 0x00007ffb9bf7c000 C:\Windows\SYSTEM32\GLU32.dll
0x00007ffbd71c0000 - 0x00007ffbd7269000 C:\Windows\System32\clbcatq.dll
0x00007ffb9bf20000 - 0x00007ffb9bf4d000 C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218\atig6pxx.dll
0x00007ffb7a5b0000 - 0x00007ffb7e2a1000 C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218\atio6axx.dll
0x00007ffbd75a0000 - 0x00007ffbd7a11000 C:\Windows\System32\SETUPAPI.dll
0x00007ffbd5920000 - 0x00007ffbd5988000 C:\Windows\System32\WINTRUST.dll
0x00007ffbd5f40000 - 0x00007ffbd6096000 C:\Windows\System32\CRYPT32.dll
0x00007ffbd5350000 - 0x00007ffbd5362000 C:\Windows\SYSTEM32\MSASN1.dll
0x00007ffbac190000 - 0x00007ffbac1ed000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl_opengl.dll
0x00007ffbd5110000 - 0x00007ffbd5128000 C:\Windows\SYSTEM32\CRYPTSP.dll
0x00007ffbd47c0000 - 0x00007ffbd47f4000 C:\Windows\system32\rsaenh.dll
0x00007ffbd5660000 - 0x00007ffbd568e000 C:\Windows\SYSTEM32\USERENV.dll
0x00007ffbd5130000 - 0x00007ffbd513c000 C:\Windows\SYSTEM32\CRYPTBASE.dll
0x00007ffbd0000000 - 0x00007ffbd0017000 C:\Windows\SYSTEM32\dhcpcsvc6.DLL
0x00007ffbcffe0000 - 0x00007ffbcfffd000 C:\Windows\SYSTEM32\dhcpcsvc.DLL
0x00007ffba9a90000 - 0x00007ffba9ad5000 C:\Users\dbott\AppData\Local\Temp\jna-95382001\jna124977103322284851.dll
0x00007ffba4910000 - 0x00007ffba49b3000 K:\git\kstarbound\freetype-2.11.1.dll
0x00007ffbc8b50000 - 0x00007ffbc8c49000 C:\Windows\SYSTEM32\textinputframework.dll
dbghelp: loaded successfully - version: 4.0.5 - missing functions: none
symbol engine: initialized successfully - sym options: 0x614 - pdb path: .;C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin;C:\Windows\SYSTEM32;C:\Windows\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_6.0.19041.1110_none_60b5254171f9507e;C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\server;C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin;C:\Program Files\Bonjour;C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21;C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218;C:\Users\dbott\AppData\Local\Temp\jna-95382001;K:\git\kstarbound
VM Arguments:
jvm_args: -Xms128m -javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\lib\idea_rt.jar=5828:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin -Dfile.encoding=UTF-8
java_command: ru.dbotthepony.kstarbound.MainKt
java_class_path (initial): K:\git\kstarbound\build\classes\java\main;K:\git\kstarbound\build\classes\kotlin\main;K:\git\kstarbound\build\resources\main;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.jetbrains.kotlin\kotlin-reflect\1.6.10\1cbe9c92c12a94eea200d23c2bbaedaf3daf5132\kotlin-reflect-1.6.10.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.jetbrains.kotlin\kotlin-stdlib\1.6.10\b8af3fe6f1ca88526914929add63cf5e7c5049af\kotlin-stdlib-1.6.10.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.apache.logging.log4j\log4j-core\2.17.1\779f60f3844dadc3ef597976fcb1e5127b1f343d\log4j-core-2.17.1.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.apache.logging.log4j\log4j-api\2.17.1\d771af8e336e372fb5399c99edabe0919aeaf5b2\log4j-api-2.17.1.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\com.google.code.gson\gson\2.8.9\8a432c1d6825781e21a02db2e2c33c5fde2833b9\gson-2.8.9.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\it.unimi.dsi\fastutil\8.5.6\76f95700418a68fbc4ac050525261f05dc681ca1\fastutil-8.5.6.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\com.google.guava\guava\31.0.1-jre\119ea2b2bc205b138974d351777b20f02b92704b\guava-31.0.1-jre.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-assimp\3.3.0\82135e856184e76d38a97f729141298d3edcf0e4\lwjgl-assimp-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-bgfx\3.3.0\b9e9a62b741bdc60f9207a4d4de6e61a2b7de6af\lwjgl-bgfx-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-glfw\3.3.0\899e34f314525596f8fdb6476d3e56104da4601d\lwjgl-glfw-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-nanovg\3.3.0\a15688d6e6c7136cebc5b63f30d120f702f6587c\lwjgl-nanovg-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-nuklear\3.3.0\8dbbdce4f28384c2abdfe8d0abff5f4c9bae286e\lwjgl-nuklear-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-openal\3.3.0\902dd57b
Launcher Type: SUN_STANDARD
[Global flags]
intx CICompilerCount = 12 {product} {ergonomic}
uint ConcGCThreads = 3 {product} {ergonomic}
uint G1ConcRefinementThreads = 13 {product} {ergonomic}
size_t G1HeapRegionSize = 8388608 {product} {ergonomic}
uintx GCDrainStackTargetSize = 64 {product} {ergonomic}
size_t InitialHeapSize = 134217728 {product} {command line}
size_t MarkStackSize = 4194304 {product} {ergonomic}
size_t MaxHeapSize = 17163091968 {product} {ergonomic}
size_t MaxNewSize = 10292822016 {product} {ergonomic}
size_t MinHeapDeltaBytes = 8388608 {product} {ergonomic}
size_t MinHeapSize = 134217728 {product} {command line}
uintx NonNMethodCodeHeapSize = 7602480 {pd product} {ergonomic}
uintx NonProfiledCodeHeapSize = 122027880 {pd product} {ergonomic}
uintx ProfiledCodeHeapSize = 122027880 {pd product} {ergonomic}
uintx ReservedCodeCacheSize = 251658240 {pd product} {ergonomic}
bool SegmentedCodeCache = true {product} {ergonomic}
size_t SoftMaxHeapSize = 17163091968 {manageable} {ergonomic}
bool UseCompressedClassPointers = true {product lp64_product} {ergonomic}
bool UseCompressedOops = true {product lp64_product} {ergonomic}
bool UseG1GC = true {product} {ergonomic}
bool UseLargePagesIndividualAllocation = false {pd product} {ergonomic}
Logging:
Log output configuration:
#0: stdout all=warning uptime,level,tags
#1: stderr all=off uptime,level,tags
Environment Variables:
JAVA_HOME=C:\Program Files\Eclipse Adoptium\jdk-17.0.4.101-hotspot\
PATH=C:\Program Files\Eclipse Adoptium\jdk-17.0.4.101-hotspot\bin;C:\Program Files\ImageMagick-7.1.0-Q16;C:\Program Files\Microsoft\jdk-11.0.12.7-hotspot\bin;C:\Program Files\ImageMagick-7.1.0-Q16-HDRI;C:\Program Files (x86)\NVIDIA Corporation\PhysX\Common;C:\Program Files (x86)\VMware\VMware Workstation\bin\;C:\Program Files\ImageMagick-7.0.10-Q16-HDRI;C:\Program Files\Python38\Scripts\;C:\Program Files\Python38\;C:\Program Files\ImageMagick-7.0.9-Q16;C:\Program Files (x86)\Common Files\Oracle\Java\javapath;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;D:\php7;C:\Program Files (x86)\Lua\5.1;C:\Program Files (x86)\Lua\5.1\clibs;C:\Program Files (x86)\Codebox\BitMeterOS;C:\moonscript;C:\Program Files\TortoiseHg\;C:\Program Files\GTK3-Runtime Win64\bin;C:\ProgramData\ComposerSetup\bin;C:\Program Files\Logstalgia\cmd;C:\Program Files\dotnet\;C:\Program Files\TortoiseSVN\bin;C:\Program Files\Gource\cmd;C:\kotlin-native-windows-1.3.72\bin;N:\platform-tools;C:\Program Files\PuTTY\;C:\Program Files\Git\cmd;C:\Windows\System32\OpenSSH\;D:\php-8.0.8-Win32-vs16-x64;C:\Program Files\LLVM\bin;C:\Program Files\PowerShell\7\;C:\Program Files\CMake\bin;C:\pypy3.8-v7.3.7-win64;C:\pypy3.8-v7.3.7-win64\Scripts;C:\Program Files\nodejs\;C:\Program Files\7-Zip;C:\Program Files\TortoiseGit\bin;C:\Users\dbott\.cargo\bin;C:\Users\dbott\.windows-build-tools\python27\;C:\Users\dbott\AppData\Local\Programs\Python\Python37\Scripts\;C:\Users\dbott\AppData\Local\Programs\Python\Python37\;C:\Users\dbott\AppData\Local\Microsoft\WindowsApps;C:\Users\dbott\AppData\Local\Programs\Microsoft VS Code\bin;K:\git\vcpkg\installed\x86-windows\include;K:\git\vcpkg\installed\x86-windows\lib;K:\git\vcpkg\installed\x86-windows\bin;C:\Users\dbott\AppData\Roaming\Composer\vendor\bin;C:\Users\dbott\.dotnet\tools;C:\Users\dbott\AppData\Local\Microsoft\WindowsApps;C:\Program Files (x86)\FreeArc\bin;C:\Users\dbott\AppData\Roaming\npm
USERNAME=dbott
OS=Windows_NT
PROCESSOR_IDENTIFIER=AMD64 Family 23 Model 113 Stepping 0, AuthenticAMD
--------------- S Y S T E M ---------------
OS:
Windows 10 , 64 bit Build 19041 (10.0.19041.1706)
OS uptime: 34 days 23:32 hours
CPU: total 16 (initial active 16) (16 cores per cpu, 2 threads per core) family 23 model 113 stepping 0 microcode 0x0, cx8, cmov, fxsr, ht, mmx, 3dnowpref, sse, sse2, sse3, ssse3, sse4a, sse4.1, sse4.2, popcnt, lzcnt, tsc, tscinvbit, avx, avx2, aes, clmul, bmi1, bmi2, adx, sha, fma, vzeroupper, clflush, clflushopt
Memory: 4k page, system-wide physical 65457M (24962M free)
TotalPageFile size 165457M (AvailPageFile size 106743M)
current process WorkingSet (physical memory assigned to process): 334M, peak: 354M
current process commit charge ("private bytes"): 431M, peak: 452M
vm_info: OpenJDK 64-Bit Server VM (17.0.1+12) for windows-amd64 JRE (17.0.1+12), built on Oct 20 2021 07:42:55 by "" with MS VC++ 16.7 (VS2019)
END.

View File

@ -1,848 +0,0 @@
#
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x00007ffb7c599920, pid=42652, tid=59756
#
# JRE version: OpenJDK Runtime Environment Temurin-17.0.1+12 (17.0.1+12) (build 17.0.1+12)
# Java VM: OpenJDK 64-Bit Server VM Temurin-17.0.1+12 (17.0.1+12, mixed mode, sharing, tiered, compressed oops, compressed class ptrs, g1 gc, windows-amd64)
# Problematic frame:
# C [atio6axx.dll+0x1fe9920]
#
# No core dump will be written. Minidumps are not enabled by default on client versions of Windows
#
# If you would like to submit a bug report, please visit:
# https://github.com/adoptium/adoptium-support/issues
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
--------------- S U M M A R Y ------------
Command Line: -Xms128m -javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\lib\idea_rt.jar=5737:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin -Dfile.encoding=UTF-8 ru.dbotthepony.kstarbound.MainKt
Host: AMD Ryzen 7 3700X 8-Core Processor , 16 cores, 63G, Windows 10 , 64 bit Build 19041 (10.0.19041.1706)
Time: Sun Sep 10 10:42:30 2023 RTZ 6 (s 10 , 64 bit Build 19041 (10.0.19041.1706) elapsed time: 6.589123 seconds (0d 0h 0m 6s)
--------------- T H R E A D ---------------
Current thread (0x000001fe2ebeedf0): JavaThread "main" [_thread_in_native, id=59756, stack(0x00000030bdf00000,0x00000030be000000)]
Stack: [0x00000030bdf00000,0x00000030be000000], sp=0x00000030bdffe9d8, free space=1018k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
C [atio6axx.dll+0x1fe9920]
Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
J 7315 org.lwjgl.opengl.GL11C.nglTexImage2D(IIIIIIIIJ)V (0 bytes) @ 0x000001fe3e35e924 [0x000001fe3e35e8a0+0x0000000000000084]
J 7314 c1 org.lwjgl.opengl.GL11C.glTexImage2D(IIIIIIIILjava/nio/ByteBuffer;)V (21 bytes) @ 0x000001fe37822b44 [0x000001fe37822960+0x00000000000001e4]
J 7313 c1 org.lwjgl.opengl.GL11.glTexImage2D(IIIIIIIILjava/nio/ByteBuffer;)V (18 bytes) @ 0x000001fe374b208c [0x000001fe374b2020+0x000000000000006c]
j ru.dbotthepony.kstarbound.client.gl.GLTexture2D.upload(IIIIIILjava/nio/ByteBuffer;)Lru/dbotthepony/kstarbound/client/gl/GLTexture2D;+105
J 7205 c1 ru.dbotthepony.kstarbound.client.gl.GLTexture2D.upload(IIIIILjava/nio/ByteBuffer;)Lru/dbotthepony/kstarbound/client/gl/GLTexture2D; (22 bytes) @ 0x000001fe36e0f08c [0x000001fe36e0ed20+0x000000000000036c]
J 7128 c2 ru.dbotthepony.kstarbound.client.StarboundClient.renderFrame()Z (1412 bytes) @ 0x000001fe3e410edc [0x000001fe3e40f9a0+0x000000000000153c]
j ru.dbotthepony.kstarbound.MainKt.main()V+253
j ru.dbotthepony.kstarbound.MainKt.main([Ljava/lang/String;)V+0
v ~StubRoutines::call_stub
siginfo: EXCEPTION_ACCESS_VIOLATION (0xc0000005), reading address 0x000001fe0fd13f10
Register to memory mapping:
RIP=0x00007ffb7c599920 atio6axx.dll
RAX=0x000001fe7dc24df8 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RBX=0x000001fe7d4c2d70 points into unknown readable memory: 0x000001fe7d4c2d78 | 78 2d 4c 7d fe 01 00 00
RCX=0x000001fe7dc24df8 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RDX=0x000001fe0fd0b320 points into unknown readable memory: 0x000001fe01127950 | 50 79 12 01 fe 01 00 00
RSP=0x00000030bdffe9d8 is pointing into the stack for thread: 0x000001fe2ebeedf0
RBP=0x00000030bdffea71 is pointing into the stack for thread: 0x000001fe2ebeedf0
RSI=0x000001fe7dc24df8 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RDI=0x0000000000001908 is an unknown value
R8 =0x0000000000008c10 is an unknown value
R9 =0x000001fe0fd13f30 is an unknown value
R10=0x00007ffb7a5b0000 atio6axx.dll
R11=0x000001fe7c947690 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
R12=0x0000000000008c10 is an unknown value
R13=0x0000000000008c10 is an unknown value
R14=0x000001fe7c885080 points into unknown readable memory: 0x00007ffb7d8691f0 | f0 91 86 7d fb 7f 00 00
R15=0x0 is NULL
Registers:
RAX=0x000001fe7dc24df8, RBX=0x000001fe7d4c2d70, RCX=0x000001fe7dc24df8, RDX=0x000001fe0fd0b320
RSP=0x00000030bdffe9d8, RBP=0x00000030bdffea71, RSI=0x000001fe7dc24df8, RDI=0x0000000000001908
R8 =0x0000000000008c10, R9 =0x000001fe0fd13f30, R10=0x00007ffb7a5b0000, R11=0x000001fe7c947690
R12=0x0000000000008c10, R13=0x0000000000008c10, R14=0x000001fe7c885080, R15=0x0000000000000000
RIP=0x00007ffb7c599920, EFLAGS=0x0000000000010246
Top of Stack: (sp=0x00000030bdffe9d8)
0x00000030bdffe9d8: 00007ffb7ad699f3 000001fe0fb8e5ff
0x00000030bdffe9e8: 0000000000000000 0000000000000000
0x00000030bdffe9f8: 00000030bdffeab0 000000000000006c
0x00000030bdffea08: 00007ffb00000001 000001fe00001908
0x00000030bdffea18: 000001fe00001401 000001fe00000000
0x00000030bdffea28: 00007ffb54920000 0000000100000000
0x00000030bdffea38: 0000000200000001 000001fe7dc24df8
0x00000030bdffea48: 0000000000008c10 0000000000000038
0x00000030bdffea58: 0000000000000000 0000ac80f072b6d3
0x00000030bdffea68: 0000003000000001 000001fe00000000
0x00000030bdffea78: 0000000000001908 0000000000001401
0x00000030bdffea88: 000000000000006c 0000000000000000
0x00000030bdffea98: 0000000000000000 000000000000006c
0x00000030bdffeaa8: 000001fe7c885080 000001fe70f58138
0x00000030bdffeab8: 00007ffb7ae43bd7 000001fe7c885000
0x00000030bdffeac8: 000001fe00000de1 000001fe00000000
Instructions: (pc=0x00007ffb7c599920)
0x00007ffb7c599820: 89 40 04 44 88 48 06 c3 4c 8b 02 8b 4a 08 44 0f
0x00007ffb7c599830: b7 4a 0c 4c 89 00 89 48 08 66 44 89 48 0c c3 0f
0x00007ffb7c599840: b7 0a 44 0f b6 42 02 66 89 08 44 88 40 02 c3 90
0x00007ffb7c599850: 4c 8b 02 8b 4a 08 44 0f b6 4a 0c 4c 89 00 89 48
0x00007ffb7c599860: 08 44 88 48 0c c3 4c 8b 02 0f b7 4a 08 4c 89 00
0x00007ffb7c599870: 66 89 48 08 c3 4c 8b 02 0f b6 4a 08 4c 89 00 88
0x00007ffb7c599880: 48 08 c3 4c 8b 02 8b 4a 08 4c 89 00 89 48 08 c3
0x00007ffb7c599890: 8b 0a 44 0f b7 42 04 89 08 66 44 89 40 04 c3 8b
0x00007ffb7c5998a0: 0a 44 0f b6 42 04 89 08 44 88 40 04 c3 48 8b 0a
0x00007ffb7c5998b0: 48 89 08 c3 0f b6 0a 88 08 c3 8b 0a 89 08 c3 90
0x00007ffb7c5998c0: 49 83 f8 20 77 17 f3 0f 6f 0a f3 42 0f 6f 54 02
0x00007ffb7c5998d0: f0 f3 0f 7f 09 f3 42 0f 7f 54 01 f0 c3 48 3b d1
0x00007ffb7c5998e0: 73 0e 4e 8d 0c 02 49 3b c9 0f 82 41 04 00 00 90
0x00007ffb7c5998f0: 83 3d 21 37 8d 01 03 0f 82 e3 02 00 00 49 81 f8
0x00007ffb7c599900: 00 20 00 00 76 16 49 81 f8 00 00 18 00 77 0d f6
0x00007ffb7c599910: 05 be d0 a3 01 02 0f 85 64 fe ff ff c5 fe 6f 02
0x00007ffb7c599920: c4 a1 7e 6f 6c 02 e0 49 81 f8 00 01 00 00 0f 86
0x00007ffb7c599930: c4 00 00 00 4c 8b c9 49 83 e1 1f 49 83 e9 20 49
0x00007ffb7c599940: 2b c9 49 2b d1 4d 03 c1 49 81 f8 00 01 00 00 0f
0x00007ffb7c599950: 86 a3 00 00 00 49 81 f8 00 00 18 00 0f 87 3e 01
0x00007ffb7c599960: 00 00 66 66 66 66 66 66 0f 1f 84 00 00 00 00 00
0x00007ffb7c599970: c5 fe 6f 0a c5 fe 6f 52 20 c5 fe 6f 5a 40 c5 fe
0x00007ffb7c599980: 6f 62 60 c5 fd 7f 09 c5 fd 7f 51 20 c5 fd 7f 59
0x00007ffb7c599990: 40 c5 fd 7f 61 60 c5 fe 6f 8a 80 00 00 00 c5 fe
0x00007ffb7c5999a0: 6f 92 a0 00 00 00 c5 fe 6f 9a c0 00 00 00 c5 fe
0x00007ffb7c5999b0: 6f a2 e0 00 00 00 c5 fd 7f 89 80 00 00 00 c5 fd
0x00007ffb7c5999c0: 7f 91 a0 00 00 00 c5 fd 7f 99 c0 00 00 00 c5 fd
0x00007ffb7c5999d0: 7f a1 e0 00 00 00 48 81 c1 00 01 00 00 48 81 c2
0x00007ffb7c5999e0: 00 01 00 00 49 81 e8 00 01 00 00 49 81 f8 00 01
0x00007ffb7c5999f0: 00 00 0f 83 78 ff ff ff 4d 8d 48 1f 49 83 e1 e0
0x00007ffb7c599a00: 4d 8b d9 49 c1 eb 05 47 8b 9c 9a 40 b0 c1 03 4d
0x00007ffb7c599a10: 03 da 41 ff e3 c4 a1 7e 6f 8c 0a 00 ff ff ff c4
Stack slot to memory mapping:
stack at sp + 0 slots: 0x00007ffb7ad699f3 atio6axx.dll
stack at sp + 1 slots: 0x000001fe0fb8e5ff is pointing into metadata
stack at sp + 2 slots: 0x0 is NULL
stack at sp + 3 slots: 0x0 is NULL
stack at sp + 4 slots: 0x00000030bdffeab0 is pointing into the stack for thread: 0x000001fe2ebeedf0
stack at sp + 5 slots: 0x000000000000006c is an unknown value
stack at sp + 6 slots: 0x00007ffb00000001 is an unknown value
stack at sp + 7 slots: 0x000001fe00001908 is pointing into metadata
--------------- P R O C E S S ---------------
Threads class SMR info:
_java_thread_list=0x000001fe0e2fd670, length=43, elements={
0x000001fe2ebeedf0, 0x000001fe6e254f00, 0x000001fe6e255d70, 0x000001fe6e26f1a0,
0x000001fe6e271b70, 0x000001fe6e272520, 0x000001fe6e272ed0, 0x000001fe6e275bd0,
0x000001fe6e278e30, 0x000001fe6f918070, 0x000001fe6f9f5940, 0x000001fe6f9fb930,
0x000001fe6f9fe310, 0x000001fe6fa277d0, 0x000001fe6fd48550, 0x000001fe6fd48a20,
0x000001fe7ea8d1b0, 0x000001fe7ea2b570, 0x000001fe7e85aed0, 0x000001fe7ea91ec0,
0x000001fe7ea99880, 0x000001fe7e87d8d0, 0x000001fe7ef75790, 0x000001fe7ef722a0,
0x000001fe7ef73110, 0x000001fe7ef72770, 0x000001fe7ef73f80, 0x000001fe7ef71dd0,
0x000001fe7ef73ab0, 0x000001fe7ef735e0, 0x000001fe7ef74450, 0x000001fe7ef72c40,
0x000001fe7ef74920, 0x000001fe7ef74df0, 0x000001fe7f224090, 0x000001fe7f229730,
0x000001fe7f2258a0, 0x000001fe7f22a0d0, 0x000001fe7f224a30, 0x000001fe05e95280,
0x000001fe05e93e40, 0x000001fe05e970e0, 0x000001fe05e975f0
}
Java Threads: ( => current thread )
=>0x000001fe2ebeedf0 JavaThread "main" [_thread_in_native, id=59756, stack(0x00000030bdf00000,0x00000030be000000)]
0x000001fe6e254f00 JavaThread "Reference Handler" daemon [_thread_blocked, id=33592, stack(0x00000030be600000,0x00000030be700000)]
0x000001fe6e255d70 JavaThread "Finalizer" daemon [_thread_blocked, id=42784, stack(0x00000030be700000,0x00000030be800000)]
0x000001fe6e26f1a0 JavaThread "Signal Dispatcher" daemon [_thread_blocked, id=6548, stack(0x00000030be800000,0x00000030be900000)]
0x000001fe6e271b70 JavaThread "Attach Listener" daemon [_thread_blocked, id=44212, stack(0x00000030be900000,0x00000030bea00000)]
0x000001fe6e272520 JavaThread "Service Thread" daemon [_thread_blocked, id=1608, stack(0x00000030bea00000,0x00000030beb00000)]
0x000001fe6e272ed0 JavaThread "Monitor Deflation Thread" daemon [_thread_blocked, id=32748, stack(0x00000030beb00000,0x00000030bec00000)]
0x000001fe6e275bd0 JavaThread "C2 CompilerThread0" daemon [_thread_blocked, id=31564, stack(0x00000030bec00000,0x00000030bed00000)]
0x000001fe6e278e30 JavaThread "C1 CompilerThread0" daemon [_thread_blocked, id=62460, stack(0x00000030bed00000,0x00000030bee00000)]
0x000001fe6f918070 JavaThread "Sweeper thread" daemon [_thread_blocked, id=44644, stack(0x00000030bee00000,0x00000030bef00000)]
0x000001fe6f9f5940 JavaThread "Common-Cleaner" daemon [_thread_blocked, id=48224, stack(0x00000030bef00000,0x00000030bf000000)]
0x000001fe6f9fb930 JavaThread "C1 CompilerThread1" daemon [_thread_blocked, id=23052, stack(0x00000030bf000000,0x00000030bf100000)]
0x000001fe6f9fe310 JavaThread "C1 CompilerThread2" daemon [_thread_blocked, id=53236, stack(0x00000030bf100000,0x00000030bf200000)]
0x000001fe6fa277d0 JavaThread "C1 CompilerThread3" daemon [_thread_blocked, id=50816, stack(0x00000030bf200000,0x00000030bf300000)]
0x000001fe6fd48550 JavaThread "Monitor Ctrl-Break" daemon [_thread_in_native, id=34572, stack(0x00000030bf400000,0x00000030bf500000)]
0x000001fe6fd48a20 JavaThread "Notification Thread" daemon [_thread_blocked, id=37712, stack(0x00000030bf500000,0x00000030bf600000)]
0x000001fe7ea8d1b0 JavaThread "JNA Cleaner" daemon [_thread_blocked, id=22200, stack(0x00000030bfa00000,0x00000030bfb00000)]
0x000001fe7ea2b570 JavaThread "OpenGL Object Cleaner for ru.dbotthepony.kstarbound.client.gl.GLStateTracker@c7ba306" daemon [_thread_blocked, id=11028, stack(0x00000030c0100000,0x00000030c0200000)]
0x000001fe7e85aed0 JavaThread "Starbound Lighting Thread 0" daemon [_thread_blocked, id=35784, stack(0x00000030c0b00000,0x00000030c0c00000)]
0x000001fe7ea91ec0 JavaThread "Starbound Lighting Thread 1" daemon [_thread_blocked, id=8936, stack(0x00000030c0c00000,0x00000030c0d00000)]
0x000001fe7ea99880 JavaThread "Starbound Lighting Thread 2" daemon [_thread_blocked, id=46208, stack(0x00000030c0d00000,0x00000030c0e00000)]
0x000001fe7e87d8d0 JavaThread "Starbound Lighting Thread 3" daemon [_thread_blocked, id=53204, stack(0x00000030c0e00000,0x00000030c0f00000)]
0x000001fe7ef75790 JavaThread "Starbound Lighting Thread 4" daemon [_thread_blocked, id=14576, stack(0x00000030c0f00000,0x00000030c1000000)]
0x000001fe7ef722a0 JavaThread "Starbound Lighting Thread 5" daemon [_thread_blocked, id=11352, stack(0x00000030c1000000,0x00000030c1100000)]
0x000001fe7ef73110 JavaThread "Starbound Lighting Thread 6" daemon [_thread_blocked, id=58112, stack(0x00000030c1100000,0x00000030c1200000)]
0x000001fe7ef72770 JavaThread "Starbound Lighting Thread 7" daemon [_thread_blocked, id=43948, stack(0x00000030c1200000,0x00000030c1300000)]
0x000001fe7ef73f80 JavaThread "Starbound Lighting Thread 8" daemon [_thread_blocked, id=53952, stack(0x00000030c1300000,0x00000030c1400000)]
0x000001fe7ef71dd0 JavaThread "Starbound Lighting Thread 9" daemon [_thread_blocked, id=23092, stack(0x00000030c1400000,0x00000030c1500000)]
0x000001fe7ef73ab0 JavaThread "Starbound Lighting Thread 10" daemon [_thread_blocked, id=62668, stack(0x00000030c1500000,0x00000030c1600000)]
0x000001fe7ef735e0 JavaThread "Starbound Lighting Thread 11" daemon [_thread_blocked, id=35136, stack(0x00000030c1600000,0x00000030c1700000)]
0x000001fe7ef74450 JavaThread "Starbound Lighting Thread 12" daemon [_thread_blocked, id=12788, stack(0x00000030c1700000,0x00000030c1800000)]
0x000001fe7ef72c40 JavaThread "Starbound Lighting Thread 13" daemon [_thread_blocked, id=34100, stack(0x00000030c1800000,0x00000030c1900000)]
0x000001fe7ef74920 JavaThread "Starbound Lighting Thread 14" daemon [_thread_blocked, id=44888, stack(0x00000030c1900000,0x00000030c1a00000)]
0x000001fe7ef74df0 JavaThread "Starbound Lighting Thread 15" daemon [_thread_blocked, id=58448, stack(0x00000030c1a00000,0x00000030c1b00000)]
0x000001fe7f224090 JavaThread "STB Image Cleaner" daemon [_thread_blocked, id=9440, stack(0x00000030c1d00000,0x00000030c1e00000)]
0x000001fe7f229730 JavaThread "ForkJoinPool.commonPool-worker-1" daemon [_thread_blocked, id=21812, stack(0x00000030c2100000,0x00000030c2200000)]
0x000001fe7f2258a0 JavaThread "ForkJoinPool.commonPool-worker-2" daemon [_thread_blocked, id=32368, stack(0x00000030c2200000,0x00000030c2300000)]
0x000001fe7f22a0d0 JavaThread "ForkJoinPool.commonPool-worker-3" daemon [_thread_blocked, id=38908, stack(0x00000030c2300000,0x00000030c2400000)]
0x000001fe7f224a30 JavaThread "Lua State Cleaner" daemon [_thread_blocked, id=38248, stack(0x00000030c2a00000,0x00000030c2b00000)]
0x000001fe05e95280 JavaThread "C2 CompilerThread1" daemon [_thread_blocked, id=30148, stack(0x00000030bf300000,0x00000030bf400000)]
0x000001fe05e93e40 JavaThread "C2 CompilerThread2" daemon [_thread_blocked, id=34528, stack(0x00000030c1e00000,0x00000030c1f00000)]
0x000001fe05e970e0 JavaThread "C2 CompilerThread3" daemon [_thread_blocked, id=54940, stack(0x00000030c1f00000,0x00000030c2000000)]
0x000001fe05e975f0 JavaThread "C2 CompilerThread4" daemon [_thread_in_native, id=31716, stack(0x00000030c2000000,0x00000030c2100000)]
Other Threads:
0x000001fe6e250300 VMThread "VM Thread" [stack: 0x00000030be500000,0x00000030be600000] [id=52432]
0x000001fe6fbb8bf0 WatcherThread [stack: 0x00000030bf600000,0x00000030bf700000] [id=42512]
0x000001fe2eca7380 GCTaskThread "GC Thread#0" [stack: 0x00000030be000000,0x00000030be100000] [id=51320]
0x000001fe701a4740 GCTaskThread "GC Thread#1" [stack: 0x00000030bf700000,0x00000030bf800000] [id=44008]
0x000001fe701bfc70 GCTaskThread "GC Thread#2" [stack: 0x00000030bf800000,0x00000030bf900000] [id=14864]
0x000001fe701e3490 GCTaskThread "GC Thread#3" [stack: 0x00000030bf900000,0x00000030bfa00000] [id=51728]
0x000001fe7e9ab1d0 GCTaskThread "GC Thread#4" [stack: 0x00000030c0200000,0x00000030c0300000] [id=62760]
0x000001fe7e9ac750 GCTaskThread "GC Thread#5" [stack: 0x00000030c0300000,0x00000030c0400000] [id=46140]
0x000001fe7e9ab9e0 GCTaskThread "GC Thread#6" [stack: 0x00000030c0400000,0x00000030c0500000] [id=62408]
0x000001fe7e9ab480 GCTaskThread "GC Thread#7" [stack: 0x00000030c0500000,0x00000030c0600000] [id=45464]
0x000001fe7e9ac1f0 GCTaskThread "GC Thread#8" [stack: 0x00000030c0600000,0x00000030c0700000] [id=59260]
0x000001fe7e9abc90 GCTaskThread "GC Thread#9" [stack: 0x00000030c0700000,0x00000030c0800000] [id=49780]
0x000001fe7e9aca00 GCTaskThread "GC Thread#10" [stack: 0x00000030c0800000,0x00000030c0900000] [id=50016]
0x000001fe7e9abf40 GCTaskThread "GC Thread#11" [stack: 0x00000030c0900000,0x00000030c0a00000] [id=30080]
0x000001fe7e9ac4a0 GCTaskThread "GC Thread#12" [stack: 0x00000030c0a00000,0x00000030c0b00000] [id=39648]
0x000001fe2ecb8280 ConcurrentGCThread "G1 Main Marker" [stack: 0x00000030be100000,0x00000030be200000] [id=60796]
0x000001fe2ecb8c90 ConcurrentGCThread "G1 Conc#0" [stack: 0x00000030be200000,0x00000030be300000] [id=37112]
0x000001fe7bab95c0 ConcurrentGCThread "G1 Conc#1" [stack: 0x00000030c1b00000,0x00000030c1c00000] [id=34660]
0x000001fe7bab9870 ConcurrentGCThread "G1 Conc#2" [stack: 0x00000030c1c00000,0x00000030c1d00000] [id=25020]
0x000001fe6e1059f0 ConcurrentGCThread "G1 Refine#0" [stack: 0x00000030be300000,0x00000030be400000] [id=17128]
0x000001fe03f75850 ConcurrentGCThread "G1 Refine#1" [stack: 0x00000030c2400000,0x00000030c2500000] [id=54700]
0x000001fe03f760f0 ConcurrentGCThread "G1 Refine#2" [stack: 0x00000030c2500000,0x00000030c2600000] [id=44136]
0x000001fe03f74fb0 ConcurrentGCThread "G1 Refine#3" [stack: 0x00000030c2600000,0x00000030c2700000] [id=14452]
0x000001fe03f766b0 ConcurrentGCThread "G1 Refine#4" [stack: 0x00000030c2700000,0x00000030c2800000] [id=42108]
0x000001fe03f75e10 ConcurrentGCThread "G1 Refine#5" [stack: 0x00000030c2800000,0x00000030c2900000] [id=49292]
0x000001fe067259c0 ConcurrentGCThread "G1 Refine#6" [stack: 0x00000030c2900000,0x00000030c2a00000] [id=26260]
0x000001fe6e106410 ConcurrentGCThread "G1 Service" [stack: 0x00000030be400000,0x00000030be500000] [id=15668]
Threads with active compile tasks:
C2 CompilerThread4 6630 7365 % 4 ru.dbotthepony.kstarbound.client.render.TileRenderer::tesselate @ 130 (184 bytes)
VM state: not at safepoint (normal execution)
VM Mutex/Monitor currently owned by a thread: None
Heap address: 0x0000000401000000, size: 16368 MB, Compressed Oops mode: Zero based, Oop shift amount: 3
CDS archive(s) mapped at: [0x0000000800000000-0x0000000800bc0000-0x0000000800bc0000), size 12320768, SharedBaseAddress: 0x0000000800000000, ArchiveRelocationMode: 0.
Compressed class space mapped at: 0x0000000800c00000-0x0000000840c00000, reserved size: 1073741824
Narrow klass base: 0x0000000800000000, Narrow klass shift: 0, Narrow klass range: 0x100000000
GC Precious Log:
CPUs: 16 total, 16 available
Memory: 65457M
Large Page Support: Disabled
NUMA Support: Disabled
Compressed Oops: Enabled (Zero based)
Heap Region Size: 8M
Heap Min Capacity: 128M
Heap Initial Capacity: 128M
Heap Max Capacity: 16368M
Pre-touch: Disabled
Parallel Workers: 13
Concurrent Workers: 3
Concurrent Refinement Workers: 13
Periodic GC: Disabled
Heap:
garbage-first heap total 589824K, used 226540K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 4 young (32768K), 3 survivors (24576K)
Metaspace used 35394K, committed 35840K, reserved 1081344K
class space used 3620K, committed 3840K, reserved 1048576K
Heap Regions: E=young(eden), S=young(survivor), O=old, HS=humongous(starts), HC=humongous(continues), CS=collection set, F=free, OA=open archive, CA=closed archive, TAMS=top-at-mark-start (previous, next)
| 0|0x0000000401000000, 0x0000000401800000, 0x0000000401800000|100%| O| |TAMS 0x0000000401800000, 0x0000000401000000| Untracked
| 1|0x0000000401800000, 0x0000000402000000, 0x0000000402000000|100%| O| |TAMS 0x0000000402000000, 0x0000000401800000| Untracked
| 2|0x0000000402000000, 0x0000000402800000, 0x0000000402800000|100%| O| |TAMS 0x0000000402800000, 0x0000000402000000| Untracked
| 3|0x0000000402800000, 0x0000000403000000, 0x0000000403000000|100%| O| |TAMS 0x0000000403000000, 0x0000000402800000| Untracked
| 4|0x0000000403000000, 0x0000000403800000, 0x0000000403800000|100%| O| |TAMS 0x0000000403800000, 0x0000000403000000| Untracked
| 5|0x0000000403800000, 0x0000000404000000, 0x0000000404000000|100%| O| |TAMS 0x0000000404000000, 0x0000000403800000| Untracked
| 6|0x0000000404000000, 0x0000000404800000, 0x0000000404800000|100%| O| |TAMS 0x0000000404800000, 0x0000000404000000| Untracked
| 7|0x0000000404800000, 0x0000000405000000, 0x0000000405000000|100%| O| |TAMS 0x0000000405000000, 0x0000000404800000| Untracked
| 8|0x0000000405000000, 0x0000000405800000, 0x0000000405800000|100%| O| |TAMS 0x0000000405800000, 0x0000000405000000| Untracked
| 9|0x0000000405800000, 0x0000000406000000, 0x0000000406000000|100%| O| |TAMS 0x0000000406000000, 0x0000000405800000| Untracked
| 10|0x0000000406000000, 0x0000000406800000, 0x0000000406800000|100%| O| |TAMS 0x0000000406800000, 0x0000000406000000| Untracked
| 11|0x0000000406800000, 0x0000000407000000, 0x0000000407000000|100%| O| |TAMS 0x0000000407000000, 0x0000000406800000| Untracked
| 12|0x0000000407000000, 0x0000000407800000, 0x0000000407800000|100%| O| |TAMS 0x0000000407800000, 0x0000000407000000| Untracked
| 13|0x0000000407800000, 0x0000000408000000, 0x0000000408000000|100%| O| |TAMS 0x0000000408000000, 0x0000000407800000| Untracked
| 14|0x0000000408000000, 0x0000000408800000, 0x0000000408800000|100%| O| |TAMS 0x0000000408800000, 0x0000000408000000| Untracked
| 15|0x0000000408800000, 0x0000000409000000, 0x0000000409000000|100%| O| |TAMS 0x0000000409000000, 0x0000000408800000| Untracked
| 16|0x0000000409000000, 0x0000000409800000, 0x0000000409800000|100%| O| |TAMS 0x0000000409800000, 0x0000000409000000| Untracked
| 17|0x0000000409800000, 0x000000040a000000, 0x000000040a000000|100%| O| |TAMS 0x0000000409e94800, 0x0000000409800000| Untracked
| 18|0x000000040a000000, 0x000000040a800000, 0x000000040a800000|100%| O| |TAMS 0x000000040a000000, 0x000000040a000000| Untracked
| 19|0x000000040a800000, 0x000000040b000000, 0x000000040b000000|100%| O| |TAMS 0x000000040a800000, 0x000000040a800000| Untracked
| 20|0x000000040b000000, 0x000000040b800000, 0x000000040b800000|100%| O| |TAMS 0x000000040b000000, 0x000000040b000000| Untracked
| 21|0x000000040b800000, 0x000000040c000000, 0x000000040c000000|100%| O| |TAMS 0x000000040b800000, 0x000000040b800000| Untracked
| 22|0x000000040c000000, 0x000000040c800000, 0x000000040c800000|100%| O| |TAMS 0x000000040c000000, 0x000000040c000000| Untracked
| 23|0x000000040c800000, 0x000000040d000000, 0x000000040d000000|100%| O| |TAMS 0x000000040c800000, 0x000000040c800000| Untracked
| 24|0x000000040d000000, 0x000000040d53b200, 0x000000040d800000| 65%| O| |TAMS 0x000000040d000000, 0x000000040d000000| Untracked
| 25|0x000000040d800000, 0x000000040d800000, 0x000000040e000000| 0%| F| |TAMS 0x000000040d800000, 0x000000040d800000| Untracked
| 26|0x000000040e000000, 0x000000040e000000, 0x000000040e800000| 0%| F| |TAMS 0x000000040e000000, 0x000000040e000000| Untracked
| 27|0x000000040e800000, 0x000000040e800000, 0x000000040f000000| 0%| F| |TAMS 0x000000040e800000, 0x000000040e800000| Untracked
| 28|0x000000040f000000, 0x000000040f000000, 0x000000040f800000| 0%| F| |TAMS 0x000000040f000000, 0x000000040f000000| Untracked
| 29|0x000000040f800000, 0x000000040f800000, 0x0000000410000000| 0%| F| |TAMS 0x000000040f800000, 0x000000040f800000| Untracked
| 30|0x0000000410000000, 0x0000000410000000, 0x0000000410800000| 0%| F| |TAMS 0x0000000410000000, 0x0000000410000000| Untracked
| 31|0x0000000410800000, 0x0000000410800000, 0x0000000411000000| 0%| F| |TAMS 0x0000000410800000, 0x0000000410800000| Untracked
| 32|0x0000000411000000, 0x0000000411000000, 0x0000000411800000| 0%| F| |TAMS 0x0000000411000000, 0x0000000411000000| Untracked
| 33|0x0000000411800000, 0x0000000411800000, 0x0000000412000000| 0%| F| |TAMS 0x0000000411800000, 0x0000000411800000| Untracked
| 34|0x0000000412000000, 0x0000000412000000, 0x0000000412800000| 0%| F| |TAMS 0x0000000412000000, 0x0000000412000000| Untracked
| 35|0x0000000412800000, 0x0000000412800000, 0x0000000413000000| 0%| F| |TAMS 0x0000000412800000, 0x0000000412800000| Untracked
| 36|0x0000000413000000, 0x0000000413000000, 0x0000000413800000| 0%| F| |TAMS 0x0000000413000000, 0x0000000413000000| Untracked
| 37|0x0000000413800000, 0x0000000413800000, 0x0000000414000000| 0%| F| |TAMS 0x0000000413800000, 0x0000000413800000| Untracked
| 38|0x0000000414000000, 0x0000000414000000, 0x0000000414800000| 0%| F| |TAMS 0x0000000414000000, 0x0000000414000000| Untracked
| 39|0x0000000414800000, 0x0000000414800000, 0x0000000415000000| 0%| F| |TAMS 0x0000000414800000, 0x0000000414800000| Untracked
| 40|0x0000000415000000, 0x0000000415000000, 0x0000000415800000| 0%| F| |TAMS 0x0000000415000000, 0x0000000415000000| Untracked
| 41|0x0000000415800000, 0x0000000415800000, 0x0000000416000000| 0%| F| |TAMS 0x0000000415800000, 0x0000000415800000| Untracked
| 42|0x0000000416000000, 0x0000000416000000, 0x0000000416800000| 0%| F| |TAMS 0x0000000416000000, 0x0000000416000000| Untracked
| 43|0x0000000416800000, 0x0000000416800000, 0x0000000417000000| 0%| F| |TAMS 0x0000000416800000, 0x0000000416800000| Untracked
| 44|0x0000000417000000, 0x0000000417000000, 0x0000000417800000| 0%| F| |TAMS 0x0000000417000000, 0x0000000417000000| Untracked
| 45|0x0000000417800000, 0x0000000417800000, 0x0000000418000000| 0%| F| |TAMS 0x0000000417800000, 0x0000000417800000| Untracked
| 46|0x0000000418000000, 0x0000000418000000, 0x0000000418800000| 0%| F| |TAMS 0x0000000418000000, 0x0000000418000000| Untracked
| 47|0x0000000418800000, 0x0000000418800000, 0x0000000419000000| 0%| F| |TAMS 0x0000000418800000, 0x0000000418800000| Untracked
| 48|0x0000000419000000, 0x0000000419800000, 0x0000000419800000|100%| S|CS|TAMS 0x0000000419000000, 0x0000000419000000| Complete
| 49|0x0000000419800000, 0x000000041a000000, 0x000000041a000000|100%| S|CS|TAMS 0x0000000419800000, 0x0000000419800000| Complete
| 50|0x000000041a000000, 0x000000041a800000, 0x000000041a800000|100%| S|CS|TAMS 0x000000041a000000, 0x000000041a000000| Complete
| 51|0x000000041a800000, 0x000000041a800000, 0x000000041b000000| 0%| F| |TAMS 0x000000041a800000, 0x000000041a800000| Untracked
| 52|0x000000041b000000, 0x000000041b000000, 0x000000041b800000| 0%| F| |TAMS 0x000000041b000000, 0x000000041b000000| Untracked
| 53|0x000000041b800000, 0x000000041b800000, 0x000000041c000000| 0%| F| |TAMS 0x000000041b800000, 0x000000041b800000| Untracked
| 54|0x000000041c000000, 0x000000041c000000, 0x000000041c800000| 0%| F| |TAMS 0x000000041c000000, 0x000000041c000000| Untracked
| 55|0x000000041c800000, 0x000000041c800000, 0x000000041d000000| 0%| F| |TAMS 0x000000041c800000, 0x000000041c800000| Untracked
| 56|0x000000041d000000, 0x000000041d000000, 0x000000041d800000| 0%| F| |TAMS 0x000000041d000000, 0x000000041d000000| Untracked
| 57|0x000000041d800000, 0x000000041d800000, 0x000000041e000000| 0%| F| |TAMS 0x000000041d800000, 0x000000041d800000| Untracked
| 58|0x000000041e000000, 0x000000041e000000, 0x000000041e800000| 0%| F| |TAMS 0x000000041e000000, 0x000000041e000000| Untracked
| 59|0x000000041e800000, 0x000000041e800000, 0x000000041f000000| 0%| F| |TAMS 0x000000041e800000, 0x000000041e800000| Untracked
| 60|0x000000041f000000, 0x000000041f000000, 0x000000041f800000| 0%| F| |TAMS 0x000000041f000000, 0x000000041f000000| Untracked
| 61|0x000000041f800000, 0x000000041f800000, 0x0000000420000000| 0%| F| |TAMS 0x000000041f800000, 0x000000041f800000| Untracked
| 62|0x0000000420000000, 0x0000000420000000, 0x0000000420800000| 0%| F| |TAMS 0x0000000420000000, 0x0000000420000000| Untracked
| 63|0x0000000420800000, 0x0000000420800000, 0x0000000421000000| 0%| F| |TAMS 0x0000000420800000, 0x0000000420800000| Untracked
| 64|0x0000000421000000, 0x0000000421000000, 0x0000000421800000| 0%| F| |TAMS 0x0000000421000000, 0x0000000421000000| Untracked
| 65|0x0000000421800000, 0x0000000421800000, 0x0000000422000000| 0%| F| |TAMS 0x0000000421800000, 0x0000000421800000| Untracked
| 66|0x0000000422000000, 0x0000000422000000, 0x0000000422800000| 0%| F| |TAMS 0x0000000422000000, 0x0000000422000000| Untracked
| 67|0x0000000422800000, 0x0000000422800000, 0x0000000423000000| 0%| F| |TAMS 0x0000000422800000, 0x0000000422800000| Untracked
| 68|0x0000000423000000, 0x0000000423000000, 0x0000000423800000| 0%| F| |TAMS 0x0000000423000000, 0x0000000423000000| Untracked
| 69|0x0000000423800000, 0x0000000423800000, 0x0000000424000000| 0%| F| |TAMS 0x0000000423800000, 0x0000000423800000| Untracked
| 70|0x0000000424000000, 0x0000000424000000, 0x0000000424800000| 0%| F| |TAMS 0x0000000424000000, 0x0000000424000000| Untracked
| 71|0x0000000424800000, 0x0000000424e46570, 0x0000000425000000| 78%| E| |TAMS 0x0000000424800000, 0x0000000424800000| Complete
Card table byte_map: [0x000001fe47f30000,0x000001fe49f30000] _byte_map_base: 0x000001fe45f28000
Marking Bits (Prev, Next): (CMBitMap*) 0x000001fe2eca7990, (CMBitMap*) 0x000001fe2eca79d0
Prev Bits: [0x000001fe4bf30000, 0x000001fe5bef0000)
Next Bits: [0x000001fe5bef0000, 0x000001fe6beb0000)
Polling page: 0x000001fe2e3c0000
Metaspace:
Usage:
Non-class: 31.03 MB used.
Class: 3.54 MB used.
Both: 34.57 MB used.
Virtual space:
Non-class space: 32.00 MB reserved, 31.25 MB ( 98%) committed, 4 nodes.
Class space: 1.00 GB reserved, 3.75 MB ( <1%) committed, 1 nodes.
Both: 1.03 GB reserved, 35.00 MB ( 3%) committed.
Chunk freelists:
Non-Class: 432.00 KB
Class: 304.00 KB
Both: 736.00 KB
MaxMetaspaceSize: unlimited
CompressedClassSpaceSize: 1.00 GB
Initial GC threshold: 21.00 MB
Current GC threshold: 52.19 MB
CDS: on
MetaspaceReclaimPolicy: balanced
- commit_granule_bytes: 65536.
- commit_granule_words: 8192.
- virtual_space_node_default_size: 1048576.
- enlarge_chunks_in_place: 1.
- new_chunks_are_fully_committed: 0.
- uncommit_free_chunks: 1.
- use_allocation_guard: 0.
- handle_deallocations: 1.
Internal statistics:
num_allocs_failed_limit: 3.
num_arena_births: 526.
num_arena_deaths: 0.
num_vsnodes_births: 5.
num_vsnodes_deaths: 0.
num_space_committed: 558.
num_space_uncommitted: 0.
num_chunks_returned_to_freelist: 3.
num_chunks_taken_from_freelist: 1793.
num_chunk_merges: 3.
num_chunk_splits: 1226.
num_chunks_enlarged: 866.
num_purges: 0.
num_inconsistent_stats: 0.
CodeHeap 'non-profiled nmethods': size=119168Kb used=5051Kb max_used=5305Kb free=114116Kb
bounds [0x000001fe3e250000, 0x000001fe3e790000, 0x000001fe456b0000]
CodeHeap 'profiled nmethods': size=119104Kb used=13230Kb max_used=14066Kb free=105873Kb
bounds [0x000001fe36e00000, 0x000001fe37be0000, 0x000001fe3e250000]
CodeHeap 'non-nmethods': size=7488Kb used=3566Kb max_used=3686Kb free=3921Kb
bounds [0x000001fe366b0000, 0x000001fe36a60000, 0x000001fe36e00000]
total_blobs=7511 nmethods=6141 adapters=1279
compilation: enabled
stopped_count=0, restarted_count=0
full_count=0
Compilation events (20 events):
Event: 6.579 Thread 0x000001fe6f9fe310 nmethod 7435 0x000001fe36e85b10 code [0x000001fe36e85cc0, 0x000001fe36e85ea8]
Event: 6.579 Thread 0x000001fe6e278e30 7438 3 ru.dbotthepony.kvector.arrays.Matrix4f$View::getC32 (8 bytes)
Event: 6.579 Thread 0x000001fe6f9fb930 nmethod 7436 0x000001fe378bb210 code [0x000001fe378bb3c0, 0x000001fe378bb5a8]
Event: 6.579 Thread 0x000001fe6f9fe310 7439 3 ru.dbotthepony.kvector.arrays.Matrix4f$View::getC33 (8 bytes)
Event: 6.579 Thread 0x000001fe6e278e30 nmethod 7438 0x000001fe378bad90 code [0x000001fe378baf40, 0x000001fe378bb128]
Event: 6.579 Thread 0x000001fe6fa277d0 nmethod 7437 0x000001fe378ba690 code [0x000001fe378ba840, 0x000001fe378baa28]
Event: 6.579 Thread 0x000001fe6f9fe310 nmethod 7439 0x000001fe379c6a90 code [0x000001fe379c6c40, 0x000001fe379c6e28]
Event: 6.579 Thread 0x000001fe6f9fb930 7440 3 ru.dbotthepony.kvector.vector.Vector2f::toDoubleVector (18 bytes)
Event: 6.580 Thread 0x000001fe6f9fb930 nmethod 7440 0x000001fe379c6490 code [0x000001fe379c6640, 0x000001fe379c6958]
Event: 6.580 Thread 0x000001fe6fa277d0 7441 3 ru.dbotthepony.kvector.vector.Vector2f::plus (27 bytes)
Event: 6.580 Thread 0x000001fe6f9fb930 7442 3 ru.dbotthepony.kvector.vector.Vector2f::plus (20 bytes)
Event: 6.580 Thread 0x000001fe6e278e30 7443 3 ru.dbotthepony.kbox2d.collision.DynamicTree::getNodeCapacity (6 bytes)
Event: 6.580 Thread 0x000001fe6f9fb930 nmethod 7442 0x000001fe36e6b110 code [0x000001fe36e6b2c0, 0x000001fe36e6b5d8]
Event: 6.580 Thread 0x000001fe6e278e30 nmethod 7443 0x000001fe37858b10 code [0x000001fe37858ca0, 0x000001fe37858db8]
Event: 6.580 Thread 0x000001fe6fa277d0 nmethod 7441 0x000001fe372df790 code [0x000001fe372df9c0, 0x000001fe372e0148]
Event: 6.581 Thread 0x000001fe05e93e40 nmethod 7423 0x000001fe3e4c2b90 code [0x000001fe3e4c2d20, 0x000001fe3e4c3218]
Event: 6.582 Thread 0x000001fe6fa277d0 7444 % 3 ru.dbotthepony.kstarbound.world.LightCalculator$calculate$1::invoke @ 55 (211 bytes)
Event: 6.583 Thread 0x000001fe6fa277d0 nmethod 7444% 0x000001fe37661390 code [0x000001fe376616c0, 0x000001fe37662b68]
Event: 6.583 Thread 0x000001fe6fa277d0 7445 3 ru.dbotthepony.kstarbound.world.LightCalculator$calculate$1::invoke (211 bytes)
Event: 6.584 Thread 0x000001fe6fa277d0 nmethod 7445 0x000001fe37504090 code [0x000001fe375043c0, 0x000001fe37505788]
GC Heap History (20 events):
Event: 2.688 GC heap before
{Heap before GC invocations=7 (full 0):
garbage-first heap total 131072K, used 74501K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 7 young (57344K), 1 survivors (8192K)
Metaspace used 29612K, committed 30016K, reserved 1081344K
class space used 3053K, committed 3264K, reserved 1048576K
}
Event: 2.700 GC heap after
{Heap after GC invocations=8 (full 0):
garbage-first heap total 172032K, used 31472K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 29612K, committed 30016K, reserved 1081344K
class space used 3053K, committed 3264K, reserved 1048576K
}
Event: 2.975 GC heap before
{Heap before GC invocations=8 (full 0):
garbage-first heap total 172032K, used 105200K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 10 young (81920K), 1 survivors (8192K)
Metaspace used 29986K, committed 30336K, reserved 1081344K
class space used 3076K, committed 3264K, reserved 1048576K
}
Event: 2.994 GC heap after
{Heap after GC invocations=9 (full 0):
garbage-first heap total 172032K, used 45881K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 29986K, committed 30336K, reserved 1081344K
class space used 3076K, committed 3264K, reserved 1048576K
}
Event: 3.221 GC heap before
{Heap before GC invocations=9 (full 0):
garbage-first heap total 172032K, used 103225K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 9 young (73728K), 2 survivors (16384K)
Metaspace used 30535K, committed 30976K, reserved 1081344K
class space used 3129K, committed 3328K, reserved 1048576K
}
Event: 3.241 GC heap after
{Heap after GC invocations=10 (full 0):
garbage-first heap total 172032K, used 57445K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 30535K, committed 30976K, reserved 1081344K
class space used 3129K, committed 3328K, reserved 1048576K
}
Event: 3.439 GC heap before
{Heap before GC invocations=10 (full 0):
garbage-first heap total 172032K, used 106597K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 8 young (65536K), 2 survivors (16384K)
Metaspace used 30989K, committed 31360K, reserved 1081344K
class space used 3156K, committed 3328K, reserved 1048576K
}
Event: 3.454 GC heap after
{Heap after GC invocations=11 (full 0):
garbage-first heap total 172032K, used 68228K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 30989K, committed 31360K, reserved 1081344K
class space used 3156K, committed 3328K, reserved 1048576K
}
Event: 3.545 GC heap before
{Heap before GC invocations=11 (full 0):
garbage-first heap total 172032K, used 109188K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 6 young (49152K), 1 survivors (8192K)
Metaspace used 31006K, committed 31360K, reserved 1081344K
class space used 3157K, committed 3328K, reserved 1048576K
}
Event: 3.559 GC heap after
{Heap after GC invocations=12 (full 0):
garbage-first heap total 294912K, used 78691K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 31006K, committed 31360K, reserved 1081344K
class space used 3157K, committed 3328K, reserved 1048576K
}
Event: 3.886 GC heap before
{Heap before GC invocations=12 (full 0):
garbage-first heap total 294912K, used 193379K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 15 young (122880K), 1 survivors (8192K)
Metaspace used 31625K, committed 32000K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 3.901 GC heap after
{Heap after GC invocations=13 (full 0):
garbage-first heap total 294912K, used 106496K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 31625K, committed 32000K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 4.116 GC heap before
{Heap before GC invocations=13 (full 0):
garbage-first heap total 294912K, used 188416K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 12 young (98304K), 2 survivors (16384K)
Metaspace used 31664K, committed 32064K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 4.137 GC heap after
{Heap after GC invocations=14 (full 0):
garbage-first heap total 294912K, used 136485K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 31664K, committed 32064K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 4.266 GC heap before
{Heap before GC invocations=14 (full 0):
garbage-first heap total 294912K, used 202021K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 10 young (81920K), 2 survivors (16384K)
Metaspace used 31677K, committed 32064K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 4.279 GC heap after
{Heap after GC invocations=15 (full 0):
garbage-first heap total 294912K, used 162386K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 31677K, committed 32064K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 4.393 GC heap before
{Heap before GC invocations=15 (full 0):
garbage-first heap total 294912K, used 211538K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 8 young (65536K), 2 survivors (16384K)
Metaspace used 31689K, committed 32064K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 4.406 GC heap after
{Heap after GC invocations=16 (full 0):
garbage-first heap total 589824K, used 187319K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 31689K, committed 32064K, reserved 1081344K
class space used 3210K, committed 3392K, reserved 1048576K
}
Event: 6.561 GC heap before
{Heap before GC invocations=17 (full 0):
garbage-first heap total 589824K, used 359351K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 22 young (180224K), 1 survivors (8192K)
Metaspace used 35382K, committed 35840K, reserved 1081344K
class space used 3620K, committed 3840K, reserved 1048576K
}
Event: 6.574 GC heap after
{Heap after GC invocations=18 (full 0):
garbage-first heap total 589824K, used 226540K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 3 young (24576K), 3 survivors (24576K)
Metaspace used 35382K, committed 35840K, reserved 1081344K
class space used 3620K, committed 3840K, reserved 1048576K
}
Deoptimization events (20 events):
Event: 6.370 Thread 0x000001fe7e87d8d0 DEOPT PACKING pc=0x000001fe379b4236 sp=0x00000030c0eff2d0
Event: 6.370 Thread 0x000001fe7e87d8d0 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c0efe910 mode 0
Event: 6.371 Thread 0x000001fe7e87d8d0 Uncommon trap: trap_request=0xffffff45 fr.pc=0x000001fe3e66076c relative=0x00000000000011ec
Event: 6.371 Thread 0x000001fe7e87d8d0 Uncommon trap: reason=unstable_if action=reinterpret pc=0x000001fe3e66076c method=ru.dbotthepony.kstarbound.world.LightCalculator$Grid.calculateSpread()V @ 623 c2
Event: 6.371 Thread 0x000001fe7e87d8d0 DEOPT PACKING pc=0x000001fe3e66076c sp=0x00000030c0eff440
Event: 6.371 Thread 0x000001fe7e87d8d0 DEOPT UNPACKING pc=0x000001fe367023a3 sp=0x00000030c0eff410 mode 2
Event: 6.372 Thread 0x000001fe7ef75790 DEOPT PACKING pc=0x000001fe379b441f sp=0x00000030c0ffec30
Event: 6.372 Thread 0x000001fe7ef75790 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c0ffe270 mode 0
Event: 6.388 Thread 0x000001fe7ea99880 DEOPT PACKING pc=0x000001fe379b449b sp=0x00000030c0dfeff0
Event: 6.388 Thread 0x000001fe7ea99880 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c0dfe630 mode 0
Event: 6.388 Thread 0x000001fe7e87d8d0 DEOPT PACKING pc=0x000001fe379b4461 sp=0x00000030c0eff2d0
Event: 6.388 Thread 0x000001fe7e87d8d0 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c0efe910 mode 0
Event: 6.403 Thread 0x000001fe7ef722a0 DEOPT PACKING pc=0x000001fe379b4461 sp=0x00000030c10fedd0
Event: 6.403 Thread 0x000001fe7ef722a0 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c10fe410 mode 0
Event: 6.404 Thread 0x000001fe7e85aed0 DEOPT PACKING pc=0x000001fe379b4461 sp=0x00000030c0bfedd0
Event: 6.404 Thread 0x000001fe7e85aed0 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c0bfe410 mode 0
Event: 6.418 Thread 0x000001fe7e85aed0 DEOPT PACKING pc=0x000001fe379b441f sp=0x00000030c0bfedd0
Event: 6.418 Thread 0x000001fe7e85aed0 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c0bfe410 mode 0
Event: 6.418 Thread 0x000001fe7ef72770 DEOPT PACKING pc=0x000001fe379b441f sp=0x00000030c12ff1e0
Event: 6.418 Thread 0x000001fe7ef72770 DEOPT UNPACKING pc=0x000001fe36702b43 sp=0x00000030c12fe820 mode 0
Classes unloaded (0 events):
No events
Classes redefined (0 events):
No events
Internal exceptions (20 events):
Event: 3.924 Thread 0x000001fe2ebeedf0 Implicit null exception at 0x000001fe3e6197cd to 0x000001fe3e619e60
Event: 3.926 Thread 0x000001fe2ebeedf0 Implicit null exception at 0x000001fe3e6186c9 to 0x000001fe3e618dec
Event: 3.929 Thread 0x000001fe2ebeedf0 Implicit null exception at 0x000001fe3e60c047 to 0x000001fe3e60c534
Event: 4.595 Thread 0x000001fe2ebeedf0 Implicit null exception at 0x000001fe3e37c1e0 to 0x000001fe3e37c72c
Event: 4.600 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x00000004203c84e8}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x00000004203c84e8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.600 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x00000004203d5070}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.newInvokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x00000004203d5070)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.601 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x00000004203da200}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x00000004203da200)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.601 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x00000004203deb50}: 'java.lang.Object java.lang.invoke.Invokers$Holder.linkToTargetMethod(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x00000004203deb50)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.615 Thread 0x000001fe2ebeedf0 Exception <a 'sun/nio/fs/WindowsException'{0x00000004204226c8}> (0x00000004204226c8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 516]
Event: 4.615 Thread 0x000001fe2ebeedf0 Exception <a 'sun/nio/fs/WindowsException'{0x0000000420422a50}> (0x0000000420422a50)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 516]
Event: 4.618 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x000000042042cba0}: 'void java.lang.invoke.DirectMethodHandle$Holder.invokeStatic(java.lang.Object, long)'> (0x000000042042cba0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.618 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000420432630}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.newInvokeSpecial(java.lang.Object, long)'> (0x0000000420432630)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.620 Thread 0x000001fe7f229730 Implicit null exception at 0x000001fe3e4f6055 to 0x000001fe3e4f7da4
Event: 4.778 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/UnsatisfiedLinkError'{0x000000041ffa5998}: Íå íàéäåíà óêàçàííàÿ ïðîöåäóðà.
> (0x000000041ffa5998)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 535]
Event: 4.797 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x000000041f0cf1a0}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.newInvokeSpecial(java.lang.Object, java.lang.Object, int, java.lang.Object)'> (0x000000041f0cf1a0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.797 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x000000041f0d2fe8}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, int, java.lang.Object)'> (0x000000041f0d2fe8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.831 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x000000041f251808}: 'int java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x000000041f251808)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.837 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x000000041f2b0b00}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, long, java.lang.Object)'> (0x000000041f2b0b00)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.837 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x000000041f2b4428}: 'java.lang.Object java.lang.invoke.Invokers$Holder.linkToTargetMethod(java.lang.Object, long, java.lang.Object, java.lang.Object)'> (0x000000041f2b4428)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.854 Thread 0x000001fe2ebeedf0 Exception <a 'java/lang/NoSuchMethodError'{0x000000041f380428}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeStatic(java.lang.Object, java.lang.Object, int, int)'> (0x000000041f380428)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
VM Operations (20 events):
Event: 4.699 Executing VM operation: HandshakeAllThreads
Event: 4.699 Executing VM operation: HandshakeAllThreads done
Event: 4.838 Executing VM operation: ICBufferFull
Event: 4.838 Executing VM operation: ICBufferFull done
Event: 4.878 Executing VM operation: HandshakeAllThreads
Event: 4.878 Executing VM operation: HandshakeAllThreads done
Event: 5.030 Executing VM operation: HandshakeAllThreads
Event: 5.030 Executing VM operation: HandshakeAllThreads done
Event: 5.085 Executing VM operation: ICBufferFull
Event: 5.085 Executing VM operation: ICBufferFull done
Event: 5.147 Executing VM operation: HandshakeAllThreads
Event: 5.148 Executing VM operation: HandshakeAllThreads done
Event: 5.189 Executing VM operation: HandshakeAllThreads
Event: 5.189 Executing VM operation: HandshakeAllThreads done
Event: 5.207 Executing VM operation: HandshakeAllThreads
Event: 5.207 Executing VM operation: HandshakeAllThreads done
Event: 6.208 Executing VM operation: Cleanup
Event: 6.208 Executing VM operation: Cleanup done
Event: 6.561 Executing VM operation: G1CollectForAllocation
Event: 6.574 Executing VM operation: G1CollectForAllocation done
Events (20 events):
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b3db10
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b3f110
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b40a90
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b42790
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b46310
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b46690
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b46c90
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b47610
Event: 5.220 Thread 0x000001fe6f918070 flushing nmethod 0x000001fe37b48390
Event: 5.694 Thread 0x000001fe05e94350 Thread exited: 0x000001fe05e94350
Event: 5.694 Thread 0x000001fe05e93e40 Thread exited: 0x000001fe05e93e40
Event: 5.694 Thread 0x000001fe05e95280 Thread exited: 0x000001fe05e95280
Event: 5.694 Thread 0x000001fe7eea1ee0 Thread exited: 0x000001fe7eea1ee0
Event: 5.694 Thread 0x000001fe7f69ca40 Thread exited: 0x000001fe7f69ca40
Event: 5.807 Thread 0x000001fe7f2d5a10 Thread exited: 0x000001fe7f2d5a10
Event: 5.808 Thread 0x000001fe7066b640 Thread exited: 0x000001fe7066b640
Event: 6.287 Thread 0x000001fe05e95280 Thread added: 0x000001fe05e95280
Event: 6.288 Thread 0x000001fe05e93e40 Thread added: 0x000001fe05e93e40
Event: 6.288 Thread 0x000001fe05e970e0 Thread added: 0x000001fe05e970e0
Event: 6.334 Thread 0x000001fe05e975f0 Thread added: 0x000001fe05e975f0
Dynamic libraries:
0x00007ff760040000 - 0x00007ff76004e000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\java.exe
0x00007ffbd8050000 - 0x00007ffbd8245000 C:\Windows\SYSTEM32\ntdll.dll
0x00007ffbd7e90000 - 0x00007ffbd7f4d000 C:\Windows\System32\KERNEL32.DLL
0x00007ffbd5990000 - 0x00007ffbd5c5d000 C:\Windows\System32\KERNELBASE.dll
0x00007ffbd5760000 - 0x00007ffbd5860000 C:\Windows\System32\ucrtbase.dll
0x00007ffbc8eb0000 - 0x00007ffbc8ec9000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\VCRUNTIME140.dll
0x00007ffbc8fe0000 - 0x00007ffbc8ff8000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\jli.dll
0x00007ffbd6df0000 - 0x00007ffbd6f90000 C:\Windows\System32\USER32.dll
0x00007ffbd58f0000 - 0x00007ffbd5912000 C:\Windows\System32\win32u.dll
0x00007ffbc2400000 - 0x00007ffbc269a000 C:\Windows\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_6.0.19041.1110_none_60b5254171f9507e\COMCTL32.dll
0x00007ffbd7a20000 - 0x00007ffbd7a4a000 C:\Windows\System32\GDI32.dll
0x00007ffbd6410000 - 0x00007ffbd64ae000 C:\Windows\System32\msvcrt.dll
0x00007ffbd5d00000 - 0x00007ffbd5e0b000 C:\Windows\System32\gdi32full.dll
0x00007ffbd5c60000 - 0x00007ffbd5cfd000 C:\Windows\System32\msvcp_win.dll
0x00007ffbd6dc0000 - 0x00007ffbd6df0000 C:\Windows\System32\IMM32.DLL
0x00007ffbcd340000 - 0x00007ffbcd34c000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\vcruntime140_1.dll
0x00007ffba9ae0000 - 0x00007ffba9b71000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\msvcp140.dll
0x00007ffb54660000 - 0x00007ffb552a6000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\server\jvm.dll
0x00007ffbd70b0000 - 0x00007ffbd715e000 C:\Windows\System32\ADVAPI32.dll
0x00007ffbd7500000 - 0x00007ffbd759c000 C:\Windows\System32\sechost.dll
0x00007ffbd6c90000 - 0x00007ffbd6db5000 C:\Windows\System32\RPCRT4.dll
0x00007ffbd7f50000 - 0x00007ffbd7f58000 C:\Windows\System32\PSAPI.DLL
0x00007ffbc01d0000 - 0x00007ffbc01d9000 C:\Windows\SYSTEM32\WSOCK32.dll
0x00007ffbcbd90000 - 0x00007ffbcbdb7000 C:\Windows\SYSTEM32\WINMM.dll
0x00007ffbcdb10000 - 0x00007ffbcdb1a000 C:\Windows\SYSTEM32\VERSION.dll
0x00007ffbd7270000 - 0x00007ffbd72db000 C:\Windows\System32\WS2_32.dll
0x00007ffbd3680000 - 0x00007ffbd3692000 C:\Windows\SYSTEM32\kernel.appcore.dll
0x00007ffbc9240000 - 0x00007ffbc924a000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\jimage.dll
0x00007ffbcf0e0000 - 0x00007ffbcf2c4000 C:\Windows\SYSTEM32\DBGHELP.DLL
0x00007ffbc23d0000 - 0x00007ffbc23fc000 C:\Windows\SYSTEM32\dbgcore.DLL
0x00007ffbd5860000 - 0x00007ffbd58e2000 C:\Windows\System32\bcryptPrimitives.dll
0x00007ffbcd790000 - 0x00007ffbcd79e000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\instrument.dll
0x00007ffbb98c0000 - 0x00007ffbb98e5000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\java.dll
0x00007ffb99a90000 - 0x00007ffb99b66000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\svml.dll
0x00007ffbd64b0000 - 0x00007ffbd6bf4000 C:\Windows\System32\SHELL32.dll
0x00007ffbd3880000 - 0x00007ffbd4014000 C:\Windows\SYSTEM32\windows.storage.dll
0x00007ffbd7b30000 - 0x00007ffbd7e84000 C:\Windows\System32\combase.dll
0x00007ffbd51c0000 - 0x00007ffbd51ec000 C:\Windows\SYSTEM32\Wldp.dll
0x00007ffbd7f60000 - 0x00007ffbd800d000 C:\Windows\System32\SHCORE.dll
0x00007ffbd7ad0000 - 0x00007ffbd7b25000 C:\Windows\System32\shlwapi.dll
0x00007ffbd56a0000 - 0x00007ffbd56bf000 C:\Windows\SYSTEM32\profapi.dll
0x00007ffbbeea0000 - 0x00007ffbbeeb8000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\zip.dll
0x00007ffbc4a00000 - 0x00007ffbc4a19000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\net.dll
0x00007ffbcd8c0000 - 0x00007ffbcd9ca000 C:\Windows\SYSTEM32\WINHTTP.dll
0x00007ffbd4f20000 - 0x00007ffbd4f8a000 C:\Windows\system32\mswsock.dll
0x00007ffbbf010000 - 0x00007ffbbf025000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\nio.dll
0x00007ffbcd760000 - 0x00007ffbcd77a000 C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin\breakgen64.dll
0x00007ffbc4ae0000 - 0x00007ffbc4ae9000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\management.dll
0x00007ffbc22c0000 - 0x00007ffbc22cb000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\management_ext.dll
0x00007ffbbe0f0000 - 0x00007ffbbe107000 C:\Windows\system32\napinsp.dll
0x00007ffbbdf90000 - 0x00007ffbbdfab000 C:\Windows\system32\pnrpnsp.dll
0x00007ffbb6a30000 - 0x00007ffbb6a45000 C:\Windows\system32\wshbth.dll
0x00007ffbd13f0000 - 0x00007ffbd140d000 C:\Windows\system32\NLAapi.dll
0x00007ffbd4ba0000 - 0x00007ffbd4bdb000 C:\Windows\SYSTEM32\IPHLPAPI.DLL
0x00007ffbd4be0000 - 0x00007ffbd4cab000 C:\Windows\SYSTEM32\DNSAPI.dll
0x00007ffbd6c60000 - 0x00007ffbd6c68000 C:\Windows\System32\NSI.dll
0x00007ffbbc030000 - 0x00007ffbbc042000 C:\Windows\System32\winrnr.dll
0x0000000061af0000 - 0x0000000061b16000 C:\Program Files\Bonjour\mdnsNSP.dll
0x00007ffbccc00000 - 0x00007ffbccc0a000 C:\Windows\System32\rasadhlp.dll
0x00007ffbcc2f0000 - 0x00007ffbcc370000 C:\Windows\System32\fwpuclnt.dll
0x00007ffbd5f10000 - 0x00007ffbd5f37000 C:\Windows\System32\bcrypt.dll
0x00007ffbb8c30000 - 0x00007ffbb8ca1000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl.dll
0x00007ffbb9230000 - 0x00007ffbb9291000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\glfw.dll
0x00007ffbb96a0000 - 0x00007ffbb96e5000 C:\Windows\SYSTEM32\dinput8.dll
0x00007ffbbda60000 - 0x00007ffbbda71000 C:\Windows\SYSTEM32\xinput1_4.dll
0x00007ffbd5e10000 - 0x00007ffbd5e5e000 C:\Windows\System32\cfgmgr32.dll
0x00007ffbd5510000 - 0x00007ffbd553c000 C:\Windows\SYSTEM32\DEVOBJ.dll
0x00007ffbd3390000 - 0x00007ffbd33bf000 C:\Windows\SYSTEM32\dwmapi.dll
0x00007ffbc89f0000 - 0x00007ffbc8b42000 C:\Windows\SYSTEM32\inputhost.dll
0x00007ffbd6340000 - 0x00007ffbd640d000 C:\Windows\System32\OLEAUT32.dll
0x00007ffbd16d0000 - 0x00007ffbd1824000 C:\Windows\SYSTEM32\wintypes.dll
0x00007ffbcfe40000 - 0x00007ffbcff36000 C:\Windows\SYSTEM32\PROPSYS.dll
0x00007ffbd2d90000 - 0x00007ffbd2e82000 C:\Windows\SYSTEM32\CoreMessaging.dll
0x00007ffbd2a30000 - 0x00007ffbd2d8e000 C:\Windows\SYSTEM32\CoreUIComponents.dll
0x00007ffbd4460000 - 0x00007ffbd4493000 C:\Windows\SYSTEM32\ntmarta.dll
0x00007ffbd31a0000 - 0x00007ffbd323e000 C:\Windows\system32\uxtheme.dll
0x00007ffbd6f90000 - 0x00007ffbd70a5000 C:\Windows\System32\MSCTF.dll
0x00007ffb9b170000 - 0x00007ffb9b296000 C:\Windows\SYSTEM32\opengl32.dll
0x00007ffb9bf50000 - 0x00007ffb9bf7c000 C:\Windows\SYSTEM32\GLU32.dll
0x00007ffbd71c0000 - 0x00007ffbd7269000 C:\Windows\System32\clbcatq.dll
0x00007ffb9bf20000 - 0x00007ffb9bf4d000 C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218\atig6pxx.dll
0x00007ffb7a5b0000 - 0x00007ffb7e2a1000 C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218\atio6axx.dll
0x00007ffbd75a0000 - 0x00007ffbd7a11000 C:\Windows\System32\SETUPAPI.dll
0x00007ffbd5920000 - 0x00007ffbd5988000 C:\Windows\System32\WINTRUST.dll
0x00007ffbd5f40000 - 0x00007ffbd6096000 C:\Windows\System32\CRYPT32.dll
0x00007ffbd5350000 - 0x00007ffbd5362000 C:\Windows\SYSTEM32\MSASN1.dll
0x00007ffbac190000 - 0x00007ffbac1ed000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl_opengl.dll
0x00007ffbd5110000 - 0x00007ffbd5128000 C:\Windows\SYSTEM32\CRYPTSP.dll
0x00007ffbd47c0000 - 0x00007ffbd47f4000 C:\Windows\system32\rsaenh.dll
0x00007ffbd5660000 - 0x00007ffbd568e000 C:\Windows\SYSTEM32\USERENV.dll
0x00007ffbd5130000 - 0x00007ffbd513c000 C:\Windows\SYSTEM32\CRYPTBASE.dll
0x00007ffbd0000000 - 0x00007ffbd0017000 C:\Windows\SYSTEM32\dhcpcsvc6.DLL
0x00007ffbcffe0000 - 0x00007ffbcfffd000 C:\Windows\SYSTEM32\dhcpcsvc.DLL
0x00007ffba9a90000 - 0x00007ffba9ad5000 C:\Users\dbott\AppData\Local\Temp\jna-95382001\jna9809531980187271138.dll
0x00007ffba4910000 - 0x00007ffba49b3000 K:\git\kstarbound\freetype-2.11.1.dll
0x00007ffbc8b50000 - 0x00007ffbc8c49000 C:\Windows\SYSTEM32\textinputframework.dll
0x00007ffba9840000 - 0x00007ffba98c1000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl_stb.dll
0x000000006e4c0000 - 0x000000006e4df000 C:\Users\dbott\AppData\Local\Temp\jffi3161326882277025995.dll
0x00007ffbc5210000 - 0x00007ffbc5220000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\verify.dll
0x00007ffba1530000 - 0x00007ffba15d4000 K:\git\kstarbound\lua54.DLL
0x00007ffbbc080000 - 0x00007ffbbc0a3000 K:\git\kstarbound\lua_glue.dll
dbghelp: loaded successfully - version: 4.0.5 - missing functions: none
symbol engine: initialized successfully - sym options: 0x614 - pdb path: .;C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin;C:\Windows\SYSTEM32;C:\Windows\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_6.0.19041.1110_none_60b5254171f9507e;C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\server;C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin;C:\Program Files\Bonjour;C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21;C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218;C:\Users\dbott\AppData\Local\Temp\jna-95382001;K:\git\kstarbound;C:\Users\dbott\AppData\Local\Temp
VM Arguments:
jvm_args: -Xms128m -javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\lib\idea_rt.jar=5737:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin -Dfile.encoding=UTF-8
java_command: ru.dbotthepony.kstarbound.MainKt
java_class_path (initial): K:\git\kstarbound\build\classes\java\main;K:\git\kstarbound\build\classes\kotlin\main;K:\git\kstarbound\build\resources\main;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.jetbrains.kotlin\kotlin-reflect\1.6.10\1cbe9c92c12a94eea200d23c2bbaedaf3daf5132\kotlin-reflect-1.6.10.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.jetbrains.kotlin\kotlin-stdlib\1.6.10\b8af3fe6f1ca88526914929add63cf5e7c5049af\kotlin-stdlib-1.6.10.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.apache.logging.log4j\log4j-core\2.17.1\779f60f3844dadc3ef597976fcb1e5127b1f343d\log4j-core-2.17.1.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.apache.logging.log4j\log4j-api\2.17.1\d771af8e336e372fb5399c99edabe0919aeaf5b2\log4j-api-2.17.1.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\com.google.code.gson\gson\2.8.9\8a432c1d6825781e21a02db2e2c33c5fde2833b9\gson-2.8.9.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\it.unimi.dsi\fastutil\8.5.6\76f95700418a68fbc4ac050525261f05dc681ca1\fastutil-8.5.6.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\com.google.guava\guava\31.0.1-jre\119ea2b2bc205b138974d351777b20f02b92704b\guava-31.0.1-jre.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-assimp\3.3.0\82135e856184e76d38a97f729141298d3edcf0e4\lwjgl-assimp-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-bgfx\3.3.0\b9e9a62b741bdc60f9207a4d4de6e61a2b7de6af\lwjgl-bgfx-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-glfw\3.3.0\899e34f314525596f8fdb6476d3e56104da4601d\lwjgl-glfw-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-nanovg\3.3.0\a15688d6e6c7136cebc5b63f30d120f702f6587c\lwjgl-nanovg-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-nuklear\3.3.0\8dbbdce4f28384c2abdfe8d0abff5f4c9bae286e\lwjgl-nuklear-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-openal\3.3.0\902dd57b
Launcher Type: SUN_STANDARD
[Global flags]
intx CICompilerCount = 12 {product} {ergonomic}
uint ConcGCThreads = 3 {product} {ergonomic}
uint G1ConcRefinementThreads = 13 {product} {ergonomic}
size_t G1HeapRegionSize = 8388608 {product} {ergonomic}
uintx GCDrainStackTargetSize = 64 {product} {ergonomic}
size_t InitialHeapSize = 134217728 {product} {command line}
size_t MarkStackSize = 4194304 {product} {ergonomic}
size_t MaxHeapSize = 17163091968 {product} {ergonomic}
size_t MaxNewSize = 10292822016 {product} {ergonomic}
size_t MinHeapDeltaBytes = 8388608 {product} {ergonomic}
size_t MinHeapSize = 134217728 {product} {command line}
uintx NonNMethodCodeHeapSize = 7602480 {pd product} {ergonomic}
uintx NonProfiledCodeHeapSize = 122027880 {pd product} {ergonomic}
uintx ProfiledCodeHeapSize = 122027880 {pd product} {ergonomic}
uintx ReservedCodeCacheSize = 251658240 {pd product} {ergonomic}
bool SegmentedCodeCache = true {product} {ergonomic}
size_t SoftMaxHeapSize = 17163091968 {manageable} {ergonomic}
bool UseCompressedClassPointers = true {product lp64_product} {ergonomic}
bool UseCompressedOops = true {product lp64_product} {ergonomic}
bool UseG1GC = true {product} {ergonomic}
bool UseLargePagesIndividualAllocation = false {pd product} {ergonomic}
Logging:
Log output configuration:
#0: stdout all=warning uptime,level,tags
#1: stderr all=off uptime,level,tags
Environment Variables:
JAVA_HOME=C:\Program Files\Eclipse Adoptium\jdk-17.0.4.101-hotspot\
PATH=C:\Program Files\Eclipse Adoptium\jdk-17.0.4.101-hotspot\bin;C:\Program Files\ImageMagick-7.1.0-Q16;C:\Program Files\Microsoft\jdk-11.0.12.7-hotspot\bin;C:\Program Files\ImageMagick-7.1.0-Q16-HDRI;C:\Program Files (x86)\NVIDIA Corporation\PhysX\Common;C:\Program Files (x86)\VMware\VMware Workstation\bin\;C:\Program Files\ImageMagick-7.0.10-Q16-HDRI;C:\Program Files\Python38\Scripts\;C:\Program Files\Python38\;C:\Program Files\ImageMagick-7.0.9-Q16;C:\Program Files (x86)\Common Files\Oracle\Java\javapath;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;D:\php7;C:\Program Files (x86)\Lua\5.1;C:\Program Files (x86)\Lua\5.1\clibs;C:\Program Files (x86)\Codebox\BitMeterOS;C:\moonscript;C:\Program Files\TortoiseHg\;C:\Program Files\GTK3-Runtime Win64\bin;C:\ProgramData\ComposerSetup\bin;C:\Program Files\Logstalgia\cmd;C:\Program Files\dotnet\;C:\Program Files\TortoiseSVN\bin;C:\Program Files\Gource\cmd;C:\kotlin-native-windows-1.3.72\bin;N:\platform-tools;C:\Program Files\PuTTY\;C:\Program Files\Git\cmd;C:\Windows\System32\OpenSSH\;D:\php-8.0.8-Win32-vs16-x64;C:\Program Files\LLVM\bin;C:\Program Files\PowerShell\7\;C:\Program Files\CMake\bin;C:\pypy3.8-v7.3.7-win64;C:\pypy3.8-v7.3.7-win64\Scripts;C:\Program Files\nodejs\;C:\Program Files\7-Zip;C:\Program Files\TortoiseGit\bin;C:\Users\dbott\.cargo\bin;C:\Users\dbott\.windows-build-tools\python27\;C:\Users\dbott\AppData\Local\Programs\Python\Python37\Scripts\;C:\Users\dbott\AppData\Local\Programs\Python\Python37\;C:\Users\dbott\AppData\Local\Microsoft\WindowsApps;C:\Users\dbott\AppData\Local\Programs\Microsoft VS Code\bin;K:\git\vcpkg\installed\x86-windows\include;K:\git\vcpkg\installed\x86-windows\lib;K:\git\vcpkg\installed\x86-windows\bin;C:\Users\dbott\AppData\Roaming\Composer\vendor\bin;C:\Users\dbott\.dotnet\tools;C:\Users\dbott\AppData\Local\Microsoft\WindowsApps;C:\Program Files (x86)\FreeArc\bin;C:\Users\dbott\AppData\Roaming\npm
USERNAME=dbott
OS=Windows_NT
PROCESSOR_IDENTIFIER=AMD64 Family 23 Model 113 Stepping 0, AuthenticAMD
--------------- S Y S T E M ---------------
OS:
Windows 10 , 64 bit Build 19041 (10.0.19041.1706)
OS uptime: 34 days 23:31 hours
CPU: total 16 (initial active 16) (16 cores per cpu, 2 threads per core) family 23 model 113 stepping 0 microcode 0x0, cx8, cmov, fxsr, ht, mmx, 3dnowpref, sse, sse2, sse3, ssse3, sse4a, sse4.1, sse4.2, popcnt, lzcnt, tsc, tscinvbit, avx, avx2, aes, clmul, bmi1, bmi2, adx, sha, fma, vzeroupper, clflush, clflushopt
Memory: 4k page, system-wide physical 65457M (24535M free)
TotalPageFile size 165457M (AvailPageFile size 106076M)
current process WorkingSet (physical memory assigned to process): 809M, peak: 831M
current process commit charge ("private bytes"): 1018M, peak: 1055M
vm_info: OpenJDK 64-Bit Server VM (17.0.1+12) for windows-amd64 JRE (17.0.1+12), built on Oct 20 2021 07:42:55 by "" with MS VC++ 16.7 (VS2019)
END.

View File

@ -1,841 +0,0 @@
#
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x00007ffb7c599979, pid=54068, tid=48396
#
# JRE version: OpenJDK Runtime Environment Temurin-17.0.1+12 (17.0.1+12) (build 17.0.1+12)
# Java VM: OpenJDK 64-Bit Server VM Temurin-17.0.1+12 (17.0.1+12, mixed mode, sharing, tiered, compressed oops, compressed class ptrs, g1 gc, windows-amd64)
# Problematic frame:
# C [atio6axx.dll+0x1fe9979]
#
# No core dump will be written. Minidumps are not enabled by default on client versions of Windows
#
# If you would like to submit a bug report, please visit:
# https://github.com/adoptium/adoptium-support/issues
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
--------------- S U M M A R Y ------------
Command Line: -Xms128m -javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\lib\idea_rt.jar=5926:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin -Dfile.encoding=UTF-8 ru.dbotthepony.kstarbound.MainKt
Host: AMD Ryzen 7 3700X 8-Core Processor , 16 cores, 63G, Windows 10 , 64 bit Build 19041 (10.0.19041.1706)
Time: Sun Sep 10 10:45:13 2023 RTZ 6 (s 10 , 64 bit Build 19041 (10.0.19041.1706) elapsed time: 14.077935 seconds (0d 0h 0m 14s)
--------------- T H R E A D ---------------
Current thread (0x000001a79cdedec0): JavaThread "main" [_thread_in_native, id=48396, stack(0x00000054a6b00000,0x00000054a6c00000)]
Stack: [0x00000054a6b00000,0x00000054a6c00000], sp=0x00000054a6bfed78, free space=1019k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
C [atio6axx.dll+0x1fe9979]
Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
J 7372 org.lwjgl.opengl.GL11C.nglTexImage2D(IIIIIIIIJ)V (0 bytes) @ 0x000001a7ac61cb24 [0x000001a7ac61caa0+0x0000000000000084]
J 7371 c1 org.lwjgl.opengl.GL11C.glTexImage2D(IIIIIIIILjava/nio/ByteBuffer;)V (21 bytes) @ 0x000001a7a50e30c4 [0x000001a7a50e2ee0+0x00000000000001e4]
J 7370 c1 org.lwjgl.opengl.GL11.glTexImage2D(IIIIIIIILjava/nio/ByteBuffer;)V (18 bytes) @ 0x000001a7a50e390c [0x000001a7a50e38a0+0x000000000000006c]
J 7502 c1 ru.dbotthepony.kstarbound.client.gl.GLTexture2D.upload(IIIIIILjava/nio/ByteBuffer;)Lru/dbotthepony/kstarbound/client/gl/GLTexture2D; (121 bytes) @ 0x000001a7a5d4b54c [0x000001a7a5d4b260+0x00000000000002ec]
J 7261 c1 ru.dbotthepony.kstarbound.client.gl.GLTexture2D.upload(IIIIILjava/nio/ByteBuffer;)Lru/dbotthepony/kstarbound/client/gl/GLTexture2D; (22 bytes) @ 0x000001a7a53eaa8c [0x000001a7a53ea720+0x000000000000036c]
J 7562 c2 ru.dbotthepony.kstarbound.client.StarboundClient.renderFrame()Z (1420 bytes) @ 0x000001a7ac98fc0c [0x000001a7ac98d660+0x00000000000025ac]
j ru.dbotthepony.kstarbound.MainKt.main()V+253
j ru.dbotthepony.kstarbound.MainKt.main([Ljava/lang/String;)V+0
v ~StubRoutines::call_stub
siginfo: EXCEPTION_ACCESS_VIOLATION (0xc0000005), reading address 0x000001a7eb57b000
Register to memory mapping:
RIP=0x00007ffb7c599979 atio6axx.dll
RAX=0x000001a7ed0035f0 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RBX=0x000001a7ec882f10 points into unknown readable memory: 0x0151015201510150 | 50 01 51 01 52 01 51 01
RCX=0x000001a7ed003b00 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RDX=0x000001a7eb57afc0 points into unknown readable memory: 0x3f0ccccd41200000 | 00 00 20 41 cd cc 0c 3f
RSP=0x00000054a6bfed78 is pointing into the stack for thread: 0x000001a79cdedec0
RBP=0x00000054a6bfee11 is pointing into the stack for thread: 0x000001a79cdedec0
RSI=0x000001a7ed0035f0 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
RDI=0x0000000000001908 is an unknown value
R8 =0x0000000000008700 is an unknown value
R9 =0xfffffffffffffff0 is an unknown value
R10=0x00007ffb7a5b0000 atio6axx.dll
R11=0x000001a7eab71690 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
R12=0x0000000000008c10 is an unknown value
R13=0x0000000000008c10 is an unknown value
R14=0x000001a7eaaaf080 points into unknown readable memory: 0x00007ffb7d8691f0 | f0 91 86 7d fb 7f 00 00
R15=0x0 is NULL
Registers:
RAX=0x000001a7ed0035f0, RBX=0x000001a7ec882f10, RCX=0x000001a7ed003b00, RDX=0x000001a7eb57afc0
RSP=0x00000054a6bfed78, RBP=0x00000054a6bfee11, RSI=0x000001a7ed0035f0, RDI=0x0000000000001908
R8 =0x0000000000008700, R9 =0xfffffffffffffff0, R10=0x00007ffb7a5b0000, R11=0x000001a7eab71690
R12=0x0000000000008c10, R13=0x0000000000008c10, R14=0x000001a7eaaaf080, R15=0x0000000000000000
RIP=0x00007ffb7c599979, EFLAGS=0x0000000000010206
Top of Stack: (sp=0x00000054a6bfed78)
0x00000054a6bfed78: 00007ffb7ad699f3 000000003f7f7ccc
0x00000054a6bfed88: 000001a7b4128000 0000000084106d53
0x00000054a6bfed98: 00000000ffffffff 0000000000000053
0x00000054a6bfeda8: 00007ffb00000001 000001a700001908
0x00000054a6bfedb8: 0000000000001401 0000000000000000
0x00000054a6bfedc8: 0000000000000000 0000000100000000
0x00000054a6bfedd8: 0000000200000001 000001a7ed0035f0
0x00000054a6bfede8: 0000000000008c10 0000000000000038
0x00000054a6bfedf8: 0000000000000000 000033d6b9f44364
0x00000054a6bfee08: 0000000000000001 0000005400000000
0x00000054a6bfee18: 0000000000001908 0000000000001401
0x00000054a6bfee28: 0000000000000053 0000000000000000
0x00000054a6bfee38: 0000000000000000 0000000000000053
0x00000054a6bfee48: 000001a7eaaaf080 000001a7dfed52c8
0x00000054a6bfee58: 00007ffb7ae43bd7 000001a7eaaaf000
0x00000054a6bfee68: 000001a700000de1 000001a700000000
Instructions: (pc=0x00007ffb7c599979)
0x00007ffb7c599879: b6 4a 08 4c 89 00 88 48 08 c3 4c 8b 02 8b 4a 08
0x00007ffb7c599889: 4c 89 00 89 48 08 c3 8b 0a 44 0f b7 42 04 89 08
0x00007ffb7c599899: 66 44 89 40 04 c3 8b 0a 44 0f b6 42 04 89 08 44
0x00007ffb7c5998a9: 88 40 04 c3 48 8b 0a 48 89 08 c3 0f b6 0a 88 08
0x00007ffb7c5998b9: c3 8b 0a 89 08 c3 90 49 83 f8 20 77 17 f3 0f 6f
0x00007ffb7c5998c9: 0a f3 42 0f 6f 54 02 f0 f3 0f 7f 09 f3 42 0f 7f
0x00007ffb7c5998d9: 54 01 f0 c3 48 3b d1 73 0e 4e 8d 0c 02 49 3b c9
0x00007ffb7c5998e9: 0f 82 41 04 00 00 90 83 3d 21 37 8d 01 03 0f 82
0x00007ffb7c5998f9: e3 02 00 00 49 81 f8 00 20 00 00 76 16 49 81 f8
0x00007ffb7c599909: 00 00 18 00 77 0d f6 05 be d0 a3 01 02 0f 85 64
0x00007ffb7c599919: fe ff ff c5 fe 6f 02 c4 a1 7e 6f 6c 02 e0 49 81
0x00007ffb7c599929: f8 00 01 00 00 0f 86 c4 00 00 00 4c 8b c9 49 83
0x00007ffb7c599939: e1 1f 49 83 e9 20 49 2b c9 49 2b d1 4d 03 c1 49
0x00007ffb7c599949: 81 f8 00 01 00 00 0f 86 a3 00 00 00 49 81 f8 00
0x00007ffb7c599959: 00 18 00 0f 87 3e 01 00 00 66 66 66 66 66 66 0f
0x00007ffb7c599969: 1f 84 00 00 00 00 00 c5 fe 6f 0a c5 fe 6f 52 20
0x00007ffb7c599979: c5 fe 6f 5a 40 c5 fe 6f 62 60 c5 fd 7f 09 c5 fd
0x00007ffb7c599989: 7f 51 20 c5 fd 7f 59 40 c5 fd 7f 61 60 c5 fe 6f
0x00007ffb7c599999: 8a 80 00 00 00 c5 fe 6f 92 a0 00 00 00 c5 fe 6f
0x00007ffb7c5999a9: 9a c0 00 00 00 c5 fe 6f a2 e0 00 00 00 c5 fd 7f
0x00007ffb7c5999b9: 89 80 00 00 00 c5 fd 7f 91 a0 00 00 00 c5 fd 7f
0x00007ffb7c5999c9: 99 c0 00 00 00 c5 fd 7f a1 e0 00 00 00 48 81 c1
0x00007ffb7c5999d9: 00 01 00 00 48 81 c2 00 01 00 00 49 81 e8 00 01
0x00007ffb7c5999e9: 00 00 49 81 f8 00 01 00 00 0f 83 78 ff ff ff 4d
0x00007ffb7c5999f9: 8d 48 1f 49 83 e1 e0 4d 8b d9 49 c1 eb 05 47 8b
0x00007ffb7c599a09: 9c 9a 40 b0 c1 03 4d 03 da 41 ff e3 c4 a1 7e 6f
0x00007ffb7c599a19: 8c 0a 00 ff ff ff c4 a1 7e 7f 8c 09 00 ff ff ff
0x00007ffb7c599a29: c4 a1 7e 6f 8c 0a 20 ff ff ff c4 a1 7e 7f 8c 09
0x00007ffb7c599a39: 20 ff ff ff c4 a1 7e 6f 8c 0a 40 ff ff ff c4 a1
0x00007ffb7c599a49: 7e 7f 8c 09 40 ff ff ff c4 a1 7e 6f 8c 0a 60 ff
0x00007ffb7c599a59: ff ff c4 a1 7e 7f 8c 09 60 ff ff ff c4 a1 7e 6f
0x00007ffb7c599a69: 4c 0a 80 c4 a1 7e 7f 4c 09 80 c4 a1 7e 6f 4c 0a
Stack slot to memory mapping:
stack at sp + 0 slots: 0x00007ffb7ad699f3 atio6axx.dll
stack at sp + 1 slots: 0x000000003f7f7ccc is an unknown value
stack at sp + 2 slots: 0x000001a7b4128000 points into unknown readable memory: 0x0000000000000000 | 00 00 00 00 00 00 00 00
stack at sp + 3 slots: 2215669075 is a compressed pointer to object: java.util.ArrayList
{0x0000000420836a98} - klass: 'java/util/ArrayList'
- ---- fields (total size 3 words):
- protected transient 'modCount' 'I' @12 25 (19)
- private 'size' 'I' @16 25 (19)
- transient 'elementData' '[Ljava/lang/Object;' @20 a 'java/lang/Object'[33] {0x0000000420839590} (841072b2)
stack at sp + 4 slots: 0x00000000ffffffff is an unknown value
stack at sp + 5 slots: 0x0000000000000053 is an unknown value
stack at sp + 6 slots: 0x00007ffb00000001 is an unknown value
stack at sp + 7 slots: 0x000001a700001908 is an unknown value
--------------- P R O C E S S ---------------
Threads class SMR info:
_java_thread_list=0x000001a7f6d10000, length=39, elements={
0x000001a79cdedec0, 0x000001a7dc470e90, 0x000001a7dc471d00, 0x000001a7dc48d810,
0x000001a7dc48e2c0, 0x000001a7ddc02090, 0x000001a7ddc02d50, 0x000001a7ddc03a30,
0x000001a7ddc044d0, 0x000001a7ddc0a3d0, 0x000001a7dc455c50, 0x000001a7dde36040,
0x000001a7dde36510, 0x000001a7eb5e09d0, 0x000001a7eb8362a0, 0x000001a7eb968d90,
0x000001a7eb969260, 0x000001a7eb5c72f0, 0x000001a7eb5c77c0, 0x000001a7df215b80,
0x000001a7df213ea0, 0x000001a7df214840, 0x000001a7df214370, 0x000001a7df214d10,
0x000001a7df2151e0, 0x000001a7df216050, 0x000001a7df2156b0, 0x000001a7df2139d0,
0x000001a7df216520, 0x000001a7df213500, 0x000001a7eb72a150, 0x000001a7eb724ab0,
0x000001a7eb727600, 0x000001a7eb728940, 0x000001a7eb7245e0, 0x000001a7eb725df0,
0x000001a7f1f4d9a0, 0x000001a7f1f52080, 0x000001a7f1f51b70
}
Java Threads: ( => current thread )
=>0x000001a79cdedec0 JavaThread "main" [_thread_in_native, id=48396, stack(0x00000054a6b00000,0x00000054a6c00000)]
0x000001a7dc470e90 JavaThread "Reference Handler" daemon [_thread_blocked, id=2792, stack(0x00000054a7200000,0x00000054a7300000)]
0x000001a7dc471d00 JavaThread "Finalizer" daemon [_thread_blocked, id=32908, stack(0x00000054a7300000,0x00000054a7400000)]
0x000001a7dc48d810 JavaThread "Signal Dispatcher" daemon [_thread_blocked, id=8260, stack(0x00000054a7400000,0x00000054a7500000)]
0x000001a7dc48e2c0 JavaThread "Attach Listener" daemon [_thread_blocked, id=45920, stack(0x00000054a7500000,0x00000054a7600000)]
0x000001a7ddc02090 JavaThread "Service Thread" daemon [_thread_blocked, id=44440, stack(0x00000054a7600000,0x00000054a7700000)]
0x000001a7ddc02d50 JavaThread "Monitor Deflation Thread" daemon [_thread_blocked, id=49940, stack(0x00000054a7700000,0x00000054a7800000)]
0x000001a7ddc03a30 JavaThread "C2 CompilerThread0" daemon [_thread_in_native, id=43024, stack(0x00000054a7800000,0x00000054a7900000)]
0x000001a7ddc044d0 JavaThread "C1 CompilerThread0" daemon [_thread_blocked, id=42260, stack(0x00000054a7900000,0x00000054a7a00000)]
0x000001a7ddc0a3d0 JavaThread "Sweeper thread" daemon [_thread_blocked, id=20956, stack(0x00000054a7a00000,0x00000054a7b00000)]
0x000001a7dc455c50 JavaThread "Common-Cleaner" daemon [_thread_blocked, id=37976, stack(0x00000054a7b00000,0x00000054a7c00000)]
0x000001a7dde36040 JavaThread "Monitor Ctrl-Break" daemon [_thread_in_native, id=50328, stack(0x00000054a7f00000,0x00000054a8000000)]
0x000001a7dde36510 JavaThread "Notification Thread" daemon [_thread_blocked, id=48336, stack(0x00000054a8000000,0x00000054a8100000)]
0x000001a7eb5e09d0 JavaThread "JNA Cleaner" daemon [_thread_blocked, id=51220, stack(0x00000054a8200000,0x00000054a8300000)]
0x000001a7eb8362a0 JavaThread "OpenGL Object Cleaner for ru.dbotthepony.kstarbound.client.gl.GLStateTracker@c7ba306" daemon [_thread_blocked, id=60984, stack(0x00000054a8d00000,0x00000054a8e00000)]
0x000001a7eb968d90 JavaThread "Starbound Lighting Thread 0" daemon [_thread_blocked, id=50768, stack(0x00000054a9700000,0x00000054a9800000)]
0x000001a7eb969260 JavaThread "Starbound Lighting Thread 1" daemon [_thread_blocked, id=44092, stack(0x00000054a9800000,0x00000054a9900000)]
0x000001a7eb5c72f0 JavaThread "Starbound Lighting Thread 2" daemon [_thread_blocked, id=44148, stack(0x00000054a9900000,0x00000054a9a00000)]
0x000001a7eb5c77c0 JavaThread "Starbound Lighting Thread 3" daemon [_thread_blocked, id=21040, stack(0x00000054a9a00000,0x00000054a9b00000)]
0x000001a7df215b80 JavaThread "Starbound Lighting Thread 4" daemon [_thread_blocked, id=15432, stack(0x00000054a9b00000,0x00000054a9c00000)]
0x000001a7df213ea0 JavaThread "Starbound Lighting Thread 5" daemon [_thread_blocked, id=39692, stack(0x00000054a9c00000,0x00000054a9d00000)]
0x000001a7df214840 JavaThread "Starbound Lighting Thread 6" daemon [_thread_blocked, id=52888, stack(0x00000054a9d00000,0x00000054a9e00000)]
0x000001a7df214370 JavaThread "Starbound Lighting Thread 7" daemon [_thread_blocked, id=47740, stack(0x00000054a9e00000,0x00000054a9f00000)]
0x000001a7df214d10 JavaThread "Starbound Lighting Thread 8" daemon [_thread_blocked, id=29272, stack(0x00000054a9f00000,0x00000054aa000000)]
0x000001a7df2151e0 JavaThread "Starbound Lighting Thread 9" daemon [_thread_blocked, id=18560, stack(0x00000054aa000000,0x00000054aa100000)]
0x000001a7df216050 JavaThread "Starbound Lighting Thread 10" daemon [_thread_blocked, id=27324, stack(0x00000054aa100000,0x00000054aa200000)]
0x000001a7df2156b0 JavaThread "Starbound Lighting Thread 11" daemon [_thread_blocked, id=39832, stack(0x00000054aa200000,0x00000054aa300000)]
0x000001a7df2139d0 JavaThread "Starbound Lighting Thread 12" daemon [_thread_blocked, id=36596, stack(0x00000054aa300000,0x00000054aa400000)]
0x000001a7df216520 JavaThread "Starbound Lighting Thread 13" daemon [_thread_blocked, id=49048, stack(0x00000054aa400000,0x00000054aa500000)]
0x000001a7df213500 JavaThread "Starbound Lighting Thread 14" daemon [_thread_blocked, id=19096, stack(0x00000054aa500000,0x00000054aa600000)]
0x000001a7eb72a150 JavaThread "Starbound Lighting Thread 15" daemon [_thread_blocked, id=3192, stack(0x00000054aa600000,0x00000054aa700000)]
0x000001a7eb724ab0 JavaThread "STB Image Cleaner" daemon [_thread_blocked, id=23352, stack(0x00000054aa900000,0x00000054aaa00000)]
0x000001a7eb727600 JavaThread "ForkJoinPool.commonPool-worker-1" daemon [_thread_blocked, id=26688, stack(0x00000054aac00000,0x00000054aad00000)]
0x000001a7eb728940 JavaThread "ForkJoinPool.commonPool-worker-2" daemon [_thread_blocked, id=55892, stack(0x00000054aad00000,0x00000054aae00000)]
0x000001a7eb7245e0 JavaThread "ForkJoinPool.commonPool-worker-3" daemon [_thread_blocked, id=37176, stack(0x00000054aae00000,0x00000054aaf00000)]
0x000001a7eb725df0 JavaThread "Lua State Cleaner" daemon [_thread_blocked, id=45144, stack(0x00000054aaf00000,0x00000054ab000000)]
0x000001a7f1f4d9a0 JavaThread "C1 CompilerThread1" daemon [_thread_blocked, id=15100, stack(0x00000054a7c00000,0x00000054a7d00000)]
0x000001a7f1f52080 JavaThread "C2 CompilerThread1" daemon [_thread_blocked, id=46740, stack(0x00000054a7d00000,0x00000054a7e00000)]
0x000001a7f1f51b70 JavaThread "C2 CompilerThread2" daemon [_thread_blocked, id=6536, stack(0x00000054a7e00000,0x00000054a7f00000)]
Other Threads:
0x000001a7dc46c290 VMThread "VM Thread" [stack: 0x00000054a7100000,0x00000054a7200000] [id=55052]
0x000001a7ddee8640 WatcherThread [stack: 0x00000054a8100000,0x00000054a8200000] [id=59748]
0x000001a79cea6450 GCTaskThread "GC Thread#0" [stack: 0x00000054a6c00000,0x00000054a6d00000] [id=60732]
0x000001a7de512730 GCTaskThread "GC Thread#1" [stack: 0x00000054a8300000,0x00000054a8400000] [id=26248]
0x000001a7de5169f0 GCTaskThread "GC Thread#2" [stack: 0x00000054a8400000,0x00000054a8500000] [id=44204]
0x000001a7de521720 GCTaskThread "GC Thread#3" [stack: 0x00000054a8500000,0x00000054a8600000] [id=20360]
0x000001a7eb9fbe60 GCTaskThread "GC Thread#4" [stack: 0x00000054a8e00000,0x00000054a8f00000] [id=21756]
0x000001a7ebadff00 GCTaskThread "GC Thread#5" [stack: 0x00000054a8f00000,0x00000054a9000000] [id=52336]
0x000001a7ebae01b0 GCTaskThread "GC Thread#6" [stack: 0x00000054a9000000,0x00000054a9100000] [id=8664]
0x000001a7eb63d640 GCTaskThread "GC Thread#7" [stack: 0x00000054a9100000,0x00000054a9200000] [id=54612]
0x000001a7eb63dd00 GCTaskThread "GC Thread#8" [stack: 0x00000054a9200000,0x00000054a9300000] [id=53600]
0x000001a7eb63dfb0 GCTaskThread "GC Thread#9" [stack: 0x00000054a9300000,0x00000054a9400000] [id=13256]
0x000001a7eb63e660 GCTaskThread "GC Thread#10" [stack: 0x00000054a9400000,0x00000054a9500000] [id=36376]
0x000001a7eb633370 GCTaskThread "GC Thread#11" [stack: 0x00000054a9500000,0x00000054a9600000] [id=10716]
0x000001a7eb632b60 GCTaskThread "GC Thread#12" [stack: 0x00000054a9600000,0x00000054a9700000] [id=20520]
0x000001a79ceb7350 ConcurrentGCThread "G1 Main Marker" [stack: 0x00000054a6d00000,0x00000054a6e00000] [id=26368]
0x000001a79ceb7d60 ConcurrentGCThread "G1 Conc#0" [stack: 0x00000054a6e00000,0x00000054a6f00000] [id=10312]
0x000001a7eb6328b0 ConcurrentGCThread "G1 Conc#1" [stack: 0x00000054aa700000,0x00000054aa800000] [id=26232]
0x000001a7eb6330c0 ConcurrentGCThread "G1 Conc#2" [stack: 0x00000054aa800000,0x00000054aa900000] [id=51836]
0x000001a7dc31f660 ConcurrentGCThread "G1 Refine#0" [stack: 0x00000054a6f00000,0x00000054a7000000] [id=54976]
0x000001a7ebc7d8c0 ConcurrentGCThread "G1 Refine#1" [stack: 0x00000054ab000000,0x00000054ab100000] [id=43020]
0x000001a7ebc7d5e0 ConcurrentGCThread "G1 Refine#2" [stack: 0x00000054ab100000,0x00000054ab200000] [id=51152]
0x000001a7ebc7dba0 ConcurrentGCThread "G1 Refine#3" [stack: 0x00000054ab200000,0x00000054ab300000] [id=13060]
0x000001a7ebc7de80 ConcurrentGCThread "G1 Refine#4" [stack: 0x00000054ab300000,0x00000054ab400000] [id=62876]
0x000001a7ebc7e160 ConcurrentGCThread "G1 Refine#5" [stack: 0x00000054ab400000,0x00000054ab500000] [id=10260]
0x000001a7ebd3a070 ConcurrentGCThread "G1 Refine#6" [stack: 0x00000054ab500000,0x00000054ab600000] [id=41384]
0x000001a7dc320080 ConcurrentGCThread "G1 Service" [stack: 0x00000054a7000000,0x00000054a7100000] [id=62036]
Threads with active compile tasks:
C2 CompilerThread0 14126 7880 4 ru.dbotthepony.kstarbound.client.world.ClientWorld$RenderRegion::addLayers (588 bytes)
VM state: not at safepoint (normal execution)
VM Mutex/Monitor currently owned by a thread: None
Heap address: 0x0000000401000000, size: 16368 MB, Compressed Oops mode: Zero based, Oop shift amount: 3
CDS archive(s) mapped at: [0x0000000800000000-0x0000000800bc0000-0x0000000800bc0000), size 12320768, SharedBaseAddress: 0x0000000800000000, ArchiveRelocationMode: 0.
Compressed class space mapped at: 0x0000000800c00000-0x0000000840c00000, reserved size: 1073741824
Narrow klass base: 0x0000000800000000, Narrow klass shift: 0, Narrow klass range: 0x100000000
GC Precious Log:
CPUs: 16 total, 16 available
Memory: 65457M
Large Page Support: Disabled
NUMA Support: Disabled
Compressed Oops: Enabled (Zero based)
Heap Region Size: 8M
Heap Min Capacity: 128M
Heap Initial Capacity: 128M
Heap Max Capacity: 16368M
Pre-touch: Disabled
Parallel Workers: 13
Concurrent Workers: 3
Concurrent Refinement Workers: 13
Periodic GC: Disabled
Heap:
garbage-first heap total 524288K, used 227413K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 1 survivors (8192K)
Metaspace used 35609K, committed 35968K, reserved 1081344K
class space used 3616K, committed 3776K, reserved 1048576K
Heap Regions: E=young(eden), S=young(survivor), O=old, HS=humongous(starts), HC=humongous(continues), CS=collection set, F=free, OA=open archive, CA=closed archive, TAMS=top-at-mark-start (previous, next)
| 0|0x0000000401000000, 0x0000000401800000, 0x0000000401800000|100%| O| |TAMS 0x0000000401800000, 0x0000000401000000| Untracked
| 1|0x0000000401800000, 0x0000000402000000, 0x0000000402000000|100%| O| |TAMS 0x0000000402000000, 0x0000000401800000| Untracked
| 2|0x0000000402000000, 0x0000000402800000, 0x0000000402800000|100%| O| |TAMS 0x0000000402800000, 0x0000000402000000| Untracked
| 3|0x0000000402800000, 0x0000000403000000, 0x0000000403000000|100%| O| |TAMS 0x0000000403000000, 0x0000000402800000| Untracked
| 4|0x0000000403000000, 0x0000000403800000, 0x0000000403800000|100%| O| |TAMS 0x0000000403800000, 0x0000000403000000| Untracked
| 5|0x0000000403800000, 0x0000000404000000, 0x0000000404000000|100%| O| |TAMS 0x0000000404000000, 0x0000000403800000| Untracked
| 6|0x0000000404000000, 0x0000000404800000, 0x0000000404800000|100%| O| |TAMS 0x0000000404800000, 0x0000000404000000| Untracked
| 7|0x0000000404800000, 0x0000000405000000, 0x0000000405000000|100%| O| |TAMS 0x0000000405000000, 0x0000000404800000| Untracked
| 8|0x0000000405000000, 0x0000000405800000, 0x0000000405800000|100%| O| |TAMS 0x0000000405800000, 0x0000000405000000| Untracked
| 9|0x0000000405800000, 0x0000000406000000, 0x0000000406000000|100%| O| |TAMS 0x0000000406000000, 0x0000000405800000| Untracked
| 10|0x0000000406000000, 0x0000000406800000, 0x0000000406800000|100%| O| |TAMS 0x0000000406800000, 0x0000000406000000| Untracked
| 11|0x0000000406800000, 0x0000000407000000, 0x0000000407000000|100%| O| |TAMS 0x0000000407000000, 0x0000000406800000| Untracked
| 12|0x0000000407000000, 0x0000000407800000, 0x0000000407800000|100%| O| |TAMS 0x0000000407800000, 0x0000000407000000| Untracked
| 13|0x0000000407800000, 0x0000000408000000, 0x0000000408000000|100%| O| |TAMS 0x0000000408000000, 0x0000000407800000| Untracked
| 14|0x0000000408000000, 0x0000000408800000, 0x0000000408800000|100%| O| |TAMS 0x0000000408800000, 0x0000000408000000| Untracked
| 15|0x0000000408800000, 0x0000000409000000, 0x0000000409000000|100%| O| |TAMS 0x0000000408800000, 0x0000000408800000| Untracked
| 16|0x0000000409000000, 0x0000000409800000, 0x0000000409800000|100%| O| |TAMS 0x0000000409000000, 0x0000000409000000| Untracked
| 17|0x0000000409800000, 0x000000040a000000, 0x000000040a000000|100%| O| |TAMS 0x0000000409800000, 0x0000000409800000| Untracked
| 18|0x000000040a000000, 0x000000040a800000, 0x000000040a800000|100%| O| |TAMS 0x000000040a000000, 0x000000040a000000| Untracked
| 19|0x000000040a800000, 0x000000040b000000, 0x000000040b000000|100%| O| |TAMS 0x000000040a800000, 0x000000040a800000| Untracked
| 20|0x000000040b000000, 0x000000040b800000, 0x000000040b800000|100%| O| |TAMS 0x000000040b000000, 0x000000040b000000| Untracked
| 21|0x000000040b800000, 0x000000040c000000, 0x000000040c000000|100%| O| |TAMS 0x000000040b800000, 0x000000040b800000| Untracked
| 22|0x000000040c000000, 0x000000040c800000, 0x000000040c800000|100%| O| |TAMS 0x000000040c000000, 0x000000040c000000| Untracked
| 23|0x000000040c800000, 0x000000040d000000, 0x000000040d000000|100%| O| |TAMS 0x000000040c800000, 0x000000040c800000| Untracked
| 24|0x000000040d000000, 0x000000040d800000, 0x000000040d800000|100%| O| |TAMS 0x000000040d000000, 0x000000040d000000| Untracked
| 25|0x000000040d800000, 0x000000040e000000, 0x000000040e000000|100%| O| |TAMS 0x000000040d800000, 0x000000040d800000| Untracked
| 26|0x000000040e000000, 0x000000040e800000, 0x000000040e800000|100%| O| |TAMS 0x000000040e000000, 0x000000040e000000| Untracked
| 27|0x000000040e800000, 0x000000040ed38a00, 0x000000040f000000| 65%| O| |TAMS 0x000000040e800000, 0x000000040e800000| Untracked
| 28|0x000000040f000000, 0x000000040f000000, 0x000000040f800000| 0%| F| |TAMS 0x000000040f000000, 0x000000040f000000| Untracked
| 29|0x000000040f800000, 0x000000040f800000, 0x0000000410000000| 0%| F| |TAMS 0x000000040f800000, 0x000000040f800000| Untracked
| 30|0x0000000410000000, 0x0000000410000000, 0x0000000410800000| 0%| F| |TAMS 0x0000000410000000, 0x0000000410000000| Untracked
| 31|0x0000000410800000, 0x0000000410800000, 0x0000000411000000| 0%| F| |TAMS 0x0000000410800000, 0x0000000410800000| Untracked
| 32|0x0000000411000000, 0x0000000411000000, 0x0000000411800000| 0%| F| |TAMS 0x0000000411000000, 0x0000000411000000| Untracked
| 33|0x0000000411800000, 0x0000000411800000, 0x0000000412000000| 0%| F| |TAMS 0x0000000411800000, 0x0000000411800000| Untracked
| 34|0x0000000412000000, 0x0000000412000000, 0x0000000412800000| 0%| F| |TAMS 0x0000000412000000, 0x0000000412000000| Untracked
| 35|0x0000000412800000, 0x0000000412800000, 0x0000000413000000| 0%| F| |TAMS 0x0000000412800000, 0x0000000412800000| Untracked
| 36|0x0000000413000000, 0x0000000413000000, 0x0000000413800000| 0%| F| |TAMS 0x0000000413000000, 0x0000000413000000| Untracked
| 37|0x0000000413800000, 0x0000000413800000, 0x0000000414000000| 0%| F| |TAMS 0x0000000413800000, 0x0000000413800000| Untracked
| 38|0x0000000414000000, 0x0000000414000000, 0x0000000414800000| 0%| F| |TAMS 0x0000000414000000, 0x0000000414000000| Untracked
| 39|0x0000000414800000, 0x0000000414800000, 0x0000000415000000| 0%| F| |TAMS 0x0000000414800000, 0x0000000414800000| Untracked
| 40|0x0000000415000000, 0x0000000415000000, 0x0000000415800000| 0%| F| |TAMS 0x0000000415000000, 0x0000000415000000| Untracked
| 41|0x0000000415800000, 0x0000000415800000, 0x0000000416000000| 0%| F| |TAMS 0x0000000415800000, 0x0000000415800000| Untracked
| 42|0x0000000416000000, 0x0000000416000000, 0x0000000416800000| 0%| F| |TAMS 0x0000000416000000, 0x0000000416000000| Untracked
| 43|0x0000000416800000, 0x0000000416800000, 0x0000000417000000| 0%| F| |TAMS 0x0000000416800000, 0x0000000416800000| Untracked
| 44|0x0000000417000000, 0x0000000417000000, 0x0000000417800000| 0%| F| |TAMS 0x0000000417000000, 0x0000000417000000| Untracked
| 45|0x0000000417800000, 0x0000000417800000, 0x0000000418000000| 0%| F| |TAMS 0x0000000417800000, 0x0000000417800000| Untracked
| 46|0x0000000418000000, 0x0000000418000000, 0x0000000418800000| 0%| F| |TAMS 0x0000000418000000, 0x0000000418000000| Untracked
| 47|0x0000000418800000, 0x00000004188dccd0, 0x0000000419000000| 10%| S|CS|TAMS 0x0000000418800000, 0x0000000418800000| Complete
| 48|0x0000000419000000, 0x0000000419000000, 0x0000000419800000| 0%| F| |TAMS 0x0000000419000000, 0x0000000419000000| Untracked
| 49|0x0000000419800000, 0x0000000419800000, 0x000000041a000000| 0%| F| |TAMS 0x0000000419800000, 0x0000000419800000| Untracked
| 50|0x000000041a000000, 0x000000041a000000, 0x000000041a800000| 0%| F| |TAMS 0x000000041a000000, 0x000000041a000000| Untracked
| 51|0x000000041a800000, 0x000000041a800000, 0x000000041b000000| 0%| F| |TAMS 0x000000041a800000, 0x000000041a800000| Untracked
| 52|0x000000041b000000, 0x000000041b000000, 0x000000041b800000| 0%| F| |TAMS 0x000000041b000000, 0x000000041b000000| Untracked
| 53|0x000000041b800000, 0x000000041b800000, 0x000000041c000000| 0%| F| |TAMS 0x000000041b800000, 0x000000041b800000| Untracked
| 54|0x000000041c000000, 0x000000041c000000, 0x000000041c800000| 0%| F| |TAMS 0x000000041c000000, 0x000000041c000000| Untracked
| 55|0x000000041c800000, 0x000000041c800000, 0x000000041d000000| 0%| F| |TAMS 0x000000041c800000, 0x000000041c800000| Untracked
| 56|0x000000041d000000, 0x000000041d000000, 0x000000041d800000| 0%| F| |TAMS 0x000000041d000000, 0x000000041d000000| Untracked
| 57|0x000000041d800000, 0x000000041d800000, 0x000000041e000000| 0%| F| |TAMS 0x000000041d800000, 0x000000041d800000| Untracked
| 58|0x000000041e000000, 0x000000041e000000, 0x000000041e800000| 0%| F| |TAMS 0x000000041e000000, 0x000000041e000000| Untracked
| 59|0x000000041e800000, 0x000000041e800000, 0x000000041f000000| 0%| F| |TAMS 0x000000041e800000, 0x000000041e800000| Untracked
| 60|0x000000041f000000, 0x000000041f000000, 0x000000041f800000| 0%| F| |TAMS 0x000000041f000000, 0x000000041f000000| Untracked
| 61|0x000000041f800000, 0x000000041f800000, 0x0000000420000000| 0%| F| |TAMS 0x000000041f800000, 0x000000041f800000| Untracked
| 62|0x0000000420000000, 0x0000000420000000, 0x0000000420800000| 0%| F| |TAMS 0x0000000420000000, 0x0000000420000000| Untracked
| 63|0x0000000420800000, 0x0000000420b7edf0, 0x0000000421000000| 43%| E| |TAMS 0x0000000420800000, 0x0000000420800000| Complete
Card table byte_map: [0x000001a7b6130000,0x000001a7b8130000] _byte_map_base: 0x000001a7b4128000
Marking Bits (Prev, Next): (CMBitMap*) 0x000001a79cea6a60, (CMBitMap*) 0x000001a79cea6aa0
Prev Bits: [0x000001a7ba130000, 0x000001a7ca0f0000)
Next Bits: [0x000001a7ca0f0000, 0x000001a7da0b0000)
Polling page: 0x000001a79ac30000
Metaspace:
Usage:
Non-class: 31.24 MB used.
Class: 3.53 MB used.
Both: 34.77 MB used.
Virtual space:
Non-class space: 32.00 MB reserved, 31.44 MB ( 98%) committed, 4 nodes.
Class space: 1.00 GB reserved, 3.69 MB ( <1%) committed, 1 nodes.
Both: 1.03 GB reserved, 35.12 MB ( 3%) committed.
Chunk freelists:
Non-Class: 464.00 KB
Class: 321.00 KB
Both: 785.00 KB
MaxMetaspaceSize: unlimited
CompressedClassSpaceSize: 1.00 GB
Initial GC threshold: 21.00 MB
Current GC threshold: 52.19 MB
CDS: on
MetaspaceReclaimPolicy: balanced
- commit_granule_bytes: 65536.
- commit_granule_words: 8192.
- virtual_space_node_default_size: 1048576.
- enlarge_chunks_in_place: 1.
- new_chunks_are_fully_committed: 0.
- uncommit_free_chunks: 1.
- use_allocation_guard: 0.
- handle_deallocations: 1.
Internal statistics:
num_allocs_failed_limit: 3.
num_arena_births: 526.
num_arena_deaths: 0.
num_vsnodes_births: 5.
num_vsnodes_deaths: 0.
num_space_committed: 560.
num_space_uncommitted: 0.
num_chunks_returned_to_freelist: 3.
num_chunks_taken_from_freelist: 1805.
num_chunk_merges: 3.
num_chunk_splits: 1247.
num_chunks_enlarged: 878.
num_purges: 0.
num_inconsistent_stats: 0.
CodeHeap 'non-profiled nmethods': size=119168Kb used=5970Kb max_used=5970Kb free=113197Kb
bounds [0x000001a7ac450000, 0x000001a7aca30000, 0x000001a7b38b0000]
CodeHeap 'profiled nmethods': size=119104Kb used=14921Kb max_used=14921Kb free=104182Kb
bounds [0x000001a7a5000000, 0x000001a7a5ea0000, 0x000001a7ac450000]
CodeHeap 'non-nmethods': size=7488Kb used=2445Kb max_used=3665Kb free=5042Kb
bounds [0x000001a7a48b0000, 0x000001a7a4c50000, 0x000001a7a5000000]
total_blobs=7978 nmethods=6610 adapters=1279
compilation: enabled
stopped_count=0, restarted_count=0
full_count=0
Compilation events (20 events):
Event: 14.026 Thread 0x000001a7f1f4d9a0 nmethod 7869 0x000001a7a5e8ce10 code [0x000001a7a5e8cfe0, 0x000001a7a5e8d1e8]
Event: 14.026 Thread 0x000001a7f1f4d9a0 7871 3 ru.dbotthepony.kstarbound.client.render.MultiMeshBuilder::get$lambda$1 (34 bytes)
Event: 14.026 Thread 0x000001a7ddc044d0 nmethod 7870 0x000001a7a5e8d310 code [0x000001a7a5e8d4a0, 0x000001a7a5e8d5e8]
Event: 14.026 Thread 0x000001a7ddc044d0 7872 3 ru.dbotthepony.kstarbound.client.gl.vertex.VertexBuilder::<init> (14 bytes)
Event: 14.026 Thread 0x000001a7ddc044d0 nmethod 7872 0x000001a7a5e8d690 code [0x000001a7a5e8d8a0, 0x000001a7a5e8dec8]
Event: 14.026 Thread 0x000001a7ddc044d0 7873 3 ru.dbotthepony.kstarbound.client.render.MultiMeshBuilder$Entry::<init> (32 bytes)
Event: 14.027 Thread 0x000001a7ddc044d0 nmethod 7873 0x000001a7a5e8e110 code [0x000001a7a5e8e3a0, 0x000001a7a5e8ef38]
Event: 14.027 Thread 0x000001a7ddc044d0 7874 3 it.unimi.dsi.fastutil.objects.Reference2ObjectOpenHashMap::insert (63 bytes)
Event: 14.027 Thread 0x000001a7f1f4d9a0 nmethod 7871 0x000001a7a5e8f310 code [0x000001a7a5e8f660, 0x000001a7a5e909a8]
Event: 14.027 Thread 0x000001a7f1f4d9a0 7875 3 it.unimi.dsi.fastutil.objects.Reference2ObjectOpenHashMap$ValueSpliterator::acceptOnIndex (10 bytes)
Event: 14.027 Thread 0x000001a7f1f4d9a0 nmethod 7875 0x000001a7a5e91110 code [0x000001a7a5e912c0, 0x000001a7a5e91648]
Event: 14.027 Thread 0x000001a7f1f4d9a0 7876 3 it.unimi.dsi.fastutil.objects.Reference2ObjectOpenHashMap$ValueSpliterator::acceptOnIndex (16 bytes)
Event: 14.027 Thread 0x000001a7ddc044d0 nmethod 7874 0x000001a7a5e91810 code [0x000001a7a5e919e0, 0x000001a7a5e91f78]
Event: 14.027 Thread 0x000001a7ddc044d0 7877 3 ru.dbotthepony.kstarbound.client.render.MultiMeshBuilder$$Lambda$174/0x0000000800eb47e8::apply (9 bytes)
Event: 14.027 Thread 0x000001a7f1f4d9a0 nmethod 7876 0x000001a7a5e92110 code [0x000001a7a5e922c0, 0x000001a7a5e924e8]
Event: 14.027 Thread 0x000001a7f1f4d9a0 7878 3 ru.dbotthepony.kstarbound.client.render.MultiMeshBuilder::meshes$lambda$2 (17 bytes)
Event: 14.027 Thread 0x000001a7ddc044d0 nmethod 7877 0x000001a7a5e92610 code [0x000001a7a5e92840, 0x000001a7a5e93048]
Event: 14.027 Thread 0x000001a7ddc044d0 7879 3 ru.dbotthepony.kstarbound.client.render.MultiMeshBuilder$meshes$1::invoke (9 bytes)
Event: 14.027 Thread 0x000001a7f1f4d9a0 nmethod 7878 0x000001a7a5e93310 code [0x000001a7a5e93540, 0x000001a7a5e93cc8]
Event: 14.028 Thread 0x000001a7ddc044d0 nmethod 7879 0x000001a7a5e93f90 code [0x000001a7a5e941c0, 0x000001a7a5e94b38]
GC Heap History (20 events):
Event: 3.070 GC heap before
{Heap before GC invocations=8 (full 0):
garbage-first heap total 163840K, used 101372K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 10 young (81920K), 2 survivors (16384K)
Metaspace used 30007K, committed 30336K, reserved 1081344K
class space used 3077K, committed 3264K, reserved 1048576K
}
Event: 3.093 GC heap after
{Heap after GC invocations=9 (full 0):
garbage-first heap total 163840K, used 47751K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 30007K, committed 30336K, reserved 1081344K
class space used 3077K, committed 3264K, reserved 1048576K
}
Event: 3.403 GC heap before
{Heap before GC invocations=9 (full 0):
garbage-first heap total 163840K, used 105095K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 9 young (73728K), 2 survivors (16384K)
Metaspace used 30922K, committed 31296K, reserved 1081344K
class space used 3149K, committed 3328K, reserved 1048576K
}
Event: 3.418 GC heap after
{Heap after GC invocations=10 (full 0):
garbage-first heap total 163840K, used 58957K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 30922K, committed 31296K, reserved 1081344K
class space used 3149K, committed 3328K, reserved 1048576K
}
Event: 3.488 GC heap before
{Heap before GC invocations=10 (full 0):
garbage-first heap total 163840K, used 108109K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 8 young (65536K), 2 survivors (16384K)
Metaspace used 30995K, committed 31360K, reserved 1081344K
class space used 3154K, committed 3328K, reserved 1048576K
}
Event: 3.503 GC heap after
{Heap after GC invocations=11 (full 0):
garbage-first heap total 262144K, used 71420K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 30995K, committed 31360K, reserved 1081344K
class space used 3154K, committed 3328K, reserved 1048576K
}
Event: 3.687 GC heap before
{Heap before GC invocations=11 (full 0):
garbage-first heap total 262144K, used 169724K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 13 young (106496K), 1 survivors (8192K)
Metaspace used 31158K, committed 31488K, reserved 1081344K
class space used 3161K, committed 3328K, reserved 1048576K
}
Event: 3.699 GC heap after
{Heap after GC invocations=12 (full 0):
garbage-first heap total 262144K, used 92811K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 31158K, committed 31488K, reserved 1081344K
class space used 3161K, committed 3328K, reserved 1048576K
}
Event: 3.900 GC heap before
{Heap before GC invocations=12 (full 0):
garbage-first heap total 262144K, used 166539K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 11 young (90112K), 2 survivors (16384K)
Metaspace used 31657K, committed 32064K, reserved 1081344K
class space used 3208K, committed 3392K, reserved 1048576K
}
Event: 3.919 GC heap after
{Heap after GC invocations=13 (full 0):
garbage-first heap total 262144K, used 118027K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 31657K, committed 32064K, reserved 1081344K
class space used 3208K, committed 3392K, reserved 1048576K
}
Event: 4.019 GC heap before
{Heap before GC invocations=13 (full 0):
garbage-first heap total 262144K, used 175371K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 9 young (73728K), 2 survivors (16384K)
Metaspace used 31664K, committed 32064K, reserved 1081344K
class space used 3208K, committed 3392K, reserved 1048576K
}
Event: 4.031 GC heap after
{Heap after GC invocations=14 (full 0):
garbage-first heap total 262144K, used 139264K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 2 young (16384K), 2 survivors (16384K)
Metaspace used 31664K, committed 32064K, reserved 1081344K
class space used 3208K, committed 3392K, reserved 1048576K
}
Event: 4.108 GC heap before
{Heap before GC invocations=14 (full 0):
garbage-first heap total 262144K, used 188416K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 8 young (65536K), 2 survivors (16384K)
Metaspace used 31676K, committed 32064K, reserved 1081344K
class space used 3208K, committed 3392K, reserved 1048576K
}
Event: 4.120 GC heap after
{Heap after GC invocations=15 (full 0):
garbage-first heap total 524288K, used 158968K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 31676K, committed 32064K, reserved 1081344K
class space used 3208K, committed 3392K, reserved 1048576K
}
Event: 4.750 GC heap before
{Heap before GC invocations=16 (full 0):
garbage-first heap total 524288K, used 331000K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 22 young (180224K), 1 survivors (8192K)
Metaspace used 35060K, committed 35456K, reserved 1081344K
class space used 3600K, committed 3776K, reserved 1048576K
}
Event: 4.768 GC heap after
{Heap after GC invocations=17 (full 0):
garbage-first heap total 524288K, used 223573K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 3 young (24576K), 3 survivors (24576K)
Metaspace used 35060K, committed 35456K, reserved 1081344K
class space used 3600K, committed 3776K, reserved 1048576K
}
Event: 10.220 GC heap before
{Heap before GC invocations=17 (full 0):
garbage-first heap total 524288K, used 330069K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 16 young (131072K), 3 survivors (24576K)
Metaspace used 35505K, committed 35904K, reserved 1081344K
class space used 3612K, committed 3776K, reserved 1048576K
}
Event: 10.224 GC heap after
{Heap after GC invocations=18 (full 0):
garbage-first heap total 524288K, used 230025K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 35505K, committed 35904K, reserved 1081344K
class space used 3612K, committed 3776K, reserved 1048576K
}
Event: 14.053 GC heap before
{Heap before GC invocations=18 (full 0):
garbage-first heap total 524288K, used 352905K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 16 young (131072K), 1 survivors (8192K)
Metaspace used 35609K, committed 35968K, reserved 1081344K
class space used 3616K, committed 3776K, reserved 1048576K
}
Event: 14.054 GC heap after
{Heap after GC invocations=19 (full 0):
garbage-first heap total 524288K, used 227413K [0x0000000401000000, 0x0000000800000000)
region size 8192K, 1 young (8192K), 1 survivors (8192K)
Metaspace used 35609K, committed 35968K, reserved 1081344K
class space used 3616K, committed 3776K, reserved 1048576K
}
Deoptimization events (20 events):
Event: 14.023 Thread 0x000001a79cdedec0 Uncommon trap: trap_request=0xffffff6e fr.pc=0x000001a7aca0953c relative=0x00000000000036fc
Event: 14.023 Thread 0x000001a79cdedec0 Uncommon trap: reason=loop_limit_check action=maybe_recompile pc=0x000001a7aca0953c method=it.unimi.dsi.fastutil.objects.ReferenceArraySet.findKey(Ljava/lang/Object;)I @ 9 c2
Event: 14.023 Thread 0x000001a79cdedec0 DEOPT PACKING pc=0x000001a7aca0953c sp=0x00000054a6bff1a0
Event: 14.023 Thread 0x000001a79cdedec0 DEOPT UNPACKING pc=0x000001a7a49023a3 sp=0x00000054a6bff080 mode 2
Event: 14.031 Thread 0x000001a7eb969260 DEOPT PACKING pc=0x000001a7a5e8591f sp=0x00000054a98fecf0
Event: 14.031 Thread 0x000001a7eb969260 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a98fe328 mode 0
Event: 14.032 Thread 0x000001a7eb968d90 DEOPT PACKING pc=0x000001a7a5e8591f sp=0x00000054a97ff0f0
Event: 14.032 Thread 0x000001a7eb968d90 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a97fe728 mode 0
Event: 14.039 Thread 0x000001a7eb5c72f0 DEOPT PACKING pc=0x000001a7a5e85736 sp=0x00000054a99fee20
Event: 14.039 Thread 0x000001a7eb5c72f0 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a99fe458 mode 0
Event: 14.039 Thread 0x000001a7eb969260 DEOPT PACKING pc=0x000001a7a5e85736 sp=0x00000054a98fecf0
Event: 14.039 Thread 0x000001a7eb969260 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a98fe328 mode 0
Event: 14.055 Thread 0x000001a7eb969260 DEOPT PACKING pc=0x000001a7a5e8591f sp=0x00000054a98fecf0
Event: 14.055 Thread 0x000001a7eb969260 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a98fe328 mode 0
Event: 14.056 Thread 0x000001a7eb5c72f0 DEOPT PACKING pc=0x000001a7a5e8591f sp=0x00000054a99fee20
Event: 14.056 Thread 0x000001a7eb5c72f0 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a99fe458 mode 0
Event: 14.070 Thread 0x000001a7eb5c77c0 DEOPT PACKING pc=0x000001a7a5e8591f sp=0x00000054a9afed90
Event: 14.070 Thread 0x000001a7eb5c77c0 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a9afe3c8 mode 0
Event: 14.070 Thread 0x000001a7df213ea0 DEOPT PACKING pc=0x000001a7a5e85736 sp=0x00000054a9cfec70
Event: 14.070 Thread 0x000001a7df213ea0 DEOPT UNPACKING pc=0x000001a7a4902b43 sp=0x00000054a9cfe2a8 mode 0
Classes unloaded (0 events):
No events
Classes redefined (0 events):
No events
Internal exceptions (20 events):
Event: 4.387 Thread 0x000001a79cdedec0 Implicit null exception at 0x000001a7ac587a9a to 0x000001a7ac587ea8
Event: 4.392 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000418b1c398}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000418b1c398)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.392 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000418b28f20}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.newInvokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000418b28f20)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.392 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000418b2e0b0}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000418b2e0b0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.392 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000418b32a00}: 'java.lang.Object java.lang.invoke.Invokers$Holder.linkToTargetMethod(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000418b32a00)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.406 Thread 0x000001a79cdedec0 Exception <a 'sun/nio/fs/WindowsException'{0x0000000418b7b278}> (0x0000000418b7b278)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 516]
Event: 4.406 Thread 0x000001a79cdedec0 Exception <a 'sun/nio/fs/WindowsException'{0x0000000418b7b600}> (0x0000000418b7b600)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 516]
Event: 4.408 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000418b86d30}: 'void java.lang.invoke.DirectMethodHandle$Holder.invokeStatic(java.lang.Object, long)'> (0x0000000418b86d30)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.408 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000418b8c7c0}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.newInvokeSpecial(java.lang.Object, long)'> (0x0000000418b8c7c0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.410 Thread 0x000001a7eb727600 Implicit null exception at 0x000001a7ac7fb40d to 0x000001a7ac7fd934
Event: 4.410 Thread 0x000001a7eb728940 Implicit null exception at 0x000001a7ac80cdf5 to 0x000001a7ac80eca8
Event: 4.410 Thread 0x000001a7eb727600 Implicit null exception at 0x000001a7ac78af21 to 0x000001a7ac78b3d8
Event: 4.414 Thread 0x000001a7eb727600 Implicit null exception at 0x000001a7ac7895f8 to 0x000001a7ac789a94
Event: 4.553 Thread 0x000001a79cdedec0 Exception <a 'java/lang/UnsatisfiedLinkError'{0x0000000418764888}: Íå íàéäåíà óêàçàííàÿ ïðîöåäóðà.
> (0x0000000418764888)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\prims\jni.cpp, line 535]
Event: 4.571 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x000000041788de00}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.newInvokeSpecial(java.lang.Object, java.lang.Object, int, java.lang.Object)'> (0x000000041788de00)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.571 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000417891c48}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, int, java.lang.Object)'> (0x0000000417891c48)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.599 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000417a10508}: 'int java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, java.lang.Object)'> (0x0000000417a10508)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.603 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000417a674a8}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeSpecial(java.lang.Object, java.lang.Object, java.lang.Object, long, java.lang.Object)'> (0x0000000417a674a8)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.604 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000417a6add0}: 'java.lang.Object java.lang.invoke.Invokers$Holder.linkToTargetMethod(java.lang.Object, long, java.lang.Object, java.lang.Object)'> (0x0000000417a6add0)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
Event: 4.616 Thread 0x000001a79cdedec0 Exception <a 'java/lang/NoSuchMethodError'{0x0000000417b36e88}: 'java.lang.Object java.lang.invoke.DirectMethodHandle$Holder.invokeStatic(java.lang.Object, java.lang.Object, int, int)'> (0x0000000417b36e88)
thrown [e:\jenkins\tmp\workspace\build\src\src\hotspot\share\interpreter\linkResolver.cpp, line 766]
VM Operations (20 events):
Event: 4.750 Executing VM operation: G1CollectForAllocation
Event: 4.768 Executing VM operation: G1CollectForAllocation done
Event: 5.768 Executing VM operation: Cleanup
Event: 5.768 Executing VM operation: Cleanup done
Event: 6.769 Executing VM operation: Cleanup
Event: 6.769 Executing VM operation: Cleanup done
Event: 7.770 Executing VM operation: Cleanup
Event: 7.770 Executing VM operation: Cleanup done
Event: 8.332 Executing VM operation: HandshakeAllThreads
Event: 8.332 Executing VM operation: HandshakeAllThreads done
Event: 9.332 Executing VM operation: Cleanup
Event: 9.332 Executing VM operation: Cleanup done
Event: 10.220 Executing VM operation: G1CollectForAllocation
Event: 10.224 Executing VM operation: G1CollectForAllocation done
Event: 11.224 Executing VM operation: Cleanup
Event: 11.224 Executing VM operation: Cleanup done
Event: 13.226 Executing VM operation: Cleanup
Event: 13.226 Executing VM operation: Cleanup done
Event: 14.053 Executing VM operation: G1CollectForAllocation
Event: 14.054 Executing VM operation: G1CollectForAllocation done
Events (20 events):
Event: 8.526 Thread 0x000001a7de5651d0 Thread exited: 0x000001a7de5651d0
Event: 8.526 Thread 0x000001a7ddd2e480 Thread exited: 0x000001a7ddd2e480
Event: 8.682 Thread 0x000001a7ddd1fd20 Thread exited: 0x000001a7ddd1fd20
Event: 8.902 Thread 0x000001a7f1f51b70 Thread added: 0x000001a7f1f51b70
Event: 8.902 Thread 0x000001a7f1f4d9a0 Thread added: 0x000001a7f1f4d9a0
Event: 9.238 Thread 0x000001a7f1f4d9a0 Thread exited: 0x000001a7f1f4d9a0
Event: 9.238 Thread 0x000001a7f1f51b70 Thread exited: 0x000001a7f1f51b70
Event: 9.256 Thread 0x000001a7f1f51b70 Thread added: 0x000001a7f1f51b70
Event: 10.762 Thread 0x000001a7f1f4e3c0 Thread added: 0x000001a7f1f4e3c0
Event: 12.102 Thread 0x000001a7f1f4e3c0 Thread exited: 0x000001a7f1f4e3c0
Event: 12.102 Thread 0x000001a7f1f51b70 Thread exited: 0x000001a7f1f51b70
Event: 13.308 Thread 0x000001a7f1f4d9a0 Thread added: 0x000001a7f1f4d9a0
Event: 13.311 Thread 0x000001a7f1f52080 Thread added: 0x000001a7f1f52080
Event: 13.312 Thread 0x000001a7f1f539d0 Thread added: 0x000001a7f1f539d0
Event: 13.314 Thread 0x000001a7f1f54e10 Thread added: 0x000001a7f1f54e10
Event: 13.314 Thread 0x000001a7f1f50220 Thread added: 0x000001a7f1f50220
Event: 13.578 Thread 0x000001a7f1f50220 Thread exited: 0x000001a7f1f50220
Event: 13.595 Thread 0x000001a7f1f54e10 Thread exited: 0x000001a7f1f54e10
Event: 13.595 Thread 0x000001a7f1f539d0 Thread exited: 0x000001a7f1f539d0
Event: 13.623 Thread 0x000001a7f1f52080 Thread exited: 0x000001a7f1f52080
Dynamic libraries:
0x00007ff760040000 - 0x00007ff76004e000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\java.exe
0x00007ffbd8050000 - 0x00007ffbd8245000 C:\Windows\SYSTEM32\ntdll.dll
0x00007ffbd7e90000 - 0x00007ffbd7f4d000 C:\Windows\System32\KERNEL32.DLL
0x00007ffbd5990000 - 0x00007ffbd5c5d000 C:\Windows\System32\KERNELBASE.dll
0x00007ffbd5760000 - 0x00007ffbd5860000 C:\Windows\System32\ucrtbase.dll
0x00007ffbc8eb0000 - 0x00007ffbc8ec9000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\VCRUNTIME140.dll
0x00007ffbc8fe0000 - 0x00007ffbc8ff8000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\jli.dll
0x00007ffbd6df0000 - 0x00007ffbd6f90000 C:\Windows\System32\USER32.dll
0x00007ffbd58f0000 - 0x00007ffbd5912000 C:\Windows\System32\win32u.dll
0x00007ffbd7a20000 - 0x00007ffbd7a4a000 C:\Windows\System32\GDI32.dll
0x00007ffbc2400000 - 0x00007ffbc269a000 C:\Windows\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_6.0.19041.1110_none_60b5254171f9507e\COMCTL32.dll
0x00007ffbd5d00000 - 0x00007ffbd5e0b000 C:\Windows\System32\gdi32full.dll
0x00007ffbd6410000 - 0x00007ffbd64ae000 C:\Windows\System32\msvcrt.dll
0x00007ffbd5c60000 - 0x00007ffbd5cfd000 C:\Windows\System32\msvcp_win.dll
0x00007ffbd6dc0000 - 0x00007ffbd6df0000 C:\Windows\System32\IMM32.DLL
0x00007ffbcd340000 - 0x00007ffbcd34c000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\vcruntime140_1.dll
0x00007ffba9ae0000 - 0x00007ffba9b71000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\msvcp140.dll
0x00007ffb54660000 - 0x00007ffb552a6000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\server\jvm.dll
0x00007ffbd70b0000 - 0x00007ffbd715e000 C:\Windows\System32\ADVAPI32.dll
0x00007ffbd7500000 - 0x00007ffbd759c000 C:\Windows\System32\sechost.dll
0x00007ffbd6c90000 - 0x00007ffbd6db5000 C:\Windows\System32\RPCRT4.dll
0x00007ffbd7f50000 - 0x00007ffbd7f58000 C:\Windows\System32\PSAPI.DLL
0x00007ffbcbd90000 - 0x00007ffbcbdb7000 C:\Windows\SYSTEM32\WINMM.dll
0x00007ffbcdb10000 - 0x00007ffbcdb1a000 C:\Windows\SYSTEM32\VERSION.dll
0x00007ffbc01d0000 - 0x00007ffbc01d9000 C:\Windows\SYSTEM32\WSOCK32.dll
0x00007ffbd7270000 - 0x00007ffbd72db000 C:\Windows\System32\WS2_32.dll
0x00007ffbd3680000 - 0x00007ffbd3692000 C:\Windows\SYSTEM32\kernel.appcore.dll
0x00007ffbc9240000 - 0x00007ffbc924a000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\jimage.dll
0x00007ffbcf0e0000 - 0x00007ffbcf2c4000 C:\Windows\SYSTEM32\DBGHELP.DLL
0x00007ffbc23d0000 - 0x00007ffbc23fc000 C:\Windows\SYSTEM32\dbgcore.DLL
0x00007ffbd5860000 - 0x00007ffbd58e2000 C:\Windows\System32\bcryptPrimitives.dll
0x00007ffbcd790000 - 0x00007ffbcd79e000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\instrument.dll
0x00007ffbb98c0000 - 0x00007ffbb98e5000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\java.dll
0x00007ffb99a90000 - 0x00007ffb99b66000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\svml.dll
0x00007ffbd64b0000 - 0x00007ffbd6bf4000 C:\Windows\System32\SHELL32.dll
0x00007ffbd3880000 - 0x00007ffbd4014000 C:\Windows\SYSTEM32\windows.storage.dll
0x00007ffbd7b30000 - 0x00007ffbd7e84000 C:\Windows\System32\combase.dll
0x00007ffbd51c0000 - 0x00007ffbd51ec000 C:\Windows\SYSTEM32\Wldp.dll
0x00007ffbd7f60000 - 0x00007ffbd800d000 C:\Windows\System32\SHCORE.dll
0x00007ffbd7ad0000 - 0x00007ffbd7b25000 C:\Windows\System32\shlwapi.dll
0x00007ffbd56a0000 - 0x00007ffbd56bf000 C:\Windows\SYSTEM32\profapi.dll
0x00007ffbbeea0000 - 0x00007ffbbeeb8000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\zip.dll
0x00007ffbc4a00000 - 0x00007ffbc4a19000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\net.dll
0x00007ffbcd8c0000 - 0x00007ffbcd9ca000 C:\Windows\SYSTEM32\WINHTTP.dll
0x00007ffbd4f20000 - 0x00007ffbd4f8a000 C:\Windows\system32\mswsock.dll
0x00007ffbbf010000 - 0x00007ffbbf025000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\nio.dll
0x00007ffbcd760000 - 0x00007ffbcd77a000 C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin\breakgen64.dll
0x00007ffbc4ae0000 - 0x00007ffbc4ae9000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\management.dll
0x00007ffbc22c0000 - 0x00007ffbc22cb000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\management_ext.dll
0x00007ffbbe0f0000 - 0x00007ffbbe107000 C:\Windows\system32\napinsp.dll
0x00007ffbbdf90000 - 0x00007ffbbdfab000 C:\Windows\system32\pnrpnsp.dll
0x00007ffbb6a30000 - 0x00007ffbb6a45000 C:\Windows\system32\wshbth.dll
0x00007ffbd13f0000 - 0x00007ffbd140d000 C:\Windows\system32\NLAapi.dll
0x00007ffbd4ba0000 - 0x00007ffbd4bdb000 C:\Windows\SYSTEM32\IPHLPAPI.DLL
0x00007ffbd4be0000 - 0x00007ffbd4cab000 C:\Windows\SYSTEM32\DNSAPI.dll
0x00007ffbd6c60000 - 0x00007ffbd6c68000 C:\Windows\System32\NSI.dll
0x00007ffbbc030000 - 0x00007ffbbc042000 C:\Windows\System32\winrnr.dll
0x0000000061af0000 - 0x0000000061b16000 C:\Program Files\Bonjour\mdnsNSP.dll
0x00007ffbccc00000 - 0x00007ffbccc0a000 C:\Windows\System32\rasadhlp.dll
0x00007ffbcc2f0000 - 0x00007ffbcc370000 C:\Windows\System32\fwpuclnt.dll
0x00007ffbd5f10000 - 0x00007ffbd5f37000 C:\Windows\System32\bcrypt.dll
0x00007ffbb8c30000 - 0x00007ffbb8ca1000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl.dll
0x00007ffbac180000 - 0x00007ffbac1e1000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\glfw.dll
0x00007ffbb96a0000 - 0x00007ffbb96e5000 C:\Windows\SYSTEM32\dinput8.dll
0x00007ffbbda60000 - 0x00007ffbbda71000 C:\Windows\SYSTEM32\xinput1_4.dll
0x00007ffbd5e10000 - 0x00007ffbd5e5e000 C:\Windows\System32\cfgmgr32.dll
0x00007ffbd5510000 - 0x00007ffbd553c000 C:\Windows\SYSTEM32\DEVOBJ.dll
0x00007ffbd3390000 - 0x00007ffbd33bf000 C:\Windows\SYSTEM32\dwmapi.dll
0x00007ffbc89f0000 - 0x00007ffbc8b42000 C:\Windows\SYSTEM32\inputhost.dll
0x00007ffbd6340000 - 0x00007ffbd640d000 C:\Windows\System32\OLEAUT32.dll
0x00007ffbd16d0000 - 0x00007ffbd1824000 C:\Windows\SYSTEM32\wintypes.dll
0x00007ffbd2d90000 - 0x00007ffbd2e82000 C:\Windows\SYSTEM32\CoreMessaging.dll
0x00007ffbcfe40000 - 0x00007ffbcff36000 C:\Windows\SYSTEM32\PROPSYS.dll
0x00007ffbd2a30000 - 0x00007ffbd2d8e000 C:\Windows\SYSTEM32\CoreUIComponents.dll
0x00007ffbd4460000 - 0x00007ffbd4493000 C:\Windows\SYSTEM32\ntmarta.dll
0x00007ffbd31a0000 - 0x00007ffbd323e000 C:\Windows\system32\uxtheme.dll
0x00007ffbd6f90000 - 0x00007ffbd70a5000 C:\Windows\System32\MSCTF.dll
0x00007ffb9b170000 - 0x00007ffb9b296000 C:\Windows\SYSTEM32\opengl32.dll
0x00007ffb9bf50000 - 0x00007ffb9bf7c000 C:\Windows\SYSTEM32\GLU32.dll
0x00007ffbd71c0000 - 0x00007ffbd7269000 C:\Windows\System32\clbcatq.dll
0x00007ffb9bf20000 - 0x00007ffb9bf4d000 C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218\atig6pxx.dll
0x00007ffb7a5b0000 - 0x00007ffb7e2a1000 C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218\atio6axx.dll
0x00007ffbd75a0000 - 0x00007ffbd7a11000 C:\Windows\System32\SETUPAPI.dll
0x00007ffbd5920000 - 0x00007ffbd5988000 C:\Windows\System32\WINTRUST.dll
0x00007ffbd5f40000 - 0x00007ffbd6096000 C:\Windows\System32\CRYPT32.dll
0x00007ffbd5350000 - 0x00007ffbd5362000 C:\Windows\SYSTEM32\MSASN1.dll
0x00007ffba99d0000 - 0x00007ffba9a2d000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl_opengl.dll
0x00007ffbd5110000 - 0x00007ffbd5128000 C:\Windows\SYSTEM32\CRYPTSP.dll
0x00007ffbd47c0000 - 0x00007ffbd47f4000 C:\Windows\system32\rsaenh.dll
0x00007ffbd5660000 - 0x00007ffbd568e000 C:\Windows\SYSTEM32\USERENV.dll
0x00007ffbd5130000 - 0x00007ffbd513c000 C:\Windows\SYSTEM32\CRYPTBASE.dll
0x00007ffbd0000000 - 0x00007ffbd0017000 C:\Windows\SYSTEM32\dhcpcsvc6.DLL
0x00007ffbcffe0000 - 0x00007ffbcfffd000 C:\Windows\SYSTEM32\dhcpcsvc.DLL
0x00007ffba9a90000 - 0x00007ffba9ad5000 C:\Users\dbott\AppData\Local\Temp\jna-95382001\jna11149125972623279360.dll
0x00007ffba4910000 - 0x00007ffba49b3000 K:\git\kstarbound\freetype-2.11.1.dll
0x00007ffbc8b50000 - 0x00007ffbc8c49000 C:\Windows\SYSTEM32\textinputframework.dll
0x00007ffba9840000 - 0x00007ffba98c1000 C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21\lwjgl_stb.dll
0x000000006e4c0000 - 0x000000006e4df000 C:\Users\dbott\AppData\Local\Temp\jffi11233893901409584800.dll
0x00007ffbc5210000 - 0x00007ffbc5220000 C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\verify.dll
0x00007ffba1530000 - 0x00007ffba15d4000 K:\git\kstarbound\lua54.DLL
0x00007ffbbc080000 - 0x00007ffbbc0a3000 K:\git\kstarbound\lua_glue.dll
0x00007ffbd7340000 - 0x00007ffbd746a000 C:\Windows\System32\ole32.dll
dbghelp: loaded successfully - version: 4.0.5 - missing functions: none
symbol engine: initialized successfully - sym options: 0x614 - pdb path: .;C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin;C:\Windows\SYSTEM32;C:\Windows\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_6.0.19041.1110_none_60b5254171f9507e;C:\Users\dbott\.gradle\jdks\jdk-17.0.1+12\bin\server;C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin;C:\Program Files\Bonjour;C:\Users\dbott\AppData\Local\Temp\lwjgldbott\3.3.0-build-21;C:\Windows\System32\DriverStore\FileRepository\u0387206.inf_amd64_081d192bd0a4e0cb\B386218;C:\Users\dbott\AppData\Local\Temp\jna-95382001;K:\git\kstarbound;C:\Users\dbott\AppData\Local\Temp
VM Arguments:
jvm_args: -Xms128m -javaagent:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\lib\idea_rt.jar=5926:C:\Program Files\JetBrains\IntelliJ IDEA Community Edition 2021.3\bin -Dfile.encoding=UTF-8
java_command: ru.dbotthepony.kstarbound.MainKt
java_class_path (initial): K:\git\kstarbound\build\classes\java\main;K:\git\kstarbound\build\classes\kotlin\main;K:\git\kstarbound\build\resources\main;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.jetbrains.kotlin\kotlin-reflect\1.6.10\1cbe9c92c12a94eea200d23c2bbaedaf3daf5132\kotlin-reflect-1.6.10.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.jetbrains.kotlin\kotlin-stdlib\1.6.10\b8af3fe6f1ca88526914929add63cf5e7c5049af\kotlin-stdlib-1.6.10.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.apache.logging.log4j\log4j-core\2.17.1\779f60f3844dadc3ef597976fcb1e5127b1f343d\log4j-core-2.17.1.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.apache.logging.log4j\log4j-api\2.17.1\d771af8e336e372fb5399c99edabe0919aeaf5b2\log4j-api-2.17.1.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\com.google.code.gson\gson\2.8.9\8a432c1d6825781e21a02db2e2c33c5fde2833b9\gson-2.8.9.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\it.unimi.dsi\fastutil\8.5.6\76f95700418a68fbc4ac050525261f05dc681ca1\fastutil-8.5.6.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\com.google.guava\guava\31.0.1-jre\119ea2b2bc205b138974d351777b20f02b92704b\guava-31.0.1-jre.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-assimp\3.3.0\82135e856184e76d38a97f729141298d3edcf0e4\lwjgl-assimp-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-bgfx\3.3.0\b9e9a62b741bdc60f9207a4d4de6e61a2b7de6af\lwjgl-bgfx-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-glfw\3.3.0\899e34f314525596f8fdb6476d3e56104da4601d\lwjgl-glfw-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-nanovg\3.3.0\a15688d6e6c7136cebc5b63f30d120f702f6587c\lwjgl-nanovg-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-nuklear\3.3.0\8dbbdce4f28384c2abdfe8d0abff5f4c9bae286e\lwjgl-nuklear-3.3.0.jar;C:\Users\dbott\.gradle\caches\modules-2\files-2.1\org.lwjgl\lwjgl-openal\3.3.0\902dd57b
Launcher Type: SUN_STANDARD
[Global flags]
intx CICompilerCount = 12 {product} {ergonomic}
uint ConcGCThreads = 3 {product} {ergonomic}
uint G1ConcRefinementThreads = 13 {product} {ergonomic}
size_t G1HeapRegionSize = 8388608 {product} {ergonomic}
uintx GCDrainStackTargetSize = 64 {product} {ergonomic}
size_t InitialHeapSize = 134217728 {product} {command line}
size_t MarkStackSize = 4194304 {product} {ergonomic}
size_t MaxHeapSize = 17163091968 {product} {ergonomic}
size_t MaxNewSize = 10292822016 {product} {ergonomic}
size_t MinHeapDeltaBytes = 8388608 {product} {ergonomic}
size_t MinHeapSize = 134217728 {product} {command line}
uintx NonNMethodCodeHeapSize = 7602480 {pd product} {ergonomic}
uintx NonProfiledCodeHeapSize = 122027880 {pd product} {ergonomic}
uintx ProfiledCodeHeapSize = 122027880 {pd product} {ergonomic}
uintx ReservedCodeCacheSize = 251658240 {pd product} {ergonomic}
bool SegmentedCodeCache = true {product} {ergonomic}
size_t SoftMaxHeapSize = 17163091968 {manageable} {ergonomic}
bool UseCompressedClassPointers = true {product lp64_product} {ergonomic}
bool UseCompressedOops = true {product lp64_product} {ergonomic}
bool UseG1GC = true {product} {ergonomic}
bool UseLargePagesIndividualAllocation = false {pd product} {ergonomic}
Logging:
Log output configuration:
#0: stdout all=warning uptime,level,tags
#1: stderr all=off uptime,level,tags
Environment Variables:
JAVA_HOME=C:\Program Files\Eclipse Adoptium\jdk-17.0.4.101-hotspot\
PATH=C:\Program Files\Eclipse Adoptium\jdk-17.0.4.101-hotspot\bin;C:\Program Files\ImageMagick-7.1.0-Q16;C:\Program Files\Microsoft\jdk-11.0.12.7-hotspot\bin;C:\Program Files\ImageMagick-7.1.0-Q16-HDRI;C:\Program Files (x86)\NVIDIA Corporation\PhysX\Common;C:\Program Files (x86)\VMware\VMware Workstation\bin\;C:\Program Files\ImageMagick-7.0.10-Q16-HDRI;C:\Program Files\Python38\Scripts\;C:\Program Files\Python38\;C:\Program Files\ImageMagick-7.0.9-Q16;C:\Program Files (x86)\Common Files\Oracle\Java\javapath;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;D:\php7;C:\Program Files (x86)\Lua\5.1;C:\Program Files (x86)\Lua\5.1\clibs;C:\Program Files (x86)\Codebox\BitMeterOS;C:\moonscript;C:\Program Files\TortoiseHg\;C:\Program Files\GTK3-Runtime Win64\bin;C:\ProgramData\ComposerSetup\bin;C:\Program Files\Logstalgia\cmd;C:\Program Files\dotnet\;C:\Program Files\TortoiseSVN\bin;C:\Program Files\Gource\cmd;C:\kotlin-native-windows-1.3.72\bin;N:\platform-tools;C:\Program Files\PuTTY\;C:\Program Files\Git\cmd;C:\Windows\System32\OpenSSH\;D:\php-8.0.8-Win32-vs16-x64;C:\Program Files\LLVM\bin;C:\Program Files\PowerShell\7\;C:\Program Files\CMake\bin;C:\pypy3.8-v7.3.7-win64;C:\pypy3.8-v7.3.7-win64\Scripts;C:\Program Files\nodejs\;C:\Program Files\7-Zip;C:\Program Files\TortoiseGit\bin;C:\Users\dbott\.cargo\bin;C:\Users\dbott\.windows-build-tools\python27\;C:\Users\dbott\AppData\Local\Programs\Python\Python37\Scripts\;C:\Users\dbott\AppData\Local\Programs\Python\Python37\;C:\Users\dbott\AppData\Local\Microsoft\WindowsApps;C:\Users\dbott\AppData\Local\Programs\Microsoft VS Code\bin;K:\git\vcpkg\installed\x86-windows\include;K:\git\vcpkg\installed\x86-windows\lib;K:\git\vcpkg\installed\x86-windows\bin;C:\Users\dbott\AppData\Roaming\Composer\vendor\bin;C:\Users\dbott\.dotnet\tools;C:\Users\dbott\AppData\Local\Microsoft\WindowsApps;C:\Program Files (x86)\FreeArc\bin;C:\Users\dbott\AppData\Roaming\npm
USERNAME=dbott
OS=Windows_NT
PROCESSOR_IDENTIFIER=AMD64 Family 23 Model 113 Stepping 0, AuthenticAMD
--------------- S Y S T E M ---------------
OS:
Windows 10 , 64 bit Build 19041 (10.0.19041.1706)
OS uptime: 34 days 23:34 hours
CPU: total 16 (initial active 16) (16 cores per cpu, 2 threads per core) family 23 model 113 stepping 0 microcode 0x0, cx8, cmov, fxsr, ht, mmx, 3dnowpref, sse, sse2, sse3, ssse3, sse4a, sse4.1, sse4.2, popcnt, lzcnt, tsc, tscinvbit, avx, avx2, aes, clmul, bmi1, bmi2, adx, sha, fma, vzeroupper, clflush, clflushopt
Memory: 4k page, system-wide physical 65457M (24517M free)
TotalPageFile size 165457M (AvailPageFile size 106196M)
current process WorkingSet (physical memory assigned to process): 722M, peak: 796M
current process commit charge ("private bytes"): 864M, peak: 973M
vm_info: OpenJDK 64-Bit Server VM (17.0.1+12) for windows-amd64 JRE (17.0.1+12), built on Oct 20 2021 07:42:55 by "" with MS VC++ 16.7 (VS2019)
END.

View File

@ -5,7 +5,6 @@ import org.apache.logging.log4j.LogManager
import org.lwjgl.Version
import org.lwjgl.glfw.GLFW.glfwSetWindowShouldClose
import ru.dbotthepony.kstarbound.client.StarboundClient
import ru.dbotthepony.kstarbound.client.render.Animator
import ru.dbotthepony.kstarbound.defs.animation.AnimationDefinition
import ru.dbotthepony.kstarbound.io.BTreeDB
import ru.dbotthepony.kstarbound.player.Avatar
@ -15,25 +14,19 @@ import ru.dbotthepony.kstarbound.util.JVMTimeSource
import ru.dbotthepony.kstarbound.world.api.IChunkCell
import ru.dbotthepony.kstarbound.world.entities.ItemEntity
import ru.dbotthepony.kstarbound.world.entities.PlayerEntity
import ru.dbotthepony.kstarbound.client.world.`object`.ClientWorldObject
import ru.dbotthepony.kstarbound.io.json.BinaryJsonReader
import ru.dbotthepony.kstarbound.io.json.VersionedJson
import ru.dbotthepony.kstarbound.io.readString
import ru.dbotthepony.kstarbound.io.readVarInt
import ru.dbotthepony.kstarbound.util.AssetPathStack
import ru.dbotthepony.kstarbound.world.`object`.WorldObject
import ru.dbotthepony.kvector.vector.Vector2d
import ru.dbotthepony.kvector.vector.Vector2f
import ru.dbotthepony.kvector.vector.Vector2i
import java.io.BufferedInputStream
import java.io.ByteArrayInputStream
import java.io.ByteArrayOutputStream
import java.io.DataInputStream
import java.io.File
import java.util.*
import java.util.concurrent.locks.LockSupport
import java.util.zip.Inflater
import java.util.zip.InflaterInputStream
import java.util.zip.InflaterOutputStream
private val LOGGER = LogManager.getLogger()
@ -54,7 +47,7 @@ fun main() {
val f = File("J:\\Steam\\steamapps\\workshop\\content\\211820\\$folder\\contents.pak")
if (f.exists()) {
starbound.addPakPath(f)
Starbound.addPakPath(f)
}
}*/
@ -104,7 +97,7 @@ fun main() {
if (obj.identifier == "ObjectEntity") {
try {
val created = ClientWorldObject.create(client.world!!, obj.content.asJsonObject)
WorldObject(client.world!!, obj.content.asJsonObject).spawn()
//println(obj.content)
//println(created)
} catch (err: Throwable) {
@ -141,12 +134,6 @@ fun main() {
val def = Starbound.gson.fromJson(Starbound.locate("/animations/dust4/dust4.animation").reader(), AnimationDefinition::class.java)
AssetPathStack.pop()
val animator = Animator(client.world!!, def)
//client.onPostDrawWorld {
// animator.render(client.gl.matrixStack)
//}
val avatar = Avatar(Starbound, UUID.randomUUID())
val quest = QuestInstance(avatar, descriptor = QuestDescriptor("floran_mission1"))
quest.init()

View File

@ -1,23 +1,20 @@
package ru.dbotthepony.kstarbound
import com.github.benmanes.caffeine.cache.Cache
import com.github.benmanes.caffeine.cache.Caffeine
import com.github.benmanes.caffeine.cache.Interner
import com.google.gson.*
import com.google.gson.internal.bind.JsonTreeReader
import it.unimi.dsi.fastutil.Hash
import com.google.gson.stream.JsonReader
import it.unimi.dsi.fastutil.objects.Object2IntOpenHashMap
import it.unimi.dsi.fastutil.objects.Object2ObjectFunction
import it.unimi.dsi.fastutil.objects.Object2ObjectOpenCustomHashMap
import it.unimi.dsi.fastutil.objects.Object2ObjectOpenHashMap
import org.apache.logging.log4j.LogManager
import org.lwjgl.stb.STBImage
import ru.dbotthepony.kstarbound.api.ISBFileLocator
import ru.dbotthepony.kstarbound.api.IStarboundFile
import ru.dbotthepony.kstarbound.api.NonExistingFile
import ru.dbotthepony.kstarbound.api.PhysicalFile
import ru.dbotthepony.kstarbound.defs.*
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.Image
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.defs.item.impl.BackArmorItemDefinition
import ru.dbotthepony.kstarbound.defs.item.impl.ChestArmorItemDefinition
import ru.dbotthepony.kstarbound.defs.item.impl.CurrencyItemDefinition
@ -81,16 +78,13 @@ import ru.dbotthepony.kstarbound.util.ItemStack
import ru.dbotthepony.kstarbound.util.JVMTimeSource
import ru.dbotthepony.kstarbound.util.AssetPathStack
import ru.dbotthepony.kstarbound.util.SBPattern
import ru.dbotthepony.kstarbound.util.HashTableInterner
import ru.dbotthepony.kstarbound.util.WriteOnce
import ru.dbotthepony.kstarbound.util.filterNotNull
import ru.dbotthepony.kstarbound.util.set
import ru.dbotthepony.kstarbound.util.traverseJsonPath
import ru.dbotthepony.kvector.vector.Vector2i
import java.io.*
import java.lang.ref.ReferenceQueue
import java.lang.ref.WeakReference
import java.text.DateFormat
import java.time.Duration
import java.util.function.BiConsumer
import java.util.function.BinaryOperator
import java.util.function.Function
@ -101,9 +95,20 @@ import kotlin.collections.ArrayList
import kotlin.random.Random
object Starbound : ISBFileLocator {
const val SECONDS_IN_TICK = 1.0 / 60.0
const val TICK_TIME_ADVANCE = 1.0 / 60.0
val strings: Interner<String> = Interner.newWeakInterner()
// currently it saves only 4 megabytes of ram on pretty big modpack
// Hrm.
// val strings: Interner<String> = Interner.newWeakInterner()
// val strings: Interner<String> = Interner { it }
// custom-made on other hand is stupidly fast,
// and provide double the memory improvement over Caffeine one
// Only downside is that congestion is predefined on interner creation
// by no means this approach is the best, but it works great for this usecase
// This is the reason why JDK is not providing "the best" tools for one specific case,
// but the best possible tool for all possible usecases
val strings: Interner<String> = HashTableInterner(5)
private val polyfill by lazy { loadInternalScript("polyfill") }
@ -252,7 +257,7 @@ object Starbound : ISBFileLocator {
registerTypeAdapterFactory(IArmorItemDefinition.Frames.Factory)
registerTypeAdapterFactory(AssetPath.Companion)
registerTypeAdapter(ImageReference.Companion)
registerTypeAdapter(SpriteReference.Companion)
registerTypeAdapterFactory(AssetReference.Companion)
@ -295,13 +300,6 @@ object Starbound : ISBFileLocator {
}
}
private val imageCache: Cache<String, ImageData> = Caffeine.newBuilder()
.softValues()
.expireAfterAccess(Duration.ofMinutes(20))
.weigher<String, ImageData> { key, value -> value.data.capacity() }
.maximumWeight(1_024L * 1_024L * 256L /* 256 МиБ */)
.build()
fun item(name: String): ItemStack {
return ItemStack(items[name] ?: return ItemStack.EMPTY)
}
@ -384,36 +382,8 @@ object Starbound : ISBFileLocator {
it.call()
}
fun imageData(path: String): ImageData {
return imageCache.get(path) {
val file = locate(path)
if (!file.exists) {
throw FileNotFoundException("No such file $file")
}
if (!file.isFile) {
throw FileNotFoundException("File $file is a directory")
}
val getWidth = intArrayOf(0)
val getHeight = intArrayOf(0)
val components = intArrayOf(0)
val data = STBImage.stbi_load_from_memory(
file.readDirect(),
getWidth, getHeight,
components, 0
) ?: throw IllegalArgumentException("File $file is not an image or it is corrupted")
ImageData(data, getWidth[0], getHeight[0], components[0])
}
}
fun imageSize(path: String): Vector2i {
val image = imageData(path)
return Vector2i(image.width, image.height)
}
// wrapping for Lua refs
private fun getImage(path: String) = Image.get(path)
/**
* **ПРЕДУПРЕЖДЕНИЕ:**
@ -459,13 +429,15 @@ object Starbound : ISBFileLocator {
}
state.setTableFunction("imageSize", this) {args ->
args.lua.push(imageSize(args.getString()))
val name = args.getString()
args.lua.push(getImage(name)?.size ?: throw FileNotFoundException("No such file $name"))
1
}
state.setTableFunction("imageSpaces", this) { args ->
// List<Vec2I> root.imageSpaces(String imagePath, Vec2F worldPosition, float spaceScan, bool flip)
val values = imageData(args.getString()).worldSpaces(args.getVector2i(), args.getDouble(), args.getBool())
val name = args.getString()
val values = getImage(name)?.worldSpaces(args.getVector2i(), args.getDouble(), args.getBool()) ?: throw FileNotFoundException("No such file $name")
args.lua.pushTable(arraySize = values.size)
val table = args.lua.stackTop
@ -480,7 +452,8 @@ object Starbound : ISBFileLocator {
}
state.setTableFunction("nonEmptyRegion", this) { args ->
args.lua.push(imageData(args.getString()).nonEmptyRegion)
val name = args.getString()
args.lua.push(getImage(name)?.nonEmptyRegion ?: throw FileNotFoundException("No such file $name"))
1
}
@ -1127,16 +1100,20 @@ object Starbound : ISBFileLocator {
private fun loadJsonFunctions(callback: (String) -> Unit, files: Collection<IStarboundFile>) {
for (listedFile in files) {
callback("Loading $listedFile")
val json = gson.fromJson(listedFile.reader(), JsonObject::class.java)
try {
val json = gson.getAdapter(JsonObject::class.java).read(JsonReader(listedFile.reader()).also { it.isLenient = true })
for ((k, v) in json.entrySet()) {
try {
callback("Loading $k from $listedFile")
val fn = gson.fromJson<JsonFunction>(JsonTreeReader(v), JsonFunction::class.java)
_jsonFunctions.add(fn, v, listedFile, k)
} catch (err: Throwable) {
logger.error("Loading json function definition $k from file $listedFile", err)
for ((k, v) in json.entrySet()) {
try {
callback("Loading $k from $listedFile")
val fn = gson.fromJson<JsonFunction>(JsonTreeReader(v), JsonFunction::class.java)
_jsonFunctions.add(fn, v, listedFile, k)
} catch (err: Exception) {
logger.error("Loading json function definition $k from file $listedFile", err)
}
}
} catch (err: Exception) {
logger.error("Loading json function definition $listedFile", err)
}
if (terminateLoading) {
@ -1148,16 +1125,21 @@ object Starbound : ISBFileLocator {
private fun loadJson2Functions(callback: (String) -> Unit, files: Collection<IStarboundFile>) {
for (listedFile in files) {
callback("Loading $listedFile")
val json = gson.fromJson(listedFile.reader(), JsonObject::class.java)
for ((k, v) in json.entrySet()) {
try {
callback("Loading $k from $listedFile")
val fn = gson.fromJson<Json2Function>(JsonTreeReader(v), Json2Function::class.java)
_json2Functions.add(fn, v, listedFile, k)
} catch (err: Throwable) {
logger.error("Loading json 2function definition $k from file $listedFile", err)
try {
val json = gson.getAdapter(JsonObject::class.java).read(JsonReader(listedFile.reader()).also { it.isLenient = true })
for ((k, v) in json.entrySet()) {
try {
callback("Loading $k from $listedFile")
val fn = gson.fromJson<Json2Function>(JsonTreeReader(v), Json2Function::class.java)
_json2Functions.add(fn, v, listedFile, k)
} catch (err: Throwable) {
logger.error("Loading json 2function definition $k from file $listedFile", err)
}
}
} catch (err: Exception) {
logger.error("Loading json 2function definition $listedFile", err)
}
if (terminateLoading) {
@ -1169,17 +1151,22 @@ object Starbound : ISBFileLocator {
private fun loadTreasurePools(callback: (String) -> Unit, files: Collection<IStarboundFile>) {
for (listedFile in files) {
callback("Loading $listedFile")
val json = gson.fromJson(listedFile.reader(), JsonObject::class.java)
for ((k, v) in json.entrySet()) {
try {
callback("Loading $k from $listedFile")
val result = gson.fromJson<TreasurePoolDefinition>(JsonTreeReader(v), TreasurePoolDefinition::class.java)
result.name = k
_treasurePools.add(result, v, listedFile)
} catch (err: Throwable) {
logger.error("Loading treasure pool definition $k from file $listedFile", err)
try {
val json = gson.getAdapter(JsonObject::class.java).read(JsonReader(listedFile.reader()).also { it.isLenient = true })
for ((k, v) in json.entrySet()) {
try {
callback("Loading $k from $listedFile")
val result = gson.fromJson<TreasurePoolDefinition>(JsonTreeReader(v), TreasurePoolDefinition::class.java)
result.name = k
_treasurePools.add(result, v, listedFile)
} catch (err: Throwable) {
logger.error("Loading treasure pool definition $k from file $listedFile", err)
}
}
} catch (err: Exception) {
logger.error("Loading treasure pool definition $listedFile", err)
}
if (terminateLoading) {
@ -1206,74 +1193,3 @@ object Starbound : ISBFileLocator {
}
}
private class StringInterner(private val segmentBits: Int) : Interner<String>, Hash.Strategy<Any> {
class Ref(referent: String, queue: ReferenceQueue<String>) : WeakReference<String>(referent, queue) {
val hash = referent.hashCode()
override fun hashCode(): Int {
return hash
}
}
override fun equals(a: Any?, b: Any?): Boolean {
if (a is String && b is Ref) return a == b.get()
if (a is Ref && b is String) return a.get() == b
return a === b
}
override fun hashCode(o: Any): Int {
return o.hashCode()
}
private val queue = ReferenceQueue<String>()
private val actualSegmentBits: Int
init {
var result = 0
for (i in 0 until segmentBits) {
result = result or (1.shl(i))
}
actualSegmentBits = result
}
private val cleaner = Runnable {
while (true) {
val ref = queue.remove() as Ref
val segment = segments[ref.hash and actualSegmentBits]
synchronized(segment) {
val removed = segment.remove(ref)
check(removed === ref) { "Expected to remove reference $ref from segment ${ref.hash and actualSegmentBits} (full hash: ${ref.hash}), but we removed $removed (removed hash: ${removed.hashCode()}, removed segment: ${removed.hashCode() and actualSegmentBits})" }
}
}
}
private val thread = Thread(cleaner, "String Interner Cleanup Thread")
init {
thread.priority = 2
thread.isDaemon = true
thread.start()
}
private val segments: Array<Object2ObjectOpenCustomHashMap<Any, Any>> = Array(1.shl(segmentBits)) { Object2ObjectOpenCustomHashMap(this) }
override fun intern(sample: String): String {
val hash = sample.hashCode()
val segment = segments[hash and actualSegmentBits]
synchronized(segment) {
val canonical = (segment[sample] as Ref?)?.get()
if (canonical != null) {
return canonical
}
val ref = Ref(sample, queue)
segment.put(ref, ref)
return sample
}
}
}

View File

@ -40,7 +40,6 @@ import java.nio.ByteBuffer
import java.nio.ByteOrder
import java.util.concurrent.locks.LockSupport
import kotlin.collections.ArrayList
import kotlin.math.roundToInt
class StarboundClient : Closeable {
val time = PausableTimeSource(JVMTimeSource.INSTANCE)
@ -353,8 +352,8 @@ class StarboundClient : Closeable {
val diff = JVMTimeSource.INSTANCE.seconds - lastRender
if (diff < Starbound.SECONDS_IN_TICK)
LockSupport.parkNanos(((Starbound.SECONDS_IN_TICK - diff) * 1_000_000_000.0).toLong())
if (diff < Starbound.TICK_TIME_ADVANCE)
LockSupport.parkNanos(((Starbound.TICK_TIME_ADVANCE - diff) * 1_000_000_000.0).toLong())
frameRenderTime = JVMTimeSource.INSTANCE.seconds - lastRender
frameRenderTimes[++frameRenderIndex % frameRenderTimes.size] = frameRenderTime
@ -504,7 +503,7 @@ class StarboundClient : Closeable {
GLFW.glfwPollEvents()
input.think()
camera.think(Starbound.SECONDS_IN_TICK)
camera.think(Starbound.TICK_TIME_ADVANCE)
gl.cleanup()

View File

@ -19,6 +19,7 @@ import ru.dbotthepony.kstarbound.client.gl.vertex.GeometryType
import ru.dbotthepony.kstarbound.client.gl.vertex.VertexBuilder
import ru.dbotthepony.kstarbound.client.render.Box2DRenderer
import ru.dbotthepony.kstarbound.client.render.Font
import ru.dbotthepony.kstarbound.defs.image.Image
import ru.dbotthepony.kvector.api.IStruct4f
import ru.dbotthepony.kvector.arrays.Matrix4fStack
import ru.dbotthepony.kvector.util2d.AABB
@ -184,7 +185,7 @@ class GLStateTracker(val client: StarboundClient) {
private set
private val cleaner = Cleaner.create { r ->
val thread = Thread(r, "OpenGL Object Cleaner for ${this@GLStateTracker}")
val thread = Thread(r, "OpenGL Cleaner for '${thread.name}'")
thread.priority = 2
thread
}
@ -479,11 +480,13 @@ class GLStateTracker(val client: StarboundClient) {
return named2DTextures0.get(path) {
named2DTextures1.get(it) {
if (!Starbound.exists(it)) {
val data = Image.get(it)
if (data == null) {
LOGGER.error("Texture {} is missing! Falling back to {}", it, missingTexturePath)
missingTexture
} else {
newTexture(it).upload(Starbound.imageData(it)).generateMips().also {
newTexture(it).upload(data).also {
it.textureMinFilter = GL_NEAREST
it.textureMagFilter = GL_NEAREST
}

View File

@ -3,7 +3,7 @@ package ru.dbotthepony.kstarbound.client.gl
import org.apache.logging.log4j.LogManager
import org.lwjgl.opengl.GL46.*
import org.lwjgl.stb.STBImage
import ru.dbotthepony.kstarbound.io.ImageData
import ru.dbotthepony.kstarbound.defs.image.Image
import ru.dbotthepony.kvector.vector.Vector2i
import java.io.File
import java.io.FileNotFoundException
@ -253,7 +253,7 @@ class GLTexture2D(val state: GLStateTracker, val name: String = "<unknown>") {
return this
}
fun upload(data: ImageData): GLTexture2D {
fun upload(data: Image): GLTexture2D {
state.ensureSameThread()
val bufferFormat = when (val numChannels = data.amountOfChannels) {

View File

@ -1,5 +1,6 @@
package ru.dbotthepony.kstarbound.client.gl.vertex
import ru.dbotthepony.kstarbound.defs.image.IUVCoordinates
import ru.dbotthepony.kstarbound.defs.image.UVCoordinates
import ru.dbotthepony.kvector.vector.RGBAColor
@ -53,11 +54,11 @@ object QuadTransformers {
}
}
fun uv(uv: UVCoordinates): QuadVertexTransformer {
fun uv(uv: IUVCoordinates): QuadVertexTransformer {
return uv(uv.u0, uv.v0, uv.u1, uv.v1)
}
fun uv(uv: UVCoordinates, lambda: QuadVertexTransformer): QuadVertexTransformer {
fun uv(uv: IUVCoordinates, lambda: QuadVertexTransformer): QuadVertexTransformer {
return uv(uv.u0, uv.v0, uv.u1, uv.v1, lambda)
}

View File

@ -1,51 +0,0 @@
package ru.dbotthepony.kstarbound.client.render
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNITf
import ru.dbotthepony.kstarbound.client.world.ClientWorld
import ru.dbotthepony.kstarbound.defs.animation.AnimationDefinition
import ru.dbotthepony.kvector.arrays.Matrix4fStack
import ru.dbotthepony.kvector.vector.Vector3f
class Animator(
val world: ClientWorld,
val def: AnimationDefinition,
val renderParams: ((String) -> String?)? = null
) {
inline val state get() = world.client.gl
val frameAnimator: FrameAnimator?
val mainSprite: RebindableSprite?
init {
if (def.frames != null && def.animationCycle != null && def.frameNumber != null) {
frameAnimator = FrameAnimator(lastFrame = def.frameNumber - 1, time = world.client.time, animationCycle = def.animationCycle)
mainSprite = RebindableSprite(world.client, def.frames, ::getRenderParam)
} else {
frameAnimator = null
mainSprite = null
}
}
private fun getRenderParam(name: String): String? {
if (name == "frame") {
return frameAnimator?.frameString
}
return renderParams?.invoke(name)
}
fun render(stack: Matrix4fStack) {
frameAnimator?.advance()
val sprite = mainSprite?.update() ?: return
sprite.texture.bind()
stack.push().last().translateWithMultiplication(Vector3f(world.client.camera.pos))
state.programs.textured.use()
state.programs.textured.transform = stack.last()
state.activeTexture = 0
state.programs.textured.texture = 0
state.flat2DTexturedQuads.singleSprite(sprite.width / PIXELS_IN_STARBOUND_UNITf, sprite.height / PIXELS_IN_STARBOUND_UNITf, 0.0, sprite.transformer)
stack.pop()
}
}

View File

@ -1,43 +0,0 @@
package ru.dbotthepony.kstarbound.client.render
import ru.dbotthepony.kstarbound.client.gl.GLStateTracker
import ru.dbotthepony.kstarbound.client.gl.GLTexture2D
import ru.dbotthepony.kstarbound.client.gl.vertex.QuadTransformers
import ru.dbotthepony.kstarbound.defs.image.AtlasConfiguration
import ru.dbotthepony.kstarbound.defs.image.IUVCoordinates
import ru.dbotthepony.kstarbound.defs.image.ImageReference
/**
* Связка текстуры-атласа + координат спрайта на ней
*/
class BoundSprite(
val sprite: AtlasConfiguration.Sprite,
val texture: GLTexture2D
) : IUVCoordinates {
/**
* Настоящая ширина спрайта, в пикселях
*/
val width = sprite.width(texture.width)
/**
* Настоящая высота спрайта, в пикселях
*/
val height = sprite.height(texture.height)
override val u0: Float
override val v0: Float
override val u1: Float
override val v1: Float
init {
val coords = sprite.compute(texture)
this.u0 = coords.u0
this.v0 = coords.v0
this.u1 = coords.u1
this.v1 = coords.v1
}
fun bind() = texture.bind()
val transformer = QuadTransformers.uv(u0, v0, u1, v1)
}

View File

@ -1,94 +0,0 @@
package ru.dbotthepony.kstarbound.client.render
import ru.dbotthepony.kstarbound.util.ITimeSource
import ru.dbotthepony.kstarbound.util.JVMTimeSource
import ru.dbotthepony.kstarbound.util.sbIntern2
/**
* Таймер для анимирования набора спрайтов
*/
class FrameAnimator(
/**
* Первый кадр в анимации
*/
val firstFrame: Int = 0,
/**
* Последний кадр в анимации
*/
val lastFrame: Int,
/**
* Сколько времени занимает один кадр
*/
var animationCycle: Double,
/**
* Зациклить ли анимацию
*/
var animationLoops: Boolean = true,
val time: ITimeSource = JVMTimeSource.INSTANCE
) {
var frame = 0
private set
/**
* Эффективное преобразование [frame] в строку
*/
val frameString: String get() {
return framenames.getOrNull(frame) ?: frame.toString()
}
private var counter = 0.0
private var lastRender = time.seconds
/**
* Разница между последним и первым кадром анимации
*/
val frameDiff = lastFrame - firstFrame
/**
* Проверяет таймер на [seconds] и продвигает фрейм анимации
*/
fun advance(seconds: Double) {
if (frameDiff == 0)
return
if (frame + firstFrame >= lastFrame && !animationLoops)
return
counter += seconds / animationCycle
if (counter >= 1.0) {
val desired = frame + counter.toInt()
if (animationLoops || desired + firstFrame < lastFrame) {
frame = desired % frameDiff
counter %= 1.0
} else {
frame = lastFrame - firstFrame
}
}
}
/**
* Проверяет таймер используя [time] и продвигает фрейм анимации
*/
fun advance() {
if (frameDiff != 0) {
advance(time.seconds - lastRender)
lastRender = time.seconds
}
}
companion object {
private val framenames = ArrayList<String>()
init {
for (i in 0 .. 500) {
framenames.add(i.toString().sbIntern2())
}
}
}
}

View File

@ -1,50 +0,0 @@
package ru.dbotthepony.kstarbound.client.render
import ru.dbotthepony.kstarbound.client.StarboundClient
import ru.dbotthepony.kstarbound.defs.image.ImageReference
class RebindableSprite(
val client: StarboundClient,
ref: ImageReference,
val renderParams: ((String) -> String?)? = null
) {
var sprite: BoundSprite? = null
private set
var ref: ImageReference = ref
private set
init {
val unbound = ref.sprite
if (unbound != null) {
sprite = BoundSprite(unbound, client.gl.loadTexture(ref.imagePath.value!!))
}
}
/**
* Обновляет [ref] и [sprite] по значениям, которые выдаст [renderParams]
*
* Возвращает новое значение [sprite]
*/
fun update(): BoundSprite? {
client.gl.ensureSameThread()
if (renderParams == null)
return sprite
val newRef = ref.with(renderParams)
if (newRef !== ref) {
ref = newRef
sprite = null
val unbound = newRef.sprite
if (unbound != null) {
sprite = BoundSprite(unbound, client.gl.loadTexture(newRef.imagePath.value!!))
}
}
return sprite
}
}

View File

@ -1,29 +1,17 @@
package ru.dbotthepony.kstarbound.client.render.entity
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNITf
import ru.dbotthepony.kstarbound.client.world.ClientChunk
import ru.dbotthepony.kstarbound.client.StarboundClient
import ru.dbotthepony.kstarbound.client.render.RebindableSprite
import ru.dbotthepony.kstarbound.world.entities.ItemEntity
import ru.dbotthepony.kvector.arrays.Matrix4fStack
class ItemRenderer(client: StarboundClient, entity: ItemEntity, chunk: ClientChunk?) : EntityRenderer(client, entity, chunk) {
private val def = entity.def
private val textures = def.inventoryIcon?.stream()?.map { RebindableSprite(client, it.image) }?.toList() ?: listOf()
override fun render(stack: Matrix4fStack) {
if (textures.isEmpty())
return
state.programs.textured.use()
state.programs.textured.transform = stack.last()
state.activeTexture = 0
state.programs.textured.texture = 0
for (unbound in textures) {
val sprite = unbound.update() ?: continue
sprite.texture.bind()
state.flat2DTexturedQuads.singleSprite(sprite.width / PIXELS_IN_STARBOUND_UNITf, sprite.height / PIXELS_IN_STARBOUND_UNITf, entity.movement.angle, sprite.transformer)
}
}
}

View File

@ -5,24 +5,22 @@ import it.unimi.dsi.fastutil.longs.Long2ObjectOpenHashMap
import it.unimi.dsi.fastutil.longs.LongArraySet
import it.unimi.dsi.fastutil.objects.ObjectArrayList
import it.unimi.dsi.fastutil.objects.ReferenceArraySet
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNITf
import ru.dbotthepony.kstarbound.client.StarboundClient
import ru.dbotthepony.kstarbound.client.render.ConfiguredMesh
import ru.dbotthepony.kstarbound.client.render.LayeredRenderer
import ru.dbotthepony.kstarbound.client.render.Mesh
import ru.dbotthepony.kstarbound.client.render.MultiMeshBuilder
import ru.dbotthepony.kstarbound.client.render.RenderLayer
import ru.dbotthepony.kstarbound.client.world.`object`.ClientWorldObject
import ru.dbotthepony.kstarbound.defs.tile.LiquidDefinition
import ru.dbotthepony.kstarbound.math.roundTowardsNegativeInfinity
import ru.dbotthepony.kstarbound.math.roundTowardsPositiveInfinity
import ru.dbotthepony.kstarbound.world.CHUNK_SIZE
import ru.dbotthepony.kstarbound.world.ChunkPos
import ru.dbotthepony.kstarbound.world.LightCalculator
import ru.dbotthepony.kstarbound.world.World
import ru.dbotthepony.kstarbound.world.api.ITileAccess
import ru.dbotthepony.kstarbound.world.api.OffsetCellAccess
import ru.dbotthepony.kstarbound.world.api.TileView
import ru.dbotthepony.kstarbound.world.entities.Entity
import ru.dbotthepony.kstarbound.world.positiveModulo
import ru.dbotthepony.kvector.api.IStruct2i
import ru.dbotthepony.kvector.util2d.AABB
@ -269,7 +267,7 @@ class ClientWorld(
for (obj in objects) {
if (obj.pos.x in client.viewportCellX .. client.viewportCellX + client.viewportCellWidth && obj.pos.y in client.viewportCellY .. client.viewportCellY + client.viewportCellHeight) {
//layers.add(RenderLayer.Object.index) {
layers.add(obj.orientation?.renderLayer ?: continue) {
layers.add(obj.orientation?.renderLayer ?: continue) { m ->
client.gl.quadWireframe {
it.quad(
obj.pos.x.toFloat(),
@ -279,9 +277,14 @@ class ClientWorld(
)
}
(obj as ClientWorldObject).drawables.forEach {
val (x, y) = obj.orientation?.imagePosition ?: Vector2f.ZERO
it.with { "default" }.render(client.gl, x = obj.pos.x.toFloat() + x, y = obj.pos.y.toFloat() + y)
obj.drawables.forEach {
val (x, y) = obj.imagePosition
it.render(
client.gl,
x = obj.pos.x.toFloat() + x / PIXELS_IN_STARBOUND_UNITf,
y = obj.pos.y.toFloat() + y / PIXELS_IN_STARBOUND_UNITf
)
}
}
@ -317,11 +320,18 @@ class ClientWorld(
}
override fun thinkInner() {
val copy = ObjectArrayList(entities)
val entities = ObjectArrayList(entities)
for (ent in copy) {
for (ent in entities) {
ent.think()
}
val objects = ObjectArrayList(objects)
for (ent in objects) {
ent.thinkShared()
ent.thinkClient()
}
}
companion object {

View File

@ -1,54 +0,0 @@
package ru.dbotthepony.kstarbound.client.world.`object`
import com.google.common.collect.ImmutableMap
import com.google.gson.JsonObject
import ru.dbotthepony.kstarbound.RegistryObject
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.client.world.ClientWorld
import ru.dbotthepony.kstarbound.defs.Drawable
import ru.dbotthepony.kstarbound.defs.animation.AnimationDefinition
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.`object`.ObjectDefinition
import ru.dbotthepony.kstarbound.world.`object`.WorldObject
import ru.dbotthepony.kvector.vector.Vector2i
class ClientWorldObject(world: ClientWorld, prototype: RegistryObject<ObjectDefinition>, pos: Vector2i) : WorldObject(world, prototype, pos) {
val clientWorld get() = world as ClientWorld
var animationParts: ImmutableMap<String, ImageReference> by Property()
var imagePosition: Vector2i by Property(Vector2i.ZERO)
var animationPosition: Vector2i by Property(Vector2i.ZERO)
val animation: AnimationDefinition? by LazyData(listOf("animationCustom", "animation")) {
/*
val custom = dataValue("animationCustom")
if (custom !is JsonObject) {
prototype.value.animation?.value
} else if (prototype.value.animation != null) {
animAdapter.fromJsonTree(merge(prototype.value.animation.json!!, custom))
} else {
null
}*/
null
}
val drawables: List<Drawable> by LazyData {
if (orientationIndex !in 0 until validOrientations) {
return@LazyData listOf()
} else {
return@LazyData orientations[orientationIndex].drawables
}
}
companion object {
private val animAdapter by lazy {
Starbound.gson.getAdapter(AnimationDefinition::class.java)
}
fun create(world: ClientWorld, data: JsonObject): ClientWorldObject {
return create(world, data, ::ClientWorldObject)
}
}
}

View File

@ -69,7 +69,7 @@ data class AssetReference<V>(val path: String?, val fullPath: String?, val value
it.isLenient = true
})
val value = AssetPathStack(fullPath) {
val value = AssetPathStack(fullPath.substringBefore(':').substringBeforeLast('/')) {
adapter.read(JsonTreeReader(json))
}

View File

@ -9,15 +9,14 @@ import com.google.gson.stream.JsonReader
import com.google.gson.stream.JsonWriter
import org.apache.logging.log4j.LogManager
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNITf
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.client.gl.GLStateTracker
import ru.dbotthepony.kstarbound.client.gl.vertex.QuadTransformers
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.consumeNull
import ru.dbotthepony.kstarbound.math.LineF
import ru.dbotthepony.kstarbound.util.AssetPathStack
import ru.dbotthepony.kstarbound.util.contains
import ru.dbotthepony.kvector.arrays.Matrix3f
import ru.dbotthepony.kvector.arrays.Matrix4f
import ru.dbotthepony.kvector.arrays.Matrix4fStack
import ru.dbotthepony.kvector.vector.RGBAColor
import ru.dbotthepony.kvector.vector.Vector2f
@ -48,7 +47,7 @@ sealed class Drawable(val position: Vector2f, val color: RGBAColor, val fullbrig
}
class Image(
val path: ImageReference,
val path: SpriteReference,
val transform: Matrix3f,
val centered: Boolean,
position: Vector2f = Vector2f.ZERO,
@ -71,11 +70,11 @@ sealed class Drawable(val position: Vector2f, val color: RGBAColor, val fullbrig
if (centered) {
gl.quadTexture(texture) {
it.quad(x - (sprite.width(texture.width) / PIXELS_IN_STARBOUND_UNITf) * 0.5f, y - (sprite.height(texture.height) / PIXELS_IN_STARBOUND_UNITf) * 0.5f, x + sprite.width(texture.width) / PIXELS_IN_STARBOUND_UNITf * 0.5f, y + sprite.height(texture.height) / PIXELS_IN_STARBOUND_UNITf * 0.5f, QuadTransformers.uv(sprite.compute(texture)))
it.quad(x - (sprite.width / PIXELS_IN_STARBOUND_UNITf) * 0.5f, y - (sprite.height / PIXELS_IN_STARBOUND_UNITf) * 0.5f, x + sprite.width / PIXELS_IN_STARBOUND_UNITf * 0.5f, y + sprite.height / PIXELS_IN_STARBOUND_UNITf * 0.5f, QuadTransformers.uv(sprite))
}
} else {
gl.quadTexture(texture) {
it.quad(x, y, x + sprite.width(texture.width) / PIXELS_IN_STARBOUND_UNITf, y + sprite.height(texture.height) / PIXELS_IN_STARBOUND_UNITf, QuadTransformers.uv(sprite.compute(texture)))
it.quad(x, y, x + sprite.width / PIXELS_IN_STARBOUND_UNITf, y + sprite.height / PIXELS_IN_STARBOUND_UNITf, QuadTransformers.uv(sprite))
}
}
}
@ -102,7 +101,7 @@ sealed class Drawable(val position: Vector2f, val color: RGBAColor, val fullbrig
private val vectors = gson.getAdapter(Vector2f::class.java)
private val vectors3 = gson.getAdapter(Vector3f::class.java)
private val colors = gson.getAdapter(RGBAColor::class.java)
private val images = gson.getAdapter(ImageReference::class.java)
private val images = gson.getAdapter(SpriteReference::class.java)
private val vertices = gson.getAdapter(TypeToken.getParameterized(ImmutableList::class.java, Vector2f::class.java)) as TypeAdapter<ImmutableList<Vector2f>>
override fun write(out: JsonWriter?, value: Drawable?) {

View File

@ -40,7 +40,7 @@ abstract class JsonDriven(val path: String) {
lazies.forEach { it.invalidate() }
}
protected inner class LazyData<T>(names: Iterable<String> = listOf(), private val initializer: () -> T) : Lazy<T> {
inner class LazyData<T>(names: Iterable<String> = listOf(), private val initializer: () -> T) : Lazy<T> {
constructor(initializer: () -> T) : this(listOf(), initializer)
init {
@ -72,7 +72,7 @@ abstract class JsonDriven(val path: String) {
}
}
protected inner class Property<T>(
inner class Property<T>(
name: String? = null,
val default: Either<Supplier<T>, JsonElement>? = null,
private var adapter: TypeAdapter<T>? = null,
@ -143,7 +143,8 @@ abstract class JsonDriven(val path: String) {
properties[checkNotNull(name)] = adapter!!.toJsonTree(t)
}
value = Supplier { t }
// value = Supplier { t }
invalidate(name!!)
}
@OptIn(ExperimentalStdlibApi::class)
@ -173,7 +174,7 @@ abstract class JsonDriven(val path: String) {
}
}
protected fun dataValue(name: String, alwaysCopy: Boolean = false): JsonElement? {
fun dataValue(name: String, alwaysCopy: Boolean = false): JsonElement? {
val defs = defs()
var value: JsonElement?
@ -191,7 +192,7 @@ abstract class JsonDriven(val path: String) {
return value
}
protected fun hasDataValue(name: String): Boolean {
fun hasDataValue(name: String): Boolean {
if (properties[name] != null) return true
return defs().any { it[name] != null }
}

View File

@ -2,7 +2,7 @@ package ru.dbotthepony.kstarbound.defs
import com.google.common.collect.ImmutableList
import com.google.common.collect.ImmutableSet
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.defs.item.api.IItemDefinition
import ru.dbotthepony.kstarbound.defs.player.BlueprintLearnList
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
@ -33,8 +33,8 @@ data class Species(
@JsonFactory
data class Gender(
val name: String,
val image: ImageReference,
val characterImage: ImageReference,
val image: SpriteReference,
val characterImage: SpriteReference,
val hairGroup: String? = null,
val hair: ImmutableSet<String>,
val shirt: ImmutableSet<RegistryReference<IItemDefinition>>,

View File

@ -2,7 +2,7 @@ package ru.dbotthepony.kstarbound.defs
import com.google.common.collect.ImmutableList
import ru.dbotthepony.kstarbound.defs.animation.AnimationDefinition
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
@JsonFactory
@ -11,7 +11,7 @@ data class StatusEffectDefinition(
val defaultDuration: Double,
val blockingStat: String? = null,
val label: String? = null,
val icon: ImageReference? = null,
val icon: SpriteReference? = null,
override val scripts: ImmutableList<AssetPath> = ImmutableList.of(),
override val scriptDelta: Int = 1,
val animationConfig: AssetReference<AnimationDefinition>? = null,

View File

@ -2,7 +2,7 @@ package ru.dbotthepony.kstarbound.defs.animation
import com.google.common.collect.ImmutableList
import com.google.common.collect.ImmutableMap
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.defs.particle.ParticleEmitter
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
import ru.dbotthepony.kstarbound.util.Either
@ -10,7 +10,7 @@ import ru.dbotthepony.kvector.vector.Vector2d
@JsonFactory
data class AnimationDefinition(
val frames: ImageReference? = null,
val frames: SpriteReference? = null,
val variants: Int? = null,
val frameNumber: Int? = null,
val animationCycle: Double? = null,
@ -78,7 +78,7 @@ data class AnimationDefinition(
val centered: Boolean? = null,
val transformationGroups: ImmutableList<String>? = null,
val offset: Vector2d? = null,
val image: ImageReference? = null
val image: SpriteReference? = null
) {
companion object {
val EMPTY = Properties()

View File

@ -1,354 +0,0 @@
package ru.dbotthepony.kstarbound.defs.image
import com.google.common.collect.ImmutableList
import com.google.common.collect.ImmutableMap
import com.google.gson.Gson
import com.google.gson.JsonArray
import com.google.gson.JsonNull
import com.google.gson.JsonObject
import com.google.gson.JsonSyntaxException
import com.google.gson.internal.bind.TypeAdapters
import com.google.gson.stream.JsonReader
import it.unimi.dsi.fastutil.ints.Int2ObjectOpenHashMap
import it.unimi.dsi.fastutil.objects.Object2ObjectArrayMap
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.api.ISBFileLocator
import ru.dbotthepony.kstarbound.client.gl.GLTexture2D
import ru.dbotthepony.kstarbound.io.json.stream
import ru.dbotthepony.kstarbound.util.AssetPathStack
import ru.dbotthepony.kvector.vector.Vector2i
import ru.dbotthepony.kvector.vector.Vector4i
import java.util.concurrent.ConcurrentHashMap
/**
* Конфигурация атласа спрайтов, собранный вручную артистом
*
* В файлах игры именуется frames
*
* Несмотря на название, НЕ ЯВЛЯЕТСЯ изображением, а лишь метаданными для *множества* возможных изображений
*/
class AtlasConfiguration private constructor(
/**
* Имя данного атласа (путь к файлу)
*/
val name: String,
/**
* Спрайты данного атласа, включая спрайты под псевдонимами
*/
val sprites: ImmutableMap<String, Sprite>,
/**
* Спрайты данного атласа, в последовательности, в которой они указаны в JSON файле
*/
val spriteList: ImmutableList<Sprite>,
) {
/**
* Первый спрайт, по своему имени (естественная сортировка)
*/
val first: Sprite = sprites[sprites.keys.stream().sorted().findFirst().orElseThrow { NoSuchElementException("No a single key present in $name") }] ?: throw NoSuchElementException("IMPOSSIBRU in $name")
private val intIndexed = Int2ObjectOpenHashMap<Sprite>()
init {
for ((k, v) in sprites.entries) {
val int = k.toIntOrNull()
if (int != null) {
intIndexed[int] = v
}
}
}
/**
* @return [Sprite] если он существует с данным [name], или `null`
*/
operator fun get(name: String): Sprite? {
return sprites[name]
}
/**
* @return [Sprite] если он существует с данным [name], или `null`
*/
operator fun get(name: Int): Sprite? {
return intIndexed[name]
}
/**
* @return [Sprite] если он существует с данным [name], или первый спрайт в атласе
*/
fun any(name: String): Sprite {
return get(name) ?: any()
}
private val any by lazy { get("root") ?: get("0") ?: get("default") ?: first }
fun any(): Sprite {
return any
}
class Sprite(
/**
* Имя данного спрайта, на которое прототипы могут ссылаться
*
* К примеру, если имя будет указано как
*
* **`active.2`**
*
* а сам атлас называется
*
* **`mything.png`**
*
* то прототипы могут ссылаться на данный спрайт как
*
* **`mything.png:active.2`**
*/
val name: String,
/**
* Позиция и размеры данного спрайта, в пикселях
*
* Нулевой размер имеет особое значение - считается, что спрайт покрывает весь атлас
*/
val position: Vector4i,
) {
/**
* Ширина, в пикселях
*
* Нулевой размер имеет особое значение - считается, что спрайт покрывает весь атлас
*/
val width = position.z - position.x
/**
* Высота, в пикселях
*
* Нулевой размер имеет особое значение - считается, что спрайт покрывает весь атлас
*/
val height = position.w - position.y
fun width(atlasWidth: Int): Int {
if (width == 0)
return atlasWidth
return width
}
fun height(atlasHeight: Int): Int {
if (height == 0)
return atlasHeight
return height
}
/**
* Вычисляет uv координаты данного спрайта на заданном полотне
*
* v вычисляется инвентированным, для учёта системы координат OpenGL
*/
fun compute(width: Int, height: Int): UVCoordinates {
require(width > 0) { "Invalid width provided: $width" }
require(height > 0) { "Invalid height provided: $height" }
if (this.width == 0 || this.height == 0) {
return UVCoordinates.FULL_OPENGL
}
return UVCoordinates(
u0 = position.x.toFloat() / width.toFloat(),
v1 = position.y.toFloat() / height.toFloat(),
u1 = position.z.toFloat() / width.toFloat(),
v0 = position.w.toFloat() / height.toFloat(),
)
}
/**
* Вычисляет uv координаты данного спрайта на заданном полотне
*/
fun compute(dimensions: Vector2i): UVCoordinates {
return compute(dimensions.x, dimensions.y)
}
/**
* Вычисляет uv координаты данного спрайта на заданном полотне
*/
fun compute(texture: GLTexture2D): UVCoordinates {
return compute(texture.width, texture.height)
}
override fun toString(): String {
return "FrameGrid.Sprite[name=$name, position=$position]"
}
}
companion object {
val EMPTY: AtlasConfiguration
init {
val sprite = Sprite("root", Vector4i(0, 0, 0, 0))
EMPTY = AtlasConfiguration("null", ImmutableMap.of("root", sprite, "default", sprite, "0", sprite), ImmutableList.of(sprite))
}
private val cache = ConcurrentHashMap<String, AtlasConfiguration>()
private fun generateFakeNames(dimensions: Vector2i): JsonArray {
return JsonArray(dimensions.y).also {
var stripElem = 0
for (stripNum in 0 until dimensions.y) {
val strip = JsonArray(dimensions.x)
for (i in 0 until dimensions.x) {
strip.add(stripElem.toString())
stripElem++
}
it.add(strip)
}
}
}
private fun parseFrames(input: JsonReader, name: String): AtlasConfiguration {
val read = TypeAdapters.JSON_ELEMENT.read(input)
if (read !is JsonObject) {
throw JsonSyntaxException("Expected to have object as top most element, $read given")
}
val frameGrid = read["frameGrid"]
val sprites = LinkedHashMap<String, Sprite>()
if (frameGrid is JsonObject) {
val size = Starbound.gson.fromJson(frameGrid["size"] ?: throw JsonSyntaxException("Missing frameGrid.size"), Vector2i::class.java)
val dimensions = Starbound.gson.fromJson(frameGrid["dimensions"] ?: throw JsonSyntaxException("Missing frameGrid.dimensions"), Vector2i::class.java)
require(size.x >= 0) { "Invalid size.x: ${size.x}" }
require(size.y >= 0) { "Invalid size.y: ${size.y}" }
require(dimensions.x >= 0) { "Invalid dimensions.x: ${dimensions.x}" }
require(dimensions.y >= 0) { "Invalid dimensions.y: ${dimensions.y}" }
val names = (frameGrid["names"] as? JsonArray ?: generateFakeNames(dimensions))
.stream().map { (it as? JsonArray)?.stream()?.map { if (it == JsonNull.INSTANCE) null else it.asString }?.toList() }.toList()
val spriteList = ArrayList<Sprite>()
for ((y, strip) in names.withIndex()) {
// разрешаем вставлять null как ленту кадров, что означает что мы должны пропустить её полностью
if (strip == null)
continue
for ((x, spriteName) in strip.withIndex()) {
// если кадр не имеет имени...
if (spriteName == null)
continue
spriteList.add(Sprite(spriteName, Vector4i(x * size.x, y * size.y, (x + 1) * size.x, (y + 1) * size.y)))
}
}
for (sprite in spriteList)
sprites[sprite.name] = sprite
} else if (frameGrid != null) {
throw JsonSyntaxException("Unexpected frameGrid element: $frameGrid")
} else {
val frameList = read["frameList"] ?: throw JsonSyntaxException("Frame grid must have either frameGrid or frameList object defined")
if (frameList !is JsonObject) {
throw JsonSyntaxException("frameList is not an object")
}
for ((spriteName, coords) in frameList.entrySet()) {
sprites[spriteName] = Sprite(spriteName, Starbound.gson.fromJson(coords, Vector4i::class.java))
}
}
val spriteList = ImmutableList.copyOf(sprites.values)
val aliases = read["aliases"]
if (aliases != null) {
if (aliases !is JsonObject)
throw JsonSyntaxException("aliases expected to be a Json object, $aliases given")
val remainingAliases = Object2ObjectArrayMap<String, String>()
for ((k, v) in aliases.entrySet())
remainingAliases[k] = v.asString
var changes = true
while (remainingAliases.isNotEmpty() && changes) {
changes = false
val i = remainingAliases.entries.iterator()
for ((k, v) in i) {
val sprite = sprites[v] ?: continue
sprites[k] = sprite
changes = true
i.remove()
}
}
for ((k, v) in remainingAliases.entries)
sprites[k] = sprites[v] ?: throw JsonSyntaxException("Alias '$k' want to refer to sprite '$v', but it does not exist")
}
return AtlasConfiguration(name, ImmutableMap.copyOf(sprites), spriteList)
}
private fun recursiveGet(name: String, folder: String): AtlasConfiguration? {
var current = folder
while (current != "/" && current != "") {
val get = cache.computeIfAbsent("$current/$name") {
val file = Starbound.locate("$it.frames")
if (file.exists) {
try {
return@computeIfAbsent parseFrames(JsonReader(file.reader()).also { it.isLenient = true }, "$it.frames")
} catch (err: Throwable) {
throw JsonSyntaxException("Caught an exception while reading frame grid $it.frames", err)
}
}
return@computeIfAbsent EMPTY
}
if (get !== EMPTY) {
return get
}
current = current.substringBeforeLast('/')
}
return null
}
/**
* Пытается найти конфигурацию (файл "frames") атласа для заданного пути (заданного изображения/атласа)
*
* Алгоритм поиска конфигурации таков:
* * Проверяется папка с целевым файлом на наличие файла с таким же именем, но с расширением frames;
* * Если файл не был найден, процесс повторяется переходом в папку выше, пока не будет достигнут корень файловой системы;
* * Если файл не был найден, процесс начинается заново, внутри целевой папки, но уже происходит поиск файла с именем default.frames;
* * Процесс повторяется как в пункте 2 пока не будет найден файл в одной из вышестоящих папок.
*
* Если ни один файл не был найден, то возвращается [EMPTY]
*
* Данная функция кеширует результаты поиска
*
*/
fun get(path: String): AtlasConfiguration {
require(path[0] == '/') { "$path is not an absolute path" }
val folder = path.substringBeforeLast('/').lowercase()
val filename = path.substringAfterLast('/').substringBefore(':').substringBefore('.').lowercase()
val direct = recursiveGet(filename, folder)
if (direct != null) return direct
val default = recursiveGet("default", folder)
if (default != null) return default
return EMPTY
}
}
}

View File

@ -0,0 +1,423 @@
package ru.dbotthepony.kstarbound.defs.image
import com.github.benmanes.caffeine.cache.Cache
import com.github.benmanes.caffeine.cache.Caffeine
import com.google.common.collect.ImmutableList
import com.google.gson.JsonArray
import com.google.gson.JsonNull
import com.google.gson.JsonObject
import com.google.gson.JsonSyntaxException
import com.google.gson.stream.JsonReader
import it.unimi.dsi.fastutil.objects.Object2ObjectArrayMap
import it.unimi.dsi.fastutil.objects.Object2ObjectLinkedOpenHashMap
import org.apache.logging.log4j.LogManager
import org.lwjgl.stb.STBImage
import org.lwjgl.system.MemoryUtil
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNIT
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNITi
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.api.IStarboundFile
import ru.dbotthepony.kstarbound.io.stream2STBIO
import ru.dbotthepony.kstarbound.util.contains
import ru.dbotthepony.kstarbound.util.get
import ru.dbotthepony.kstarbound.util.getObject
import ru.dbotthepony.kvector.vector.Vector2i
import ru.dbotthepony.kvector.vector.Vector4i
import java.io.BufferedInputStream
import java.io.FileNotFoundException
import java.lang.ref.Cleaner
import java.lang.ref.WeakReference
import java.nio.ByteBuffer
import java.time.Duration
import java.util.Collections
import java.util.Optional
import java.util.concurrent.ConcurrentHashMap
import java.util.concurrent.locks.ReentrantLock
class Image private constructor(
val source: IStarboundFile,
val path: String,
val width: Int,
val height: Int,
val amountOfChannels: Int,
sprites: List<DataSprite>?
) {
init {
check(width >= 0) { "Invalid width $width" }
check(height >= 0) { "Invalid height $height" }
check(amountOfChannels in 1 .. 4) { "Unknown number of channels $amountOfChannels" }
}
private val spritesInternal = Object2ObjectLinkedOpenHashMap<String, Sprite>()
private var dataRef: WeakReference<ByteBuffer>? = null
private val lock = ReentrantLock()
init {
if (sprites == null) {
this.spritesInternal["default"] = Sprite("default", 0, 0, width, height)
} else {
for (data in sprites) {
this.spritesInternal[data.name] = Sprite(
data.name,
data.coordinates.x,
data.coordinates.y,
data.coordinates.z - data.coordinates.x,
data.coordinates.w - data.coordinates.y)
}
}
}
val data: ByteBuffer get() {
var get = dataRef?.get()
if (get != null)
return get
lock.lock()
try {
get = dataRef?.get()
if (get != null)
return get
get = dataCache.get(path) {
val getWidth = intArrayOf(0)
val getHeight = intArrayOf(0)
val components = intArrayOf(0)
val data = STBImage.stbi_load_from_memory(
source.readDirect(),
getWidth, getHeight,
components, 0
) ?: throw IllegalArgumentException("File $source is not an image or it is corrupted")
val address = MemoryUtil.memAddress(data)
cleaner.register(data) { STBImage.nstbi_image_free(address) }
check(getWidth[0] == width && getHeight[0] == height && components[0] == amountOfChannels) {
"Actual loaded image differs from constructed (this $width x $height with $amountOfChannels channels; loaded ${getWidth[0]} x ${getHeight[0]} with ${components[0]} channels)"
}
data
}
dataRef = WeakReference(get)
return get
} finally {
lock.unlock()
}
}
val size = Vector2i(width, height)
val sprites: Map<String, Sprite> = Collections.unmodifiableMap(this.spritesInternal)
val first: Sprite = this.spritesInternal.values.first()
val whole = Sprite("this", 0, 0, width, height)
val nonEmptyRegion get() = whole.nonEmptyRegion
operator fun get(x: Int, y: Int): Int {
return whole[x, y]
}
operator fun get(x: Int, y: Int, flip: Boolean): Int {
return whole[x, y, flip]
}
operator fun get(name: String): Sprite? {
return spritesInternal[name]
}
fun isTransparent(x: Int, y: Int, flip: Boolean): Boolean {
return whole.isTransparent(x, y, flip)
}
fun worldSpaces(pixelOffset: Vector2i, spaceScan: Double, flip: Boolean): List<Vector2i> {
return whole.worldSpaces(pixelOffset, spaceScan, flip)
}
private data class DataSprite(val name: String, val coordinates: Vector4i)
inner class Sprite(val name: String, val x: Int, val y: Int, val width: Int, val height: Int) : IUVCoordinates {
// flip coordinates to account for opengl
override val u0: Float = x.toFloat() / this@Image.width
override val v1: Float = y.toFloat() / this@Image.height
override val u1: Float = (x.toFloat() + this.width.toFloat()) / this@Image.width
override val v0: Float = (y.toFloat() + this.height.toFloat()) / this@Image.height
operator fun get(x: Int, y: Int): Int {
require(x in 0 until width && y in 0 until height) { "Position out of bounds: $x $y" }
val offset = (this.y + y) * this@Image.width * amountOfChannels + (this.x + x) * amountOfChannels
val data = data
when (amountOfChannels) {
4 -> return data[offset].toInt() or
data[offset + 1].toInt().shl(8) or
data[offset + 2].toInt().shl(16) or
data[offset + 3].toInt().shl(24)
3 -> return data[offset].toInt() or
data[offset + 1].toInt().shl(8) or
data[offset + 2].toInt().shl(16)
2 -> return data[offset].toInt() or
data[offset + 1].toInt().shl(8)
1 -> return data[offset].toInt()
else -> throw IllegalStateException()
}
}
operator fun get(x: Int, y: Int, flip: Boolean): Int {
if (flip) {
require(x in 0 until width && y in 0 until height) { "Position out of bounds: $x $y" }
return this[width - x - 1, y]
} else {
return this[x, y]
}
}
fun isTransparent(x: Int, y: Int, flip: Boolean): Boolean {
if (x !in 0 until width) return true
if (y !in 0 until height) return true
if (amountOfChannels != 4) return false
return this[x, y, flip] and 0xFF != 0x0
}
val nonEmptyRegion by lazy {
if (amountOfChannels == 4) {
var x0 = 0
var y0 = 0
search@for (y in 0 until height) {
for (x in 0 until width) {
if (this[x, y] and 0xFF != 0x0) {
x0 = x
y0 = y
break@search
}
}
}
var x1 = x0
var y1 = y0
search@for (y in height - 1 downTo y0) {
for (x in width - 1 downTo x0) {
if (this[x, y] and 0xFF != 0x0) {
x1 = x
y1 = y
break@search
}
}
}
return@lazy Vector4i(x0, y0, x1, y1)
}
Vector4i(0, 0, width, height)
}
fun worldSpaces(pixelOffset: Vector2i, spaceScan: Double, flip: Boolean): List<Vector2i> {
if (amountOfChannels != 3 && amountOfChannels != 4) throw IllegalStateException("Can not check world space taken by image with $amountOfChannels color channels")
val xDivL = pixelOffset.x % PIXELS_IN_STARBOUND_UNITi
val yDivB = pixelOffset.y % PIXELS_IN_STARBOUND_UNITi
val xDivR = (pixelOffset.x + width) % PIXELS_IN_STARBOUND_UNITi
val yDivT = (pixelOffset.y + height) % PIXELS_IN_STARBOUND_UNITi
val leftMostX = pixelOffset.x / PIXELS_IN_STARBOUND_UNITi - (if (xDivL != 0) 1 else 0)
val bottomMostY = pixelOffset.y / PIXELS_IN_STARBOUND_UNITi - (if (yDivB != 0) 1 else 0)
val rightMostX = (pixelOffset.x + width) / PIXELS_IN_STARBOUND_UNITi + (if (xDivR != 0) 1 else 0)
val topMostY = (pixelOffset.y + height) / PIXELS_IN_STARBOUND_UNITi + (if (yDivT != 0) 1 else 0)
val result = ArrayList<Vector2i>()
for (y in bottomMostY .. topMostY) {
for (x in leftMostX .. rightMostX) {
val left = x * PIXELS_IN_STARBOUND_UNITi
val bottom = y * PIXELS_IN_STARBOUND_UNITi
var transparentPixels = 0
for (sX in 0 until PIXELS_IN_STARBOUND_UNITi) {
for (sY in 0 until PIXELS_IN_STARBOUND_UNITi) {
if (isTransparent(xDivL + sX + left, yDivB + sY + bottom, flip)) {
transparentPixels++
}
}
}
if (transparentPixels * FILL_RATIO >= spaceScan) {
result.add(Vector2i(x, y))
}
}
}
return result
}
}
companion object {
const val FILL_RATIO = 1 / (PIXELS_IN_STARBOUND_UNIT * PIXELS_IN_STARBOUND_UNIT)
private val objects by lazy { Starbound.gson.getAdapter(JsonObject::class.java) }
private val vectors by lazy { Starbound.gson.getAdapter(Vector4i::class.java) }
private val vectors2 by lazy { Starbound.gson.getAdapter(Vector2i::class.java) }
private val cache = ConcurrentHashMap<String, Optional<List<DataSprite>>>()
private val imageCache = ConcurrentHashMap<String, Optional<Image>>()
private val logger = LogManager.getLogger()
private val cleaner = Cleaner.create { Thread(it, "STB Image Cleaner") }
private val dataCache: Cache<String, ByteBuffer> = Caffeine.newBuilder()
.softValues()
.expireAfterAccess(Duration.ofMinutes(20))
.weigher<String, ByteBuffer> { key, value -> value.capacity() }
.maximumWeight(1_024L * 1_024L * 256L /* 256 МиБ */)
.build()
@JvmStatic
fun get(path: String): Image? {
return imageCache.computeIfAbsent(path) {
try {
val file = Starbound.locate(it)
if (!file.exists) {
throw FileNotFoundException("No such file $it")
}
if (!file.isFile) {
throw FileNotFoundException("File $it is a directory")
}
val getWidth = intArrayOf(0)
val getHeight = intArrayOf(0)
val components = intArrayOf(0)
val status = STBImage.stbi_info_from_callbacks(
stream2STBIO(BufferedInputStream(file.open())), 0L,
getWidth, getHeight,
components
)
if (!status)
throw IllegalArgumentException("File $file is not an image or it is corrupted")
Optional.of(Image(file, it, getWidth[0], getHeight[0], components[0], getConfig(it)))
} catch (err: Exception) {
logger.error("Failed to load image at path $it", err)
Optional.empty()
}
}.orElse(null)
}
private fun generateFakeNames(dimensions: Vector2i): JsonArray {
return JsonArray(dimensions.y).also {
var stripElem = 0
for (stripNum in 0 until dimensions.y) {
val strip = JsonArray(dimensions.x)
for (i in 0 until dimensions.x) {
strip.add(stripElem.toString())
stripElem++
}
it.add(strip)
}
}
}
private fun parseFrames(read: JsonObject): List<DataSprite> {
val begin = read.get("begin", vectors2) { Vector2i.ZERO }
val sprites = LinkedHashMap<String, DataSprite>()
if ("frameGrid" in read) {
val frameGrid = read.getObject("frameGrid")
val size = vectors2.fromJsonTree(frameGrid["size"] ?: throw JsonSyntaxException("Missing frameGrid.size"))
val dimensions = vectors2.fromJsonTree(frameGrid["dimensions"] ?: throw JsonSyntaxException("Missing frameGrid.dimensions"))
require(size.x >= 0 && size.y >= 0) { "Invalid size: $size" }
require(dimensions.x > 0 && dimensions.y > 0) { "Invalid dimensions: $dimensions" }
val names = (frameGrid.get("names") { generateFakeNames(dimensions) })
.map { (it as? JsonArray)?.map { if (it == JsonNull.INSTANCE) null else it.asString } }.toList()
for ((y, strip) in names.withIndex()) {
// разрешаем вставлять null как ленту кадров, что означает что мы должны пропустить её полностью
if (strip == null) continue
for ((x, spriteName) in strip.withIndex()) {
// если кадр не имеет имени...
if (spriteName == null) continue
require(y < dimensions.y && x < dimensions.x) { "Sprite at $x $y is out of bounds for frame grid with dimensions of $dimensions" }
sprites[spriteName] = DataSprite(spriteName, Vector4i(begin.x + x * size.x, begin.y + y * size.y, begin.x + (x + 1) * size.x, begin.y + (y + 1) * size.y))
}
}
}
if ("frameList" in read) {
for ((spriteName, coords) in read.getObject("frameList").entrySet()) {
sprites[spriteName] = DataSprite(spriteName, vectors.fromJsonTree(coords))
}
}
val aliases = Object2ObjectArrayMap<String, String>()
for ((k, v) in read.get("aliases") { JsonObject() }.entrySet())
aliases[k] = v.asString
var changes = true
while (aliases.isNotEmpty() && changes) {
changes = false
val i = aliases.entries.iterator()
for ((k, v) in i) {
require(k !in sprites) { "Sprite with name '$k' already defined" }
val sprite = sprites[v] ?: continue
sprites[k] = sprite.copy(name = k)
changes = true
i.remove()
}
}
for ((k, v) in aliases.entries)
throw JsonSyntaxException("Alias '$k' want to refer to sprite '$v', but it does not exist")
return ImmutableList.copyOf(sprites.values)
}
private fun compute(it: String): Optional<List<DataSprite>> {
val find = Starbound.locate("$it.frames")
if (!find.exists) {
return Optional.empty()
} else {
return Optional.of(parseFrames(objects.read(JsonReader(find.reader()).also { it.isLenient = true })))
}
}
private fun getConfig(path: String): List<DataSprite>? {
var folder = path.substringBefore(':').substringBeforeLast('/')
val name = path.substringBefore(':').substringAfterLast('/').substringBefore('.')
while (true) {
val find = cache.computeIfAbsent("$folder/$name", ::compute).or { cache.computeIfAbsent("$folder/default", ::compute) }
if (find.isPresent)
return find.get()
folder = folder.substringBeforeLast('/')
if (folder.isEmpty()) return null
}
}
}
}

View File

@ -1,123 +0,0 @@
package ru.dbotthepony.kstarbound.defs.image
import com.google.gson.Gson
import com.google.gson.JsonSyntaxException
import com.google.gson.TypeAdapter
import com.google.gson.TypeAdapterFactory
import com.google.gson.reflect.TypeToken
import com.google.gson.stream.JsonReader
import com.google.gson.stream.JsonToken
import com.google.gson.stream.JsonWriter
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.defs.AssetPath
import ru.dbotthepony.kstarbound.io.json.consumeNull
import ru.dbotthepony.kstarbound.util.AssetPathStack
import ru.dbotthepony.kstarbound.util.SBPattern
/**
* @see [AtlasConfiguration.Companion.get]
*/
class ImageReference private constructor(
val raw: AssetPath,
val imagePath: SBPattern,
val spritePath: SBPattern?,
val atlas: AtlasConfiguration?,
) {
/**
* Спрайт, на которое ссылается данный референс, или `null` если:
* * [atlas] равен `null`
* * [spritePath] является шаблоном и определены не все значения
* * [spritePath] не является правильным именем спрайта внутри [atlas] (смотрим [AtlasConfiguration.get])
*/
val sprite by lazy {
if (atlas == null)
null
else if (spritePath == null)
atlas.any()
else
atlas[spritePath.value ?: return@lazy null]
}
fun with(values: (String) -> String?): ImageReference {
val imagePath = this.imagePath.with(values)
var spritePath = this.spritePath?.with(values)
if (spritePath == null) {
val frame = values.invoke("frame")
if (frame != null) {
spritePath = SBPattern.FRAME.with(values)
}
}
if (imagePath != this.imagePath || spritePath != this.spritePath) {
if (imagePath != this.imagePath) {
val resolved = imagePath.value
if (resolved == null)
return ImageReference(raw, imagePath, spritePath, null)
else
return ImageReference(raw, imagePath, spritePath, AtlasConfiguration.get(resolved))
} else {
return ImageReference(raw, imagePath, spritePath, atlas)
}
}
return this
}
fun with(values: Map<String, String>): ImageReference {
return with(values::get)
}
override fun equals(other: Any?): Boolean {
return other is ImageReference && other.imagePath == imagePath && other.spritePath == spritePath && other.atlas == atlas
}
override fun hashCode(): Int {
return imagePath.hashCode() * 31 + spritePath.hashCode()
}
override fun toString(): String {
return "ImageReference[$imagePath:$spritePath]"
}
companion object : TypeAdapter<ImageReference>() {
val NEVER = ImageReference(AssetPath("", ""), SBPattern.EMPTY, null, null)
private val strings by lazy { Starbound.gson.getAdapter(String::class.java) }
override fun write(out: JsonWriter, value: ImageReference?) {
out.value(value?.raw?.fullPath)
}
@JvmStatic
fun create(path: String): ImageReference {
if (path == "")
return NEVER
val split = path.split(':')
if (split.size > 2) {
throw JsonSyntaxException("Ambiguous image reference: $path")
}
val imagePath = if (split.size == 2) SBPattern.of(split[0]) else SBPattern.of(path)
val spritePath = if (split.size == 2) SBPattern.of(split[1]) else null
if (imagePath.isPlainString) {
val remapped = AssetPathStack.remap(split[0])
return ImageReference(AssetPath(path, AssetPathStack.remap(path)), SBPattern.raw(remapped), spritePath, AtlasConfiguration.get(remapped))
} else {
return ImageReference(AssetPath(path, path), imagePath, spritePath, null)
}
}
override fun read(`in`: JsonReader): ImageReference? {
if (`in`.consumeNull())
return null
return create(strings.read(`in`))
}
}
}

View File

@ -0,0 +1,102 @@
package ru.dbotthepony.kstarbound.defs.image
import com.google.gson.JsonSyntaxException
import com.google.gson.TypeAdapter
import com.google.gson.stream.JsonReader
import com.google.gson.stream.JsonWriter
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.defs.AssetPath
import ru.dbotthepony.kstarbound.io.json.consumeNull
import ru.dbotthepony.kstarbound.util.AssetPathStack
import ru.dbotthepony.kstarbound.util.SBPattern
class SpriteReference private constructor(
val raw: AssetPath,
val imagePath: SBPattern,
val spritePath: SBPattern?,
val image: Image?,
) {
val sprite by lazy {
if (image == null)
null
else if (spritePath == null)
image.first
else
image[spritePath.value ?: return@lazy null]
}
fun with(values: (String) -> String?): SpriteReference {
val imagePath = this.imagePath.with(values)
val spritePath = this.spritePath?.with(values)
if (imagePath != this.imagePath || spritePath != this.spritePath) {
if (imagePath != this.imagePath) {
val resolved = imagePath.value
if (resolved == null)
return SpriteReference(raw, imagePath, spritePath, null)
else
return SpriteReference(raw, imagePath, spritePath, Image.get(resolved))
} else {
return SpriteReference(raw, imagePath, spritePath, image)
}
}
return this
}
fun with(values: Map<String, String>): SpriteReference {
return with(values::get)
}
override fun equals(other: Any?): Boolean {
return other is SpriteReference && other.imagePath == imagePath && other.spritePath == spritePath && other.image == image
}
override fun hashCode(): Int {
return imagePath.hashCode() * 31 + spritePath.hashCode()
}
override fun toString(): String {
return "SpriteReference[$imagePath:$spritePath]"
}
companion object : TypeAdapter<SpriteReference>() {
val NEVER = SpriteReference(AssetPath("", ""), SBPattern.EMPTY, null, null)
private val strings by lazy { Starbound.gson.getAdapter(String::class.java) }
override fun write(out: JsonWriter, value: SpriteReference?) {
out.value(value?.raw?.fullPath)
}
@JvmStatic
fun create(path: String): SpriteReference {
if (path == "")
return NEVER
val split = path.split(':')
if (split.size > 2) {
throw JsonSyntaxException("Ambiguous image reference: $path")
}
val imagePath = if (split.size == 2) SBPattern.of(split[0]) else SBPattern.of(path)
val spritePath = if (split.size == 2) SBPattern.of(split[1]) else null
if (imagePath.isPlainString) {
val remapped = AssetPathStack.remap(split[0])
return SpriteReference(AssetPath(path, AssetPathStack.remap(path)), SBPattern.raw(remapped), spritePath, Image.get(remapped))
} else {
return SpriteReference(AssetPath(path, path), imagePath, spritePath, null)
}
}
override fun read(`in`: JsonReader): SpriteReference? {
if (`in`.consumeNull())
return null
return create(strings.read(`in`))
}
}
}

View File

@ -1,9 +1,9 @@
package ru.dbotthepony.kstarbound.defs.item
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.builder.JsonImplementation
@JsonImplementation(InventoryIcon::class)
interface IInventoryIcon {
val image: ImageReference
val image: SpriteReference
}

View File

@ -1,26 +1,23 @@
package ru.dbotthepony.kstarbound.defs.item
import com.google.gson.Gson
import com.google.gson.JsonPrimitive
import com.google.gson.TypeAdapter
import com.google.gson.TypeAdapterFactory
import com.google.gson.internal.bind.JsonTreeReader
import com.google.gson.reflect.TypeToken
import com.google.gson.stream.JsonReader
import com.google.gson.stream.JsonToken
import com.google.gson.stream.JsonWriter
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.builder.FactoryAdapter
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
import ru.dbotthepony.kstarbound.util.AssetPathStack
data class InventoryIcon(
override val image: ImageReference
override val image: SpriteReference
) : IInventoryIcon {
companion object : TypeAdapter<InventoryIcon>() {
private val adapter by lazy { FactoryAdapter.createFor(InventoryIcon::class, JsonFactory(), Starbound.gson) }
private val images by lazy { Starbound.gson.getAdapter(ImageReference::class.java) }
private val images by lazy { Starbound.gson.getAdapter(SpriteReference::class.java) }
override fun write(out: JsonWriter, value: InventoryIcon?) {
if (value == null)

View File

@ -7,7 +7,7 @@ import com.google.gson.reflect.TypeToken
import com.google.gson.stream.JsonReader
import com.google.gson.stream.JsonToken
import com.google.gson.stream.JsonWriter
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.builder.FactoryAdapter
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
import ru.dbotthepony.kstarbound.io.json.builder.JsonImplementation
@ -30,15 +30,15 @@ interface IArmorItemDefinition : ILeveledItemDefinition, IScriptableItemDefiniti
@JsonImplementation(Frames::class)
interface IFrames {
val body: ImageReference
val backSleeve: ImageReference?
val frontSleeve: ImageReference?
val body: SpriteReference
val backSleeve: SpriteReference?
val frontSleeve: SpriteReference?
}
data class Frames(
override val body: ImageReference,
override val backSleeve: ImageReference? = null,
override val frontSleeve: ImageReference? = null,
override val body: SpriteReference,
override val backSleeve: SpriteReference? = null,
override val frontSleeve: SpriteReference? = null,
) : IFrames {
object Factory : TypeAdapterFactory {
override fun <T : Any?> create(gson: Gson, type: TypeToken<T>): TypeAdapter<T>? {
@ -46,7 +46,7 @@ interface IArmorItemDefinition : ILeveledItemDefinition, IScriptableItemDefiniti
return object : TypeAdapter<Frames>() {
private val adapter = FactoryAdapter.createFor(Frames::class, JsonFactory(), gson)
private val frames = gson.getAdapter(ImageReference::class.java)
private val frames = gson.getAdapter(SpriteReference::class.java)
override fun write(out: JsonWriter, value: Frames?) {
adapter.write(out, value)

View File

@ -2,14 +2,14 @@ package ru.dbotthepony.kstarbound.defs.monster
import com.google.common.collect.ImmutableMap
import com.google.gson.JsonElement
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
@JsonFactory
data class MonsterSkillDefinition(
val name: String,
val label: String? = null,
val image: ImageReference? = null,
val image: SpriteReference? = null,
val config: ImmutableMap<String, JsonElement> = ImmutableMap.of(),
val animationParameters: ImmutableMap<String, JsonElement> = ImmutableMap.of(),
)

View File

@ -148,21 +148,11 @@ data class ObjectOrientation(
if (drawable is Drawable.Image) {
val bound = drawable.path.with { "default" }
val sprite = bound.sprite ?: throw IllegalStateException("Not a valid sprite reference: ${bound.raw} (${bound.imagePath} / ${bound.spritePath})")
val image = Starbound.imageData(bound.imagePath.value ?: throw IllegalStateException("Incomplete image path: ${bound.imagePath}"))
val width = sprite.width(image.width)
val height = sprite.height(image.height)
if (width != image.width || height != image.height) {
//throw NotImplementedError("Space scan of sprite is not supported yet")
occupySpaces = ImmutableSet.of()
} else {
val new = ImmutableSet.Builder<Vector2i>()
new.addAll(occupySpaces)
new.addAll(image.worldSpaces(imagePositionI, obj["spaceScan"].asDouble, flipImages))
occupySpaces = new.build()
}
val new = ImmutableSet.Builder<Vector2i>()
new.addAll(occupySpaces)
new.addAll(sprite.worldSpaces(imagePositionI, obj["spaceScan"].asDouble, flipImages))
occupySpaces = new.build()
}
}
} catch (err: Throwable) {

View File

@ -3,7 +3,7 @@ package ru.dbotthepony.kstarbound.defs.particle
import ru.dbotthepony.kstarbound.defs.AssetReference
import ru.dbotthepony.kstarbound.defs.animation.AnimationDefinition
import ru.dbotthepony.kstarbound.defs.animation.DestructionAction
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
import ru.dbotthepony.kstarbound.util.SBPattern
import ru.dbotthepony.kvector.vector.RGBAColor
@ -14,7 +14,7 @@ import ru.dbotthepony.kvector.vector.Vector4d
data class ParticleConfig(
val type: ParticleType,
val animation: AssetReference<AnimationDefinition>? = null,
val image: ImageReference? = null,
val image: SpriteReference? = null,
override val offset: Vector2d? = null,
override val position: Vector2d? = null,
override val offsetRegion: Vector4d? = null,

View File

@ -1,13 +1,13 @@
package ru.dbotthepony.kstarbound.defs.tile
import ru.dbotthepony.kstarbound.defs.image.ImageReference
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.io.json.builder.JsonFactory
import ru.dbotthepony.kstarbound.io.json.builder.JsonNotNull
@JsonFactory
data class RenderParameters(
@JsonNotNull
val texture: ImageReference?,
val texture: SpriteReference?,
val variants: Int = 0,
val multiColored: Boolean = false,
val occludesBelow: Boolean = false,

View File

@ -1,145 +0,0 @@
package ru.dbotthepony.kstarbound.io
import org.lwjgl.stb.STBImage
import org.lwjgl.system.MemoryUtil.memAddress
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNIT
import ru.dbotthepony.kstarbound.PIXELS_IN_STARBOUND_UNITi
import ru.dbotthepony.kvector.vector.Vector2i
import ru.dbotthepony.kvector.vector.Vector4i
import java.lang.ref.Cleaner
import java.nio.ByteBuffer
private val cleaner = Cleaner.create { Thread(it, "STB Image Cleaner") }
class ImageData(val data: ByteBuffer, val width: Int, val height: Int, val amountOfChannels: Int) {
init {
val address = memAddress(data)
cleaner.register(data) { STBImage.nstbi_image_free(address) }
check(width >= 0) { "Invalid width $width" }
check(height >= 0) { "Invalid height $height" }
check(amountOfChannels in 1 .. 4) { "Unknown number of channels $amountOfChannels" }
}
operator fun get(x: Int, y: Int): Int {
require(x in 0 until width) { "X out of bounds: $x" }
require(y in 0 until height) { "Y out of bounds: $y" }
val offset = y * width * amountOfChannels + x * amountOfChannels
when (amountOfChannels) {
4 -> return data[offset].toInt() or
data[offset + 1].toInt().shl(8) or
data[offset + 2].toInt().shl(16) or
data[offset + 3].toInt().shl(24)
3 -> return data[offset].toInt() or
data[offset + 1].toInt().shl(8) or
data[offset + 2].toInt().shl(16)
2 -> return data[offset].toInt() or
data[offset + 1].toInt().shl(8)
1 -> return data[offset].toInt()
else -> throw IllegalStateException()
}
}
operator fun get(x: Int, y: Int, flip: Boolean): Int {
require(x in 0 until width) { "X out of bounds: $x" }
require(y in 0 until height) { "Y out of bounds: $y" }
if (flip) {
return this[width - x - 1, y]
} else {
return this[x, y]
}
}
fun isTransparent(x: Int, y: Int, flip: Boolean): Boolean {
if (x !in 0 until width) return true
if (y !in 0 until height) return true
if (amountOfChannels != 4) return false
return this[x, y, flip] and 0xFF != 0x0
}
fun worldSpaces(pixelOffset: Vector2i, spaceScan: Double, flip: Boolean): List<Vector2i> {
if (amountOfChannels != 3 && amountOfChannels != 4) throw IllegalStateException("Can not check world space taken by image with $amountOfChannels color channels")
val xDivL = pixelOffset.x % PIXELS_IN_STARBOUND_UNITi
val yDivB = pixelOffset.y % PIXELS_IN_STARBOUND_UNITi
val xDivR = (pixelOffset.x + width) % PIXELS_IN_STARBOUND_UNITi
val yDivT = (pixelOffset.y + height) % PIXELS_IN_STARBOUND_UNITi
val leftMostX = pixelOffset.x / PIXELS_IN_STARBOUND_UNITi - (if (xDivL != 0) 1 else 0)
val bottomMostY = pixelOffset.y / PIXELS_IN_STARBOUND_UNITi - (if (yDivB != 0) 1 else 0)
val rightMostX = (pixelOffset.x + width) / PIXELS_IN_STARBOUND_UNITi + (if (xDivR != 0) 1 else 0)
val topMostY = (pixelOffset.y + height) / PIXELS_IN_STARBOUND_UNITi + (if (yDivT != 0) 1 else 0)
val result = ArrayList<Vector2i>()
for (y in bottomMostY .. topMostY) {
for (x in leftMostX .. rightMostX) {
val left = x * PIXELS_IN_STARBOUND_UNITi
val bottom = y * PIXELS_IN_STARBOUND_UNITi
var transparentPixels = 0
for (sX in 0 until PIXELS_IN_STARBOUND_UNITi) {
for (sY in 0 until PIXELS_IN_STARBOUND_UNITi) {
if (isTransparent(xDivL + sX + left, yDivB + sY + bottom, flip)) {
transparentPixels++
}
}
}
if (transparentPixels * FILL_RATIO >= spaceScan) {
result.add(Vector2i(x, y))
}
}
}
return result
}
val nonEmptyRegion by lazy {
if (amountOfChannels == 4) {
var x0 = 0
var y0 = 0
search@for (y in 0 until height) {
for (x in 0 until width) {
if (this[x, y] and 0xFF != 0x0) {
x0 = x
y0 = y
break@search
}
}
}
var x1 = x0
var y1 = y0
search@for (y in height - 1 downTo y0) {
for (x in width - 1 downTo x0) {
if (this[x, y] and 0xFF != 0x0) {
x1 = x
y1 = y
break@search
}
}
}
return@lazy Vector4i(x0, y0, x1, y1)
}
Vector4i(0, 0, width, height)
}
companion object {
const val FILL_RATIO = 1 / (PIXELS_IN_STARBOUND_UNIT * PIXELS_IN_STARBOUND_UNIT)
}
}

View File

@ -0,0 +1,38 @@
package ru.dbotthepony.kstarbound.io
import org.lwjgl.stb.STBIEOFCallback
import org.lwjgl.stb.STBIIOCallbacks
import org.lwjgl.stb.STBIReadCallback
import org.lwjgl.stb.STBIReadCallbackI
import org.lwjgl.stb.STBISkipCallback
import org.lwjgl.system.MemoryUtil
import java.io.InputStream
fun stream2STBIO(stream: InputStream): STBIIOCallbacks {
require(stream.markSupported()) { "Provided stream must support mark" }
val callback = STBIIOCallbacks.create()
val read = STBIReadCallback.create(STBIReadCallbackI { _, buf, size ->
val readBuf = ByteArray(size)
val read = stream.read(readBuf)
for (i in 0 until read) {
MemoryUtil.memPutByte(buf + i, readBuf[i])
}
return@STBIReadCallbackI read
})
val skip = STBISkipCallback.create { _, n -> stream.skip(n.toLong()) }
val eof = STBIEOFCallback.create {
stream.mark(1)
val empty = stream.read() == -1
stream.reset()
if (empty) 1 else 0
}
callback.set(read, skip, eof)
return callback
}

View File

@ -14,6 +14,7 @@ import com.google.gson.stream.JsonWriter
import it.unimi.dsi.fastutil.objects.Object2ObjectArrayMap
import it.unimi.dsi.fastutil.objects.ObjectOpenHashSet
import org.apache.logging.log4j.LogManager
import ru.dbotthepony.kstarbound.util.sbIntern
import java.util.Arrays
import java.util.stream.Stream
import kotlin.reflect.KClass
@ -65,20 +66,20 @@ class EnumAdapter<T : Enum<T>>(private val enum: KClass<T>, values: Stream<T> =
val builder = Object2ObjectArrayMap<String, T>()
for (value in this.values) {
builder[value.name] = value
builder[value.name.uppercase()] = value
builder[value.name.lowercase()] = value
builder[value.name.sbIntern()] = value
builder[value.name.uppercase().sbIntern()] = value
builder[value.name.lowercase().sbIntern()] = value
val spaced = value.name.replace('_', ' ')
val stitched = value.name.replace("_", "")
val spaced = value.name.replace('_', ' ').sbIntern()
val stitched = value.name.replace("_", "").sbIntern()
builder[spaced] = value
builder[spaced.uppercase()] = value
builder[spaced.lowercase()] = value
builder[spaced.sbIntern()] = value
builder[spaced.uppercase().sbIntern()] = value
builder[spaced.lowercase().sbIntern()] = value
builder[stitched] = value
builder[stitched.uppercase()] = value
builder[stitched.lowercase()] = value
builder[stitched.sbIntern()] = value
builder[stitched.uppercase().sbIntern()] = value
builder[stitched.lowercase().sbIntern()] = value
}
mapping = ImmutableMap.copyOf(builder)

View File

@ -135,3 +135,15 @@ fun JsonObject.getObject(key: String): JsonObject {
if (!has(key)) throw JsonSyntaxException("Expected object at $key, got nothing")
return this[key] as? JsonObject ?: throw JsonSyntaxException("Expected object at $key, got ${this[key]}")
}
inline fun <reified T : JsonElement> JsonObject.get(key: String, orElse: () -> T): T {
if (!has(key))
return orElse.invoke()
val value = this[key]
if (value !is T)
throw JsonSyntaxException("Expected ${T::class.java.simpleName} at $key; got ${value::class.simpleName} ($value)")
return value
}

View File

@ -0,0 +1,245 @@
package ru.dbotthepony.kstarbound.util
import com.github.benmanes.caffeine.cache.Interner
import it.unimi.dsi.fastutil.HashCommon
import it.unimi.dsi.fastutil.objects.ObjectArrayList
import ru.dbotthepony.kstarbound.stream
import java.lang.ref.ReferenceQueue
import java.lang.ref.WeakReference
import java.util.concurrent.locks.LockSupport
import java.util.stream.StreamSupport
class HashTableInterner<T : Any>(private val segmentBits: Int) : Interner<T> {
companion object {
private val interners = ArrayList<WeakReference<HashTableInterner<*>>>()
private fun run() {
var wait = 1_000_000L
val minWait = 1_000_000L
val maxWait = 1_000_000_000L
while (true) {
var any = 0
synchronized(interners) {
val i = interners.iterator()
for (v in i) {
val get = v.get()
if (get == null) {
i.remove()
} else {
for (segment in get.segments) {
synchronized(segment) {
any += segment.cleanup()
}
}
}
}
}
if (any != 0) {
wait = (wait - 1_000_000L * any).coerceAtLeast(minWait)
} else {
wait = (wait + 1_000_000L).coerceAtMost(maxWait)
}
LockSupport.parkNanos(wait)
}
}
private val thread = Thread(::run, "Interner Cleanup")
init {
thread.priority = 2
thread.isDaemon = true
thread.start()
}
}
class Ref<T : Any>(referent: T, queue: ReferenceQueue<T>) : WeakReference<T>(referent, queue), Iterable<Ref<T>> {
val hash = referent.hashCode()
var nextEntry: Ref<T>? = null
override fun hashCode(): Int {
return hash
}
override fun equals(other: Any?): Boolean {
return other === this
}
fun insert(value: Ref<T>) {
var current = this
while (current.nextEntry != null) {
current = current.nextEntry!!
}
current.nextEntry = value
}
fun remove(value: Ref<T>): Boolean {
var current = this
while (true) {
if (current.nextEntry === value) {
current.nextEntry = current.nextEntry!!.nextEntry
return true
} else if (current.nextEntry == null) {
return false
} else {
current = current.nextEntry!!
}
}
}
override fun iterator(): Iterator<Ref<T>> {
return object : Iterator<Ref<T>> {
private var next: Ref<T>? = this@Ref
override fun hasNext(): Boolean {
return next != null
}
override fun next(): Ref<T> {
val next = next ?: throw NoSuchElementException()
this.next = next.nextEntry
return next
}
}
}
}
private val actualSegmentBits: Int
init {
var result = 0
for (i in 0 until segmentBits) {
result = result or (1.shl(i))
}
actualSegmentBits = result
}
private val segments: Array<Segment> = Array(1.shl(segmentBits)) { Segment() }
init {
synchronized(interners) {
interners.add(WeakReference(this))
}
}
// chained linking hash table backed by plain array
// while this increase memory usage (linked list), this greatly
// simplify logic, and make scanning a bit faster because we don't jump to neighbour nodes
// (assuming past our neighbour there is no such key)
private inner class Segment : Interner<T> {
private var mask = 31
private var mem = arrayOfNulls<Ref<T>>(32)
private var stored = 0
private val queue = ReferenceQueue<T>()
fun cleanup(): Int {
var any = 0
while (true) {
val p = queue.poll() as Ref<T>? ?: return any
remove(p)
any++
}
}
private fun hash(e: Any): Int {
return HashCommon.mix(e.hashCode().rotateRight(segmentBits)) and mask
}
private fun grow() {
mask = (mask shl 1) or 1
val old = mem.stream()
.filter { it != null }
.flatMap { ObjectArrayList(it!!.iterator()).stream() }
.filter { !it.refersTo(null) }
.collect(ObjectArrayList.toList())
for (elem in old) {
elem.nextEntry = null
}
mem = arrayOfNulls(mem.size shl 1)
val mem = mem
for (elem in old) {
val ehash = hash(elem)
val existing = mem[ehash]
if (existing == null) {
mem[ehash] = elem
} else {
existing.insert(elem)
}
}
}
fun remove(ref: Ref<T>): Boolean {
val hash = hash(ref)
val mem = mem
val search = mem[hash]
if (search == null) {
return false
} else if (search === ref) {
mem[hash] = search.nextEntry
check(--stored >= 0) { "Stored count turned negative" }
return true
} else {
return search.remove(ref).also {
if (it) check(--stored >= 0) { "Stored count turned negative" }
}
}
}
override fun intern(sample: T): T {
if (stored >= mem.size * 0.75f) grow()
val mem = mem
val hash = hash(sample)
var search = mem[hash]
while (search != null) {
val get = search.get()
if (get == sample)
return get
else if (get == null) {
check(remove(search)) { "Unable to remove null entry $search at hash $hash" }
search = search.nextEntry
} else {
search = search.nextEntry
}
}
val ref = Ref(sample, queue)
val existing = mem[hash]
if (existing == null)
mem[hash] = ref
else
existing.insert(ref)
stored++
return sample
}
}
override fun intern(sample: T): T {
val hash = HashCommon.mix(sample.hashCode())
val segment = segments[hash and actualSegmentBits]
synchronized(segment) {
return segment.intern(sample)
}
}
}

View File

@ -2,7 +2,6 @@ package ru.dbotthepony.kstarbound.util
import com.github.benmanes.caffeine.cache.Interner
import com.google.common.collect.ImmutableList
import com.google.common.collect.ImmutableMap
import com.google.common.collect.ImmutableSet
import com.google.gson.Gson
import com.google.gson.TypeAdapter
@ -10,9 +9,7 @@ import com.google.gson.TypeAdapterFactory
import com.google.gson.reflect.TypeToken
import com.google.gson.stream.JsonReader
import com.google.gson.stream.JsonWriter
import it.unimi.dsi.fastutil.objects.Object2ObjectArrayMap
import ru.dbotthepony.kstarbound.Starbound
import java.util.Arrays
/**
* Шаблонизировання строка в стиле Starbound'а
@ -155,14 +152,11 @@ class SBPattern private constructor(
}
companion object : TypeAdapterFactory {
private val interner: Interner<SBPattern> = Interner.newWeakInterner()
private val interner: Interner<SBPattern> = HashTableInterner(5)
@JvmField
val EMPTY = raw("")
@JvmField
val FRAME = of("<frame>")
override fun <T : Any?> create(gson: Gson, type: TypeToken<T>): TypeAdapter<T>? {
if (type.rawType == SBPattern::class.java) {
return object : TypeAdapter<SBPattern>() {

View File

@ -320,12 +320,11 @@ abstract class World<This : World<This, ChunkType>, ChunkType : Chunk<This, Chun
fun think() {
try {
for (chunk in dirtyPhysicsChunks) {
for (chunk in dirtyPhysicsChunks)
chunk.bakeCollisions()
}
dirtyPhysicsChunks.clear()
physics.step(Starbound.SECONDS_IN_TICK, 6, 4)
physics.step(Starbound.TICK_TIME_ADVANCE, 6, 4)
thinkInner()
ticks++
} catch(err: Throwable) {

View File

@ -1,5 +1,7 @@
package ru.dbotthepony.kstarbound.world.api
import com.google.common.collect.ImmutableMap
enum class TileColor {
DEFAULT,
RED,
@ -11,11 +13,28 @@ enum class TileColor {
BLACK,
WHITE;
val lowercase = name.lowercase()
companion object {
private val values = values()
private val map: ImmutableMap<String, TileColor>
init {
val builder = ImmutableMap.Builder<String, TileColor>()
for (entry in entries) {
builder.put(entry.name, entry)
builder.put(entry.name.lowercase(), entry)
}
map = builder.build()
}
fun of(index: Int): TileColor {
return values.getOrElse(index) { DEFAULT }
return entries.getOrElse(index) { DEFAULT }
}
fun of(name: String): TileColor {
return map[name] ?: map[name.lowercase()] ?: DEFAULT
}
}
}

View File

@ -119,20 +119,20 @@ abstract class WalkableMovementController<T : AliveWalkingEntity>(entity: T) : M
if (onGround && !isDucked) {
when (moveDirection) {
Move.STAND_STILL -> {
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.SECONDS_IN_TICK * brakeForce)
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.TICK_TIME_ADVANCE * brakeForce)
}
Move.MOVE_LEFT -> {
if (body.linearVelocity.x > 0.0) {
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.SECONDS_IN_TICK * brakeForce)
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.TICK_TIME_ADVANCE * brakeForce)
}
if (body.linearVelocity.x > -topSpeed) {
body.linearVelocity += Vector2d(x = -moveSpeed * Starbound.SECONDS_IN_TICK)
body.linearVelocity += Vector2d(x = -moveSpeed * Starbound.TICK_TIME_ADVANCE)
// Ghost collision prevention
if (body.linearVelocity.x.absoluteValue < 1) {
body.linearVelocity += -Starbound.SECONDS_IN_TICK * world.gravity * 2.0
body.linearVelocity += -Starbound.TICK_TIME_ADVANCE * world.gravity * 2.0
}
}
@ -187,15 +187,15 @@ abstract class WalkableMovementController<T : AliveWalkingEntity>(entity: T) : M
Move.MOVE_RIGHT -> {
if (body.linearVelocity.x < 0.0) {
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.SECONDS_IN_TICK * brakeForce)
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.TICK_TIME_ADVANCE * brakeForce)
}
if (body.linearVelocity.x < topSpeed) {
body.linearVelocity += Vector2d(x = moveSpeed * Starbound.SECONDS_IN_TICK)
body.linearVelocity += Vector2d(x = moveSpeed * Starbound.TICK_TIME_ADVANCE)
// Ghost collision prevention
if (body.linearVelocity.x.absoluteValue < 1) {
body.linearVelocity += -Starbound.SECONDS_IN_TICK * world.gravity * 2.0
body.linearVelocity += -Starbound.TICK_TIME_ADVANCE * world.gravity * 2.0
}
}
@ -264,15 +264,15 @@ abstract class WalkableMovementController<T : AliveWalkingEntity>(entity: T) : M
}
Move.MOVE_LEFT -> {
body.linearVelocity += Vector2d(x = -freeFallMoveSpeed * Starbound.SECONDS_IN_TICK)
body.linearVelocity += Vector2d(x = -freeFallMoveSpeed * Starbound.TICK_TIME_ADVANCE)
}
Move.MOVE_RIGHT -> {
body.linearVelocity += Vector2d(x = freeFallMoveSpeed * Starbound.SECONDS_IN_TICK)
body.linearVelocity += Vector2d(x = freeFallMoveSpeed * Starbound.TICK_TIME_ADVANCE)
}
}
} else if (onGround && isDucked) {
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.SECONDS_IN_TICK * brakeForce)
body.linearVelocity += Vector2d(x = -body.linearVelocity.x * Starbound.TICK_TIME_ADVANCE * brakeForce)
}
if (wantsToDuck && onGround) {

View File

@ -4,42 +4,76 @@ import com.google.common.collect.ImmutableMap
import com.google.gson.JsonObject
import com.google.gson.TypeAdapter
import com.google.gson.reflect.TypeToken
import it.unimi.dsi.fastutil.objects.Object2ObjectOpenHashMap
import ru.dbotthepony.kstarbound.RegistryObject
import ru.dbotthepony.kstarbound.Starbound
import ru.dbotthepony.kstarbound.client.world.ClientWorld
import ru.dbotthepony.kstarbound.defs.Drawable
import ru.dbotthepony.kstarbound.defs.JsonDriven
import ru.dbotthepony.kstarbound.defs.image.SpriteReference
import ru.dbotthepony.kstarbound.defs.`object`.ObjectDefinition
import ru.dbotthepony.kstarbound.defs.`object`.ObjectOrientation
import ru.dbotthepony.kstarbound.util.get
import ru.dbotthepony.kstarbound.util.set
import ru.dbotthepony.kstarbound.world.Direction
import ru.dbotthepony.kstarbound.world.LightCalculator
import ru.dbotthepony.kstarbound.world.World
import ru.dbotthepony.kstarbound.world.api.TileColor
import ru.dbotthepony.kvector.vector.RGBAColor
import ru.dbotthepony.kvector.vector.Vector2i
abstract class WorldObject(
open class WorldObject(
val world: World<*, *>,
val prototype: RegistryObject<ObjectDefinition>,
val pos: Vector2i,
) : JsonDriven(prototype.file.computeDirectory()) {
constructor(world: World<*, *>, data: JsonObject) : this(
world,
Starbound.worldObjects[data["name"]?.asString ?: throw IllegalArgumentException("Missing object name")] ?: throw IllegalArgumentException("No such object defined for '${data["name"]}'"),
data.get("tilePosition", vectors) { throw IllegalArgumentException("No tilePosition was present in saved data") }
) {
direction = data.get("direction", directions) { Direction.LEFT }
orientationIndex = data.get("orientationIndex", -1)
interactive = data.get("interactive", false)
data["uniqueId"]?.let {
if (!it.isJsonNull)
uniqueId = it.asString
}
for ((k, v) in data.get("parameters") { JsonObject() }.entrySet()) {
properties[k] = v.deepCopy()
}
}
//
// internal runtime properties
//
val clientWorld get() = world as ClientWorld
val orientations = prototype.value.orientations
val validOrientations = orientations.size
protected val renderParamLocations = Object2ObjectOpenHashMap<String, () -> String?>()
private var frame = 0
set(value) {
if (field != value) {
field = value
drawablesCache.invalidate()
}
}
// scriptStorage - json object
var uniqueId: String? = null
var interactive = false
var direction = Direction.LEFT
init {
world.objects.add(this)
}
private var frameTimer = 0.0
var isRemoved = false
private set
var isSpawned = false
private set
fun remove() {
if (isRemoved) return
check(world.objects.remove(this))
}
//
// top level properties
//
var uniqueId: String? = null
var interactive = false
var direction = Direction.LEFT
var orientationIndex = -1
set(value) {
@ -49,16 +83,84 @@ abstract class WorldObject(
}
}
//
// json driven properties
//
var color: TileColor by Property(TileColor.DEFAULT)
var animationParts: ImmutableMap<String, SpriteReference> by Property()
var imagePosition: Vector2i by Property(Vector2i.ZERO)
var animationPosition: Vector2i by Property(Vector2i.ZERO)
init {
renderParamLocations["color"] = { color.lowercase }
renderParamLocations["frame"] = { frame.toString() }
}
private val drawablesCache = LazyData {
orientation?.drawables?.map { it.with(::getRenderParam) } ?: listOf()
}
val drawables: List<Drawable> by drawablesCache
fun getRenderParam(key: String): String? {
return renderParamLocations[key]?.invoke() ?: "default"
}
override fun invalidate(name: String) {
super.invalidate(name)
if (name in renderParamLocations) {
drawablesCache.invalidate()
}
}
override fun invalidate() {
super.invalidate()
}
protected open fun innerSpawn() {}
protected open fun innerRemove() {}
fun spawn() {
if (isSpawned) return
isSpawned = true
world.objects.add(this)
innerSpawn()
invalidate()
}
open fun remove() {
if (isRemoved || !isSpawned) return
isRemoved = true
check(world.objects.remove(this))
innerRemove()
}
open fun thinkShared() {
}
open fun thinkClient() {
val orientation = orientation
if (orientation != null) {
frameTimer = (frameTimer + Starbound.TICK_TIME_ADVANCE) % orientation.animationCycle
frame = (frameTimer / orientation.animationCycle * orientation.frames).toInt()
}
}
open fun thinkServer() {
}
val orientation: ObjectOrientation? get() {
return orientations.getOrNull(orientationIndex)
}
override fun defs(): Collection<JsonObject> {
if (orientationIndex in 0 until validOrientations) {
return listOf(orientations[orientationIndex].json, prototype.jsonObject)
} else {
return listOf(prototype.jsonObject)
}
val get = orientation
return if (get == null) listOf(prototype.jsonObject) else listOf(get.json, prototype.jsonObject)
}
val lightColors: ImmutableMap<String, RGBAColor> by LazyData(listOf("lightColor", "lightColors")) {
@ -78,39 +180,6 @@ abstract class WorldObject(
private val colors0 by lazy { Starbound.gson.getAdapter(RGBAColor::class.java) }
private val strings by lazy { Starbound.gson.getAdapter(String::class.java) }
private val directions by lazy { Starbound.gson.getAdapter(Direction::class.java) }
fun <W : World<*, *>, T : WorldObject> create(world: W, data: JsonObject, factory: (W, RegistryObject<ObjectDefinition>, Vector2i) -> T): T {
val tilePosition = Starbound.gson.fromJson(data["tilePosition"], Vector2i::class.java) ?: throw IllegalArgumentException("No tilePosition was present in saved data")
val name = data["name"]?.asString ?: throw IllegalArgumentException("Missing object name")
val def = Starbound.worldObjects[name] ?: throw IllegalArgumentException("No such object defined for '$name'")
val obj = factory(world, def, tilePosition)
data["direction"]?.let {
obj.direction = directions.fromJsonTree(it)
}
data["orientationIndex"]?.let {
obj.orientationIndex = it.asInt
}
data["interactive"]?.let {
obj.interactive = it.asBoolean
}
data["uniqueId"]?.let {
if (!it.isJsonNull)
obj.uniqueId = it.asString
}
data["parameters"]?.let {
for ((k, v) in it.asJsonObject.entrySet()) {
obj.properties[k] = v
}
}
obj.invalidate()
return obj
}
private val vectors by lazy { Starbound.gson.getAdapter(Vector2i::class.java) }
}
}