| 
			
				|  | Cheat Engine The Official Site of Cheat Engine
 
 
 |  
 
	
		| View previous topic :: View next topic |  
		| Author | Message |  
		| hdf13 Advanced Cheater
 
  Reputation: 1 
 Joined: 18 Sep 2013
 Posts: 75
 
 
 | 
			
				|  Posted: Sat Aug 23, 2014 6:16 am    Post subject: Auto assembly disable self |   |  
				| 
 |  
				| I'm not sure if this is the right forum section to ask this, but is it possible for an option/auto assembly, to run only once, and than disable itself? So each time it is activated, nothing happens, until the replaced code segment is run by the game, than once it was, the cheat disables itself. 
 Edit:
 Solution can be found here: http://forum.cheatengine.org/viewtopic.php?p=5549105#5549105
 
 Last edited by hdf13 on Fri Aug 29, 2014 8:04 pm; edited 1 time in total
 |  |  
		| Back to top |  |  
		|  |  
		| daspamer Grandmaster Cheater Supreme
 
  Reputation: 54 
 Joined: 13 Sep 2011
 Posts: 1588
 
 
 | 
			
				|  Posted: Sat Aug 23, 2014 7:45 am    Post subject: Re: Auto assembly disable self |   |  
				| 
 |  
				|  	  | hdf13 wrote: |  	  | I'm not sure if this is the right forum section to ask this, but is it possible for an option/auto assembly, to run only once, and than disable itself? So each time it is activated, nothing happens, until the replaced code segment is run by the game, than once it was, the cheat disables itself. | 
 example
 
  	  | Code: |  	  | ...
 alloc(flag, 4)
 flag:
 db 00
 ...
 script:
 ...
 push ecx
 mov ecx,[flag]
 cmp ecx,1
 pop ecx
 je exit
 mov [flag], 1
 ...
 
 | 
 _________________
 
 I'm rusty and getting older, help me re-learn lua. |  |  
		| Back to top |  |  
		|  |  
		| hdf13 Advanced Cheater
 
  Reputation: 1 
 Joined: 18 Sep 2013
 Posts: 75
 
 
 | 
			
				|  Posted: Sat Aug 23, 2014 8:28 am    Post subject: |   |  
				| 
 |  
				| That is not good, as it does not put the original code back in place, it does not free up the allocated memory, and it does not uncheck the box by the script in the table. |  |  
		| Back to top |  |  
		|  |  
		| omoe Grandmaster Cheater
 
  Reputation: 8 
 Joined: 11 Jun 2013
 Posts: 547
 
 
 | 
			
				|  Posted: Thu Aug 28, 2014 3:42 pm    Post subject: |   |  
				| 
 |  
				| Use lua , memoryrecord_freeze(memoryrecord) to activate
 memoryrecord_unfreeze(memoryrecord) to deactivate
 _________________
 
 Hey! , Rep++ . |  |  
		| Back to top |  |  
		|  |  
		| hdf13 Advanced Cheater
 
  Reputation: 1 
 Joined: 18 Sep 2013
 Posts: 75
 
 
 | 
			
				|  Posted: Thu Aug 28, 2014 5:57 pm    Post subject: |   |  
				| 
 |  
				| @omoe: 
 Your solution has actually nothing to do with my problem.
 |  |  
		| Back to top |  |  
		|  |  
		| Geri Moderator
 
 ![]() Reputation: 111 
 Joined: 05 Feb 2010
 Posts: 5636
 
 
 |  |  
		| Back to top |  |  
		|  |  
		| hdf13 Advanced Cheater
 
  Reputation: 1 
 Joined: 18 Sep 2013
 Posts: 75
 
 
 | 
			
				|  Posted: Fri Aug 29, 2014 5:20 am    Post subject: |   |  
				| 
 |  
				| @Geri: 
 Would readmem() not be a better method in this case? But still, it is pretty important, that the script gets properly deactivated. The idea is, to be able to make options, that you activate with a hotkey, and they run only once, but than you can reactivate them again. So like to set a specific value to something, add to a value, or to run an ingame function.
 
 I guess, there is no way to do this now than, so this is a feature request.
 Need a function, that runs in auto assembly, and when run, deactivates the option, as if the X in the table was clicked. I don't think LUA would work, as that only works as a preprocessor.
 |  |  
		| Back to top |  |  
		|  |  
		| Dark Byte Site Admin
 
  Reputation: 470 
 Joined: 09 May 2003
 Posts: 25806
 Location: The netherlands
 
 | 
			
				|  Posted: Fri Aug 29, 2014 5:33 am    Post subject: |   |  
				| 
 |  
				| What about a script that instantly deactivates itself after being activated ? (before the code has been executed) 
 e.g in the enable section start a timer with an interval of 1 millisecond that disables the script. And let the script have an empty [disable] section. Then let your own script restore the bytes
 
 
 alternatively, look at template->call ce lua function.
 Then from inside your code injection call a lua script that disables the specific cheat entry in cheat engine
 _________________
 
 Do not ask me about online cheats. I don't know any and wont help finding them.
 Like my help? Join me on Patreon so i can keep helping
 |  |  
		| Back to top |  |  
		|  |  
		| Geri Moderator
 
 ![]() Reputation: 111 
 Joined: 05 Feb 2010
 Posts: 5636
 
 
 | 
			
				|  Posted: Fri Aug 29, 2014 6:12 am    Post subject: |   |  
				| 
 |  
				|  	  | hdf13 wrote: |  	  | @Geri: 
 Would readmem() not be a better method in this case? But still, it is pretty important, that the script gets properly deactivated. The idea is, to be able to make options, that you activate with a hotkey, and they run only once, but than you can reactivate them again. So like to set a specific value to something, add to a value, or to run an ingame function.
 
 | 
 
 Readmem is not enough, because you have to make lots of changes in the template to use it for your own code. Not every code has the same length etc.
 
 You can reactivate them again. If you scroll at the bottom of the article, you will see an example for it.
 
 
  	  | Quote: |  	  | The script above is having a little problem, it is not doing anything when you disable the code, so users would actually hit the hotkey twice to enable the cheat after every use. To solve that, here is another example: 
 
  	  | Code: |  	  | [ENABLE] //code from here to '[DISABLE]' will be used to enable the cheat
 globalalloc(mycode,512)
 globalalloc(originalcode,6)
 label(returnhere)
 originalcode:
 db 29 83 58 04 00 00
 
 fullaccess(00420F3E,6) //make read/write/execute
 00420F3E:
 jmp mycode
 nop
 returnhere:
 
 mycode:
 mov [ebx+0458],(int)999
 
 //restore with original bytes
 pushad //can't be bothered
 pushfd
 cld
 mov ecx,6  //nr of bytes
 mov esi, originalcode
 mov edi, 00420F3E
 rep movsb
 popfd
 popad
 
 
 jmp returnhere
 
 
 [DISABLE]
 //code from here till the end of the code will be used to disable the cheat
 globalalloc(mycode,512)                   //I have changed the alloc to globalalloc so it is allocated only once, not all the time when you run the script
 globalalloc(originalcode,6)
 label(returnhere)
 originalcode:
 db 29 83 58 04 00 00
 
 fullaccess(00420F3E,6) //make read/write/execute
 00420F3E:
 jmp mycode
 nop
 returnhere:
 
 mycode:
 mov [ebx+0458],(int)999
 
 //restore with original bytes
 pushad //can't be bothered
 pushfd
 cld
 mov ecx,6  //nr of bytes
 mov esi, originalcode
 mov edi, 00420F3E
 rep movsb
 popfd
 popad
 
 
 jmp returnhere
 | 
 | 
 
 This way, the script will be executed once, whenever you enable or disable the cheat. In order to avoid allocating memory over and over again, I have used globalalloc instead of alloc.
 
 
  	  | Quote: |  	  | GLOBALALLOC(name,size) : Will allocate a certain amount of memory and registers the specified name. Using GlobalAlloc in other scripts will then not allocate the memory again, but reuse the already existing memory. (Or allocate it anyhow if found it was not allocated yet) | 
 
 I think that this is about the most similar result compared to what you are looking for without using lua. The memory will not be deallocated, but at least not allocated again and again. The checkbox will not be unchecked automatically, but whenever it is switched into either on or off state, it will enable the script for one use.
 _________________
 
 |  |  
		| Back to top |  |  
		|  |  
		| hdf13 Advanced Cheater
 
  Reputation: 1 
 Joined: 18 Sep 2013
 Posts: 75
 
 
 | 
			
				|  Posted: Fri Aug 29, 2014 7:00 am    Post subject: |   |  
				| 
 |  
				|  	  | Dark Byte wrote: |  	  | What about a script that instantly deactivates itself after being activated ? (before the code has been executed) 
 e.g in the enable section start a timer with an interval of 1 millisecond that disables the script. And let the script have an empty [disable] section. Then let your own script restore the bytes
 
 
 alternatively, look at template->call ce lua function.
 Then from inside your code injection call a lua script that disables the specific cheat entry in cheat engine
 | 
 
 This solution sounds interesting, but what about unregistersymbol and dealloc if there is no disable section?
 Also, can you give an example, for how to disable a cheat entry with lua from auto assembly? I can't see any such function in the lua docs for CE.
 
 @Geri:
 The unregistersymbol problem persists with your approach as well.
 |  |  
		| Back to top |  |  
		|  |  
		| Dark Byte Site Admin
 
  Reputation: 470 
 Joined: 09 May 2003
 Posts: 25806
 Location: The netherlands
 
 | 
			
				|  Posted: Fri Aug 29, 2014 7:11 am    Post subject: |   |  
				| 
 |  
				| there is NO way to free the memory from inside your code (if it's gone your code will end up executing non existent code and thus crash) 
 But if you use globalalloc instead of alloc all future allocations will make use of that one block of memory, preventing memory leaks
 
 And there is really no need to unregister symbols. Unregistering symbols just means that ce will error out when a specific symbol is looked up instead of giving the last known address of that symbol (Also, since your injected code would destroy itself there'd be no need to even bother registering symbols)
 
 --
 
 one other method you could do is in [enable] launch a timer with a function that disables the entry IF a specific address has been given a value, and also let your own script check if that address if set, and if not, run the code once and set it else skip, and in the [disable] have code that cleans up everything as usual
 _________________
 
 Do not ask me about online cheats. I don't know any and wont help finding them.
 Like my help? Join me on Patreon so i can keep helping
 
 Last edited by Dark Byte on Fri Aug 29, 2014 7:17 am; edited 2 times in total
 |  |  
		| Back to top |  |  
		|  |  
		| Geri Moderator
 
 ![]() Reputation: 111 
 Joined: 05 Feb 2010
 Posts: 5636
 
 
 | 
			
				|  Posted: Fri Aug 29, 2014 7:16 am    Post subject: |   |  
				| 
 |  
				|  	  | hdf13 wrote: |  	  | @Geri:
 The unregistersymbol problem persists with your approach as well.
 | 
 
 Yes, you can't use unregistersymbol. But if the problem is registering a symbol over and over again, you can use globalalloc instead of registersymbol. Globalalloc is allocating memory and registering it for global use (even outside of the script) and it will be done only once.
 
 Other than that, yes. I said this solution is just similar to what you are looking for, but not exactly what you wish to achieve.
 _________________
 
 |  |  
		| Back to top |  |  
		|  |  
		| hdf13 Advanced Cheater
 
  Reputation: 1 
 Joined: 18 Sep 2013
 Posts: 75
 
 
 | 
			
				|  Posted: Fri Aug 29, 2014 7:32 am    Post subject: |   |  
				| 
 |  
				| Ok, so I can use globalalloc to store variables persistently (like value addresses), so no need for registersymbol, I now know, how the code can put original values back, once it is run, all that remains is to instantly disable itself, but I have no idea, how to do that with lua calls, or how to do that timer bit. Can you give an example for those? |  |  
		| Back to top |  |  
		|  |  
		| Geri Moderator
 
 ![]() Reputation: 111 
 Joined: 05 Feb 2010
 Posts: 5636
 
 
 | 
			
				|  Posted: Fri Aug 29, 2014 5:17 pm    Post subject: |   |  
				| 
 |  
				| There is no AA command for this, so it can be done only in lua as DB said. But I have never tried this, so ask him about it. _________________
 
 |  |  
		| Back to top |  |  
		|  |  
		| ++METHOS I post too much
 
 ![]() Reputation: 92 
 Joined: 29 Oct 2010
 Posts: 4197
 
 
 | 
			
				|  Posted: Fri Aug 29, 2014 5:48 pm    Post subject: |   |  
				| 
 |  
				| You must use additional coding (LUA or other) to force the script to disable itself after each run. You can not use assembly inside of that script to achieve this. 
 The only purpose I can see with wanting to do this is to remain undetected against periodic memory checks. If you have another reason, I would be interested in knowing what that reason is.
 |  |  
		| Back to top |  |  
		|  |  
		|  |  
  
	| 
 
 | You cannot post new topics in this forum You cannot reply to topics in this forum
 You cannot edit your posts in this forum
 You cannot delete your posts in this forum
 You cannot vote in polls in this forum
 You cannot attach files in this forum
 You can download files in this forum
 
 |  |