Example names are now more readable (ExampleLauncher.Load())

ExampleLauncher behavior is now more consistent when launching GameWindow and WinForm examples. The launcher becomes invisible, and the launched examples exist in the same thread as the launcher.
Better documentation for IExample.cs
This commit is contained in:
the_fiddler 2007-09-02 00:02:10 +00:00
parent 4c2bb7f9b4
commit 6af814b655
2 changed files with 92 additions and 72 deletions

View file

@ -29,49 +29,41 @@ namespace Examples
{ {
public partial class ExampleLauncher : Form public partial class ExampleLauncher : Form
{ {
/// <summary> SortedList<string, string> examples = new SortedList<string, string>();
/// The main entry point for the application.
/// </summary>
[STAThread]
static void Main()
{
try
{
if (File.Exists("debug.log"))
File.Delete("debug.log");
}
catch (Exception e)
{
MessageBox.Show("Could not access debug.log", e.ToString());
}
Debug.Listeners.Clear();
Debug.Listeners.Add(new TextWriterTraceListener("debug.log"));
Debug.Listeners.Add(new ConsoleTraceListener());
Debug.AutoFlush = true;
try
{
using (Form exampleLauncher = new ExampleLauncher())
{
Application.EnableVisualStyles();
Application.Run(exampleLauncher);
}
}
finally
{
Debug.Flush();
Debug.Close();
Trace.Flush();
Trace.Close();
}
}
public ExampleLauncher() public ExampleLauncher()
{ {
InitializeComponent(); InitializeComponent();
} }
public void ExampleLauncher_Load(object sender, EventArgs e)
{
// Get all examples
Type[] types = Assembly.GetExecutingAssembly().GetTypes();
foreach (Type type in types)
{
if (type.GetInterface("IExample") != null)
{
examples.Add(
type.Namespace.Replace("Examples.", String.Empty) + " " +
type.Name.Substring(1, 2) + ": " +
type.Name.Substring(3).Replace('_', ' '),
type.Namespace + "." + type.Name);
}
}
foreach (string s in examples.Keys)
listBox1.Items.Add(s);
// Select first item
if (listBox1.Items.Count > 0)
{
this.listBox1.SelectedIndex = 0;
}
}
delegate void LaunchDelegate(object example);
void Launch(object example) void Launch(object example)
{ {
Type ex = example as Type; Type ex = example as Type;
@ -81,32 +73,8 @@ namespace Examples
} }
catch (Exception expt) catch (Exception expt)
{ {
MessageBox.Show(String.Format("Stacktrace:{0}{1}{0}{0}Inner exception:{0}{2}", MessageBox.Show(String.Format("Stacktrace:{0}{1}{0}{0}Inner exception:{0}{2}",
System.Environment.NewLine, expt.StackTrace, expt.InnerException), expt.Message); System.Environment.NewLine, expt.StackTrace, expt.InnerException), expt.Message);
}
}
public void ExampleLauncher_Load(object sender, EventArgs e)
{
SortedList<string, string> sl = new SortedList<string, string>();
// Get all examples
Type[] types = Assembly.GetExecutingAssembly().GetTypes();
foreach (Type type in types)
{
if (type.GetInterface("IExample") != null)
{
sl.Add((type.Namespace.Replace("Examples.", String.Empty) + ": " + type.Name).Replace('_', ' '), null);
}
}
foreach (string s in sl.Keys)
listBox1.Items.Add(s);
// Select first item
if (listBox1.Items.Count > 0)
{
this.listBox1.SelectedIndex = 0;
} }
} }
@ -114,19 +82,22 @@ namespace Examples
{ {
if (listBox1.SelectedItem != null) if (listBox1.SelectedItem != null)
{ {
Type example = Type example = Assembly.GetExecutingAssembly().GetType(
Assembly.GetExecutingAssembly().GetType( examples[listBox1.SelectedItem.ToString()], true, true);
"Examples." + listBox1.SelectedItem.ToString().Replace(": ", ".").Replace(' ', '_'),
true,
true);
Debug.Print("Launching example: {0}", example.ToString()); Debug.Print("Launching example: {0}", example.ToString());
this.Visible = false;
if (example.BaseType == typeof(GameWindow)) if (example.BaseType == typeof(GameWindow))
{ {
// Start the GameWindow in a new thread - it runs its own message loop, and it would // Start the GameWindow in a new thread - it runs its own message loop, and it would
// interfere with the message loop of the ExampleLauncher. // interfere with the message loop of the ExampleLauncher.
new Thread(Launch).Start(example); //Thread t = new Thread(Launch);
//t.Start(example);
//t = null;
Launch(example);
//IAsyncResult res = BeginInvoke(new LaunchDelegate(Launch), example);
//EndInvoke(res);
} }
else if (example.BaseType == typeof(Form)) else if (example.BaseType == typeof(Form))
{ {
@ -134,7 +105,10 @@ namespace Examples
{ {
// In this we do not want a different thread: these examples rely on the Application.Idle // In this we do not want a different thread: these examples rely on the Application.Idle
// event, which would then be raised by both the ExampleLauncher thread *and* the new one! // event, which would then be raised by both the ExampleLauncher thread *and* the new one!
this.AddOwnedForm((Form)example.GetConstructor(Type.EmptyTypes).Invoke(null)); Form f = (Form)example.GetConstructor(Type.EmptyTypes).Invoke(null);
f.ShowDialog(this);
f.Dispose();
f = null;
} }
catch (Exception expt) catch (Exception expt)
{ {
@ -146,8 +120,16 @@ namespace Examples
expt.InnerException expt.InnerException
), ),
expt.Message); expt.Message);
throw;
} }
} }
GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();
this.Visible = true;
} }
} }
@ -170,5 +152,43 @@ namespace Examples
{ {
RunExample(); RunExample();
} }
/// <summary>
/// The main entry point for the application.
/// </summary>
[STAThread]
static void Main()
{
try
{
if (File.Exists("debug.log"))
File.Delete("debug.log");
}
catch (Exception e)
{
MessageBox.Show("Could not access debug.log", e.ToString());
}
Debug.Listeners.Clear();
Debug.Listeners.Add(new TextWriterTraceListener("debug.log"));
Debug.Listeners.Add(new ConsoleTraceListener());
Debug.AutoFlush = true;
try
{
using (Form exampleLauncher = new ExampleLauncher())
{
Application.EnableVisualStyles();
Application.Run(exampleLauncher);
}
}
finally
{
Debug.Flush();
Debug.Close();
Trace.Flush();
Trace.Close();
}
}
} }
} }

View file

@ -11,8 +11,8 @@ using System.Text;
namespace Examples namespace Examples
{ {
/// <summary> /// <summary>
/// Examples should implement this (empty) interface, so that the ExampleLauncher /// This interface is is used by the ExampleLauncher to identify OpenTK examples,
/// can identify them. /// your applications do not need to implement or use it.
/// </summary> /// </summary>
interface IExample interface IExample
{ {