using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; using Cosmos.Compiler.Debug; using System.Windows.Threading; using Cosmos.VS.Debug; using System.Threading; namespace Cosmos.Cosmos_VS_Windows { public partial class AssemblyUC : UserControl { static public byte[] mData = new byte[0]; string mCode = ""; bool mFilter = true; public AssemblyUC() { InitializeComponent(); mitmCopy.Click += new RoutedEventHandler(mitmCopy_Click); Update(mData); } void mitmCopy_Click(object sender, RoutedEventArgs e) { Clipboard.SetText(mCode); } protected void Display(bool aFilter) { tblkSource.Inlines.Clear(); if (mData.Length == 0) { return; } mCode = Encoding.ASCII.GetString(mData); string[] xLines = mCode.Split('\n'); foreach (string xLine in xLines) { string xDisplayLine = xLine; string xTestLine = xLine.Trim().ToUpper(); if (aFilter) { if (xTestLine == "INT3") { continue; } else if (xTestLine.StartsWith("; #")) { // Comments which are signals for the parser continue; } else if (xTestLine.EndsWith("#:")) { // Hidden labels (ASM stepping, only add noise for user) continue; } else if (xTestLine.Length == 0) { continue; } xDisplayLine = xDisplayLine.Trim(); if (!xTestLine.EndsWith(":")) { tblkSource.Inlines.Add(new LineBreak()); // Add blank line before labels xDisplayLine = "\t" + xDisplayLine; } } var xRun = new Run(xDisplayLine); if (xTestLine.EndsWith(":")) { xRun.Foreground = Brushes.Black; } else if (xTestLine.StartsWith(";")) { xRun.Foreground = Brushes.Green; } else { xRun.Foreground = Brushes.Blue; } tblkSource.Inlines.Add(xRun); tblkSource.Inlines.Add(new LineBreak()); } } public void Update(byte[] aData) { mData = aData; Display(mFilter); } } }