Updated to SFML 2.2. Fixed LINK build on Linux.
This commit is contained in:
parent
a91f99d111
commit
193322a33e
|
@ -64,7 +64,7 @@
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
<Optimization>Disabled</Optimization>
|
<Optimization>Disabled</Optimization>
|
||||||
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;_DEBUG;DEV_VERSION;BKPT_SUPPORT;GBA_LOGGING;MMX;ASM;_CRT_SECURE_NO_WARNINGS;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;_DEBUG;SFML_SYSTEM_EXPORTS;SFML_NETWORK_EXPORTS;DEV_VERSION;BKPT_SUPPORT;GBA_LOGGING;MMX;ASM;_CRT_SECURE_NO_WARNINGS;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<StringPooling>false</StringPooling>
|
<StringPooling>false</StringPooling>
|
||||||
<MinimalRebuild>true</MinimalRebuild>
|
<MinimalRebuild>true</MinimalRebuild>
|
||||||
<BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
|
<BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
|
||||||
|
@ -110,7 +110,7 @@
|
||||||
<InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion>
|
<InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion>
|
||||||
<FavorSizeOrSpeed>Speed</FavorSizeOrSpeed>
|
<FavorSizeOrSpeed>Speed</FavorSizeOrSpeed>
|
||||||
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;GBA_LOGGING;OEMRESOURCE;MMX;ASM;FINAL_VERSION;BKPT_SUPPORT;_CRT_SECURE_NO_DEPRECATE;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;SFML_SYSTEM_EXPORTS;SFML_NETWORK_EXPORTS;GBA_LOGGING;OEMRESOURCE;MMX;ASM;FINAL_VERSION;BKPT_SUPPORT;_CRT_SECURE_NO_DEPRECATE;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
<EnableEnhancedInstructionSet>StreamingSIMDExtensions</EnableEnhancedInstructionSet>
|
<EnableEnhancedInstructionSet>StreamingSIMDExtensions</EnableEnhancedInstructionSet>
|
||||||
<FloatingPointModel>Fast</FloatingPointModel>
|
<FloatingPointModel>Fast</FloatingPointModel>
|
||||||
|
|
|
@ -118,7 +118,7 @@
|
||||||
<ClInclude Include="..\..\src\gba\BreakpointStructures.h">
|
<ClInclude Include="..\..\src\gba\BreakpointStructures.h">
|
||||||
<Filter>Core\GBA</Filter>
|
<Filter>Core\GBA</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClInclude Include="..\..\src\gba\debugger-expr-yacc.h">
|
<ClInclude Include="..\..\src\gba\debugger-expr-yacc.hpp">
|
||||||
<Filter>Core\GBA</Filter>
|
<Filter>Core\GBA</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClInclude Include="..\..\src\gba\EEprom.h">
|
<ClInclude Include="..\..\src\gba\EEprom.h">
|
||||||
|
|
|
@ -71,7 +71,7 @@
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
<Optimization>Disabled</Optimization>
|
<Optimization>Disabled</Optimization>
|
||||||
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;_DEBUG;DEV_VERSION;BKPT_SUPPORT;GBA_LOGGING;MMX;ASM;_CRT_SECURE_NO_WARNINGS;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;_DEBUG;SFML_SYSTEM_EXPORTS;SFML_NETWORK_EXPORTS;DEV_VERSION;BKPT_SUPPORT;GBA_LOGGING;MMX;ASM;_CRT_SECURE_NO_WARNINGS;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<StringPooling>false</StringPooling>
|
<StringPooling>false</StringPooling>
|
||||||
<MinimalRebuild>true</MinimalRebuild>
|
<MinimalRebuild>true</MinimalRebuild>
|
||||||
<BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
|
<BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks>
|
||||||
|
@ -117,7 +117,7 @@
|
||||||
<InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion>
|
<InlineFunctionExpansion>AnySuitable</InlineFunctionExpansion>
|
||||||
<FavorSizeOrSpeed>Speed</FavorSizeOrSpeed>
|
<FavorSizeOrSpeed>Speed</FavorSizeOrSpeed>
|
||||||
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>..\..\src;..\..\fex;..\..\..\dependencies\libpng;..\..\..\dependencies\msvc;..\..\..\dependencies\SFML\include;..\..\..\dependencies\SubWCRev;..\..\..\dependencies\zlib;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;GBA_LOGGING;OEMRESOURCE;MMX;ASM;FINAL_VERSION;BKPT_SUPPORT;_CRT_SECURE_NO_DEPRECATE;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
<PreprocessorDefinitions>WIN32;_WINDOWS;NDEBUG;SFML_SYSTEM_EXPORTS;SFML_NETWORK_EXPORTS;GBA_LOGGING;OEMRESOURCE;MMX;ASM;FINAL_VERSION;BKPT_SUPPORT;_CRT_SECURE_NO_DEPRECATE;HAS_FILE_EXTRACTOR;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
<RuntimeLibrary>MultiThreaded</RuntimeLibrary>
|
||||||
<EnableEnhancedInstructionSet>StreamingSIMDExtensions</EnableEnhancedInstructionSet>
|
<EnableEnhancedInstructionSet>StreamingSIMDExtensions</EnableEnhancedInstructionSet>
|
||||||
<FloatingPointModel>Fast</FloatingPointModel>
|
<FloatingPointModel>Fast</FloatingPointModel>
|
||||||
|
|
|
@ -1000,6 +1000,7 @@ void gbWriteMemory(register u16 address, register u8 value)
|
||||||
case 0x02: {
|
case 0x02: {
|
||||||
gbSerialOn = (value & 0x80);
|
gbSerialOn = (value & 0x80);
|
||||||
#ifndef NO_LINK
|
#ifndef NO_LINK
|
||||||
|
#if (defined __WIN32__ || defined _WIN32)
|
||||||
//trying to detect whether the game has exited multiplay mode, pokemon blue start w/ 0x7e while pocket racing start w/ 0x7c
|
//trying to detect whether the game has exited multiplay mode, pokemon blue start w/ 0x7e while pocket racing start w/ 0x7c
|
||||||
if (EmuReseted || (gbMemory[0xff02] & 0x7c) || (value & 0x7c) || (!(value & 0x81))) {
|
if (EmuReseted || (gbMemory[0xff02] & 0x7c) || (value & 0x7c) || (!(value & 0x81))) {
|
||||||
LinkFirstTime = true;
|
LinkFirstTime = true;
|
||||||
|
@ -1035,6 +1036,7 @@ void gbWriteMemory(register u16 address, register u8 value)
|
||||||
|
|
||||||
gbSerialBits = 0;
|
gbSerialBits = 0;
|
||||||
return;
|
return;
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2493,10 +2495,12 @@ static void gbSelectColorizationPalette()
|
||||||
void gbReset()
|
void gbReset()
|
||||||
{
|
{
|
||||||
#ifndef NO_LINK
|
#ifndef NO_LINK
|
||||||
|
#if (defined __WIN32__ || defined _WIN32)
|
||||||
if (GetLinkMode() == LINK_GAMEBOY) {
|
if (GetLinkMode() == LINK_GAMEBOY) {
|
||||||
EmuReseted = true;
|
EmuReseted = true;
|
||||||
gbInitLink();
|
gbInitLink();
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gbGetHardwareType();
|
gbGetHardwareType();
|
||||||
|
@ -5556,6 +5560,7 @@ void gbEmulate(int ticksToStop)
|
||||||
gbMemory[0xff41] = register_STAT;
|
gbMemory[0xff41] = register_STAT;
|
||||||
|
|
||||||
#ifndef NO_LINK
|
#ifndef NO_LINK
|
||||||
|
#if (defined __WIN32__ || defined _WIN32)
|
||||||
// serial emulation
|
// serial emulation
|
||||||
gbSerialOn = (gbMemory[0xff02] & 0x80);
|
gbSerialOn = (gbMemory[0xff02] & 0x80);
|
||||||
static int SIOctr = 0;
|
static int SIOctr = 0;
|
||||||
|
@ -5649,6 +5654,7 @@ void gbEmulate(int ticksToStop)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
soundTicks -= clockTicks;
|
soundTicks -= clockTicks;
|
||||||
|
|
|
@ -323,17 +323,17 @@ static ConnectionState gba_connection_state = LINK_OK;
|
||||||
static int linktime = 0;
|
static int linktime = 0;
|
||||||
|
|
||||||
static GBASockClient* dol = NULL;
|
static GBASockClient* dol = NULL;
|
||||||
static sf::IPAddress joybusHostAddr = sf::IPAddress::LocalHost;
|
static sf::IpAddress joybusHostAddr = sf::IpAddress::LocalHost;
|
||||||
|
|
||||||
static const LinkDriver linkDrivers[] =
|
static const LinkDriver linkDrivers[] =
|
||||||
{
|
{
|
||||||
#if (defined __WIN32__ || defined _WIN32)
|
#if (defined __WIN32__ || defined _WIN32)
|
||||||
{ LINK_CABLE_IPC, InitIPC, NULL, StartCableIPC, UpdateCableIPC, CloseIPC, false },
|
{ LINK_CABLE_IPC, InitIPC, NULL, StartCableIPC, UpdateCableIPC, CloseIPC, false },
|
||||||
{ LINK_RFU_IPC, InitIPC, NULL, StartRFU, UpdateRFUIPC, CloseIPC, false },
|
{ LINK_RFU_IPC, InitIPC, NULL, StartRFU, UpdateRFUIPC, CloseIPC, false },
|
||||||
{ LINK_GAMEBOY, InitIPC, NULL, NULL, NULL, CloseIPC, false },
|
{ LINK_GAMEBOY, InitIPC, NULL, NULL, NULL, CloseIPC, false },
|
||||||
#endif
|
#endif
|
||||||
{ LINK_CABLE_SOCKET, InitSocket, ConnectUpdateSocket, StartCableSocket, UpdateSocket, CloseSocket, true },
|
{ LINK_CABLE_SOCKET, InitSocket, ConnectUpdateSocket, StartCableSocket, UpdateSocket, CloseSocket, true },
|
||||||
{ LINK_GAMECUBE_DOLPHIN, JoyBusConnect, NULL, NULL, JoyBusUpdate, JoyBusShutdown, false }
|
{ LINK_GAMECUBE_DOLPHIN, JoyBusConnect, NULL, NULL, JoyBusUpdate, JoyBusShutdown, false }
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
|
@ -345,7 +345,8 @@ enum
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
sf::SocketTCP tcpsocket;
|
sf::TcpSocket tcpsocket;
|
||||||
|
sf::TcpListener tcplistener;
|
||||||
int numslaves;
|
int numslaves;
|
||||||
int connectedSlaves;
|
int connectedSlaves;
|
||||||
int type;
|
int type;
|
||||||
|
@ -355,7 +356,7 @@ typedef struct {
|
||||||
|
|
||||||
class lserver{
|
class lserver{
|
||||||
int numbytes;
|
int numbytes;
|
||||||
sf::Selector<sf::SocketTCP> fdset;
|
sf::SocketSelector fdset;
|
||||||
//timeval udptimeout;
|
//timeval udptimeout;
|
||||||
char inbuffer[256], outbuffer[256];
|
char inbuffer[256], outbuffer[256];
|
||||||
s32 *intinbuffer;
|
s32 *intinbuffer;
|
||||||
|
@ -366,15 +367,15 @@ class lserver{
|
||||||
int done;
|
int done;
|
||||||
public:
|
public:
|
||||||
int howmanytimes;
|
int howmanytimes;
|
||||||
sf::SocketTCP tcpsocket[4];
|
sf::TcpSocket tcpsocket[4];
|
||||||
sf::IPAddress udpaddr[4];
|
sf::IpAddress udpaddr[4];
|
||||||
lserver(void);
|
lserver(void);
|
||||||
void Send(void);
|
void Send(void);
|
||||||
void Recv(void);
|
void Recv(void);
|
||||||
};
|
};
|
||||||
|
|
||||||
class lclient{
|
class lclient{
|
||||||
sf::Selector<sf::SocketTCP> fdset;
|
sf::SocketSelector fdset;
|
||||||
char inbuffer[256], outbuffer[256];
|
char inbuffer[256], outbuffer[256];
|
||||||
s32 *intinbuffer;
|
s32 *intinbuffer;
|
||||||
u16 *u16inbuffer;
|
u16 *u16inbuffer;
|
||||||
|
@ -382,7 +383,7 @@ class lclient{
|
||||||
u16 *u16outbuffer;
|
u16 *u16outbuffer;
|
||||||
int numbytes;
|
int numbytes;
|
||||||
public:
|
public:
|
||||||
sf::IPAddress serveraddr;
|
sf::IpAddress serveraddr;
|
||||||
unsigned short serverport;
|
unsigned short serverport;
|
||||||
int numtransfers;
|
int numtransfers;
|
||||||
lclient(void);
|
lclient(void);
|
||||||
|
@ -474,20 +475,20 @@ void GetLinkServerHost(char * const host, size_t size) {
|
||||||
host[0] = '\0';
|
host[0] = '\0';
|
||||||
|
|
||||||
if (linkDriver && linkDriver->mode == LINK_GAMECUBE_DOLPHIN)
|
if (linkDriver && linkDriver->mode == LINK_GAMECUBE_DOLPHIN)
|
||||||
strncpy(host, joybusHostAddr.ToString().c_str(), size);
|
strncpy(host, joybusHostAddr.toString().c_str(), size);
|
||||||
else if (lanlink.server)
|
else if (lanlink.server)
|
||||||
strncpy(host, sf::IPAddress::GetLocalAddress().ToString().c_str(), size);
|
strncpy(host, sf::IpAddress::getLocalAddress().toString().c_str(), size);
|
||||||
else
|
else
|
||||||
strncpy(host, lc.serveraddr.ToString().c_str(), size);
|
strncpy(host, lc.serveraddr.toString().c_str(), size);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SetLinkServerHost(const char *host) {
|
bool SetLinkServerHost(const char *host) {
|
||||||
sf::IPAddress addr = sf::IPAddress(host);
|
sf::IpAddress addr = sf::IpAddress(host);
|
||||||
|
|
||||||
lc.serveraddr = addr;
|
lc.serveraddr = addr;
|
||||||
joybusHostAddr = addr;
|
joybusHostAddr = addr;
|
||||||
|
|
||||||
return addr.IsValid();
|
return addr != sf::IpAddress::None;
|
||||||
}
|
}
|
||||||
|
|
||||||
int GetLinkPlayerId() {
|
int GetLinkPlayerId() {
|
||||||
|
@ -646,8 +647,10 @@ void StartGPLink(u16 value)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GP:
|
case GP:
|
||||||
|
#if (defined __WIN32__ || defined _WIN32)
|
||||||
if (GetLinkMode() == LINK_RFU_IPC)
|
if (GetLinkMode() == LINK_RFU_IPC)
|
||||||
rfu_state = RFU_INIT;
|
rfu_state = RFU_INIT;
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -700,9 +703,9 @@ void lserver::Send(void) {
|
||||||
outbuffer[0] = 4;
|
outbuffer[0] = 4;
|
||||||
outbuffer[1] = -32; //0xe0
|
outbuffer[1] = -32; //0xe0
|
||||||
for(i=1;i<=lanlink.numslaves;i++) {
|
for(i=1;i<=lanlink.numslaves;i++) {
|
||||||
tcpsocket[i].Send(outbuffer, 4);
|
tcpsocket[i].send(outbuffer, 4);
|
||||||
size_t nr;
|
size_t nr;
|
||||||
tcpsocket[i].Receive(inbuffer, 4, nr);
|
tcpsocket[i].receive(inbuffer, 4, nr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
outbuffer[1] = tspeed;
|
outbuffer[1] = tspeed;
|
||||||
|
@ -711,27 +714,27 @@ void lserver::Send(void) {
|
||||||
if(lanlink.numslaves==1) {
|
if(lanlink.numslaves==1) {
|
||||||
if(lanlink.type==0) {
|
if(lanlink.type==0) {
|
||||||
outbuffer[0] = 8;
|
outbuffer[0] = 8;
|
||||||
tcpsocket[1].Send(outbuffer, 8);
|
tcpsocket[1].send(outbuffer, 8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(lanlink.numslaves==2) {
|
else if(lanlink.numslaves==2) {
|
||||||
WRITE16LE(&u16outbuffer[4], linkdata[2]);
|
WRITE16LE(&u16outbuffer[4], linkdata[2]);
|
||||||
if(lanlink.type==0) {
|
if(lanlink.type==0) {
|
||||||
outbuffer[0] = 10;
|
outbuffer[0] = 10;
|
||||||
tcpsocket[1].Send(outbuffer, 10);
|
tcpsocket[1].send(outbuffer, 10);
|
||||||
WRITE16LE(&u16outbuffer[4], linkdata[1]);
|
WRITE16LE(&u16outbuffer[4], linkdata[1]);
|
||||||
tcpsocket[2].Send(outbuffer, 10);
|
tcpsocket[2].send(outbuffer, 10);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if(lanlink.type==0) {
|
if(lanlink.type==0) {
|
||||||
outbuffer[0] = 12;
|
outbuffer[0] = 12;
|
||||||
WRITE16LE(&u16outbuffer[4], linkdata[2]);
|
WRITE16LE(&u16outbuffer[4], linkdata[2]);
|
||||||
WRITE16LE(&u16outbuffer[5], linkdata[3]);
|
WRITE16LE(&u16outbuffer[5], linkdata[3]);
|
||||||
tcpsocket[1].Send(outbuffer, 12);
|
tcpsocket[1].send(outbuffer, 12);
|
||||||
WRITE16LE(&u16outbuffer[4], linkdata[1]);
|
WRITE16LE(&u16outbuffer[4], linkdata[1]);
|
||||||
tcpsocket[2].Send(outbuffer, 12);
|
tcpsocket[2].send(outbuffer, 12);
|
||||||
WRITE16LE(&u16outbuffer[5], linkdata[2]);
|
WRITE16LE(&u16outbuffer[5], linkdata[2]);
|
||||||
tcpsocket[3].Send(outbuffer, 12);
|
tcpsocket[3].send(outbuffer, 12);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -741,10 +744,10 @@ void lserver::Send(void) {
|
||||||
void lserver::Recv(void) {
|
void lserver::Recv(void) {
|
||||||
int numbytes;
|
int numbytes;
|
||||||
if(lanlink.type==0) { // TCP
|
if(lanlink.type==0) { // TCP
|
||||||
fdset.Clear();
|
fdset.clear();
|
||||||
for(i=0;i<lanlink.numslaves;i++) fdset.Add(tcpsocket[i+1]);
|
for(i=0;i<lanlink.numslaves;i++) fdset.add(tcpsocket[i+1]);
|
||||||
// was linktimeout/1000 (i.e., drop ms part), but that's wrong
|
// was linktimeout/1000 (i.e., drop ms part), but that's wrong
|
||||||
if (fdset.Wait((float)(linktimeout / 1000.)) == 0)
|
if (fdset.wait(sf::seconds((float)(linktimeout / 1000.))) == 0)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -754,7 +757,7 @@ void lserver::Recv(void) {
|
||||||
inbuffer[0] = 1;
|
inbuffer[0] = 1;
|
||||||
while(numbytes<howmanytimes*inbuffer[0]) {
|
while(numbytes<howmanytimes*inbuffer[0]) {
|
||||||
size_t nr;
|
size_t nr;
|
||||||
tcpsocket[i+1].Receive(inbuffer+numbytes, howmanytimes*inbuffer[0]-numbytes, nr);
|
tcpsocket[i+1].receive(inbuffer+numbytes, howmanytimes*inbuffer[0]-numbytes, nr);
|
||||||
numbytes += nr;
|
numbytes += nr;
|
||||||
}
|
}
|
||||||
if(howmanytimes>1) memmove(inbuffer, inbuffer+inbuffer[0]*(howmanytimes-1), inbuffer[0]);
|
if(howmanytimes>1) memmove(inbuffer, inbuffer+inbuffer[0]*(howmanytimes-1), inbuffer[0]);
|
||||||
|
@ -765,10 +768,10 @@ void lserver::Recv(void) {
|
||||||
outbuffer[0] = 4;
|
outbuffer[0] = 4;
|
||||||
outbuffer[1] = -32;
|
outbuffer[1] = -32;
|
||||||
for(i=1;i<lanlink.numslaves;i++) {
|
for(i=1;i<lanlink.numslaves;i++) {
|
||||||
tcpsocket[i].Send(outbuffer, 12);
|
tcpsocket[i].send(outbuffer, 12);
|
||||||
size_t nr;
|
size_t nr;
|
||||||
tcpsocket[i].Receive(inbuffer, 256, nr);
|
tcpsocket[i].receive(inbuffer, 256, nr);
|
||||||
tcpsocket[i].Close();
|
tcpsocket[i].disconnect();
|
||||||
}
|
}
|
||||||
CloseLink();
|
CloseLink();
|
||||||
return;
|
return;
|
||||||
|
@ -793,16 +796,16 @@ lclient::lclient(void) {
|
||||||
|
|
||||||
void lclient::CheckConn(void) {
|
void lclient::CheckConn(void) {
|
||||||
size_t nr;
|
size_t nr;
|
||||||
lanlink.tcpsocket.Receive(inbuffer, 1, nr);
|
lanlink.tcpsocket.receive(inbuffer, 1, nr);
|
||||||
numbytes = nr;
|
numbytes = nr;
|
||||||
if(numbytes>0) {
|
if(numbytes>0) {
|
||||||
while(numbytes<inbuffer[0]) {
|
while(numbytes<inbuffer[0]) {
|
||||||
lanlink.tcpsocket.Receive(inbuffer+numbytes, inbuffer[0] - numbytes, nr);
|
lanlink.tcpsocket.receive(inbuffer+numbytes, inbuffer[0] - numbytes, nr);
|
||||||
numbytes += nr;
|
numbytes += nr;
|
||||||
}
|
}
|
||||||
if(inbuffer[1]==-32) {
|
if(inbuffer[1]==-32) {
|
||||||
outbuffer[0] = 4;
|
outbuffer[0] = 4;
|
||||||
lanlink.tcpsocket.Send(outbuffer, 4);
|
lanlink.tcpsocket.send(outbuffer, 4);
|
||||||
systemScreenMessage(_("Server disconnected."));
|
systemScreenMessage(_("Server disconnected."));
|
||||||
CloseLink();
|
CloseLink();
|
||||||
return;
|
return;
|
||||||
|
@ -823,11 +826,11 @@ void lclient::CheckConn(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void lclient::Recv(void) {
|
void lclient::Recv(void) {
|
||||||
fdset.Clear();
|
fdset.clear();
|
||||||
// old code used socket # instead of mask again
|
// old code used socket # instead of mask again
|
||||||
fdset.Add(lanlink.tcpsocket);
|
fdset.add(lanlink.tcpsocket);
|
||||||
// old code stripped off ms again
|
// old code stripped off ms again
|
||||||
if (fdset.Wait((float)(linktimeout / 1000.)) == 0)
|
if (fdset.wait(sf::seconds((float)(linktimeout / 1000.))) == 0)
|
||||||
{
|
{
|
||||||
numtransfers = 0;
|
numtransfers = 0;
|
||||||
return;
|
return;
|
||||||
|
@ -836,12 +839,12 @@ void lclient::Recv(void) {
|
||||||
inbuffer[0] = 1;
|
inbuffer[0] = 1;
|
||||||
size_t nr;
|
size_t nr;
|
||||||
while(numbytes<inbuffer[0]) {
|
while(numbytes<inbuffer[0]) {
|
||||||
lanlink.tcpsocket.Receive(inbuffer+numbytes, inbuffer[0] - numbytes, nr);
|
lanlink.tcpsocket.receive(inbuffer+numbytes, inbuffer[0] - numbytes, nr);
|
||||||
numbytes += nr;
|
numbytes += nr;
|
||||||
}
|
}
|
||||||
if(inbuffer[1]==-32) {
|
if(inbuffer[1]==-32) {
|
||||||
outbuffer[0] = 4;
|
outbuffer[0] = 4;
|
||||||
lanlink.tcpsocket.Send(outbuffer, 4);
|
lanlink.tcpsocket.send(outbuffer, 4);
|
||||||
systemScreenMessage(_("Server disconnected."));
|
systemScreenMessage(_("Server disconnected."));
|
||||||
CloseLink();
|
CloseLink();
|
||||||
return;
|
return;
|
||||||
|
@ -863,7 +866,7 @@ void lclient::Send() {
|
||||||
outbuffer[0] = 4;
|
outbuffer[0] = 4;
|
||||||
outbuffer[1] = linkid<<2;
|
outbuffer[1] = linkid<<2;
|
||||||
WRITE16LE(&u16outbuffer[1], linkdata[linkid]);
|
WRITE16LE(&u16outbuffer[1], linkdata[linkid]);
|
||||||
lanlink.tcpsocket.Send(outbuffer, 4);
|
lanlink.tcpsocket.send(outbuffer, 4);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -877,11 +880,11 @@ static ConnectionState InitSocket() {
|
||||||
if (lanlink.server) {
|
if (lanlink.server) {
|
||||||
lanlink.connectedSlaves = 0;
|
lanlink.connectedSlaves = 0;
|
||||||
// should probably use GetPublicAddress()
|
// should probably use GetPublicAddress()
|
||||||
//sid->ShowServerIP(sf::IPAddress::GetLocalAddress());
|
//sid->ShowServerIP(sf::IpAddress::getLocalAddress());
|
||||||
|
|
||||||
// too bad Listen() doesn't take an address as well
|
// too bad Listen() doesn't take an address as well
|
||||||
// then again, old code used INADDR_ANY anyway
|
// then again, old code used INADDR_ANY anyway
|
||||||
if (!lanlink.tcpsocket.Listen(IP_LINK_PORT))
|
if (lanlink.tcplistener.listen(IP_LINK_PORT) == sf::Socket::Error)
|
||||||
// Note: old code closed socket & retried once on bind failure
|
// Note: old code closed socket & retried once on bind failure
|
||||||
return LINK_ERROR; // FIXME: error code?
|
return LINK_ERROR; // FIXME: error code?
|
||||||
else
|
else
|
||||||
|
@ -889,11 +892,11 @@ static ConnectionState InitSocket() {
|
||||||
} else {
|
} else {
|
||||||
lc.serverport = IP_LINK_PORT;
|
lc.serverport = IP_LINK_PORT;
|
||||||
|
|
||||||
if (!lc.serveraddr.IsValid()) {
|
if (lc.serveraddr == sf::IpAddress::None) {
|
||||||
return LINK_ERROR;
|
return LINK_ERROR;
|
||||||
} else {
|
} else {
|
||||||
lanlink.tcpsocket.SetBlocking(false);
|
lanlink.tcpsocket.setBlocking(false);
|
||||||
sf::Socket::Status status = lanlink.tcpsocket.Connect(lc.serverport, lc.serveraddr);
|
sf::Socket::Status status = lanlink.tcpsocket.connect(lc.serveraddr, lc.serverport);
|
||||||
|
|
||||||
if (status == sf::Socket::Error || status == sf::Socket::Disconnected)
|
if (status == sf::Socket::Error || status == sf::Socket::Disconnected)
|
||||||
return LINK_ERROR;
|
return LINK_ERROR;
|
||||||
|
@ -907,17 +910,17 @@ static ConnectionState ConnectUpdateSocket(char * const message, size_t size) {
|
||||||
ConnectionState newState = LINK_NEEDS_UPDATE;
|
ConnectionState newState = LINK_NEEDS_UPDATE;
|
||||||
|
|
||||||
if (lanlink.server) {
|
if (lanlink.server) {
|
||||||
sf::Selector<sf::SocketTCP> fdset;
|
sf::SocketSelector fdset;
|
||||||
fdset.Add(lanlink.tcpsocket);
|
fdset.add(lanlink.tcplistener);
|
||||||
|
|
||||||
if (fdset.Wait(0.1) == 1) {
|
if (fdset.wait(sf::seconds(0.1f))) {
|
||||||
int nextSlave = lanlink.connectedSlaves + 1;
|
int nextSlave = lanlink.connectedSlaves + 1;
|
||||||
|
|
||||||
sf::Socket::Status st = lanlink.tcpsocket.Accept(ls.tcpsocket[nextSlave]);
|
sf::Socket::Status st = lanlink.tcplistener.accept(ls.tcpsocket[nextSlave]);
|
||||||
|
|
||||||
if (st == sf::Socket::Error) {
|
if (st == sf::Socket::Error) {
|
||||||
for (int j = 1; j < nextSlave; j++)
|
for (int j = 1; j < nextSlave; j++)
|
||||||
ls.tcpsocket[j].Close();
|
ls.tcpsocket[j].disconnect();
|
||||||
|
|
||||||
snprintf(message, size, N_("Network error."));
|
snprintf(message, size, N_("Network error."));
|
||||||
newState = LINK_ERROR;
|
newState = LINK_ERROR;
|
||||||
|
@ -926,7 +929,7 @@ static ConnectionState ConnectUpdateSocket(char * const message, size_t size) {
|
||||||
packet << static_cast<sf::Uint16>(nextSlave)
|
packet << static_cast<sf::Uint16>(nextSlave)
|
||||||
<< static_cast<sf::Uint16>(lanlink.numslaves);
|
<< static_cast<sf::Uint16>(lanlink.numslaves);
|
||||||
|
|
||||||
ls.tcpsocket[nextSlave].Send(packet);
|
ls.tcpsocket[nextSlave].send(packet);
|
||||||
|
|
||||||
snprintf(message, size, N_("Player %d connected"), nextSlave);
|
snprintf(message, size, N_("Player %d connected"), nextSlave);
|
||||||
|
|
||||||
|
@ -939,7 +942,7 @@ static ConnectionState ConnectUpdateSocket(char * const message, size_t size) {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << true;
|
packet << true;
|
||||||
|
|
||||||
ls.tcpsocket[i].Send(packet);
|
ls.tcpsocket[i].send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(message, size, N_("All players connected"));
|
snprintf(message, size, N_("All players connected"));
|
||||||
|
@ -948,7 +951,7 @@ static ConnectionState ConnectUpdateSocket(char * const message, size_t size) {
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
sf::Socket::Status status = lanlink.tcpsocket.Receive(packet);
|
sf::Socket::Status status = lanlink.tcpsocket.receive(packet);
|
||||||
|
|
||||||
if (status == sf::Socket::Error || status == sf::Socket::Disconnected) {
|
if (status == sf::Socket::Error || status == sf::Socket::Disconnected) {
|
||||||
snprintf(message, size, N_("Network error."));
|
snprintf(message, size, N_("Network error."));
|
||||||
|
@ -976,9 +979,9 @@ static ConnectionState ConnectUpdateSocket(char * const message, size_t size) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sf::Selector<sf::SocketTCP> fdset;
|
sf::SocketSelector fdset;
|
||||||
fdset.Add(lanlink.tcpsocket);
|
fdset.add(lanlink.tcpsocket);
|
||||||
fdset.Wait(0.1);
|
fdset.wait(sf::seconds(0.1f));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1109,7 +1112,7 @@ static void CloseSocket() {
|
||||||
char outbuffer[4];
|
char outbuffer[4];
|
||||||
outbuffer[0] = 4;
|
outbuffer[0] = 4;
|
||||||
outbuffer[1] = -32;
|
outbuffer[1] = -32;
|
||||||
if(lanlink.type==0) lanlink.tcpsocket.Send(outbuffer, 4);
|
if(lanlink.type==0) lanlink.tcpsocket.send(outbuffer, 4);
|
||||||
} else {
|
} else {
|
||||||
char outbuffer[12];
|
char outbuffer[12];
|
||||||
int i;
|
int i;
|
||||||
|
@ -1117,12 +1120,12 @@ static void CloseSocket() {
|
||||||
outbuffer[1] = -32;
|
outbuffer[1] = -32;
|
||||||
for(i=1;i<=lanlink.numslaves;i++) {
|
for(i=1;i<=lanlink.numslaves;i++) {
|
||||||
if(lanlink.type==0) {
|
if(lanlink.type==0) {
|
||||||
ls.tcpsocket[i].Send(outbuffer, 12);
|
ls.tcpsocket[i].send(outbuffer, 12);
|
||||||
}
|
}
|
||||||
ls.tcpsocket[i].Close();
|
ls.tcpsocket[i].disconnect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
lanlink.tcpsocket.Close();
|
lanlink.tcpsocket.disconnect();
|
||||||
}
|
}
|
||||||
|
|
||||||
// call this to clean up crashed program's shared state
|
// call this to clean up crashed program's shared state
|
||||||
|
|
|
@ -4,18 +4,18 @@
|
||||||
|
|
||||||
// Currently only for Joybus communications
|
// Currently only for Joybus communications
|
||||||
|
|
||||||
GBASockClient::GBASockClient(sf::IPAddress _server_addr)
|
GBASockClient::GBASockClient(sf::IpAddress _server_addr)
|
||||||
{
|
{
|
||||||
if (!_server_addr.IsValid())
|
if (_server_addr == sf::IpAddress::None)
|
||||||
server_addr = sf::IPAddress::LocalHost;
|
server_addr = sf::IpAddress::LocalHost;
|
||||||
else
|
else
|
||||||
server_addr = _server_addr;
|
server_addr = _server_addr;
|
||||||
|
|
||||||
client.Connect(0xd6ba, server_addr);
|
client.connect(server_addr, 0xd6ba);
|
||||||
client.SetBlocking(false);
|
client.setBlocking(false);
|
||||||
|
|
||||||
clock_client.Connect(0xc10c, server_addr);
|
clock_client.connect(server_addr, 0xc10c);
|
||||||
clock_client.SetBlocking(false);
|
clock_client.setBlocking(false);
|
||||||
|
|
||||||
clock_sync = 0;
|
clock_sync = 0;
|
||||||
is_disconnected = false;
|
is_disconnected = false;
|
||||||
|
@ -23,8 +23,8 @@ GBASockClient::GBASockClient(sf::IPAddress _server_addr)
|
||||||
|
|
||||||
GBASockClient::~GBASockClient()
|
GBASockClient::~GBASockClient()
|
||||||
{
|
{
|
||||||
client.Close();
|
client.disconnect();
|
||||||
clock_client.Close();
|
clock_client.disconnect();
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 clock_sync_ticks = 0;
|
u32 clock_sync_ticks = 0;
|
||||||
|
@ -34,7 +34,7 @@ void GBASockClient::Send(std::vector<char> data)
|
||||||
char* plain_data = new char[data.size()];
|
char* plain_data = new char[data.size()];
|
||||||
std::copy(data.begin(), data.end(), plain_data);
|
std::copy(data.begin(), data.end(), plain_data);
|
||||||
|
|
||||||
client.Send(plain_data, data.size());
|
client.send(plain_data, data.size());
|
||||||
|
|
||||||
delete[] plain_data;
|
delete[] plain_data;
|
||||||
}
|
}
|
||||||
|
@ -48,11 +48,11 @@ char GBASockClient::ReceiveCmd(char* data_in, bool block)
|
||||||
std::size_t num_received = 0;
|
std::size_t num_received = 0;
|
||||||
if (block || clock_sync == 0)
|
if (block || clock_sync == 0)
|
||||||
{
|
{
|
||||||
sf::SelectorTCP Selector;
|
sf::SocketSelector Selector;
|
||||||
Selector.Add(client);
|
Selector.add(client);
|
||||||
Selector.Wait(6);
|
Selector.wait(sf::seconds(6));
|
||||||
}
|
}
|
||||||
if (client.Receive(data_in, 5, num_received) == sf::Socket::Disconnected)
|
if (client.receive(data_in, 5, num_received) == sf::Socket::Disconnected)
|
||||||
Disconnect();
|
Disconnect();
|
||||||
|
|
||||||
return data_in[0];
|
return data_in[0];
|
||||||
|
@ -65,7 +65,7 @@ void GBASockClient::ReceiveClock(bool block)
|
||||||
|
|
||||||
char sync_ticks[4] = { 0, 0, 0, 0 };
|
char sync_ticks[4] = { 0, 0, 0, 0 };
|
||||||
std::size_t num_received = 0;
|
std::size_t num_received = 0;
|
||||||
if (clock_client.Receive(sync_ticks, 4, num_received) == sf::Socket::Disconnected)
|
if (clock_client.receive(sync_ticks, 4, num_received) == sf::Socket::Disconnected)
|
||||||
Disconnect();
|
Disconnect();
|
||||||
|
|
||||||
if (num_received == 4)
|
if (num_received == 4)
|
||||||
|
@ -88,12 +88,12 @@ void GBASockClient::ClockSync(u32 ticks)
|
||||||
void GBASockClient::Disconnect()
|
void GBASockClient::Disconnect()
|
||||||
{
|
{
|
||||||
is_disconnected = true;
|
is_disconnected = true;
|
||||||
client.Close();
|
client.disconnect();
|
||||||
clock_client.Close();
|
clock_client.disconnect();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool GBASockClient::IsDisconnected()
|
bool GBASockClient::IsDisconnected()
|
||||||
{
|
{
|
||||||
return !client.IsValid() || !clock_client.IsValid() || is_disconnected;
|
return is_disconnected;
|
||||||
}
|
}
|
||||||
#endif // NO_LINK
|
#endif // NO_LINK
|
||||||
|
|
|
@ -6,10 +6,10 @@
|
||||||
class GBASockClient
|
class GBASockClient
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
GBASockClient(sf::IPAddress _server_addr);
|
GBASockClient(sf::IpAddress _server_addr);
|
||||||
~GBASockClient();
|
~GBASockClient();
|
||||||
|
|
||||||
bool Connect(sf::IPAddress server_addr);
|
bool Connect(sf::IpAddress server_addr);
|
||||||
void Send(std::vector<char> data);
|
void Send(std::vector<char> data);
|
||||||
char ReceiveCmd(char* data_in, bool block);
|
char ReceiveCmd(char* data_in, bool block);
|
||||||
void ReceiveClock(bool block);
|
void ReceiveClock(bool block);
|
||||||
|
@ -19,9 +19,9 @@ public:
|
||||||
bool IsDisconnected();
|
bool IsDisconnected();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
sf::IPAddress server_addr;
|
sf::IpAddress server_addr;
|
||||||
sf::SocketTCP client;
|
sf::TcpSocket client;
|
||||||
sf::SocketTCP clock_client;
|
sf::TcpSocket clock_client;
|
||||||
|
|
||||||
s32 clock_sync;
|
s32 clock_sync;
|
||||||
bool is_disconnected;
|
bool is_disconnected;
|
||||||
|
|
Loading…
Reference in New Issue