mirror of
https://github.com/JetSetIlly/Gopher2600.git
synced 2024-05-20 05:40:49 -04:00
685bf7ccc7
added properties package ROM select window display property information
84 lines
2.5 KiB
Go
84 lines
2.5 KiB
Go
// This file is part of Gopher2600.
|
|
//
|
|
// Gopher2600 is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Gopher2600 is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Gopher2600. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package debugger
|
|
|
|
import (
|
|
"github.com/jetsetilly/gopher2600/debugger/govern"
|
|
"github.com/jetsetilly/gopher2600/disassembly"
|
|
"github.com/jetsetilly/gopher2600/logger"
|
|
"github.com/jetsetilly/gopher2600/properties"
|
|
)
|
|
|
|
// PushFunction onto the event queue. Used to ensure that the events are
|
|
// inserted into the emulation loop correctly.
|
|
func (dbg *Debugger) PushFunction(f func()) {
|
|
select {
|
|
case dbg.events.PushedFunction <- f:
|
|
default:
|
|
logger.Log("debugger", "dropped raw event push")
|
|
}
|
|
}
|
|
|
|
// PushFunctionImmediate is the same as PushFunction but the event handler will
|
|
// return to the input loop for immediate action.
|
|
func (dbg *Debugger) PushFunctionImmediate(f func()) {
|
|
select {
|
|
case dbg.events.PushedFunctionImmediate <- f:
|
|
default:
|
|
logger.Log("debugger", "dropped raw event push (to return channel)")
|
|
}
|
|
}
|
|
|
|
// PushSetMode sets the mode of the emulation.
|
|
func (dbg *Debugger) PushSetMode(mode govern.Mode) {
|
|
dbg.PushFunctionImmediate(func() {
|
|
dbg.setMode(mode)
|
|
})
|
|
}
|
|
|
|
// PushSetPause sets the pause state of the emulation.
|
|
func (dbg *Debugger) PushSetPause(paused bool) {
|
|
switch dbg.Mode() {
|
|
case govern.ModePlay:
|
|
dbg.PushFunction(func() {
|
|
if paused {
|
|
dbg.setState(govern.Paused)
|
|
} else {
|
|
dbg.setState(govern.Running)
|
|
}
|
|
})
|
|
case govern.ModeDebugger:
|
|
logger.Logf("debugger", "not reacting to SetPause() in debugger mode (use terminal input instead)")
|
|
}
|
|
}
|
|
|
|
// PushTogglePCBreak sets or unsets a PC break at the address rerpresented by the
|
|
// disassembly entry.
|
|
func (dbg *Debugger) PushTogglePCBreak(e *disassembly.Entry) {
|
|
f := e
|
|
dbg.PushFunction(func() {
|
|
dbg.halting.breakpoints.togglePCBreak(f)
|
|
})
|
|
}
|
|
|
|
// PushPropertyLookup looks up the supplied MD5 hash in the properties table
|
|
func (dbg *Debugger) PushPropertyLookup(hashMD5 string, result chan properties.Entry) {
|
|
dbg.PushFunctionImmediate(func() {
|
|
e, _ := dbg.pro.Lookup(hashMD5)
|
|
result <- e
|
|
})
|
|
}
|