|
@@ -39,6 +39,32 @@ function Core_ClientServerListener::onMapLoadComplete(%this)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+function Core_ClientServerListener::onmapLoadFail(%this, %isFine)
|
|
|
|
+{
|
|
|
|
+ if (%isFine)
|
|
|
|
+ {
|
|
|
|
+ %this.onMapLoadComplete();
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ $moduleLoadedFailed++;
|
|
|
|
+ echo("onmapLoadFail!");
|
|
|
|
+ if ($moduleLoadedFailed>1) return; // yeah, we know
|
|
|
|
+
|
|
|
|
+ $Server::LoadFailMsg = "Failed to load map!";
|
|
|
|
+ // Inform clients that are already connected
|
|
|
|
+
|
|
|
|
+ for (%clientIndex = 0; %clientIndex < ClientGroup.getCount(); %clientIndex++)
|
|
|
|
+ {
|
|
|
|
+ %cl = ClientGroup.getObject( %clientIndex );
|
|
|
|
+ %cl.onConnectionDropped($Server::LoadFailMsg);
|
|
|
|
+ %cl.endMission();
|
|
|
|
+ %cl.resetGhosting();
|
|
|
|
+ %cl.clearPaths();
|
|
|
|
+ }
|
|
|
|
+ destroyServer();
|
|
|
|
+}
|
|
|
|
+
|
|
function Core_ClientServer::onCreate( %this )
|
|
function Core_ClientServer::onCreate( %this )
|
|
{
|
|
{
|
|
echo("\n--------- Initializing Directory: scripts ---------");
|
|
echo("\n--------- Initializing Directory: scripts ---------");
|
|
@@ -61,8 +87,10 @@ function Core_ClientServer::onCreate( %this )
|
|
initClient();
|
|
initClient();
|
|
}
|
|
}
|
|
%this.GetEventManager().registerEvent("mapLoadComplete");
|
|
%this.GetEventManager().registerEvent("mapLoadComplete");
|
|
|
|
+ %this.GetEventManager().registerEvent("mapLoadFail");
|
|
%this.listener = new ScriptMsgListener() {class = Core_ClientServerListener;};
|
|
%this.listener = new ScriptMsgListener() {class = Core_ClientServerListener;};
|
|
%this.GetEventManager().subscribe( %this.listener, "mapLoadComplete" );
|
|
%this.GetEventManager().subscribe( %this.listener, "mapLoadComplete" );
|
|
|
|
+ %this.GetEventManager().subscribe( %this.listener, "mapLoadFail" );
|
|
}
|
|
}
|
|
|
|
|
|
function Core_ClientServer::onDestroy( %this )
|
|
function Core_ClientServer::onDestroy( %this )
|