mirror of
https://github.com/DrBeef/Raze.git
synced 2024-11-15 17:01:51 +00:00
Function for changing map in multiplayer
git-svn-id: https://svn.eduke32.com/eduke32@414 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
760e784ffc
commit
a35a73796c
5 changed files with 32 additions and 98 deletions
|
@ -242,5 +242,6 @@ extern void sendquit(void);
|
||||||
|
|
||||||
extern void adduserquote(char *daquote);
|
extern void adduserquote(char *daquote);
|
||||||
extern char *stripcolorcodes(char *t);
|
extern char *stripcolorcodes(char *t);
|
||||||
|
extern void mpchangemap(char volume, char level);
|
||||||
|
|
||||||
#endif // __funct_h__
|
#endif // __funct_h__
|
||||||
|
|
|
@ -7482,23 +7482,7 @@ FOUNDCHEAT:
|
||||||
ud.m_player_skill = ud.player_skill = cheatbuf[i] - '1';
|
ud.m_player_skill = ud.player_skill = cheatbuf[i] - '1';
|
||||||
}
|
}
|
||||||
if (numplayers > 1 && myconnectindex == connecthead)
|
if (numplayers > 1 && myconnectindex == connecthead)
|
||||||
{
|
mpchangemap(ud.m_volume_number,ud.m_level_number);
|
||||||
tempbuf[0] = 5;
|
|
||||||
tempbuf[1] = ud.m_level_number;
|
|
||||||
tempbuf[2] = ud.m_volume_number;
|
|
||||||
tempbuf[3] = ud.m_player_skill;
|
|
||||||
tempbuf[4] = ud.m_monsters_off;
|
|
||||||
tempbuf[5] = ud.m_respawn_monsters;
|
|
||||||
tempbuf[6] = ud.m_respawn_items;
|
|
||||||
tempbuf[7] = ud.m_respawn_inventory;
|
|
||||||
tempbuf[8] = ud.m_coop;
|
|
||||||
tempbuf[9] = ud.m_marker;
|
|
||||||
tempbuf[10] = ud.m_ffire;
|
|
||||||
tempbuf[11] = ud.m_noexits;
|
|
||||||
|
|
||||||
for (i=connecthead;i>=0;i=connectpoint2[i])
|
|
||||||
sendpacket(i,tempbuf,12);
|
|
||||||
}
|
|
||||||
else ps[myconnectindex].gm |= MODE_RESTART;
|
else ps[myconnectindex].gm |= MODE_RESTART;
|
||||||
|
|
||||||
ps[myconnectindex].cheat_phase = 0;
|
ps[myconnectindex].cheat_phase = 0;
|
||||||
|
@ -9511,6 +9495,30 @@ void sendboardname(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void mpchangemap(char volume, char level)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
tempbuf[0] = 5;
|
||||||
|
tempbuf[1] = ud.m_level_number = level;
|
||||||
|
tempbuf[2] = ud.m_volume_number = volume;
|
||||||
|
tempbuf[3] = ud.m_player_skill+1;
|
||||||
|
tempbuf[4] = ud.m_monsters_off;
|
||||||
|
tempbuf[5] = ud.m_respawn_monsters;
|
||||||
|
tempbuf[6] = ud.m_respawn_items;
|
||||||
|
tempbuf[7] = ud.m_respawn_inventory;
|
||||||
|
tempbuf[8] = ud.m_coop;
|
||||||
|
tempbuf[9] = ud.m_marker;
|
||||||
|
tempbuf[10] = ud.m_ffire;
|
||||||
|
tempbuf[11] = ud.m_noexits;
|
||||||
|
|
||||||
|
for (i=connecthead;i>=0;i=connectpoint2[i])
|
||||||
|
{
|
||||||
|
if (i != myconnectindex) sendpacket(i,tempbuf,12);
|
||||||
|
if ((!networkmode) && (myconnectindex != connecthead)) break; //slaves in M/S mode only send to master
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void getnames(void)
|
static void getnames(void)
|
||||||
{
|
{
|
||||||
int l;
|
int l;
|
||||||
|
|
|
@ -4475,26 +4475,7 @@ SKIPJIBS:
|
||||||
ud.m_volume_number = ud.volume_number = volnume;
|
ud.m_volume_number = ud.volume_number = volnume;
|
||||||
ud.m_level_number = ud.level_number = levnume;
|
ud.m_level_number = ud.level_number = levnume;
|
||||||
if (numplayers > 1 && myconnectindex == connecthead)
|
if (numplayers > 1 && myconnectindex == connecthead)
|
||||||
{
|
mpchangemap(volnume,levnume);
|
||||||
tempbuf[0] = 5;
|
|
||||||
tempbuf[1] = ud.m_level_number;
|
|
||||||
tempbuf[2] = ud.m_volume_number;
|
|
||||||
tempbuf[3] = ud.m_player_skill;
|
|
||||||
tempbuf[4] = ud.m_monsters_off;
|
|
||||||
tempbuf[5] = ud.m_respawn_monsters;
|
|
||||||
tempbuf[6] = ud.m_respawn_items;
|
|
||||||
tempbuf[7] = ud.m_respawn_inventory;
|
|
||||||
tempbuf[8] = ud.m_coop;
|
|
||||||
tempbuf[9] = ud.m_marker;
|
|
||||||
tempbuf[10] = ud.m_ffire;
|
|
||||||
tempbuf[11] = ud.m_noexits;
|
|
||||||
|
|
||||||
for (i=connecthead;i>=0;i=connectpoint2[i])
|
|
||||||
{
|
|
||||||
if (i != myconnectindex) sendpacket(i,tempbuf,12);
|
|
||||||
if ((!networkmode) && (myconnectindex != connecthead)) break; //slaves in M/S mode only send to master
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ps[myconnectindex].gm |= MODE_EOL;
|
ps[myconnectindex].gm |= MODE_EOL;
|
||||||
|
|
|
@ -4498,11 +4498,6 @@ VOLUME_ALL_40x:
|
||||||
{
|
{
|
||||||
if (plrvotes > (numplayers>>1) || !ps[myconnectindex].i || (!networkmode && myconnectindex == connecthead))
|
if (plrvotes > (numplayers>>1) || !ps[myconnectindex].i || (!networkmode && myconnectindex == connecthead))
|
||||||
{
|
{
|
||||||
tempbuf[0] = 5;
|
|
||||||
tempbuf[1] = ud.m_level_number;
|
|
||||||
tempbuf[2] = ud.m_volume_number;
|
|
||||||
tempbuf[3] = ud.m_player_skill+1;
|
|
||||||
|
|
||||||
if (ud.m_player_skill == 3) ud.m_respawn_monsters = 1;
|
if (ud.m_player_skill == 3) ud.m_respawn_monsters = 1;
|
||||||
else ud.m_respawn_monsters = 0;
|
else ud.m_respawn_monsters = 0;
|
||||||
|
|
||||||
|
@ -4511,26 +4506,14 @@ VOLUME_ALL_40x:
|
||||||
|
|
||||||
ud.m_respawn_inventory = 1;
|
ud.m_respawn_inventory = 1;
|
||||||
|
|
||||||
tempbuf[4] = ud.m_monsters_off;
|
|
||||||
tempbuf[5] = ud.m_respawn_monsters;
|
|
||||||
tempbuf[6] = ud.m_respawn_items;
|
|
||||||
tempbuf[7] = ud.m_respawn_inventory;
|
|
||||||
tempbuf[8] = ud.m_coop;
|
|
||||||
tempbuf[9] = ud.m_marker;
|
|
||||||
tempbuf[10] = ud.m_ffire;
|
|
||||||
tempbuf[11] = ud.m_noexits;
|
|
||||||
|
|
||||||
for (c=connecthead;c>=0;c=connectpoint2[c])
|
for (c=connecthead;c>=0;c=connectpoint2[c])
|
||||||
{
|
{
|
||||||
resetweapons(c);
|
resetweapons(c);
|
||||||
resetinventory(c);
|
resetinventory(c);
|
||||||
|
|
||||||
}
|
}
|
||||||
for (c=connecthead;c>=0;c=connectpoint2[c])
|
|
||||||
{
|
mpchangemap(ud.m_volume_number,ud.m_level_number);
|
||||||
if (c != myconnectindex) sendpacket(c,tempbuf,12);
|
|
||||||
if ((!networkmode) && (myconnectindex != connecthead)) break; //slaves in M/S mode only send to master
|
|
||||||
}
|
|
||||||
|
|
||||||
if (voting == myconnectindex)
|
if (voting == myconnectindex)
|
||||||
adduserquote("VOTE SUCCEEDED");
|
adduserquote("VOTE SUCCEEDED");
|
||||||
|
|
|
@ -101,28 +101,7 @@ int osdcmd_changelevel(const osdfuncparm_t *parm)
|
||||||
if (numplayers > 1)
|
if (numplayers > 1)
|
||||||
{
|
{
|
||||||
if (myconnectindex == connecthead && networkmode == 0)
|
if (myconnectindex == connecthead && networkmode == 0)
|
||||||
{
|
mpchangemap(volume,level);
|
||||||
int i;
|
|
||||||
|
|
||||||
tempbuf[0] = 5;
|
|
||||||
tempbuf[1] = ud.m_level_number = level;
|
|
||||||
tempbuf[2] = ud.m_volume_number = volume;
|
|
||||||
tempbuf[3] = ud.m_player_skill;
|
|
||||||
tempbuf[4] = ud.m_monsters_off;
|
|
||||||
tempbuf[5] = ud.m_respawn_monsters;
|
|
||||||
tempbuf[6] = ud.m_respawn_items;
|
|
||||||
tempbuf[7] = ud.m_respawn_inventory;
|
|
||||||
tempbuf[8] = ud.m_coop;
|
|
||||||
tempbuf[9] = ud.m_marker;
|
|
||||||
tempbuf[10] = ud.m_ffire;
|
|
||||||
tempbuf[11] = ud.m_noexits;
|
|
||||||
|
|
||||||
for (i=connecthead;i>=0;i=connectpoint2[i])
|
|
||||||
{
|
|
||||||
if (i != myconnectindex) sendpacket(i,tempbuf,12);
|
|
||||||
if ((!networkmode) && (myconnectindex != connecthead)) break; //slaves in M/S mode only send to master
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (voting == -1)
|
else if (voting == -1)
|
||||||
{
|
{
|
||||||
ud.m_volume_number = volume;
|
ud.m_volume_number = volume;
|
||||||
|
@ -221,25 +200,7 @@ int osdcmd_map(const osdfuncparm_t *parm)
|
||||||
if (myconnectindex == connecthead && networkmode == 0)
|
if (myconnectindex == connecthead && networkmode == 0)
|
||||||
{
|
{
|
||||||
sendboardname();
|
sendboardname();
|
||||||
|
mpchangemap(0,7);
|
||||||
tempbuf[0] = 5;
|
|
||||||
tempbuf[1] = ud.m_level_number = 7;
|
|
||||||
tempbuf[2] = ud.m_volume_number = 0;
|
|
||||||
tempbuf[3] = ud.m_player_skill;
|
|
||||||
tempbuf[4] = ud.m_monsters_off;
|
|
||||||
tempbuf[5] = ud.m_respawn_monsters;
|
|
||||||
tempbuf[6] = ud.m_respawn_items;
|
|
||||||
tempbuf[7] = ud.m_respawn_inventory;
|
|
||||||
tempbuf[8] = ud.m_coop;
|
|
||||||
tempbuf[9] = ud.m_marker;
|
|
||||||
tempbuf[10] = ud.m_ffire;
|
|
||||||
tempbuf[11] = ud.m_noexits;
|
|
||||||
|
|
||||||
for (i=connecthead;i>=0;i=connectpoint2[i])
|
|
||||||
{
|
|
||||||
if (i != myconnectindex) sendpacket(i,tempbuf,12);
|
|
||||||
if ((!networkmode) && (myconnectindex != connecthead)) break; //slaves in M/S mode only send to master
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (voting == -1)
|
else if (voting == -1)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue