| View previous topic :: View next topic |
| Author |
Message |
TheyCallMeTim13 Wiki Contributor
Reputation: 51
Joined: 24 Feb 2017 Posts: 976 Location: Pluto
|
Posted: Sat Mar 04, 2017 8:34 pm Post subject: String Stream Returning nil. |
|
|
So I made a lua extension that reads cea file local and if not found reads table files.
Extension:
link: http{://}forum{.}cheatengine{.}org/viewtopic{.}php?t=603440
I ended up coming up with this to read the table files.
| Code: |
local tableFile = findTableFile(ceaFile)
if tableFile == nil then
Logger.error(format('I2CETH: getAutoAssembleFileSection: Error opening table file: "%s"', ceaFile), err)
return nil
end
local stream = tableFile.getData()
local fileStr = nil
local bytes = stream.read(stream.Size)
for i = 1, #bytes do
if fileStr == nil then
fileStr = ''
end
fileStr = fileStr .. string.char(bytes[i])
end
|
Which returns the file string with out problems.
but I got this from 'panraven' in the new forum, and it worked the first few times but now mostly (not every time) returns nil.
| Code: |
local tableFile = findTableFile(ceaFile)
if tableFile == nil then
Logger.error(format('I2CETH: getAutoAssembleFileSection: Error opening table file: "%s"', ceaFile), err)
return nil
end
-- START: Not Working
local stringStream = createStringStream()
stringStream.copyFrom(tableFile.Stream, tableFile.Stream.Size)
local fileStr = stringStream.DataString
stringStream.Destroy()
-- END: Not Working
|
Basically 'stringStream.DataString' keeps returning nil.
So I do have a work around but I was just trying to figure out why it, seemingly, randomly fails.
Not a big issue but still bugs me not knowing why. _________________
|
|
| Back to top |
|
 |
panraven Grandmaster Cheater
Reputation: 62
Joined: 01 Oct 2008 Posts: 958
|
Posted: Sat Mar 04, 2017 10:32 pm Post subject: |
|
|
I tried c&p you code within a 100x for-loop to load a same 4M binary table file, and count its returned string sum. The result return correctly. So stringStream is ok to handle binary file.
It may be something outside the code to cause the inconsistency?
I've no idea why too~
btw, I also do an unrelated test where do above almost the same with 10000x of a 500k table file with or without destroy the stringStream explicitly and manually. (since there is a follow up at fearlessrevolution about destroying object)
If destroy, the CE memory usage is around 70~80M during the loop.
If not destroy, the CE memory usage grow to as large as 10G during the loop, but all released soon after the loop.
It seems CE will auto-destroy at least stringStream object, but only when CE has 'leisure time?', it may be better manually destroy that's manually created.
bye~ _________________
- Retarded. |
|
| Back to top |
|
 |
TheyCallMeTim13 Wiki Contributor
Reputation: 51
Joined: 24 Feb 2017 Posts: 976 Location: Pluto
|
Posted: Sun Mar 05, 2017 12:25 am Post subject: |
|
|
Yeah just weird how it worked fine for a while, then just kinda stopped, I feel like there has to be some thing I add that caused it, but just can't find it.
I'll keep playing with it.
Thanks again for the help though.
I think I have read a lot of your posts so this isn't first time you have helped me. _________________
|
|
| Back to top |
|
 |
mgr.inz.Player I post too much
Reputation: 222
Joined: 07 Nov 2008 Posts: 4438 Location: W kraju nad Wisla. UTC+01:00
|
Posted: Sun Mar 05, 2017 6:23 am Post subject: Re: String Stream Returning nil. |
|
|
I also used copyFrom() method many times. I also had few problems. And this is my conclusion: always set Position property when using copyFrom.
Try this:
| Code: | local tableFile = findTableFile(ceaFile)
if tableFile == nil then
Logger.error(format('I2CETH: getAutoAssembleFileSection: Error opening table file: "%s"', ceaFile), err)
return nil
end
local stringStream = createStringStream()
local tableFileStream = tableFile.Stream
tableFileStream.Position = 0
stringStream.copyFrom(tableFileStream, tableFileStream.Size)
local fileStr = stringStream.DataString
stringStream.destroy()
|
_________________
|
|
| Back to top |
|
 |
TheyCallMeTim13 Wiki Contributor
Reputation: 51
Joined: 24 Feb 2017 Posts: 976 Location: Pluto
|
Posted: Sun Mar 05, 2017 12:11 pm Post subject: |
|
|
OK, That really make sense, I never told it where to read form, Kinda know it was some thing small but just could't see it.
I will have to give it a try, Thanks for the all the help. _________________
|
|
| Back to top |
|
 |
|