about summary refs log tree commit diff
diff options
context:
space:
mode:
authorEmile <hanemile@protonmail.com>2020-02-22 16:56:26 +0100
committerEmile <hanemile@protonmail.com>2020-02-22 16:56:26 +0100
commit2889dea36fee0491ebf9df82bd2611f26b57f168 (patch)
tree8f852fe0e87a0710260e06e55017556ff5c0edf0
parentbccb90b150393f693fffe2477fc31f1efced2186 (diff)
rename
-rw-r--r--src/main.go (renamed from src/r2pipe.go)19
1 files changed, 13 insertions, 6 deletions
diff --git a/src/r2pipe.go b/src/main.go
index a672567..b11ea45 100644
--- a/src/r2pipe.go
+++ b/src/main.go
@@ -3,6 +3,7 @@ package main
 import (
 	"fmt"
 	"log"
+	"strings"
 	"time"
 )
 
@@ -45,11 +46,18 @@ func main() {
 		address := randomOffsets[bot]
 		placeBot(r2p, config.Bots[bot], address)
 
+		// store the initial address of the bot int the struct field
+		config.Bots[bot].Addr = address
+
 		// define the instruction point and the stack pointer
 		log.Printf("[i] setting up the PC and SP for bot %d", bot)
 		_ = r2cmd(r2p, fmt.Sprintf("aer PC=%d", address))
 		_ = r2cmd(r2p, fmt.Sprintf("aer SP=SP+%d", address))
 
+		// dump the registers of the user for being able to switch inbetween them
+		initialRegisers := strings.Replace(r2cmd(r2p, "aerR"), "\n", ";", -1)
+		config.Bots[bot].Regs = initialRegisers
+
 		// print the instruction point and the stack pointer
 		botStackPointer := r2cmd(r2p, "aerR~esp[2]")
 		log.Printf("[i] bot %d esp = %s", bot, botStackPointer)
@@ -70,17 +78,16 @@ func main() {
 	i := 0
 	for true {
 
-		// clear the screen
+		// Step, then print the users registers
 		registers := stepIn(r2p)
-
-		// Print the users screen
+		config.Bots[i].Regs = registers
 		fmt.Println(user(r2p, i, registers, config))
 
 		// switch players
-		i = switchPlayer(i, config)
+		i = switchPlayer(r2p, i, config)
 
-		// sleep
-		time.Sleep(2 * time.Second)
+		// sleepti
+		time.Sleep(100 * time.Millisecond)
 	}
 
 	r2p.Close()