mirror of
https://git.alee14.me/shiftos-archive/ShiftOS_TheReturn.git
synced 2025-01-22 18:02:16 +00:00
ReflectMan Saves The Day..............
Refactored every part in the code that used that damn foreach loop. All assemblies are now loaded on startup into an array, and the results of GetType() on each are concatenated into another array. The parts of the code that were loading the assemblies and scanning them themselves now look to ReflectMan.Types, and all disk I/O is limited to the first time ReflectMan is accessed. While I was there I also replaced some other foreach loops with array comprehensions and such to speed things up - there is a noticeable improvement. It doesn't seem to have broken anything, but I'd appreciate if someone could do more stress testing for me.
This commit is contained in:
parent
c3deaa23ff
commit
107a98686a
21 changed files with 376 additions and 665 deletions
|
@ -92,70 +92,51 @@ namespace ShiftOS.WinForms.Applications
|
|||
{
|
||||
flbody.Controls.Clear(); //Clear the icon list.
|
||||
|
||||
List<Type> types = new List<Type>();
|
||||
Type[] types = Array.FindAll(ReflectMan.Types, x => x.GetCustomAttributes(false).FirstOrDefault(y => y is DefaultIconAttribute) != null);
|
||||
|
||||
foreach(var exe in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
pageCount = types.GetPageCount(pageSize);
|
||||
|
||||
foreach (var type in Array.FindAll(types.GetItemsOnPage(currentPage, pageSize), t => Shiftorium.UpgradeAttributesUnlocked(t)))
|
||||
{
|
||||
if(exe.ToLower().EndsWith(".exe") || exe.ToLower().EndsWith(".dll"))
|
||||
var pnl = new Panel();
|
||||
pnl.Height = 30;
|
||||
pnl.Width = flbody.Width - 15;
|
||||
flbody.Controls.Add(pnl);
|
||||
pnl.Show();
|
||||
var pic = new PictureBox();
|
||||
pic.SizeMode = PictureBoxSizeMode.StretchImage;
|
||||
pic.Size = new Size(24, 24);
|
||||
pic.Image = GetIcon(type.Name);
|
||||
pnl.Controls.Add(pic);
|
||||
pic.Left = 5;
|
||||
pic.Top = (pnl.Height - pic.Height) / 2;
|
||||
pic.Show();
|
||||
var lbl = new Label();
|
||||
lbl.Tag = "header3";
|
||||
lbl.AutoSize = true;
|
||||
lbl.Text = NameChangerBackend.GetNameRaw(type);
|
||||
ControlManager.SetupControl(lbl);
|
||||
pnl.Controls.Add(lbl);
|
||||
lbl.CenterParent();
|
||||
lbl.Show();
|
||||
var btn = new Button();
|
||||
btn.Text = "Change...";
|
||||
btn.AutoSize = true;
|
||||
btn.AutoSizeMode = AutoSizeMode.GrowAndShrink;
|
||||
pnl.Controls.Add(btn);
|
||||
btn.Left = (pnl.Width - btn.Width) - 5;
|
||||
btn.Top = (pnl.Height - btn.Height) / 2;
|
||||
btn.Click += (o, a) =>
|
||||
{
|
||||
try
|
||||
var gfp = new GraphicPicker(pic.Image, lbl.Text + " icon", ImageLayout.Stretch, (raw, img, layout) =>
|
||||
{
|
||||
var asm = Assembly.LoadFile(exe);
|
||||
|
||||
var typeList = asm.GetTypes().Where(x => x.GetCustomAttributes(false).FirstOrDefault(y => y is DefaultIconAttribute) != null);
|
||||
types.AddRange(typeList);
|
||||
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
|
||||
pageCount = types.ToArray().GetPageCount(pageSize);
|
||||
|
||||
foreach (var type in types.ToArray().GetItemsOnPage(currentPage, pageSize))
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
var pnl = new Panel();
|
||||
pnl.Height = 30;
|
||||
pnl.Width = flbody.Width - 15;
|
||||
flbody.Controls.Add(pnl);
|
||||
pnl.Show();
|
||||
var pic = new PictureBox();
|
||||
pic.SizeMode = PictureBoxSizeMode.StretchImage;
|
||||
pic.Size = new Size(24, 24);
|
||||
pic.Image = GetIcon(type.Name);
|
||||
pnl.Controls.Add(pic);
|
||||
pic.Left = 5;
|
||||
pic.Top = (pnl.Height - pic.Height) / 2;
|
||||
pic.Show();
|
||||
var lbl = new Label();
|
||||
lbl.Tag = "header3";
|
||||
lbl.AutoSize = true;
|
||||
lbl.Text = NameChangerBackend.GetNameRaw(type);
|
||||
ControlManager.SetupControl(lbl);
|
||||
pnl.Controls.Add(lbl);
|
||||
lbl.CenterParent();
|
||||
lbl.Show();
|
||||
var btn = new Button();
|
||||
btn.Text = "Change...";
|
||||
btn.AutoSize = true;
|
||||
btn.AutoSizeMode = AutoSizeMode.GrowAndShrink;
|
||||
pnl.Controls.Add(btn);
|
||||
btn.Left = (pnl.Width - btn.Width) - 5;
|
||||
btn.Top = (pnl.Height - btn.Height) / 2;
|
||||
btn.Click += (o, a) =>
|
||||
{
|
||||
var gfp = new GraphicPicker(pic.Image, lbl.Text + " icon", ImageLayout.Stretch, (raw, img, layout) =>
|
||||
{
|
||||
pic.Image = img;
|
||||
SetIcon(type.Name, raw);
|
||||
});
|
||||
AppearanceManager.SetupDialog(gfp);
|
||||
};
|
||||
btn.Show();
|
||||
ControlManager.SetupControls(pnl);
|
||||
}
|
||||
pic.Image = img;
|
||||
SetIcon(type.Name, raw);
|
||||
});
|
||||
AppearanceManager.SetupDialog(gfp);
|
||||
};
|
||||
btn.Show();
|
||||
ControlManager.SetupControls(pnl);
|
||||
}
|
||||
|
||||
btnnext.Visible = (currentPage < pageCount - 1);
|
||||
|
|
|
@ -150,79 +150,60 @@ namespace ShiftOS.WinForms.Applications
|
|||
{
|
||||
|
||||
txturl.Text = url;
|
||||
foreach(var exe in Directory.GetFiles(Environment.CurrentDirectory))
|
||||
try
|
||||
{
|
||||
if(exe.EndsWith(".exe") || exe.EndsWith(".dll"))
|
||||
foreach (var type in Array.FindAll(ReflectMan.Types, t => t.GetInterfaces().Contains(typeof(IShiftnetSite)) && t.BaseType == typeof(UserControl) && Shiftorium.UpgradeAttributesUnlocked(t)))
|
||||
{
|
||||
try
|
||||
var attribute = type.GetCustomAttributes(false).FirstOrDefault(x => x is ShiftnetSiteAttribute && (x as ShiftnetSiteAttribute).Url == url) as ShiftnetSiteAttribute;
|
||||
if (attribute != null)
|
||||
{
|
||||
var asm = Assembly.LoadFile(exe);
|
||||
foreach (var type in asm.GetTypes())
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IShiftnetSite)))
|
||||
var obj = (IShiftnetSite)Activator.CreateInstance(type, null);
|
||||
obj.GoToUrl += (u) =>
|
||||
{
|
||||
if (type.BaseType == typeof(UserControl))
|
||||
{
|
||||
var attribute = type.GetCustomAttributes(false).FirstOrDefault(x => x is ShiftnetSiteAttribute) as ShiftnetSiteAttribute;
|
||||
if (attribute != null)
|
||||
{
|
||||
if (attribute.Url == url)
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
var obj = (IShiftnetSite)Activator.CreateInstance(type, null);
|
||||
obj.GoToUrl += (u) =>
|
||||
{
|
||||
History.Push(CurrentUrl);
|
||||
NavigateToUrl(u);
|
||||
};
|
||||
obj.GoBack += () =>
|
||||
{
|
||||
string u = History.Pop();
|
||||
Future.Push(u);
|
||||
NavigateToUrl(u);
|
||||
};
|
||||
CurrentPage = obj;
|
||||
this.pnlcanvas.Controls.Clear();
|
||||
this.pnlcanvas.Controls.Add((UserControl)obj);
|
||||
((UserControl)obj).Show();
|
||||
((UserControl)obj).Dock = DockStyle.Fill;
|
||||
obj.OnUpgrade();
|
||||
obj.OnSkinLoad();
|
||||
obj.Setup();
|
||||
AppearanceManager.SetWindowTitle(this, attribute.Name + " - Shiftnet");
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
pnlcanvas.Controls.Clear();
|
||||
var tlbl = new Label();
|
||||
tlbl.Text = "Server error in \"" + url + "\" application.";
|
||||
tlbl.Tag = "header1";
|
||||
tlbl.AutoSize = true;
|
||||
tlbl.Location = new Point(10, 10);
|
||||
tlbl.Dock = DockStyle.Top;
|
||||
pnlcanvas.Controls.Add(tlbl);
|
||||
tlbl.Show();
|
||||
|
||||
var crash = new Label();
|
||||
crash.Dock = DockStyle.Fill;
|
||||
crash.AutoSize = false;
|
||||
crash.Text = ex.ToString();
|
||||
pnlcanvas.Controls.Add(crash);
|
||||
crash.Show();
|
||||
crash.BringToFront();
|
||||
ControlManager.SetupControls(pnlcanvas);
|
||||
return;
|
||||
History.Push(CurrentUrl);
|
||||
NavigateToUrl(u);
|
||||
};
|
||||
obj.GoBack += () =>
|
||||
{
|
||||
string u = History.Pop();
|
||||
Future.Push(u);
|
||||
NavigateToUrl(u);
|
||||
};
|
||||
CurrentPage = obj;
|
||||
this.pnlcanvas.Controls.Clear();
|
||||
this.pnlcanvas.Controls.Add((UserControl)obj);
|
||||
((UserControl)obj).Show();
|
||||
((UserControl)obj).Dock = DockStyle.Fill;
|
||||
obj.OnUpgrade();
|
||||
obj.OnSkinLoad();
|
||||
obj.Setup();
|
||||
AppearanceManager.SetWindowTitle(this, attribute.Name + " - Shiftnet");
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
pnlcanvas.Controls.Clear();
|
||||
var tlbl = new Label();
|
||||
tlbl.Text = "Server error in \"" + url + "\" application.";
|
||||
tlbl.Tag = "header1";
|
||||
tlbl.AutoSize = true;
|
||||
tlbl.Location = new Point(10, 10);
|
||||
tlbl.Dock = DockStyle.Top;
|
||||
pnlcanvas.Controls.Add(tlbl);
|
||||
tlbl.Show();
|
||||
|
||||
var crash = new Label();
|
||||
crash.Dock = DockStyle.Fill;
|
||||
crash.AutoSize = false;
|
||||
crash.Text = ex.ToString();
|
||||
pnlcanvas.Controls.Add(crash);
|
||||
crash.Show();
|
||||
crash.BringToFront();
|
||||
ControlManager.SetupControls(pnlcanvas);
|
||||
return;
|
||||
}
|
||||
pnlcanvas.Controls.Clear();
|
||||
var lbl = new Label();
|
||||
lbl.Text = "Page not found!";
|
||||
|
|
|
@ -114,8 +114,12 @@ namespace ShiftOS.WinForms.Applications
|
|||
|
||||
private void SetList()
|
||||
{
|
||||
lbnoupgrades.Hide();
|
||||
lbupgrades.Items.Clear();
|
||||
if (upgrades.Length == 0)
|
||||
return;
|
||||
lbnoupgrades.Hide();
|
||||
if (CategoryId > upgrades.Length)
|
||||
CategoryId = 0;
|
||||
try
|
||||
{
|
||||
lbupgrades.Items.AddRange(upgrades[CategoryId].Keys.ToArray());
|
||||
|
@ -250,6 +254,7 @@ namespace ShiftOS.WinForms.Applications
|
|||
|
||||
private void moveCat(short direction) // direction is -1 to move backwards or 1 to move forwards
|
||||
{
|
||||
if (cats.Length == 0) return;
|
||||
CategoryId += direction;
|
||||
CategoryId %= cats.Length;
|
||||
if (CategoryId < 0) CategoryId += cats.Length; // fix modulo on negatives
|
||||
|
|
|
@ -679,28 +679,13 @@ namespace ShiftOS.WinForms
|
|||
[Command("list", description ="Lists all story IDs.")]
|
||||
public static bool ListIds()
|
||||
{
|
||||
foreach(var exec in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if(exec.ToLower().EndsWith(".exe") || exec.ToLower().EndsWith(".dll"))
|
||||
foreach(var type in ReflectMan.Types)
|
||||
foreach(var method in type.GetMethods(BindingFlags.Public | BindingFlags.Static))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(exec);
|
||||
{
|
||||
foreach(var type in asm.GetTypes())
|
||||
{
|
||||
foreach(var method in type.GetMethods(BindingFlags.Public | BindingFlags.Static))
|
||||
{
|
||||
var attr = method.GetCustomAttributes(false).FirstOrDefault(x => x is StoryAttribute);
|
||||
if (attr != null)
|
||||
Console.WriteLine(" - " + (attr as StoryAttribute).StoryID);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
var attr = method.GetCustomAttributes(false).FirstOrDefault(x => x is StoryAttribute);
|
||||
if (attr != null)
|
||||
Console.WriteLine(" - " + (attr as StoryAttribute).StoryID);
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -114,53 +114,39 @@ namespace ShiftOS.WinForms
|
|||
{
|
||||
var defaultList = JsonConvert.DeserializeObject<List<ShiftoriumUpgrade>>(Properties.Resources.Shiftorium);
|
||||
|
||||
foreach(var exe in Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach (var type in ReflectMan.Types)
|
||||
{
|
||||
if (exe.EndsWith(".exe") || exe.EndsWith(".dll"))
|
||||
var attribs = type.GetCustomAttributes(false);
|
||||
var attrib = attribs.FirstOrDefault(x => x is AppscapeEntryAttribute) as AppscapeEntryAttribute;
|
||||
if (attrib != null)
|
||||
{
|
||||
try
|
||||
var upgrade = new ShiftoriumUpgrade
|
||||
{
|
||||
var asm = Assembly.LoadFile(exe);
|
||||
foreach (var type in asm.GetTypes())
|
||||
{
|
||||
var attrib = type.GetCustomAttributes(false).FirstOrDefault(x => x is AppscapeEntryAttribute) as AppscapeEntryAttribute;
|
||||
if (attrib != null)
|
||||
{
|
||||
var upgrade = new ShiftoriumUpgrade
|
||||
{
|
||||
Id = attrib.Name.ToLower().Replace(" ", "_"),
|
||||
Name = attrib.Name,
|
||||
Description = attrib.Description,
|
||||
Cost = attrib.Cost,
|
||||
Category = attrib.Category,
|
||||
Dependencies = (string.IsNullOrWhiteSpace(attrib.DependencyString)) ? "appscape_handled_nodisplay" : "appscape_handled_nodisplay;" + attrib.DependencyString
|
||||
};
|
||||
defaultList.Add(upgrade);
|
||||
}
|
||||
|
||||
var sattrib = type.GetCustomAttributes(false).FirstOrDefault(x => x is StpContents) as StpContents;
|
||||
if (sattrib != null)
|
||||
{
|
||||
var upgrade = new ShiftoriumUpgrade
|
||||
{
|
||||
Id = sattrib.Upgrade,
|
||||
Name = sattrib.Name,
|
||||
Description = "This is a hidden dummy upgrade for the .stp file installation attribute \"" + sattrib.Name + "\".",
|
||||
Cost = 0,
|
||||
Category = "If this is shown, there's a bug in the Shiftorium Provider or the user is a supreme Shifter.",
|
||||
Dependencies = "dummy_nodisplay"
|
||||
};
|
||||
defaultList.Add(upgrade);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
catch { }
|
||||
Id = attrib.Name.ToLower().Replace(" ", "_"),
|
||||
Name = attrib.Name,
|
||||
Description = attrib.Description,
|
||||
Cost = attrib.Cost,
|
||||
Category = attrib.Category,
|
||||
Dependencies = (string.IsNullOrWhiteSpace(attrib.DependencyString)) ? "appscape_handled_nodisplay" : "appscape_handled_nodisplay;" + attrib.DependencyString
|
||||
};
|
||||
defaultList.Add(upgrade);
|
||||
}
|
||||
|
||||
var sattrib = attribs.FirstOrDefault(x => x is StpContents) as StpContents;
|
||||
if (sattrib != null)
|
||||
{
|
||||
var upgrade = new ShiftoriumUpgrade
|
||||
{
|
||||
Id = sattrib.Upgrade,
|
||||
Name = sattrib.Name,
|
||||
Description = "This is a hidden dummy upgrade for the .stp file installation attribute \"" + sattrib.Name + "\".",
|
||||
Cost = 0,
|
||||
Category = "If this is shown, there's a bug in the Shiftorium Provider or the user is a supreme Shifter.",
|
||||
Dependencies = "dummy_nodisplay"
|
||||
};
|
||||
defaultList.Add(upgrade);
|
||||
}
|
||||
|
||||
}
|
||||
return defaultList;
|
||||
}
|
||||
|
|
|
@ -207,33 +207,21 @@ namespace ShiftOS.WinForms.ShiftnetSites
|
|||
if (result == true)
|
||||
{
|
||||
SaveSystem.CurrentSave.Codepoints -= upg.Cost;
|
||||
foreach (var exe in Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach (var type in ReflectMan.Types)
|
||||
{
|
||||
if (exe.EndsWith(".exe") || exe.EndsWith(".dll"))
|
||||
var attrib = type.GetCustomAttributes(false).FirstOrDefault(x => x is AppscapeEntryAttribute) as AppscapeEntryAttribute;
|
||||
if (attrib != null)
|
||||
{
|
||||
try
|
||||
if (attrib.Name == upg.Name)
|
||||
{
|
||||
var asm = Assembly.LoadFile(exe);
|
||||
foreach (var type in asm.GetTypes())
|
||||
{
|
||||
var attrib = type.GetCustomAttributes(false).FirstOrDefault(x => x is AppscapeEntryAttribute) as AppscapeEntryAttribute;
|
||||
if (attrib != null)
|
||||
{
|
||||
if (attrib.Name == upg.Name)
|
||||
{
|
||||
var installer = new Applications.Installer();
|
||||
var installation = new AppscapeInstallation(upg.Name, attrib.DownloadSize, upg.ID);
|
||||
AppearanceManager.SetupWindow(installer);
|
||||
installer.InitiateInstall(installation);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
var installer = new Applications.Installer();
|
||||
var installation = new AppscapeInstallation(upg.Name, attrib.DownloadSize, upg.ID);
|
||||
AppearanceManager.SetupWindow(installer);
|
||||
installer.InitiateInstall(installation);
|
||||
return;
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
|
|
@ -39,49 +39,30 @@ namespace ShiftOS.WinForms.ShiftnetSites
|
|||
{
|
||||
//Get the Fundamentals List
|
||||
flfundamentals.Controls.Clear();
|
||||
foreach (var exe in Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach (var type in Array.FindAll(ReflectMan.Types, t => t.GetInterfaces().Contains(typeof(IShiftnetSite)) && t.BaseType == typeof(UserControl) && Shiftorium.UpgradeAttributesUnlocked(t)))
|
||||
{
|
||||
if (exe.EndsWith(".exe") || exe.EndsWith(".dll"))
|
||||
var attrs = type.GetCustomAttributes(false);
|
||||
var attribute = attrs.FirstOrDefault(x => x is ShiftnetSiteAttribute) as ShiftnetSiteAttribute;
|
||||
if (attribute != null)
|
||||
{
|
||||
try
|
||||
if (attrs.OfType<ShiftnetFundamentalAttribute>().Any())
|
||||
{
|
||||
var asm = Assembly.LoadFile(exe);
|
||||
foreach (var type in asm.GetTypes())
|
||||
var dash = new Label();
|
||||
dash.Text = " - ";
|
||||
dash.AutoSize = true;
|
||||
flfundamentals.Controls.Add(dash);
|
||||
dash.Show();
|
||||
var link = new LinkLabel();
|
||||
link.Text = attribute.Name;
|
||||
link.Click += (o, a) =>
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IShiftnetSite)))
|
||||
{
|
||||
if (type.BaseType == typeof(UserControl))
|
||||
{
|
||||
var attribute = type.GetCustomAttributes(false).FirstOrDefault(x => x is ShiftnetSiteAttribute) as ShiftnetSiteAttribute;
|
||||
if (attribute != null)
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
if (type.GetCustomAttributes(false).FirstOrDefault(x => x is ShiftnetFundamentalAttribute) != null)
|
||||
{
|
||||
var dash = new Label();
|
||||
dash.Text = " - ";
|
||||
dash.AutoSize = true;
|
||||
flfundamentals.Controls.Add(dash);
|
||||
dash.Show();
|
||||
var link = new LinkLabel();
|
||||
link.Text = attribute.Name;
|
||||
link.Click += (o, a) =>
|
||||
{
|
||||
GoToUrl?.Invoke(attribute.Url);
|
||||
};
|
||||
flfundamentals.Controls.Add(link);
|
||||
flfundamentals.SetFlowBreak(link, true);
|
||||
link.Show();
|
||||
link.LinkColor = SkinEngine.LoadedSkin.ControlTextColor;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
GoToUrl?.Invoke(attribute.Url);
|
||||
};
|
||||
flfundamentals.Controls.Add(link);
|
||||
flfundamentals.SetFlowBreak(link, true);
|
||||
link.Show();
|
||||
link.LinkColor = SkinEngine.LoadedSkin.ControlTextColor;
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -34,53 +34,38 @@ namespace ShiftOS.WinForms.ShiftnetSites
|
|||
public void SetupListing()
|
||||
{
|
||||
fllist.Controls.Clear();
|
||||
foreach(var exec in Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach (var type in Array.FindAll(ReflectMan.Types, t => t.GetInterfaces().Contains(typeof(IShiftnetSite))))
|
||||
{
|
||||
if(exec.ToLower().EndsWith(".exe") || exec.ToLower().EndsWith(".dll"))
|
||||
var attr = type.GetCustomAttributes(false).FirstOrDefault(x => x is ShiftnetSiteAttribute) as ShiftnetSiteAttribute;
|
||||
if (attr != null)
|
||||
{
|
||||
try
|
||||
if (attr.Url.StartsWith("shiftnet/"))
|
||||
{
|
||||
var asm = Assembly.LoadFile(exec);
|
||||
var types = asm.GetTypes();
|
||||
foreach (var type in types)
|
||||
var lnk = new LinkLabel();
|
||||
lnk.LinkColor = SkinEngine.LoadedSkin.ControlTextColor;
|
||||
lnk.Text = attr.Name;
|
||||
var desc = new Label();
|
||||
desc.AutoSize = true;
|
||||
lnk.AutoSize = true;
|
||||
desc.MaximumSize = new Size(this.Width / 3, 0);
|
||||
desc.Text = attr.Description;
|
||||
desc.Padding = new Padding
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IShiftnetSite)))
|
||||
{
|
||||
var attr = type.GetCustomAttributes(false).FirstOrDefault(x => x is ShiftnetSiteAttribute) as ShiftnetSiteAttribute;
|
||||
if (attr != null)
|
||||
{
|
||||
if (attr.Url.StartsWith("shiftnet/"))
|
||||
{
|
||||
var lnk = new LinkLabel();
|
||||
lnk.LinkColor = SkinEngine.LoadedSkin.ControlTextColor;
|
||||
lnk.Text = attr.Name;
|
||||
var desc = new Label();
|
||||
desc.AutoSize = true;
|
||||
lnk.AutoSize = true;
|
||||
desc.MaximumSize = new Size(this.Width / 3, 0);
|
||||
desc.Text = attr.Description;
|
||||
desc.Padding = new Padding
|
||||
{
|
||||
Bottom = 25,
|
||||
Top = 0,
|
||||
Left = 10,
|
||||
Right = 10
|
||||
};
|
||||
lnk.Click += (o, a) =>
|
||||
{
|
||||
GoToUrl?.Invoke(attr.Url);
|
||||
};
|
||||
fllist.Controls.Add(lnk);
|
||||
fllist.Controls.Add(desc);
|
||||
ControlManager.SetupControls(lnk);
|
||||
lnk.Show();
|
||||
desc.Show();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Bottom = 25,
|
||||
Top = 0,
|
||||
Left = 10,
|
||||
Right = 10
|
||||
};
|
||||
lnk.Click += (o, a) =>
|
||||
{
|
||||
GoToUrl?.Invoke(attr.Url);
|
||||
};
|
||||
fllist.Controls.Add(lnk);
|
||||
fllist.Controls.Add(desc);
|
||||
ControlManager.SetupControls(lnk);
|
||||
lnk.Show();
|
||||
desc.Show();
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,36 +16,12 @@ namespace ShiftOS.WinForms
|
|||
{
|
||||
public static Dictionary<DesktopWidgetAttribute, Type> GetAllWidgetTypes()
|
||||
{
|
||||
Dictionary<DesktopWidgetAttribute, Type> types = new Dictionary<WinForms.DesktopWidgetAttribute, Type>();
|
||||
foreach(var exe in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if(exe.EndsWith(".exe") || exe.EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(exe);
|
||||
foreach(var type in asm.GetTypes())
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IDesktopWidget)))
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
foreach (var attrib in type.GetCustomAttributes(false))
|
||||
{
|
||||
if (attrib is DesktopWidgetAttribute)
|
||||
{
|
||||
var dw = attrib as DesktopWidgetAttribute;
|
||||
types.Add(dw, type);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
return types;
|
||||
var ret = new Dictionary<DesktopWidgetAttribute, Type>();
|
||||
var types = Array.FindAll(ReflectMan.Types, t => t.GetInterfaces().Contains(typeof(IDesktopWidget)) && Shiftorium.UpgradeAttributesUnlocked(t));
|
||||
foreach (var type in types)
|
||||
foreach (var attrib in Array.FindAll(type.GetCustomAttributes(false), a => a is DesktopWidgetAttribute))
|
||||
ret.Add(attrib as DesktopWidgetAttribute, type);
|
||||
return ret;
|
||||
}
|
||||
|
||||
internal static void SaveDetails(Type type, WidgetDetails location)
|
||||
|
|
|
@ -63,55 +63,16 @@ namespace ShiftOS.Engine
|
|||
{
|
||||
List<LauncherItem> win = new List<LauncherItem>();
|
||||
|
||||
foreach (var asmExec in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach (var type in Array.FindAll(ReflectMan.Types, t => t.GetInterfaces().Contains(typeof(IShiftOSWindow)) && Shiftorium.UpgradeAttributesUnlocked(t)))
|
||||
{
|
||||
if (asmExec.EndsWith(".dll") | asmExec.EndsWith(".exe"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFrom(asmExec);
|
||||
|
||||
if (asm.GetReferencedAssemblies().Contains("ShiftOS.Engine") || asm.FullName.Contains("ShiftOS.Engine"))
|
||||
foreach (var attr in type.GetCustomAttributes(false))
|
||||
if (!(attr is MultiplayerOnlyAttribute && !KernelWatchdog.MudConnected))
|
||||
if (attr is LauncherAttribute)
|
||||
{
|
||||
foreach (var type in asm.GetTypes())
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IShiftOSWindow)))
|
||||
{
|
||||
bool isAllowed = true;
|
||||
foreach (var attr in type.GetCustomAttributes(false))
|
||||
{
|
||||
if(attr is MultiplayerOnlyAttribute)
|
||||
{
|
||||
if(KernelWatchdog.MudConnected == false)
|
||||
{
|
||||
isAllowed = false;
|
||||
|
||||
}
|
||||
}
|
||||
if (isAllowed == true)
|
||||
{
|
||||
if (attr is LauncherAttribute)
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
var launch = attr as LauncherAttribute;
|
||||
if (launch.UpgradeInstalled)
|
||||
{
|
||||
win.Add(new LauncherItem { DisplayData = launch, LaunchType = type });
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
var launch = attr as LauncherAttribute;
|
||||
if (launch.UpgradeInstalled)
|
||||
win.Add(new LauncherItem { DisplayData = launch, LaunchType = type });
|
||||
}
|
||||
}
|
||||
catch
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
foreach(var file in Utils.GetFiles(Paths.GetPath("applauncher")))
|
||||
|
|
|
@ -58,25 +58,7 @@ namespace ShiftOS.Engine
|
|||
//HEY LETS FIND THE WINDOWS
|
||||
public static IEnumerable<Type> GetAllWindowTypes()
|
||||
{
|
||||
List<Type> types = new List<Type>();
|
||||
foreach(var file in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
// hey if a thing is an exe or a dll show up plz kthx
|
||||
if(file.EndsWith(".exe") || file.EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(file);
|
||||
foreach(var type in asm.GetTypes())
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IShiftOSWindow)))
|
||||
types.Add(type);
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
return types;
|
||||
return Array.FindAll(ReflectMan.Types, t => t.GetInterfaces().Contains(typeof(IShiftOSWindow)));
|
||||
}
|
||||
|
||||
// hey you know that window we just made appear? well give it its title
|
||||
|
|
|
@ -771,84 +771,41 @@ shiftorium.buy{{upgrade:""{upg.ID}""}}");
|
|||
{
|
||||
var app = args["app"] as string;
|
||||
//ANNND now we start reflecting...
|
||||
foreach (var asmExec in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach (var type in Array.FindAll(ReflectMan.Types, t => t.BaseType == typeof(UserControl)))
|
||||
{
|
||||
if (asmExec.EndsWith(".exe") || asmExec.EndsWith(".dll"))
|
||||
var attr = type.GetCustomAttributes(false).FirstOrDefault(a => a is WinOpenAttribute && app == (a as WinOpenAttribute).ID);
|
||||
if (attr != null)
|
||||
{
|
||||
var asm = Assembly.LoadFile(asmExec);
|
||||
try
|
||||
if (SaveSystem.CurrentSave.Upgrades.ContainsKey(app))
|
||||
{
|
||||
foreach (var type in asm.GetTypes())
|
||||
if (Shiftorium.UpgradeInstalled(app))
|
||||
{
|
||||
if (type.BaseType == typeof(UserControl))
|
||||
{
|
||||
foreach (var attr in type.GetCustomAttributes(false))
|
||||
{
|
||||
if (attr is WinOpenAttribute)
|
||||
{
|
||||
if (app == (attr as WinOpenAttribute).ID)
|
||||
{
|
||||
if (SaveSystem.CurrentSave.Upgrades.ContainsKey(app))
|
||||
{
|
||||
if (Shiftorium.UpgradeInstalled(app))
|
||||
{
|
||||
IShiftOSWindow frm = Activator.CreateInstance(type) as IShiftOSWindow;
|
||||
AppearanceManager.SetupWindow(frm);
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new Exception($"{app} was not found on your system! Try looking in the shiftorium...");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
IShiftOSWindow frm = Activator.CreateInstance(type) as IShiftOSWindow;
|
||||
AppearanceManager.SetupWindow(frm);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
IShiftOSWindow frm = Activator.CreateInstance(type) as IShiftOSWindow;
|
||||
AppearanceManager.SetupWindow(frm);
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new Exception($"{app} was not found on your system! Try looking in the shiftorium...");
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
|
||||
else
|
||||
{
|
||||
IShiftOSWindow frm = Activator.CreateInstance(type) as IShiftOSWindow;
|
||||
AppearanceManager.SetupWindow(frm);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
foreach (var asmExec in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if (asmExec.EndsWith(".exe") || asmExec.EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(asmExec);
|
||||
|
||||
foreach (var type in asm.GetTypes())
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IShiftOSWindow)))
|
||||
{
|
||||
foreach (var attr in type.GetCustomAttributes(false))
|
||||
{
|
||||
if (attr is WinOpenAttribute)
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
Console.WriteLine("win.open{app:\"" + (attr as WinOpenAttribute).ID + "\"}");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
|
||||
foreach (var type in Array.FindAll(ReflectMan.Types, t => t.GetInterfaces().Contains(typeof(IShiftOSWindow)) && Shiftorium.UpgradeAttributesUnlocked(t)))
|
||||
foreach (var attr in Array.FindAll(type.GetCustomAttributes(false), a => a is WinOpenAttribute))
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
Console.WriteLine("win.open{app:\"" + (attr as WinOpenAttribute).ID + "\"}");
|
||||
|
||||
|
||||
return true;
|
||||
|
|
|
@ -41,26 +41,7 @@ namespace ShiftOS.Engine
|
|||
/// <returns>An array of <see cref="Type"/>s containing the found objects.</returns>
|
||||
public static Type[] GetAllStatusIcons()
|
||||
{
|
||||
List<Type> lst = new List<Type>();
|
||||
foreach(var exec in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if(exec.ToLower().EndsWith(".exe") || exec.ToLower().EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(exec);
|
||||
foreach(var type in asm.GetTypes().Where(x => x.GetInterfaces().Contains(typeof(IStatusIcon))))
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
lst.Add(type);
|
||||
}
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
return lst.ToArray();
|
||||
return Array.FindAll(ReflectMan.Types, x => x.GetInterfaces().Contains(typeof(IStatusIcon)) && Shiftorium.UpgradeAttributesUnlocked(x));
|
||||
}
|
||||
|
||||
|
||||
|
|
80
ShiftOS_TheReturn/ReflectMan.cs
Normal file
80
ShiftOS_TheReturn/ReflectMan.cs
Normal file
|
@ -0,0 +1,80 @@
|
|||
/*
|
||||
* MIT License
|
||||
*
|
||||
* Copyright (c) 2017 Michael VanOverbeek and ShiftOS devs
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace ShiftOS.Engine
|
||||
{
|
||||
public static class ReflectMan
|
||||
{
|
||||
private static Assembly[] asms = null;
|
||||
public static Assembly[] Asms
|
||||
{
|
||||
get
|
||||
{
|
||||
if (asms == null)
|
||||
LoadAssemblies();
|
||||
return asms;
|
||||
}
|
||||
}
|
||||
|
||||
private static Type[] types = null;
|
||||
public static Type[] Types
|
||||
{
|
||||
get
|
||||
{
|
||||
if (types == null)
|
||||
FindTypes();
|
||||
return types;
|
||||
}
|
||||
}
|
||||
|
||||
private static void LoadAssemblies()
|
||||
{
|
||||
var ret = new List<Assembly>();
|
||||
foreach (var exe in Array.FindAll(System.IO.Directory.GetFiles(Environment.CurrentDirectory), n => n.EndsWith(".exe") || n.EndsWith(".dll")))
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(exe);
|
||||
if (asm.GetReferencedAssemblies().Contains("ShiftOS.Engine") || asm.FullName.Contains("ShiftOS.Engine"))
|
||||
ret.Add(asm);
|
||||
}
|
||||
catch { } // probably not a managed assembly
|
||||
asms = ret.ToArray();
|
||||
}
|
||||
|
||||
private static void FindTypes()
|
||||
{
|
||||
var ret = new List<Type>();
|
||||
foreach (var asm in Asms)
|
||||
ret.AddRange(asm.GetTypes());
|
||||
types = ret.ToArray();
|
||||
}
|
||||
}
|
||||
}
|
|
@ -205,55 +205,14 @@ end");
|
|||
//This temporary proxy() method will be used by the API prober.
|
||||
Lua.proxy = new Func<string, dynamic>((objName) =>
|
||||
{
|
||||
foreach (var f in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if (f.EndsWith(".exe") || f.EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
|
||||
var asm = Assembly.LoadFile(f);
|
||||
foreach (var type in asm.GetTypes())
|
||||
{
|
||||
if (type.Name == objName)
|
||||
{
|
||||
dynamic dynObj = Activator.CreateInstance(type);
|
||||
return dynObj;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
dynamic dynObj = ReflectMan.Types.FirstOrDefault(t => t.Name == objName);
|
||||
if (dynObj != null)
|
||||
return dynObj;
|
||||
throw new Exception("{CLASS_NOT_FOUND}");
|
||||
});
|
||||
|
||||
foreach (var f in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if (f.EndsWith(".exe") || f.EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var thisasm = Assembly.LoadFile(f);
|
||||
foreach (var type in thisasm.GetTypes())
|
||||
{
|
||||
foreach (var attr in type.GetCustomAttributes(false))
|
||||
{
|
||||
if (attr is ExposedAttribute)
|
||||
{
|
||||
var eattr = attr as ExposedAttribute;
|
||||
Lua($"{eattr.Name} = proxy(\"{type.Name}\")");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
foreach (var type in ReflectMan.Types)
|
||||
foreach (var attr in Array.FindAll(type.GetCustomAttributes(false), a => a is ExposedAttribute))
|
||||
Lua($"{(attr as ExposedAttribute).Name} = proxy(\"{type.Name}\")");
|
||||
//Now we can null out the proxy() method as it can cause security risks.
|
||||
Lua.isRunning = new Func<bool>(() => { return this.Running; });
|
||||
Lua.proxy = null;
|
||||
|
|
|
@ -110,32 +110,19 @@ Ping: {ServerManager.DigitalSocietyPing} ms
|
|||
{
|
||||
string[] split = msg.GUID.Split('|');
|
||||
bool finished = false;
|
||||
foreach (var exec in Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if(exec.ToLower().EndsWith(".exe") || exec.ToLower().EndsWith(".dll"))
|
||||
if (split[0] == SaveSystem.CurrentSave.SystemName)
|
||||
foreach(var type in Array.FindAll(ReflectMan.Types, x => x.GetInterfaces().Contains(typeof(Server)) && Shiftorium.UpgradeAttributesUnlocked(x)))
|
||||
{
|
||||
try
|
||||
var attrib = type.GetCustomAttributes().FirstOrDefault(x => x is ServerAttribute) as ServerAttribute;
|
||||
if(attrib != null)
|
||||
{
|
||||
var asm = Assembly.LoadFile(exec);
|
||||
foreach(var type in asm.GetTypes().Where(x => x.GetInterfaces().Contains(typeof(Server))))
|
||||
if(split[1] == attrib.Port.ToString())
|
||||
{
|
||||
var attrib = type.GetCustomAttributes().FirstOrDefault(x => x is ServerAttribute) as ServerAttribute;
|
||||
if(attrib != null)
|
||||
{
|
||||
if(split[0] == SaveSystem.CurrentSave.SystemName && split[1] == attrib.Port.ToString())
|
||||
{
|
||||
if (Shiftorium.UpgradeAttributesUnlocked(type))
|
||||
{
|
||||
type.GetMethods(BindingFlags.Public | BindingFlags.Instance).FirstOrDefault(x => x.Name == "MessageReceived")?.Invoke(Activator.CreateInstance(type), null);
|
||||
finished = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
type.GetMethods(BindingFlags.Public | BindingFlags.Instance).FirstOrDefault(x => x.Name == "MessageReceived")?.Invoke(Activator.CreateInstance(type), null);
|
||||
finished = true;
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
if (finished == false)
|
||||
{
|
||||
Forward(split[2], "Error", $"{split[0]}:{split[1]}: connection refused");
|
||||
|
|
|
@ -123,6 +123,7 @@
|
|||
<DesignTime>True</DesignTime>
|
||||
<DependentUpon>Resources.resx</DependentUpon>
|
||||
</Compile>
|
||||
<Compile Include="ReflectMan.cs" />
|
||||
<Compile Include="SaveSystem.cs" />
|
||||
<Compile Include="Scripting.cs" />
|
||||
<Compile Include="Server.cs" />
|
||||
|
|
|
@ -214,23 +214,11 @@ namespace ShiftOS.Engine
|
|||
{
|
||||
upgDb = new List<ShiftoriumUpgrade>();
|
||||
//Now we probe for ShiftoriumUpgradeAttributes for mods.
|
||||
foreach (var file in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
{
|
||||
if (file.EndsWith(".exe") || file.EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(file);
|
||||
foreach (var type in asm.GetTypes())
|
||||
foreach (var type in ReflectMan.Types)
|
||||
{
|
||||
if (type.GetInterfaces().Contains(typeof(IShiftoriumProvider)))
|
||||
{
|
||||
if (type.GetCustomAttributes().FirstOrDefault(x => x is ShiftoriumProviderAttribute) != null)
|
||||
{
|
||||
var _p = Activator.CreateInstance(type, null) as IShiftoriumProvider;
|
||||
upgDb.AddRange(_p.GetDefaults());
|
||||
}
|
||||
}
|
||||
if (type.GetCustomAttributes().Any(x => x is ShiftoriumProviderAttribute))
|
||||
upgDb.AddRange((Activator.CreateInstance(type, null) as IShiftoriumProvider).GetDefaults());
|
||||
|
||||
|
||||
ShiftoriumUpgradeAttribute attrib = type.GetCustomAttributes(false).FirstOrDefault(x => x is ShiftoriumUpgradeAttribute) as ShiftoriumUpgradeAttribute;
|
||||
|
@ -310,10 +298,6 @@ namespace ShiftOS.Engine
|
|||
}
|
||||
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
|
|
@ -242,38 +242,16 @@ namespace ShiftOS.Engine
|
|||
/// <returns>The resulting icon image.</returns>
|
||||
public static Image GetDefaultIcon(string id)
|
||||
{
|
||||
if (_iconProber == null)
|
||||
if (_iconProber != null)
|
||||
{
|
||||
return new Bitmap(16, 16);
|
||||
}
|
||||
else
|
||||
{
|
||||
foreach (var f in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach (var type in Array.FindAll(ReflectMan.Types, t => t.Name == id))
|
||||
{
|
||||
if (f.EndsWith(".exe") || f.EndsWith(".dll"))
|
||||
{
|
||||
try
|
||||
{
|
||||
var asm = Assembly.LoadFile(f);
|
||||
foreach (var type in asm.GetTypes())
|
||||
{
|
||||
if (type.Name == id)
|
||||
{
|
||||
foreach (var attr in type.GetCustomAttributes(true))
|
||||
{
|
||||
if (attr is DefaultIconAttribute)
|
||||
{
|
||||
return _iconProber.GetIcon(attr as DefaultIconAttribute);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
var attr = Array.Find(type.GetCustomAttributes(true), a => a is DefaultIconAttribute);
|
||||
if (attr != null)
|
||||
return _iconProber.GetIcon(attr as DefaultIconAttribute);
|
||||
}
|
||||
return new Bitmap(16, 16);
|
||||
}
|
||||
return new Bitmap(16, 16);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
|
|
@ -134,55 +134,42 @@ namespace ShiftOS.Engine
|
|||
/// <param name="stid">The storyline ID to start.</param>
|
||||
public static void Start(string stid)
|
||||
{
|
||||
foreach (var exec in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
if (SaveSystem.CurrentSave.StoriesExperienced == null)
|
||||
SaveSystem.CurrentSave.StoriesExperienced = new List<string>();
|
||||
foreach (var type in ReflectMan.Types)
|
||||
{
|
||||
if(exec.EndsWith(".exe") || exec.EndsWith(".dll"))
|
||||
foreach (var mth in type.GetMethods(BindingFlags.Public | BindingFlags.Static))
|
||||
{
|
||||
try
|
||||
foreach (var attrib in Array.FindAll(mth.GetCustomAttributes(false), a => a is StoryAttribute))
|
||||
{
|
||||
if (SaveSystem.CurrentSave.StoriesExperienced == null)
|
||||
SaveSystem.CurrentSave.StoriesExperienced = new List<string>();
|
||||
var asm = Assembly.LoadFile(exec);
|
||||
foreach(var type in asm.GetTypes())
|
||||
var story = attrib as StoryAttribute;
|
||||
if (story.StoryID == stid)
|
||||
{
|
||||
foreach(var mth in type.GetMethods(BindingFlags.Public | BindingFlags.Static))
|
||||
new Thread(() =>
|
||||
{
|
||||
foreach(var attrib in mth.GetCustomAttributes(false))
|
||||
Context = new Engine.StoryContext
|
||||
{
|
||||
if(attrib is StoryAttribute)
|
||||
{
|
||||
var story = attrib as StoryAttribute;
|
||||
if(story.StoryID == stid)
|
||||
{
|
||||
new Thread(() =>
|
||||
{
|
||||
Context = new Engine.StoryContext
|
||||
{
|
||||
Id = stid,
|
||||
Method = mth,
|
||||
AutoComplete = true,
|
||||
};
|
||||
SaveSystem.CurrentSave.PickupPoint = Context.Id;
|
||||
Context.OnComplete += () =>
|
||||
{
|
||||
StoryComplete?.Invoke(stid);
|
||||
SaveSystem.CurrentSave.PickupPoint = null;
|
||||
};
|
||||
mth.Invoke(null, null);
|
||||
if (Context.AutoComplete)
|
||||
{
|
||||
Context.MarkComplete();
|
||||
}
|
||||
}).Start();
|
||||
return;
|
||||
}
|
||||
}
|
||||
Id = stid,
|
||||
Method = mth,
|
||||
AutoComplete = true,
|
||||
};
|
||||
SaveSystem.CurrentSave.PickupPoint = Context.Id;
|
||||
Context.OnComplete += () =>
|
||||
{
|
||||
StoryComplete?.Invoke(stid);
|
||||
SaveSystem.CurrentSave.PickupPoint = null;
|
||||
};
|
||||
mth.Invoke(null, null);
|
||||
if (Context.AutoComplete)
|
||||
{
|
||||
Context.MarkComplete();
|
||||
}
|
||||
}
|
||||
}).Start();
|
||||
return;
|
||||
}
|
||||
}
|
||||
catch (Exception ex) { throw ex; }
|
||||
}
|
||||
|
||||
}
|
||||
#if DEBUG
|
||||
throw new ArgumentException("Story ID not found: " + stid + " - Talk to Michael. NOW.");
|
||||
|
|
|
@ -295,54 +295,40 @@ namespace ShiftOS.Engine
|
|||
public static void PopulateTerminalCommands()
|
||||
{
|
||||
Commands = new List<TerminalCommand>();
|
||||
foreach(var exec in System.IO.Directory.GetFiles(Environment.CurrentDirectory))
|
||||
foreach(var type in ReflectMan.Types)
|
||||
{
|
||||
if(exec.ToLower().EndsWith(".exe") || exec.ToLower().EndsWith(".dll"))
|
||||
var ns = type.GetCustomAttributes(false).FirstOrDefault(x => x is Namespace) as Namespace;
|
||||
if(ns != null)
|
||||
{
|
||||
try
|
||||
foreach(var mth in type.GetMethods(BindingFlags.Public | BindingFlags.Static))
|
||||
{
|
||||
var asm = Assembly.LoadFile(exec);
|
||||
foreach(var type in asm.GetTypes())
|
||||
var cmd = mth.GetCustomAttributes(false).FirstOrDefault(x => x is Command);
|
||||
if(cmd != null)
|
||||
{
|
||||
var ns = type.GetCustomAttributes(false).FirstOrDefault(x => x is Namespace) as Namespace;
|
||||
if(ns != null)
|
||||
var tc = new TerminalCommand();
|
||||
tc.RequiresElevation = !(type.GetCustomAttributes(false).FirstOrDefault(x => x is KernelModeAttribute) == null);
|
||||
|
||||
tc.NamespaceInfo = ns;
|
||||
|
||||
tc.CommandInfo = cmd as Command;
|
||||
tc.RequiresElevation = tc.RequiresElevation || !(mth.GetCustomAttributes(false).FirstOrDefault(x => x is KernelModeAttribute) == null);
|
||||
tc.RequiredArguments = new List<string>();
|
||||
foreach (var arg in mth.GetCustomAttributes(false).Where(x=>x is RequiresArgument))
|
||||
{
|
||||
foreach(var mth in type.GetMethods(BindingFlags.Public | BindingFlags.Static))
|
||||
{
|
||||
var cmd = mth.GetCustomAttributes(false).FirstOrDefault(x => x is Command);
|
||||
if(cmd != null)
|
||||
{
|
||||
var tc = new TerminalCommand();
|
||||
tc.RequiresElevation = !(type.GetCustomAttributes(false).FirstOrDefault(x => x is KernelModeAttribute) == null);
|
||||
|
||||
tc.NamespaceInfo = ns;
|
||||
|
||||
tc.CommandInfo = cmd as Command;
|
||||
tc.RequiresElevation = tc.RequiresElevation || !(mth.GetCustomAttributes(false).FirstOrDefault(x => x is KernelModeAttribute) == null);
|
||||
tc.RequiredArguments = new List<string>();
|
||||
foreach (var arg in mth.GetCustomAttributes(false).Where(x=>x is RequiresArgument))
|
||||
{
|
||||
var rarg = arg as RequiresArgument;
|
||||
tc.RequiredArguments.Add(rarg.argument);
|
||||
}
|
||||
var rupg = mth.GetCustomAttributes(false).FirstOrDefault(x => x is RequiresUpgradeAttribute) as RequiresUpgradeAttribute;
|
||||
if (rupg != null)
|
||||
tc.Dependencies = rupg.Upgrade;
|
||||
else
|
||||
tc.Dependencies = "";
|
||||
tc.CommandType = type;
|
||||
tc.CommandHandler = mth;
|
||||
if (!Commands.Contains(tc))
|
||||
Commands.Add(tc);
|
||||
}
|
||||
}
|
||||
var rarg = arg as RequiresArgument;
|
||||
tc.RequiredArguments.Add(rarg.argument);
|
||||
}
|
||||
var rupg = mth.GetCustomAttributes(false).FirstOrDefault(x => x is RequiresUpgradeAttribute) as RequiresUpgradeAttribute;
|
||||
if (rupg != null)
|
||||
tc.Dependencies = rupg.Upgrade;
|
||||
else
|
||||
tc.Dependencies = "";
|
||||
tc.CommandType = type;
|
||||
tc.CommandHandler = mth;
|
||||
if (!Commands.Contains(tc))
|
||||
Commands.Add(tc);
|
||||
}
|
||||
}
|
||||
catch(Exception e)
|
||||
{
|
||||
Console.WriteLine("[termdb] Error: " + e.ToString());
|
||||
}
|
||||
}
|
||||
}
|
||||
Console.WriteLine("[termdb] " + Commands.Count + " commands found.");
|
||||
|
|
Loading…
Reference in a new issue