Example #1
0
        private void RefreshStatus()
        {
            string logFolder = Environment.GetFolderPath(Environment.SpecialFolder.UserProfile) + "\\LWATracing";

            if (!Directory.Exists(logFolder))
            {
                _files.Clear();
                ActiveLog = null;
                return;
            }

            string[] files = null;
            try
            {
                files = Directory.GetFiles(logFolder, "LWAPlugin*.log", SearchOption.TopDirectoryOnly);
            }
            catch (Exception) { }

            if ((files == null) || (files.Length == 0))
            {
                _files.Clear();
                ActiveLog = null;
                return;
            }

            Dictionary <string, LogFile> clone = _files;

            _files = new Dictionary <string, LogFile>();

            foreach (string filename in files)
            {
                try
                {
                    LogFile log = null;
                    if (clone.ContainsKey(filename))
                    {
                        log = clone[filename];
                        clone.Remove(filename);
                    }
                    else
                    {
                        log = new LogFile(filename, this);
                    }

                    _files[filename] = log;
                    log.Refresh();

                    if (ActiveLog == null)
                    {
                        ActiveLog = log;
                    }
                    else
                    {
                        if (File.GetLastWriteTime(filename) > File.GetLastWriteTime(ActiveLog.FileName))
                        {
                            ActiveLog = log;
                        }
                    }
                }
                catch (Exception) { }
            }

            clone.Clear();
        }
Example #2
0
 void log_DataChanged(object sender, LogFileDataChangedEventArgs args)
 {
     PluginMonitor.LogFile file = sender as PluginMonitor.LogFile;
     plugin_log_data.Text = file.Data;
 }
Example #3
0
 public PluginLoggerActiveLogChangedEventArgs(LogFile newLog, LogFile oldLog)
 {
     this.NewLog = newLog;
     this.OldLog = oldLog;
 }