small fixes to VersionInfo wrapper, added Current_Race in Memory.xml to new version and ported friendship plugin to memory.xml model

develop
Warmist 2011-08-09 11:31:51 +03:00
parent 148afde4eb
commit a94ba4392c
6 changed files with 26 additions and 18 deletions

@ -2263,6 +2263,7 @@
<Address name="current_menu_state" value="0x14f5fac" /> <Address name="current_menu_state" value="0x14f5fac" />
</Group> </Group>
<Group name="Creatures"> <Group name="Creatures">
<Address name="current_race" value="0x14F0C28" />
<Group name="creature"> <Group name="creature">
<Offset name="flags3" value="0xE8"/> <Offset name="flags3" value="0xE8"/>
</Group> </Group>

@ -77,7 +77,7 @@ DFhackCExport command_result plugin_onupdate ( Core * c )
catch(lua::exception &e) catch(lua::exception &e)
{ {
c->con.printerr("Error OnTick:%s\n",e.what()); c->con.printerr("Error OnTick:%s\n",e.what());
c->con.printerr("%s",lua::DebugDump(lua::glua::Get()).c_str()); c->con.printerr("%s\n",lua::DebugDump(lua::glua::Get()).c_str());
c->con.msleep(1000); c->con.msleep(1000);
} }
} }
@ -104,7 +104,7 @@ void InterpreterLoop(Core* c)
catch(lua::exception &e) catch(lua::exception &e)
{ {
con.printerr("Error:%s\n",e.what()); con.printerr("Error:%s\n",e.what());
c->con.printerr("%s",lua::DebugDump(lua::glua::Get()).c_str()); c->con.printerr("%s\n",lua::DebugDump(lua::glua::Get()).c_str());
s.settop(0); s.settop(0);
} }
con.lineedit(">>",curline); con.lineedit(">>",curline);
@ -125,7 +125,7 @@ DFhackCExport command_result lua_run (Core * c, vector <string> & parameters)
catch(lua::exception &e) catch(lua::exception &e)
{ {
con.printerr("Error:%s\n",e.what()); con.printerr("Error:%s\n",e.what());
c->con.printerr("%s",lua::DebugDump(lua::glua::Get()).c_str()); c->con.printerr("%s\n",lua::DebugDump(lua::glua::Get()).c_str());
} }
} }
else else
@ -150,7 +150,7 @@ DFhackCExport command_result dfusion (Core * c, vector <string> & parameters)
catch(lua::exception &e) catch(lua::exception &e)
{ {
con.printerr("Error:%s\n",e.what()); con.printerr("Error:%s\n",e.what());
c->con.printerr("%s",lua::DebugDump(lua::glua::Get()).c_str()); c->con.printerr("%s\n",lua::DebugDump(lua::glua::Get()).c_str());
} }
s.settop(0);// clean up s.settop(0);// clean up
mymutex->unlock(); mymutex->unlock();

@ -321,7 +321,9 @@ function findVectors()
end end
function GetRaceToken(p) --actually gets token... function GetRaceToken(p) --actually gets token...
local vec=engine.peek(offsets.getEx('CreatureGloss'),ptr_vector) print(string.format("%x vs %x",offsets.getEx('CreatureGloss'),VersionInfo.getGroup("Materials"):getAddress("creature_type_vector")))
--local vec=engine.peek(offsets.getEx('CreatureGloss'),ptr_vector)
local vec=engine.peek(VersionInfo.getGroup("Materials"):getAddress("creature_type_vector"),ptr_vector)
--print("Vector ok") --print("Vector ok")
local off=vec:getval(p) local off=vec:getval(p)
--print("Offset:"..off) --print("Offset:"..off)

@ -1,6 +1,6 @@
function friendship_in.patch() function friendship_in.patch()
pos=GetTextRegion().start pos=GetTextRegion().start
local crace=offsets.getEx("CurrentRace") local crace=add_race --offsets.getEx("CurrentRace")
hits={} hits={}
i=1 i=1
repeat repeat

@ -40,10 +40,15 @@ end
Two more compares are missing. There are calls instead (same function) Two more compares are missing. There are calls instead (same function)
]]-- ]]--
if not(FILE) then if not(FILE) then
print("race num:"..engine.peekw(offsets.getEx("CurrentRace"))) --print("race num:"..engine.peekw(offsets.getEx("CurrentRace")))
print("Your current race is:"..GetRaceToken(engine.peekw(offsets.getEx('CurrentRace')))) --print(string.format("%x vs %x",offsets.getEx("CurrentRace"),VersionInfo.getGroup("Creatures"):getAddress("current_race")))
print("If this is wrong please quit now (by ctrl+c)") add_race=VersionInfo.getGroup("Creatures"):getAddress("current_race")
io.stdin:read() print("Race num:"..engine.peekw(add_race))
print("Your current race is:"..GetRaceToken(engine.peekw(add_race)))
print("If this is wrong please type 'q'")
if(io.stdin:read()=='q') then
return
end
end end
friendship_in={} friendship_in={}
dofile("dfusion/friendship/install.lua") dofile("dfusion/friendship/install.lua")

@ -9,35 +9,35 @@ OffsetGroup::OffsetGroup(lua_State *L,int id):tblid(id)
int OffsetGroup::getOffset(lua_State *L) int OffsetGroup::getOffset(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
int32_t ret=p->getOffset(st.as<std::string>(2)); int32_t ret=p->getOffset(st.as<std::string>(1));
st.push(ret); st.push(ret);
return 1; return 1;
} }
int OffsetGroup::getAddress(lua_State *L) int OffsetGroup::getAddress(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
uint32_t ret=p->getAddress(st.as<std::string>(2)); uint32_t ret=p->getAddress(st.as<std::string>(1));
st.push(ret); st.push(ret);
return 1; return 1;
} }
int OffsetGroup::getHexValue(lua_State *L) int OffsetGroup::getHexValue(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
uint32_t ret=p->getHexValue(st.as<std::string>(2)); uint32_t ret=p->getHexValue(st.as<std::string>(1));
st.push(ret); st.push(ret);
return 1; return 1;
} }
int OffsetGroup::getString(lua_State *L) int OffsetGroup::getString(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
std::string ret=p->getString(st.as<std::string>(2)); std::string ret=p->getString(st.as<std::string>(1));
st.push(ret); st.push(ret);
return 1; return 1;
} }
int OffsetGroup::getGroup(lua_State *L) int OffsetGroup::getGroup(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
DFHack::OffsetGroup* t= p->getGroup(st.as<std::string>(2)); DFHack::OffsetGroup* t= p->getGroup(st.as<std::string>(1));
st.getglobal("OffsetGroup"); st.getglobal("OffsetGroup");
st.getfield("new"); st.getfield("new");
st.getglobal("OffsetGroup"); st.getglobal("OffsetGroup");
@ -49,7 +49,7 @@ int OffsetGroup::getSafeOffset(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
int32_t out; int32_t out;
bool ret=p->getSafeOffset(st.as<std::string>(2),out); bool ret=p->getSafeOffset(st.as<std::string>(1),out);
st.push(ret); st.push(ret);
st.push(out); st.push(out);
return 2; return 2;
@ -58,7 +58,7 @@ int OffsetGroup::getSafeAddress(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
uint32_t out; uint32_t out;
bool ret=p->getSafeAddress(st.as<std::string>(2),out); bool ret=p->getSafeAddress(st.as<std::string>(1),out);
st.push(ret); st.push(ret);
st.push(out); st.push(out);
return 2; return 2;
@ -67,7 +67,7 @@ int OffsetGroup::PrintOffsets(lua_State *L)
{ {
lua::state st(L); lua::state st(L);
std::string output; std::string output;
output=p->PrintOffsets(st.as<int>(2)); output=p->PrintOffsets(st.as<int>(1));
st.push(output); st.push(output);
return 1; return 1;
} }