ClassiCube/Program.cs
2015-04-04 13:05:53 +11:00

91 lines
No EOL
2.9 KiB
C#

using System;
using System.Diagnostics;
using System.IO;
using System.Net;
using System.Windows.Forms;
namespace ClassicalSharp {
class Program {
[STAThread]
public static void Main( string[] args ) {
if( !Debugger.IsAttached ) {
AppDomain.CurrentDomain.UnhandledException += UnhandledException;
}
Console.WriteLine( "Starting " + Utils.AppName + ".." );
if( !AllResourcesExist( "terrain.png", "char.png", "clouds.png" ) ) {
return;
}
if( args.Length < 4 ) {
Fail( "ClassicalSharp.exe is only the raw client. You must either use the launcher or"
+ " provide command line arguments to start the client." );
return;
}
IPAddress ip = null;
if( !IPAddress.TryParse( args[2], out ip ) ) {
Fail( "Invalid IP \"" + args[2] + '"' );
}
int port = 0;
if( !Int32.TryParse( args[3], out port ) ) {
Fail( "Invalid port \"" + args[3] + '"' );
return;
} else if( port < ushort.MinValue || port > ushort.MaxValue ) {
Fail( "Specified port " + port + " is out of valid range." );
}
string skinServer = args.Length >= 5 ? args[4] : "http://s3.amazonaws.com/MinecraftSkins/";
using( Game game = new Game() ) {
game.Username = args[0];
game.Mppass = args[1];
game.IPAddress = ip;
game.Port = port;
game.skinServer = skinServer;
game.Run();
}
}
static bool AllResourcesExist( params string[] resources ) {
foreach( string resource in resources ) {
if( !File.Exists( resource ) ) {
Fail( resource + " not found. Cannot start." );
return false;
}
}
return true;
}
static void Fail( string text ) {
Utils.LogWarning( text );
Console.WriteLine( "Press any key to exit.." );
Console.ReadKey( true );
}
static void UnhandledException( object sender, UnhandledExceptionEventArgs e ) {
// So we don't get the normal unhelpful crash dialog on Windows.
Exception ex = (Exception)e.ExceptionObject;
string error = ex.GetType().FullName + ": " + ex.Message + Environment.NewLine + ex.StackTrace;
try {
using( StreamWriter writer = new StreamWriter( "crash.log", true ) ) {
writer.WriteLine( "Crash time: " + DateTime.Now.ToString() );
writer.WriteLine( error );
writer.WriteLine();
}
} catch( Exception ) {
}
MessageBox.Show(
"Oh dear. ClassicalSharp has crashed." + Environment.NewLine + Environment.NewLine +
" The cause of the crash has been logged to \"crash.log\". Please consider reporting the " +
"crash (and the circumstances that caused it) to github.com/UnknownShadow200/ClassicalSharp/issues " +
Environment.NewLine + Environment.NewLine +
"(the cause of the crash is reproduced below)" + Environment.NewLine + error,
"ClassicalSharp has crashed" );
Environment.Exit( 1 );
}
}
}