# HG changeset patch
# User adminsh@apollo
# Date 1333029644 -3600
# Node ID 3783cb9b371ff01ae02a510ab93fdf78a20c1660
# Parent c8c79f05d76f8a481bac3005aa85263bfb307451
Working version
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/Libs/AxInterop.AcroPDFLib.dll
Binary file PdfViewAndPrint/Libs/AxInterop.AcroPDFLib.dll has changed
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint.sln
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint.sln Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,20 @@
+
+Microsoft Visual Studio Solution File, Format Version 11.00
+# Visual Studio 2010
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PdfViewAndPrint", "PdfViewAndPrint\PdfViewAndPrint.csproj", "{1339C473-6A53-443A-9B7C-E805F639A367}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|x86 = Debug|x86
+ Release|x86 = Release|x86
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {1339C473-6A53-443A-9B7C-E805F639A367}.Debug|x86.ActiveCfg = Debug|x86
+ {1339C473-6A53-443A-9B7C-E805F639A367}.Debug|x86.Build.0 = Debug|x86
+ {1339C473-6A53-443A-9B7C-E805F639A367}.Release|x86.ActiveCfg = Release|x86
+ {1339C473-6A53-443A-9B7C-E805F639A367}.Release|x86.Build.0 = Release|x86
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+EndGlobal
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/App.xaml
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/App.xaml Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,8 @@
+
+
+
+
+
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/App.xaml.cs
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/App.xaml.cs Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,14 @@
+using System;
+using System.Collections.Generic;
+using System.Configuration;
+using System.Windows;
+
+namespace PdfViewAndPrint
+{
+ ///
+ /// Interaction logic for App.xaml
+ ///
+ public partial class App : Application
+ {
+ }
+}
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/FTSE_INDEX_LINKED_ETFs.pdf
Binary file PdfViewAndPrint/PdfViewAndPrint/FTSE_INDEX_LINKED_ETFs.pdf has changed
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/MainWindow.xaml
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/MainWindow.xaml Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,63 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ You need Adobe Acrobat Reader installed on the client machine to view PDFs in WPF (via a WinFormsHost)
+
+
+
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/MainWindow.xaml.cs
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/MainWindow.xaml.cs Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,96 @@
+using System;
+using System.Threading.Tasks;
+using System.Windows;
+using System.Windows.Threading;
+using Acrobat;
+
+namespace PdfViewAndPrint
+{
+ ///
+ /// Interaction logic for MainWindow.xaml
+ ///
+ public partial class MainWindow
+ {
+ private string pdfFilePath;
+
+ public MainWindow()
+ {
+ InitializeComponent();
+
+ // create win forms control and hook up event handling for notification
+ var winFormsUserControl = new WinFormsUserControl();
+ winFormsUserControl.Notification += winFormsUserControl_Notification;
+ windowsFormsHost.Child = winFormsUserControl;
+
+ if (string.IsNullOrEmpty(pdfFilePath))
+ SetButtons(false);
+ }
+
+ public delegate void ActionDelegate();
+
+ private void winFormsUserControl_Notification(object sender, NotifyEventArgs e)
+ {
+ Dispatcher.BeginInvoke(new Action(() => this.StatusBarText.Text = e.Message), DispatcherPriority.Background);
+ }
+
+ private void btnClose_Click(object sender, RoutedEventArgs e)
+ {
+ Application.Current.Shutdown();
+ }
+
+ private void btnLoad_Click(object sender, RoutedEventArgs e)
+ {
+ var dialog = new Microsoft.Win32.OpenFileDialog
+ {
+ DefaultExt = ".pdf",
+ Filter = "PDF documents (.pdf)|*.pdf"
+ };
+
+
+ var result = dialog.ShowDialog();
+
+ if (result != true)
+ {
+ SetButtons(false);
+ return;
+ }
+
+ pdfFilePath = dialog.FileName;
+
+ //Task.Factory.StartNew(() =>
+ ((WinFormsUserControl)this.windowsFormsHost.Child).LoadPdf(pdfFilePath);
+ //);
+
+ SetButtons(true);
+ }
+
+ private void SetButtons(bool isEnabled)
+ {
+ btnPrint.IsEnabled = isEnabled;
+ btnOpen.IsEnabled = isEnabled;
+ }
+
+ private void btnPrint_Click(object sender, RoutedEventArgs e)
+ {
+
+ }
+
+ private void btnOpen_Click(object sender, RoutedEventArgs e)
+ {
+ Task.Factory.StartNew(OpenInAcrobat);
+ }
+
+ private void OpenInAcrobat()
+ {
+ var acrobat = new AcroApp();
+ acrobat.Show();
+
+ var avDoc = new AcroAVDoc();
+
+ if (avDoc.Open(pdfFilePath, ""))
+ StatusBarText.Text = pdfFilePath + " loaded";
+ else
+ StatusBarText.Text = pdfFilePath + " cannot be opened in Acrobat Reader";
+ }
+ }
+}
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/Pdf.ico
Binary file PdfViewAndPrint/PdfViewAndPrint/Pdf.ico has changed
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/PdfViewAndPrint.csproj
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/PdfViewAndPrint.csproj Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,145 @@
+
+
+
+ Debug
+ x86
+ 8.0.30703
+ 2.0
+ {1339C473-6A53-443A-9B7C-E805F639A367}
+ WinExe
+ Properties
+ PdfViewAndPrint
+ PdfViewAndPrint
+ v4.0
+ Client
+ 512
+ {60dc8134-eba5-43b8-bcc9-bb4bc16c2548};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}
+ 4
+
+
+ x86
+ true
+ full
+ false
+ bin\Debug\
+ DEBUG;TRACE
+ prompt
+ 4
+
+
+ x86
+ pdbonly
+ true
+ bin\Release\
+ TRACE
+ prompt
+ 4
+
+
+
+
+
+
+
+
+ 4.0
+
+
+
+
+
+
+
+
+ MSBuild:Compile
+ Designer
+
+
+ UserControl
+
+
+ WinFormsUserControl.cs
+
+
+ MSBuild:Compile
+ Designer
+
+
+ App.xaml
+ Code
+
+
+ MainWindow.xaml
+ Code
+
+
+
+
+ Code
+
+
+ True
+ True
+ Resources.resx
+
+
+ True
+ Settings.settings
+ True
+
+
+ PreserveNewest
+
+
+ ResXFileCodeGenerator
+ Resources.Designer.cs
+
+
+ WinFormsUserControl.cs
+
+
+ PreserveNewest
+
+
+ SettingsSingleFileGenerator
+ Settings.Designer.cs
+
+
+
+
+
+ {E64169B3-3592-47D2-816E-602C5C13F328}
+ 1
+ 1
+ 0
+ tlbimp
+ False
+ True
+
+
+ {05BFD3F1-6319-4F30-B752-C7A22889BCC4}
+ 1
+ 0
+ 0
+ tlbimp
+ False
+ True
+
+
+ {05BFD3F1-6319-4F30-B752-C7A22889BCC4}
+ 1
+ 0
+ 0
+ aximp
+ False
+
+
+
+
+
\ No newline at end of file
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/Properties/AssemblyInfo.cs
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/Properties/AssemblyInfo.cs Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,55 @@
+using System.Reflection;
+using System.Resources;
+using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
+using System.Windows;
+
+// General Information about an assembly is controlled through the following
+// set of attributes. Change these attribute values to modify the information
+// associated with an assembly.
+[assembly: AssemblyTitle("PdfViewAndPrint")]
+[assembly: AssemblyDescription("")]
+[assembly: AssemblyConfiguration("")]
+[assembly: AssemblyCompany("")]
+[assembly: AssemblyProduct("PdfViewAndPrint")]
+[assembly: AssemblyCopyright("Copyright © 2012")]
+[assembly: AssemblyTrademark("")]
+[assembly: AssemblyCulture("")]
+
+// Setting ComVisible to false makes the types in this assembly not visible
+// to COM components. If you need to access a type in this assembly from
+// COM, set the ComVisible attribute to true on that type.
+[assembly: ComVisible(false)]
+
+//In order to begin building localizable applications, set
+//CultureYouAreCodingWith in your .csproj file
+//inside a . For example, if you are using US english
+//in your source files, set the to en-US. Then uncomment
+//the NeutralResourceLanguage attribute below. Update the "en-US" in
+//the line below to match the UICulture setting in the project file.
+
+//[assembly: NeutralResourcesLanguage("en-US", UltimateResourceFallbackLocation.Satellite)]
+
+
+[assembly: ThemeInfo(
+ ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located
+ //(used if a resource is not found in the page,
+ // or application resource dictionaries)
+ ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located
+ //(used if a resource is not found in the page,
+ // app, or any theme specific resource dictionaries)
+)]
+
+
+// Version information for an assembly consists of the following four values:
+//
+// Major Version
+// Minor Version
+// Build Number
+// Revision
+//
+// You can specify all the values or you can default the Build and Revision Numbers
+// by using the '*' as shown below:
+// [assembly: AssemblyVersion("1.0.*")]
+[assembly: AssemblyVersion("1.0.0.0")]
+[assembly: AssemblyFileVersion("1.0.0.0")]
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/Properties/Resources.Designer.cs
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/Properties/Resources.Designer.cs Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,71 @@
+//------------------------------------------------------------------------------
+//
+// This code was generated by a tool.
+// Runtime Version:4.0.30319.17379
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//
+//------------------------------------------------------------------------------
+
+namespace PdfViewAndPrint.Properties
+{
+
+
+ ///
+ /// A strongly-typed resource class, for looking up localized strings, etc.
+ ///
+ // This class was auto-generated by the StronglyTypedResourceBuilder
+ // class via a tool like ResGen or Visual Studio.
+ // To add or remove a member, edit your .ResX file then rerun ResGen
+ // with the /str option, or rebuild your VS project.
+ [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")]
+ [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
+ [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()]
+ internal class Resources
+ {
+
+ private static global::System.Resources.ResourceManager resourceMan;
+
+ private static global::System.Globalization.CultureInfo resourceCulture;
+
+ [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")]
+ internal Resources()
+ {
+ }
+
+ ///
+ /// Returns the cached ResourceManager instance used by this class.
+ ///
+ [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
+ internal static global::System.Resources.ResourceManager ResourceManager
+ {
+ get
+ {
+ if ((resourceMan == null))
+ {
+ global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("PdfViewAndPrint.Properties.Resources", typeof(Resources).Assembly);
+ resourceMan = temp;
+ }
+ return resourceMan;
+ }
+ }
+
+ ///
+ /// Overrides the current thread's CurrentUICulture property for all
+ /// resource lookups using this strongly typed resource class.
+ ///
+ [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
+ internal static global::System.Globalization.CultureInfo Culture
+ {
+ get
+ {
+ return resourceCulture;
+ }
+ set
+ {
+ resourceCulture = value;
+ }
+ }
+ }
+}
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/Properties/Resources.resx
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/Properties/Resources.resx Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,117 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ text/microsoft-resx
+
+
+ 2.0
+
+
+ System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
+
+
+ System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
+
+
\ No newline at end of file
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/Properties/Settings.Designer.cs
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/Properties/Settings.Designer.cs Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,30 @@
+//------------------------------------------------------------------------------
+//
+// This code was generated by a tool.
+// Runtime Version:4.0.30319.17379
+//
+// Changes to this file may cause incorrect behavior and will be lost if
+// the code is regenerated.
+//
+//------------------------------------------------------------------------------
+
+namespace PdfViewAndPrint.Properties
+{
+
+
+ [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()]
+ [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "10.0.0.0")]
+ internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase
+ {
+
+ private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings())));
+
+ public static Settings Default
+ {
+ get
+ {
+ return defaultInstance;
+ }
+ }
+ }
+}
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/Properties/Settings.settings
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/Properties/Settings.settings Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,7 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/WinFormsUserControl.Designer.cs
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/WinFormsUserControl.Designer.cs Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,62 @@
+namespace PdfViewAndPrint
+{
+ partial class WinFormsUserControl
+ {
+ ///
+ /// Required designer variable.
+ ///
+ private System.ComponentModel.IContainer components = null;
+
+ ///
+ /// Clean up any resources being used.
+ ///
+ /// true if managed resources should be disposed; otherwise, false.
+ protected override void Dispose(bool disposing)
+ {
+ if (disposing && (components != null))
+ {
+ components.Dispose();
+ }
+ base.Dispose(disposing);
+ }
+
+ #region Component Designer generated code
+
+ ///
+ /// Required method for Designer support - do not modify
+ /// the contents of this method with the code editor.
+ ///
+ private void InitializeComponent()
+ {
+ System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(WinFormsUserControl));
+ this.axAcroPDF1 = new AxAcroPDFLib.AxAcroPDF();
+ ((System.ComponentModel.ISupportInitialize)(this.axAcroPDF1)).BeginInit();
+ this.SuspendLayout();
+ //
+ // axAcroPDF1
+ //
+ this.axAcroPDF1.Dock = System.Windows.Forms.DockStyle.Fill;
+ this.axAcroPDF1.Enabled = true;
+ this.axAcroPDF1.Location = new System.Drawing.Point(0, 0);
+ this.axAcroPDF1.Name = "axAcroPDF1";
+ this.axAcroPDF1.OcxState = ((System.Windows.Forms.AxHost.State)(resources.GetObject("axAcroPDF1.OcxState")));
+ this.axAcroPDF1.Size = new System.Drawing.Size(150, 150);
+ this.axAcroPDF1.TabIndex = 0;
+ //
+ // WinFormsUserControl
+ //
+ this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
+ this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
+ this.Controls.Add(this.axAcroPDF1);
+ this.Name = "WinFormsUserControl";
+ this.Load += new System.EventHandler(this.WinFormsUserControl_Load);
+ ((System.ComponentModel.ISupportInitialize)(this.axAcroPDF1)).EndInit();
+ this.ResumeLayout(false);
+
+ }
+
+ #endregion
+
+ private AxAcroPDFLib.AxAcroPDF axAcroPDF1;
+ }
+}
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/WinFormsUserControl.cs
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/WinFormsUserControl.cs Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,49 @@
+using System;
+using System.Windows.Forms;
+
+namespace PdfViewAndPrint
+{
+ public partial class WinFormsUserControl : UserControl
+ {
+ public WinFormsUserControl()
+ {
+ InitializeComponent();
+ }
+
+ private void WinFormsUserControl_Load(object sender, EventArgs e)
+ {
+
+ }
+
+ public void LoadPdf(string pdfFilePath)
+ {
+ try
+ {
+ this.axAcroPDF1.LoadFile(pdfFilePath);
+ }
+ catch (Exception e)
+ {
+ OnNotify(e.Message);
+ }
+ }
+
+
+ #region Event code to pass messages back to WPF
+
+ public delegate void NotifyEventHandler(object sender, NotifyEventArgs e);
+ public event NotifyEventHandler Notification;
+ protected void OnNotify(string message)
+ {
+ if (Notification != null)
+ Notification(this, new NotifyEventArgs() {Message = message});
+ }
+
+ #endregion
+
+ }
+
+ public class NotifyEventArgs : EventArgs
+ {
+ public string Message { get; set; }
+ }
+}
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/PdfViewAndPrint/WinFormsUserControl.resx
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/PdfViewAndPrint/WinFormsUserControl.resx Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,128 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ text/microsoft-resx
+
+
+ 2.0
+
+
+ System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
+
+
+ System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
+
+
+
+ AAEAAAD/////AQAAAAAAAAAMAgAAAFdTeXN0ZW0uV2luZG93cy5Gb3JtcywgVmVyc2lvbj00LjAuMC4w
+ LCBDdWx0dXJlPW5ldXRyYWwsIFB1YmxpY0tleVRva2VuPWI3N2E1YzU2MTkzNGUwODkFAQAAACFTeXN0
+ ZW0uV2luZG93cy5Gb3Jtcy5BeEhvc3QrU3RhdGUBAAAABERhdGEHAgIAAAAJAwAAAA8DAAAAIQAAAAIB
+ AAAAAQAAAAAAAAAAAAAAAAwAAAAACQAA2BMAANgTAAAL
+
+
+
\ No newline at end of file
diff -r c8c79f05d76f -r 3783cb9b371f PdfViewAndPrint/clean.bat
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/PdfViewAndPrint/clean.bat Thu Mar 29 15:00:44 2012 +0100
@@ -0,0 +1,18 @@
+del /s /ah /f *.suo
+del /s /f *.user
+del /s /f *.cache
+del /s /f *.keep
+del /s /ah StyleCop.Cache
+
+rd /s /q bin obj ClientBin _Resharper.* _Upgrade* TestResults
+
+del dirs.txt
+dir /s /b /ad bin > dirs.txt
+dir /s /b /ad obj >> dirs.txt
+dir /s /b /ad ClientBin >> dirs.txt
+dir /s /b /ad _Resharper.* >> dirs.txt
+dir /s /b /ad _Upgrade* >> dirs.txt
+dir /s /b /ad TestResults >> dirs.txt
+
+for /f "delims=;" %%i in (dirs.txt) DO rd /s /q "%%i"
+del dirs.txt