Hello everyone! I need some tips or tutorials how to hack [Link] (nw.exe) based games. Most of those games is indie. The problem is - i can't find values even if I use "unknown initial value" and value type - "all. Such as health bars or power bars, etc. Even if I found right address for the value on the screen (number of lives or other things, which represented by number on the screen) and change it, nothing happens in the game.
A few of games, based on nw.js (this is not advertising!):
[Link] [Link] [Link] [Link]
Sorry for orthographic error's, eng is not my native lang.
I've played a few where you can find or manage to extract the js code (after some time spent googling) and modify it directly, other than that I haven't had much luck when double scans didn't work but I haven't played too many of them either. Part of the problem with JS (to my limited understanding of how the engines are implemented) is that's it's garbage collected and passes around values a lot along with closures and byte code etc.
hm, reading this [Link] gives me an idea to try using 4 byte values with the first / most significant / sign bit set...
@gir489_2 while JS does use the IEEE 754 Floating Point standard it doesn't use the binary32 single precision 4 byte "float" type but the binary64 double precision 8 byte "double" type ([Link]). Also the link above would prove you wrong about integer types when the V8 engine is used...
just in case it caused confusion, by that I meant the thibaultlaurens link not the one about the floating point format...
[Link] wrote:Tagged values
To have an efficient representation of numbers and JavaScript objects, V8 represents both with a 32 bit value. It uses a bit to know if it is an object (flag = 1) or an integer (flag = 0) called here SMall Integer or SMI because of its 31 bits. Then, if a numeric value is bigger than 31 bits, V8 will box the number, turning it into a double and creating a new object to put the number inside.
While the ECMAScript standard JS is based on may not have defined an integer type if the implementation of the engine that you are going to be working with to hack a game does then saying that JS doesn't have an integer type is practically wrong and worse than meaningless to everyone trying to hack a game on that engine (worse because then their looking in the wrong direction to find the value they want). I'd have agreed with you before reading that post, and while I haven't tested so it could still be incorrect, saying you're not wrong without more evidence when there's something saying you are is a bit silly.
Oh, and based on [Link] it's the low bit that's used not the high bit (sign) bit like I'd assumed previously.