2020-10-03 21:38:26 +00:00
|
|
|
package izapple2
|
2019-05-18 21:40:59 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
|
|
|
/*
|
|
|
|
Logger card. It never existed, I use it to trace accesses to the card.
|
|
|
|
*/
|
|
|
|
|
2020-10-14 19:54:51 +00:00
|
|
|
// CardLogger is a fake card to log soft switch invocations
|
|
|
|
type CardLogger struct {
|
2019-05-18 21:40:59 +00:00
|
|
|
cardBase
|
|
|
|
}
|
|
|
|
|
2024-01-06 20:48:23 +00:00
|
|
|
func newCardLoggerBuilder() *cardBuilder {
|
|
|
|
return &cardBuilder{
|
|
|
|
name: "Softswitch logger card",
|
|
|
|
description: "Card to log softswitch accesses",
|
|
|
|
buildFunc: func(params map[string]string) (Card, error) {
|
|
|
|
return &CardLogger{}, nil
|
|
|
|
},
|
|
|
|
}
|
2020-10-14 19:54:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *CardLogger) assign(a *Apple2, slot int) {
|
2022-08-05 17:43:17 +00:00
|
|
|
c.addCardSoftSwitches(func(address uint8, data uint8, write bool) uint8 {
|
2021-05-09 17:48:54 +00:00
|
|
|
if write {
|
|
|
|
fmt.Printf("[cardLogger] Write access to softswith 0x%x for slot %v, value 0x%02x.\n", address, slot, data)
|
|
|
|
} else {
|
|
|
|
fmt.Printf("[cardLogger] Read access to softswith 0x%x for slot %v.\n", address, slot)
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}, "LOGGER")
|
2019-05-18 21:40:59 +00:00
|
|
|
|
|
|
|
c.cardBase.assign(a, slot)
|
|
|
|
}
|