diff --git a/src/BizHawk.Client.Common/lua/LuaDocumentation.cs b/src/BizHawk.Client.Common/lua/LuaDocumentation.cs
index c794bb6f16..b06d8dbf37 100644
--- a/src/BizHawk.Client.Common/lua/LuaDocumentation.cs
+++ b/src/BizHawk.Client.Common/lua/LuaDocumentation.cs
@@ -41,8 +41,9 @@ namespace BizHawk.Client.Common
** a string containing a CSS3/X11 color name e.g. ""blue"", ""palegoldenrod""; or
** a Color created with forms.createcolor.
** As noted above, luacolor? indicates nil may also be passed.
-* luaf
-** A Lua function. Note that these are always parameters, and never return values of a call
+* nluafunc
+** A Lua function. Note that these are always parameters, and never return values of a call.
+** Some callbacks will be called with arguments, if the function you register has the right number of parameters. This will be noted in the registration function's docs.
* table
** A standard Lua table
* something else
diff --git a/src/BizHawk.Client.Common/lua/LuaHelperLibs/EventsLuaLibrary.cs b/src/BizHawk.Client.Common/lua/LuaHelperLibs/EventsLuaLibrary.cs
index c3e18f1c41..aec845bcc0 100644
--- a/src/BizHawk.Client.Common/lua/LuaHelperLibs/EventsLuaLibrary.cs
+++ b/src/BizHawk.Client.Common/lua/LuaHelperLibs/EventsLuaLibrary.cs
@@ -98,7 +98,7 @@ namespace BizHawk.Client.Common
.Guid.ToString();
[LuaDeprecatedMethod]
- [LuaMethod("onmemoryexecute", "Fires immediately before the given address is executed by the core")]
+ [LuaMethod("onmemoryexecute", "Fires immediately before the given address is executed by the core. Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value to be executed (or {{0}} always, if this feature is only partially implemented).")]
public string OnMemoryExecute(
LuaFunction luaf,
uint address,
@@ -109,8 +109,8 @@ namespace BizHawk.Client.Common
return OnBusExec(luaf, address, name: name, scope: scope);
}
- [LuaMethodExample("local exec_cb_id = event.on_bus_exec(\r\n\tfunction()\r\n\t\tconsole.log( \"Fires immediately before the given address is executed by the core\" );\r\n\tend\r\n\t, 0x200, \"Frame name\", \"System Bus\" );")]
- [LuaMethod("on_bus_exec", "Fires immediately before the given address is executed by the core")]
+ [LuaMethodExample("local exec_cb_id = event.on_bus_exec(\r\n\tfunction(addr, val, flags)\r\n\t\tconsole.log( \"Fires immediately before the given address is executed by the core. {{val}} is the value to be executed (or {{0}} always, if this feature is only partially implemented).\" );\r\n\tend\r\n\t, 0x200, \"Frame name\", \"System Bus\" );")]
+ [LuaMethod("on_bus_exec", "Fires immediately before the given address is executed by the core. Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value to be executed (or {{0}} always, if this feature is only partially implemented).")]
public string OnBusExec(
LuaFunction luaf,
uint address,
@@ -145,7 +145,7 @@ namespace BizHawk.Client.Common
}
[LuaDeprecatedMethod]
- [LuaMethod("onmemoryexecuteany", "Fires immediately before any address is executed by the core (CPU-intensive)")]
+ [LuaMethod("onmemoryexecuteany", "Fires immediately before every instruction executed (in the specified scope) by the core (CPU-intensive). Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value to be executed (or {{0}} always, if this feature is only partially implemented).")]
public string OnMemoryExecuteAny(
LuaFunction luaf,
string name = null,
@@ -155,8 +155,8 @@ namespace BizHawk.Client.Common
return OnBusExecAny(luaf, name: name, scope: scope);
}
- [LuaMethodExample("local exec_cb_id = event.on_bus_exec_any(\r\n\tfunction()\r\n\t\tconsole.log( \"Fires immediately before every instruction executed (in the specified scope) by the core (CPU-intensive)\" );\r\n\tend\r\n\t, \"Frame name\", \"System Bus\" );")]
- [LuaMethod("on_bus_exec_any", "Fires immediately before every instruction executed (in the specified scope) by the core (CPU-intensive)")]
+ [LuaMethodExample("local exec_cb_id = event.on_bus_exec_any(\r\n\tfunction(addr, val, flags)\r\n\t\tconsole.log( \"Fires immediately before every instruction executed (in the specified scope) by the core (CPU-intensive). {{val}} is the value to be executed (or {{0}} always, if this feature is only partially implemented).\" );\r\n\tend\r\n\t, \"Frame name\", \"System Bus\" );")]
+ [LuaMethod("on_bus_exec_any", "Fires immediately before every instruction executed (in the specified scope) by the core (CPU-intensive). Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value to be executed (or {{0}} always, if this feature is only partially implemented).")]
public string OnBusExecAny(
LuaFunction luaf,
string name = null,
@@ -195,7 +195,7 @@ namespace BizHawk.Client.Common
}
[LuaDeprecatedMethod]
- [LuaMethod("onmemoryread", "Fires after the given address is read by the core. If no address is given, it will attach to every memory read")]
+ [LuaMethod("onmemoryread", "Fires immediately before the given address is read by the core. Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value read. If no address is given, it will fire on every memory read.")]
public string OnMemoryRead(
LuaFunction luaf,
uint? address = null,
@@ -206,8 +206,8 @@ namespace BizHawk.Client.Common
return OnBusRead(luaf, address, name: name, scope: scope);
}
- [LuaMethodExample("local exec_cb_id = event.on_bus_read(\r\n\tfunction()\r\n\t\tconsole.log( \"Fires after the given address is read by the core. If no address is given, it will attach to every memory read\" );\r\n\tend\r\n\t, 0x200, \"Frame name\" );")]
- [LuaMethod("on_bus_read", "Fires after the given address is read by the core. If no address is given, it will attach to every memory read")]
+ [LuaMethodExample("local exec_cb_id = event.on_bus_read(\r\n\tfunction(addr, val, flags)\r\n\t\tconsole.log( \"Fires immediately before the given address is read by the core. {{val}} is the value read. If no address is given, it will fire on every memory read.\" );\r\n\tend\r\n\t, 0x200, \"Frame name\" );")]
+ [LuaMethod("on_bus_read", "Fires immediately before the given address is read by the core. Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value read. If no address is given, it will fire on every memory read.")]
public string OnBusRead(
LuaFunction luaf,
uint? address = null,
@@ -241,7 +241,7 @@ namespace BizHawk.Client.Common
}
[LuaDeprecatedMethod]
- [LuaMethod("onmemorywrite", "Fires after the given address is written by the core. If no address is given, it will attach to every memory write")]
+ [LuaMethod("onmemorywrite", "Fires immediately before the given address is written by the core. Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value to be written (or {{0}} always, if this feature is only partially implemented). If no address is given, it will fire on every memory write.")]
public string OnMemoryWrite(
LuaFunction luaf,
uint? address = null,
@@ -252,8 +252,8 @@ namespace BizHawk.Client.Common
return OnBusWrite(luaf, address, name: name, scope: scope);
}
- [LuaMethodExample("local exec_cb_id = event.on_bus_write(\r\n\tfunction()\r\n\t\tconsole.log( \"Fires after the given address is written by the core. If no address is given, it will attach to every memory write\" );\r\n\tend\r\n\t, 0x200, \"Frame name\" );")]
- [LuaMethod("on_bus_write", "Fires after the given address is written by the core. If no address is given, it will attach to every memory write")]
+ [LuaMethodExample("local exec_cb_id = event.on_bus_write(\r\n\tfunction(addr, val, flags)\r\n\t\tconsole.log( \"Fires immediately before the given address is written by the core. {{val}} is the value to be written (or {{0}} always, if this feature is only partially implemented). If no address is given, it will fire on every memory write.\" );\r\n\tend\r\n\t, 0x200, \"Frame name\" );")]
+ [LuaMethod("on_bus_write", "Fires immediately before the given address is written by the core. Your callback can have 3 parameters {{(addr, val, flags)}}. {{val}} is the value to be written (or {{0}} always, if this feature is only partially implemented). If no address is given, it will fire on every memory write.")]
public string OnBusWrite(
LuaFunction luaf,
uint? address = null,
diff --git a/src/BizHawk.Emulation.Common/Interfaces/IMemoryCallbackSystem.cs b/src/BizHawk.Emulation.Common/Interfaces/IMemoryCallbackSystem.cs
index 8b4e562f1e..1c6e9ad9a2 100644
--- a/src/BizHawk.Emulation.Common/Interfaces/IMemoryCallbackSystem.cs
+++ b/src/BizHawk.Emulation.Common/Interfaces/IMemoryCallbackSystem.cs
@@ -5,7 +5,7 @@ using System.Collections.Generic;
namespace BizHawk.Emulation.Common
{
-
+ /// For reads/execs, the value read/executed; for writes, the value to be written. Cores may pass the default 0 if write/exec is partially implemented.
public delegate void MemoryCallbackDelegate(uint address, uint value, uint flags);
///
@@ -99,11 +99,15 @@ namespace BizHawk.Emulation.Common
/// This service defines a memory callback used by an IMemoryCallbackSystem implementation
///
///
+ ///
public interface IMemoryCallback
{
MemoryCallbackType Type { get; }
string Name { get; }
+
+ ///
MemoryCallbackDelegate Callback { get; }
+
uint? Address { get; }
uint? AddressMask { get; }
string Scope { get; }