From 716b60826bd7ca82dd70ed8ceb524528f86b8edf Mon Sep 17 00:00:00 2001
From: ​
Date: Thu, 1 Jan 1970 00:00:00 +0000
Subject: invoice total 3

---
 invoice_total3/InvoiceTotal/InvoiceTotal.csproj    | 138 ++++++++++++++
 invoice_total3/InvoiceTotal/Program.cs             |  22 +++
 .../InvoiceTotal/Properties/AssemblyInfo.cs        |  33 ++++
 .../InvoiceTotal/Properties/Resources.Designer.cs  |  63 ++++++
 .../InvoiceTotal/Properties/Resources.resx         | 117 ++++++++++++
 .../InvoiceTotal/Properties/Settings.Designer.cs   |  26 +++
 .../InvoiceTotal/Properties/Settings.settings      |   7 +
 invoice_total3/InvoiceTotal/app.config             |   3 +
 .../InvoiceTotal/bin/Debug/InvoiceTotal.exe        | Bin 0 -> 12288 bytes
 .../InvoiceTotal/bin/Debug/InvoiceTotal.exe.config |   3 +
 .../InvoiceTotal/bin/Debug/InvoiceTotal.pdb        | Bin 0 -> 26112 bytes
 .../InvoiceTotal/frmInvoiceTotal.Designer.cs       | 211 +++++++++++++++++++++
 invoice_total3/InvoiceTotal/frmInvoiceTotal.cs     |  59 ++++++
 invoice_total3/InvoiceTotal/frmInvoiceTotal.resx   | 120 ++++++++++++
 ...NETFramework,Version=v4.8.AssemblyAttributes.cs |   4 +
 .../DesignTimeResolveAssemblyReferencesInput.cache | Bin 0 -> 2252 bytes
 .../InvoiceTotal.Properties.Resources.resources    | Bin 0 -> 180 bytes
 .../InvoiceTotal.csproj.AssemblyReference.cache    | Bin 0 -> 6088 bytes
 .../InvoiceTotal.csproj.CoreCompileInputs.cache    |   1 +
 .../Debug/InvoiceTotal.csproj.FileListAbsolute.txt |  10 +
 .../InvoiceTotal.csproj.GenerateResource.cache     | Bin 0 -> 146 bytes
 .../InvoiceTotal/obj/Debug/InvoiceTotal.exe        | Bin 0 -> 12288 bytes
 .../Debug/InvoiceTotal.frmInvoiceTotal.resources   | Bin 0 -> 180 bytes
 .../InvoiceTotal/obj/Debug/InvoiceTotal.pdb        | Bin 0 -> 26112 bytes
 24 files changed, 817 insertions(+)
 create mode 100644 invoice_total3/InvoiceTotal/InvoiceTotal.csproj
 create mode 100644 invoice_total3/InvoiceTotal/Program.cs
 create mode 100644 invoice_total3/InvoiceTotal/Properties/AssemblyInfo.cs
 create mode 100644 invoice_total3/InvoiceTotal/Properties/Resources.Designer.cs
 create mode 100644 invoice_total3/InvoiceTotal/Properties/Resources.resx
 create mode 100644 invoice_total3/InvoiceTotal/Properties/Settings.Designer.cs
 create mode 100644 invoice_total3/InvoiceTotal/Properties/Settings.settings
 create mode 100644 invoice_total3/InvoiceTotal/app.config
 create mode 100644 invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe
 create mode 100644 invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe.config
 create mode 100644 invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.pdb
 create mode 100644 invoice_total3/InvoiceTotal/frmInvoiceTotal.Designer.cs
 create mode 100644 invoice_total3/InvoiceTotal/frmInvoiceTotal.cs
 create mode 100644 invoice_total3/InvoiceTotal/frmInvoiceTotal.resx
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/.NETFramework,Version=v4.8.AssemblyAttributes.cs
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.Properties.Resources.resources
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.AssemblyReference.cache
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.CoreCompileInputs.cache
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.FileListAbsolute.txt
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.GenerateResource.cache
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.exe
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.frmInvoiceTotal.resources
 create mode 100644 invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.pdb

(limited to 'invoice_total3/InvoiceTotal')

diff --git a/invoice_total3/InvoiceTotal/InvoiceTotal.csproj b/invoice_total3/InvoiceTotal/InvoiceTotal.csproj
new file mode 100644
index 0000000..c67214c
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/InvoiceTotal.csproj
@@ -0,0 +1,138 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="12.0">
+  <PropertyGroup>
+    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
+    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
+    <ProductVersion>9.0.21022</ProductVersion>
+    <SchemaVersion>2.0</SchemaVersion>
+    <ProjectGuid>{ABFE3FFD-56CF-4B23-8ED5-EBBBAF6EFD39}</ProjectGuid>
+    <OutputType>WinExe</OutputType>
+    <AppDesignerFolder>Properties</AppDesignerFolder>
+    <RootNamespace>InvoiceTotal</RootNamespace>
+    <AssemblyName>InvoiceTotal</AssemblyName>
+    <FileUpgradeFlags>
+    </FileUpgradeFlags>
+    <OldToolsVersion>3.5</OldToolsVersion>
+    <UpgradeBackupLocation>
+    </UpgradeBackupLocation>
+    <IsWebBootstrapper>true</IsWebBootstrapper>
+    <TargetFrameworkVersion>v4.8</TargetFrameworkVersion>
+    <PublishUrl>http://localhost/InvoiceTotal/</PublishUrl>
+    <Install>true</Install>
+    <InstallFrom>Web</InstallFrom>
+    <UpdateEnabled>true</UpdateEnabled>
+    <UpdateMode>Foreground</UpdateMode>
+    <UpdateInterval>7</UpdateInterval>
+    <UpdateIntervalUnits>Days</UpdateIntervalUnits>
+    <UpdatePeriodically>false</UpdatePeriodically>
+    <UpdateRequired>false</UpdateRequired>
+    <MapFileExtensions>true</MapFileExtensions>
+    <ApplicationRevision>0</ApplicationRevision>
+    <ApplicationVersion>1.0.0.%2a</ApplicationVersion>
+    <UseApplicationTrust>false</UseApplicationTrust>
+    <BootstrapperEnabled>true</BootstrapperEnabled>
+    <TargetFrameworkProfile>
+    </TargetFrameworkProfile>
+  </PropertyGroup>
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
+    <DebugSymbols>true</DebugSymbols>
+    <DebugType>full</DebugType>
+    <Optimize>false</Optimize>
+    <OutputPath>bin\Debug\</OutputPath>
+    <DefineConstants>DEBUG;TRACE</DefineConstants>
+    <ErrorReport>prompt</ErrorReport>
+    <WarningLevel>4</WarningLevel>
+    <Prefer32Bit>false</Prefer32Bit>
+    <LangVersion>8.0</LangVersion>
+  </PropertyGroup>
+  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
+    <DebugType>pdbonly</DebugType>
+    <Optimize>true</Optimize>
+    <OutputPath>bin\Release\</OutputPath>
+    <DefineConstants>TRACE</DefineConstants>
+    <ErrorReport>prompt</ErrorReport>
+    <WarningLevel>4</WarningLevel>
+    <Prefer32Bit>false</Prefer32Bit>
+  </PropertyGroup>
+  <ItemGroup>
+    <Reference Include="Microsoft.CSharp" />
+    <Reference Include="System" />
+    <Reference Include="System.Core">
+      <RequiredTargetFramework>3.5</RequiredTargetFramework>
+    </Reference>
+    <Reference Include="System.Data" />
+    <Reference Include="System.Data.DataSetExtensions">
+      <RequiredTargetFramework>3.5</RequiredTargetFramework>
+    </Reference>
+    <Reference Include="System.Deployment" />
+    <Reference Include="System.Drawing" />
+    <Reference Include="System.Net.Http" />
+    <Reference Include="System.Windows.Forms" />
+    <Reference Include="System.Xml" />
+    <Reference Include="System.Xml.Linq">
+      <RequiredTargetFramework>3.5</RequiredTargetFramework>
+    </Reference>
+  </ItemGroup>
+  <ItemGroup>
+    <Compile Include="frmInvoiceTotal.cs">
+      <SubType>Form</SubType>
+    </Compile>
+    <Compile Include="frmInvoiceTotal.Designer.cs">
+      <DependentUpon>frmInvoiceTotal.cs</DependentUpon>
+    </Compile>
+    <Compile Include="Program.cs" />
+    <Compile Include="Properties\AssemblyInfo.cs" />
+    <EmbeddedResource Include="frmInvoiceTotal.resx">
+      <DependentUpon>frmInvoiceTotal.cs</DependentUpon>
+      <SubType>Designer</SubType>
+    </EmbeddedResource>
+    <EmbeddedResource Include="Properties\Resources.resx">
+      <Generator>ResXFileCodeGenerator</Generator>
+      <LastGenOutput>Resources.Designer.cs</LastGenOutput>
+      <SubType>Designer</SubType>
+    </EmbeddedResource>
+    <Compile Include="Properties\Resources.Designer.cs">
+      <AutoGen>True</AutoGen>
+      <DependentUpon>Resources.resx</DependentUpon>
+      <DesignTime>True</DesignTime>
+    </Compile>
+    <None Include="app.config" />
+    <None Include="Properties\Settings.settings">
+      <Generator>SettingsSingleFileGenerator</Generator>
+      <LastGenOutput>Settings.Designer.cs</LastGenOutput>
+    </None>
+    <Compile Include="Properties\Settings.Designer.cs">
+      <AutoGen>True</AutoGen>
+      <DependentUpon>Settings.settings</DependentUpon>
+      <DesignTimeSharedInput>True</DesignTimeSharedInput>
+    </Compile>
+  </ItemGroup>
+  <ItemGroup>
+    <BootstrapperPackage Include="Microsoft.Net.Client.3.5">
+      <Visible>False</Visible>
+      <ProductName>.NET Framework 3.5 SP1 Client Profile</ProductName>
+      <Install>false</Install>
+    </BootstrapperPackage>
+    <BootstrapperPackage Include="Microsoft.Net.Framework.2.0">
+      <Visible>False</Visible>
+      <ProductName>.NET Framework 2.0 %28x86%29</ProductName>
+      <Install>true</Install>
+    </BootstrapperPackage>
+    <BootstrapperPackage Include="Microsoft.Net.Framework.3.0">
+      <Visible>False</Visible>
+      <ProductName>.NET Framework 3.0 %28x86%29</ProductName>
+      <Install>false</Install>
+    </BootstrapperPackage>
+    <BootstrapperPackage Include="Microsoft.Net.Framework.3.5">
+      <Visible>False</Visible>
+      <ProductName>.NET Framework 3.5</ProductName>
+      <Install>false</Install>
+    </BootstrapperPackage>
+    <BootstrapperPackage Include="Microsoft.Net.Framework.3.5.SP1">
+      <Visible>False</Visible>
+      <ProductName>.NET Framework 3.5 SP1</ProductName>
+      <Install>false</Install>
+    </BootstrapperPackage>
+  </ItemGroup>
+  <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
+</Project>
\ No newline at end of file
diff --git a/invoice_total3/InvoiceTotal/Program.cs b/invoice_total3/InvoiceTotal/Program.cs
new file mode 100644
index 0000000..7f14579
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/Program.cs
@@ -0,0 +1,22 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Threading.Tasks;
+using System.Windows.Forms;
+
+namespace InvoiceTotal
+{
+	static class Program
+	{
+		/// <summary>
+		/// The main entry point for the application.
+		/// </summary>
+		[STAThread]
+		static void Main()
+		{
+			Application.EnableVisualStyles();
+            Application.SetCompatibleTextRenderingDefault(false);
+            Application.Run(new frmInvoiceTotal());
+		}
+	}
+}
\ No newline at end of file
diff --git a/invoice_total3/InvoiceTotal/Properties/AssemblyInfo.cs b/invoice_total3/InvoiceTotal/Properties/AssemblyInfo.cs
new file mode 100644
index 0000000..1d4eb9a
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/Properties/AssemblyInfo.cs
@@ -0,0 +1,33 @@
+using System.Reflection;
+using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
+
+// 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("InvoiceTotal")]
+[assembly: AssemblyDescription("The solution to exercise 4-1 from 'Murach's C# 2005' by Joel Murach")]
+[assembly: AssemblyConfiguration("")]
+[assembly: AssemblyCompany("Mike Murach & Associates, Inc.")]
+[assembly: AssemblyProduct("InvoiceTotal")]
+[assembly: AssemblyCopyright("Copyright �  2006")]
+[assembly: AssemblyTrademark("")]
+[assembly: AssemblyCulture("")]
+
+// Setting ComVisible to false makes the types in this assembly not visible 
+// to COM componenets.  If you need to access a type in this assembly from 
+// COM, set the ComVisible attribute to true on that type.
+[assembly: ComVisible(false)]
+
+// The following GUID is for the ID of the typelib if this project is exposed to COM
+[assembly: Guid("d7e81a3a-db10-47e8-9d34-9338f490ba9d")]
+
+// Version information for an assembly consists of the following four values:
+//
+//      Major Version
+//      Minor Version 
+//      Build Number
+//      Revision
+//
+[assembly: AssemblyVersion("1.0.0.0")]
+[assembly: AssemblyFileVersion("1.0.0.0")]
diff --git a/invoice_total3/InvoiceTotal/Properties/Resources.Designer.cs b/invoice_total3/InvoiceTotal/Properties/Resources.Designer.cs
new file mode 100644
index 0000000..1021f4b
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/Properties/Resources.Designer.cs
@@ -0,0 +1,63 @@
+//------------------------------------------------------------------------------
+// <auto-generated>
+//     This code was generated by a tool.
+//     Runtime Version:4.0.30319.42000
+//
+//     Changes to this file may cause incorrect behavior and will be lost if
+//     the code is regenerated.
+// </auto-generated>
+//------------------------------------------------------------------------------
+
+namespace InvoiceTotal.Properties {
+    using System;
+    
+    
+    /// <summary>
+    ///   A strongly-typed resource class, for looking up localized strings, etc.
+    /// </summary>
+    // 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", "16.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() {
+        }
+        
+        /// <summary>
+        ///   Returns the cached ResourceManager instance used by this class.
+        /// </summary>
+        [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
+        internal static global::System.Resources.ResourceManager ResourceManager {
+            get {
+                if (object.ReferenceEquals(resourceMan, null)) {
+                    global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("InvoiceTotal.Properties.Resources", typeof(Resources).Assembly);
+                    resourceMan = temp;
+                }
+                return resourceMan;
+            }
+        }
+        
+        /// <summary>
+        ///   Overrides the current thread's CurrentUICulture property for all
+        ///   resource lookups using this strongly typed resource class.
+        /// </summary>
+        [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
+        internal static global::System.Globalization.CultureInfo Culture {
+            get {
+                return resourceCulture;
+            }
+            set {
+                resourceCulture = value;
+            }
+        }
+    }
+}
diff --git a/invoice_total3/InvoiceTotal/Properties/Resources.resx b/invoice_total3/InvoiceTotal/Properties/Resources.resx
new file mode 100644
index 0000000..ffecec8
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/Properties/Resources.resx
@@ -0,0 +1,117 @@
+<?xml version="1.0" encoding="utf-8"?>
+<root>
+  <!-- 
+    Microsoft ResX Schema 
+    
+    Version 2.0
+    
+    The primary goals of this format is to allow a simple XML format 
+    that is mostly human readable. The generation and parsing of the 
+    various data types are done through the TypeConverter classes 
+    associated with the data types.
+    
+    Example:
+    
+    ... ado.net/XML headers & schema ...
+    <resheader name="resmimetype">text/microsoft-resx</resheader>
+    <resheader name="version">2.0</resheader>
+    <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
+    <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
+    <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
+    <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
+    <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
+        <value>[base64 mime encoded serialized .NET Framework object]</value>
+    </data>
+    <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
+        <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
+        <comment>This is a comment</comment>
+    </data>
+                
+    There are any number of "resheader" rows that contain simple 
+    name/value pairs.
+    
+    Each data row contains a name, and value. The row also contains a 
+    type or mimetype. Type corresponds to a .NET class that support 
+    text/value conversion through the TypeConverter architecture. 
+    Classes that don't support this are serialized and stored with the 
+    mimetype set.
+    
+    The mimetype is used for serialized objects, and tells the 
+    ResXResourceReader how to depersist the object. This is currently not 
+    extensible. For a given mimetype the value must be set accordingly:
+    
+    Note - application/x-microsoft.net.object.binary.base64 is the format 
+    that the ResXResourceWriter will generate, however the reader can 
+    read any of the formats listed below.
+    
+    mimetype: application/x-microsoft.net.object.binary.base64
+    value   : The object must be serialized with 
+            : System.Serialization.Formatters.Binary.BinaryFormatter
+            : and then encoded with base64 encoding.
+    
+    mimetype: application/x-microsoft.net.object.soap.base64
+    value   : The object must be serialized with 
+            : System.Runtime.Serialization.Formatters.Soap.SoapFormatter
+            : and then encoded with base64 encoding.
+
+    mimetype: application/x-microsoft.net.object.bytearray.base64
+    value   : The object must be serialized into a byte array 
+            : using a System.ComponentModel.TypeConverter
+            : and then encoded with base64 encoding.
+    -->
+  <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
+    <xsd:element name="root" msdata:IsDataSet="true">
+      <xsd:complexType>
+        <xsd:choice maxOccurs="unbounded">
+          <xsd:element name="metadata">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" />
+              </xsd:sequence>
+              <xsd:attribute name="name" type="xsd:string" />
+              <xsd:attribute name="type" type="xsd:string" />
+              <xsd:attribute name="mimetype" type="xsd:string" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="assembly">
+            <xsd:complexType>
+              <xsd:attribute name="alias" type="xsd:string" />
+              <xsd:attribute name="name" type="xsd:string" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="data">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
+                <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
+              </xsd:sequence>
+              <xsd:attribute name="name" type="xsd:string" msdata:Ordinal="1" />
+              <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
+              <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="resheader">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
+              </xsd:sequence>
+              <xsd:attribute name="name" type="xsd:string" use="required" />
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:choice>
+      </xsd:complexType>
+    </xsd:element>
+  </xsd:schema>
+  <resheader name="resmimetype">
+    <value>text/microsoft-resx</value>
+  </resheader>
+  <resheader name="version">
+    <value>2.0</value>
+  </resheader>
+  <resheader name="reader">
+    <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
+  </resheader>
+  <resheader name="writer">
+    <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
+  </resheader>
+</root>
\ No newline at end of file
diff --git a/invoice_total3/InvoiceTotal/Properties/Settings.Designer.cs b/invoice_total3/InvoiceTotal/Properties/Settings.Designer.cs
new file mode 100644
index 0000000..8525954
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/Properties/Settings.Designer.cs
@@ -0,0 +1,26 @@
+//------------------------------------------------------------------------------
+// <auto-generated>
+//     This code was generated by a tool.
+//     Runtime Version:4.0.30319.42000
+//
+//     Changes to this file may cause incorrect behavior and will be lost if
+//     the code is regenerated.
+// </auto-generated>
+//------------------------------------------------------------------------------
+
+namespace InvoiceTotal.Properties {
+    
+    
+    [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()]
+    [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "16.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 --git a/invoice_total3/InvoiceTotal/Properties/Settings.settings b/invoice_total3/InvoiceTotal/Properties/Settings.settings
new file mode 100644
index 0000000..abf36c5
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/Properties/Settings.settings
@@ -0,0 +1,7 @@
+<?xml version='1.0' encoding='utf-8'?>
+<SettingsFile xmlns="http://schemas.microsoft.com/VisualStudio/2004/01/settings" CurrentProfile="(Default)">
+  <Profiles>
+    <Profile Name="(Default)" />
+  </Profiles>
+  <Settings />
+</SettingsFile>
diff --git a/invoice_total3/InvoiceTotal/app.config b/invoice_total3/InvoiceTotal/app.config
new file mode 100644
index 0000000..99dca75
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/app.config
@@ -0,0 +1,3 @@
+<?xml version="1.0"?>
+<configuration>
+<startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.8"/></startup></configuration>
diff --git a/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe
new file mode 100644
index 0000000..d59aa71
Binary files /dev/null and b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe differ
diff --git a/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe.config b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe.config
new file mode 100644
index 0000000..99dca75
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.exe.config
@@ -0,0 +1,3 @@
+<?xml version="1.0"?>
+<configuration>
+<startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.8"/></startup></configuration>
diff --git a/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.pdb b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.pdb
new file mode 100644
index 0000000..32609a8
Binary files /dev/null and b/invoice_total3/InvoiceTotal/bin/Debug/InvoiceTotal.pdb differ
diff --git a/invoice_total3/InvoiceTotal/frmInvoiceTotal.Designer.cs b/invoice_total3/InvoiceTotal/frmInvoiceTotal.Designer.cs
new file mode 100644
index 0000000..04a8425
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/frmInvoiceTotal.Designer.cs
@@ -0,0 +1,211 @@
+namespace InvoiceTotal
+{
+	partial class frmInvoiceTotal
+	{
+		/// <summary>
+		/// Required designer variable.
+		/// </summary>
+		private System.ComponentModel.IContainer components = null;
+
+		/// <summary>
+		/// Clean up any resources being used.
+		/// </summary>
+		/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
+		protected override void Dispose(bool disposing)
+		{
+			if (disposing && (components != null))
+			{
+				components.Dispose();
+			}
+			base.Dispose(disposing);
+		}
+
+		#region Windows Form Designer generated code
+
+		/// <summary>
+		/// Required method for Designer support - do not modify
+		/// the contents of this method with the code editor.
+		/// </summary>
+		private void InitializeComponent()
+		{
+            this.label1 = new System.Windows.Forms.Label();
+            this.label2 = new System.Windows.Forms.Label();
+            this.label3 = new System.Windows.Forms.Label();
+            this.label4 = new System.Windows.Forms.Label();
+            this.label5 = new System.Windows.Forms.Label();
+            this.label6 = new System.Windows.Forms.Label();
+            this.label7 = new System.Windows.Forms.Label();
+            this.txtSubtotal = new System.Windows.Forms.TextBox();
+            this.btnCalculate = new System.Windows.Forms.Button();
+            this.btnExit = new System.Windows.Forms.Button();
+            this.txtDiscountPercent = new System.Windows.Forms.TextBox();
+            this.txtDiscountAmount = new System.Windows.Forms.TextBox();
+            this.txtTotal = new System.Windows.Forms.TextBox();
+            this.SuspendLayout();
+            // 
+            // label1
+            // 
+            this.label1.AutoSize = true;
+            this.label1.Location = new System.Drawing.Point(20, 12);
+            this.label1.Name = "label1";
+            this.label1.Size = new System.Drawing.Size(49, 13);
+            this.label1.TabIndex = 0;
+            this.label1.Text = "&Subtotal:";
+            this.label1.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
+            // 
+            // label2
+            // 
+            this.label2.AutoSize = true;
+            this.label2.Location = new System.Drawing.Point(20, 38);
+            this.label2.Name = "label2";
+            this.label2.Size = new System.Drawing.Size(92, 13);
+            this.label2.TabIndex = 1;
+            this.label2.Text = "Discount Percent:";
+            this.label2.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
+            // 
+            // label3
+            // 
+            this.label3.AutoSize = true;
+            this.label3.Location = new System.Drawing.Point(21, 65);
+            this.label3.Name = "label3";
+            this.label3.Size = new System.Drawing.Size(91, 13);
+            this.label3.TabIndex = 2;
+            this.label3.Text = "Discount Amount:";
+            this.label3.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
+            // 
+            // label4
+            // 
+            this.label4.AutoSize = true;
+            this.label4.Location = new System.Drawing.Point(21, 91);
+            this.label4.Name = "label4";
+            this.label4.Size = new System.Drawing.Size(34, 13);
+            this.label4.TabIndex = 3;
+            this.label4.Text = "Total:";
+            this.label4.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
+            // 
+            // label5
+            // 
+            this.label5.AutoSize = true;
+            this.label5.Location = new System.Drawing.Point(128, 40);
+            this.label5.Name = "label5";
+            this.label5.Size = new System.Drawing.Size(0, 13);
+            this.label5.TabIndex = 4;
+            this.label5.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
+            // 
+            // label6
+            // 
+            this.label6.AutoSize = true;
+            this.label6.Location = new System.Drawing.Point(128, 70);
+            this.label6.Name = "label6";
+            this.label6.Size = new System.Drawing.Size(0, 13);
+            this.label6.TabIndex = 5;
+            this.label6.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
+            // 
+            // label7
+            // 
+            this.label7.AutoSize = true;
+            this.label7.Location = new System.Drawing.Point(128, 101);
+            this.label7.Name = "label7";
+            this.label7.Size = new System.Drawing.Size(0, 13);
+            this.label7.TabIndex = 6;
+            this.label7.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
+            // 
+            // txtSubtotal
+            // 
+            this.txtSubtotal.Location = new System.Drawing.Point(115, 9);
+            this.txtSubtotal.Name = "txtSubtotal";
+            this.txtSubtotal.Size = new System.Drawing.Size(100, 20);
+            this.txtSubtotal.TabIndex = 1;
+            // 
+            // btnCalculate
+            // 
+            this.btnCalculate.Location = new System.Drawing.Point(53, 122);
+            this.btnCalculate.Name = "btnCalculate";
+            this.btnCalculate.Size = new System.Drawing.Size(75, 23);
+            this.btnCalculate.TabIndex = 2;
+            this.btnCalculate.Text = "&Calculate";
+            this.btnCalculate.Click += new System.EventHandler(this.btnCalculate_Click);
+            // 
+            // btnExit
+            // 
+            this.btnExit.DialogResult = System.Windows.Forms.DialogResult.Cancel;
+            this.btnExit.Location = new System.Drawing.Point(140, 122);
+            this.btnExit.Name = "btnExit";
+            this.btnExit.Size = new System.Drawing.Size(75, 23);
+            this.btnExit.TabIndex = 3;
+            this.btnExit.Text = "E&xit";
+            this.btnExit.Click += new System.EventHandler(this.btnExit_Click);
+            // 
+            // txtDiscountPercent
+            // 
+            this.txtDiscountPercent.Location = new System.Drawing.Point(115, 35);
+            this.txtDiscountPercent.Name = "txtDiscountPercent";
+            this.txtDiscountPercent.ReadOnly = true;
+            this.txtDiscountPercent.Size = new System.Drawing.Size(100, 20);
+            this.txtDiscountPercent.TabIndex = 10;
+            this.txtDiscountPercent.TabStop = false;
+            // 
+            // txtDiscountAmount
+            // 
+            this.txtDiscountAmount.Location = new System.Drawing.Point(115, 62);
+            this.txtDiscountAmount.Name = "txtDiscountAmount";
+            this.txtDiscountAmount.ReadOnly = true;
+            this.txtDiscountAmount.Size = new System.Drawing.Size(100, 20);
+            this.txtDiscountAmount.TabIndex = 11;
+            this.txtDiscountAmount.TabStop = false;
+            // 
+            // txtTotal
+            // 
+            this.txtTotal.Location = new System.Drawing.Point(115, 88);
+            this.txtTotal.Name = "txtTotal";
+            this.txtTotal.ReadOnly = true;
+            this.txtTotal.Size = new System.Drawing.Size(100, 20);
+            this.txtTotal.TabIndex = 12;
+            this.txtTotal.TabStop = false;
+            // 
+            // frmInvoiceTotal
+            // 
+            this.AcceptButton = this.btnCalculate;
+            this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
+            this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
+            this.CancelButton = this.btnExit;
+            this.ClientSize = new System.Drawing.Size(237, 159);
+            this.Controls.Add(this.txtTotal);
+            this.Controls.Add(this.txtDiscountAmount);
+            this.Controls.Add(this.txtDiscountPercent);
+            this.Controls.Add(this.btnExit);
+            this.Controls.Add(this.btnCalculate);
+            this.Controls.Add(this.txtSubtotal);
+            this.Controls.Add(this.label7);
+            this.Controls.Add(this.label6);
+            this.Controls.Add(this.label5);
+            this.Controls.Add(this.label4);
+            this.Controls.Add(this.label3);
+            this.Controls.Add(this.label2);
+            this.Controls.Add(this.label1);
+            this.Name = "frmInvoiceTotal";
+            this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen;
+            this.Text = "Invoice Total";
+            this.ResumeLayout(false);
+            this.PerformLayout();
+
+		}
+
+		#endregion
+
+		private System.Windows.Forms.Label label1;
+		private System.Windows.Forms.Label label2;
+		private System.Windows.Forms.Label label3;
+		private System.Windows.Forms.Label label4;
+		private System.Windows.Forms.Label label5;
+		private System.Windows.Forms.Label label6;
+		private System.Windows.Forms.Label label7;
+		private System.Windows.Forms.TextBox txtSubtotal;
+		private System.Windows.Forms.Button btnCalculate;
+		private System.Windows.Forms.Button btnExit;
+		private System.Windows.Forms.TextBox txtDiscountPercent;
+		private System.Windows.Forms.TextBox txtDiscountAmount;
+		private System.Windows.Forms.TextBox txtTotal;
+	}
+}
+
diff --git a/invoice_total3/InvoiceTotal/frmInvoiceTotal.cs b/invoice_total3/InvoiceTotal/frmInvoiceTotal.cs
new file mode 100644
index 0000000..94edf91
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/frmInvoiceTotal.cs
@@ -0,0 +1,59 @@
+using System;
+using System.Collections.Generic;
+using System.ComponentModel;
+using System.Data;
+using System.Drawing;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using System.Windows.Forms;
+
+namespace InvoiceTotal
+{
+	public partial class frmInvoiceTotal : Form
+	{
+		public frmInvoiceTotal()
+		{
+			InitializeComponent();
+		}
+
+		private void btnCalculate_Click(object sender, EventArgs e)
+		{
+			try {
+				if (txtSubtotal.Text == "") {
+					MessageBox.Show("Please enter a subtotal",
+						"Entry Error");
+					return;
+				}
+				decimal subtotal = Decimal.Parse(txtSubtotal.Text);
+				if (subtotal <= 0 || subtotal >= 10000) {
+					MessageBox.Show("The subtotal must be in the "
+						+ "range of 1 to 9999", "Entry Error");
+					return;
+				}
+				decimal discountPercent = .25m;
+				decimal discountAmount = subtotal * discountPercent;
+				decimal invoiceTotal = subtotal - discountAmount;
+
+				discountAmount = Math.Round(discountAmount, 2);
+				invoiceTotal = Math.Round(invoiceTotal, 2);
+
+				txtDiscountPercent.Text = discountPercent.ToString("p1");
+				txtDiscountAmount.Text = discountAmount.ToString();
+				txtTotal.Text = invoiceTotal.ToString();
+				txtSubtotal.Focus();
+			}
+			catch {
+				MessageBox.Show(
+					"Please enter a valid subtotal for the "
+					+ "subtotal field.", "Entry Error");
+			}
+
+		}
+
+		private void btnExit_Click(object sender, EventArgs e)
+		{
+			this.Close();
+		}
+	}
+}
\ No newline at end of file
diff --git a/invoice_total3/InvoiceTotal/frmInvoiceTotal.resx b/invoice_total3/InvoiceTotal/frmInvoiceTotal.resx
new file mode 100644
index 0000000..c7e0d4b
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/frmInvoiceTotal.resx
@@ -0,0 +1,120 @@
+<?xml version="1.0" encoding="utf-8"?>
+<root>
+  <!-- 
+    Microsoft ResX Schema 
+    
+    Version 2.0
+    
+    The primary goals of this format is to allow a simple XML format 
+    that is mostly human readable. The generation and parsing of the 
+    various data types are done through the TypeConverter classes 
+    associated with the data types.
+    
+    Example:
+    
+    ... ado.net/XML headers & schema ...
+    <resheader name="resmimetype">text/microsoft-resx</resheader>
+    <resheader name="version">2.0</resheader>
+    <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
+    <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
+    <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
+    <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
+    <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
+        <value>[base64 mime encoded serialized .NET Framework object]</value>
+    </data>
+    <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
+        <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
+        <comment>This is a comment</comment>
+    </data>
+                
+    There are any number of "resheader" rows that contain simple 
+    name/value pairs.
+    
+    Each data row contains a name, and value. The row also contains a 
+    type or mimetype. Type corresponds to a .NET class that support 
+    text/value conversion through the TypeConverter architecture. 
+    Classes that don't support this are serialized and stored with the 
+    mimetype set.
+    
+    The mimetype is used for serialized objects, and tells the 
+    ResXResourceReader how to depersist the object. This is currently not 
+    extensible. For a given mimetype the value must be set accordingly:
+    
+    Note - application/x-microsoft.net.object.binary.base64 is the format 
+    that the ResXResourceWriter will generate, however the reader can 
+    read any of the formats listed below.
+    
+    mimetype: application/x-microsoft.net.object.binary.base64
+    value   : The object must be serialized with 
+            : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
+            : and then encoded with base64 encoding.
+    
+    mimetype: application/x-microsoft.net.object.soap.base64
+    value   : The object must be serialized with 
+            : System.Runtime.Serialization.Formatters.Soap.SoapFormatter
+            : and then encoded with base64 encoding.
+
+    mimetype: application/x-microsoft.net.object.bytearray.base64
+    value   : The object must be serialized into a byte array 
+            : using a System.ComponentModel.TypeConverter
+            : and then encoded with base64 encoding.
+    -->
+  <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
+    <xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
+    <xsd:element name="root" msdata:IsDataSet="true">
+      <xsd:complexType>
+        <xsd:choice maxOccurs="unbounded">
+          <xsd:element name="metadata">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" />
+              </xsd:sequence>
+              <xsd:attribute name="name" use="required" type="xsd:string" />
+              <xsd:attribute name="type" type="xsd:string" />
+              <xsd:attribute name="mimetype" type="xsd:string" />
+              <xsd:attribute ref="xml:space" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="assembly">
+            <xsd:complexType>
+              <xsd:attribute name="alias" type="xsd:string" />
+              <xsd:attribute name="name" type="xsd:string" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="data">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
+                <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
+              </xsd:sequence>
+              <xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
+              <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
+              <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
+              <xsd:attribute ref="xml:space" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="resheader">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
+              </xsd:sequence>
+              <xsd:attribute name="name" type="xsd:string" use="required" />
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:choice>
+      </xsd:complexType>
+    </xsd:element>
+  </xsd:schema>
+  <resheader name="resmimetype">
+    <value>text/microsoft-resx</value>
+  </resheader>
+  <resheader name="version">
+    <value>2.0</value>
+  </resheader>
+  <resheader name="reader">
+    <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
+  </resheader>
+  <resheader name="writer">
+    <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
+  </resheader>
+</root>
\ No newline at end of file
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/.NETFramework,Version=v4.8.AssemblyAttributes.cs b/invoice_total3/InvoiceTotal/obj/Debug/.NETFramework,Version=v4.8.AssemblyAttributes.cs
new file mode 100644
index 0000000..3cf0af3
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/obj/Debug/.NETFramework,Version=v4.8.AssemblyAttributes.cs
@@ -0,0 +1,4 @@
+// <autogenerated />
+using System;
+using System.Reflection;
+[assembly: global::System.Runtime.Versioning.TargetFrameworkAttribute(".NETFramework,Version=v4.8", FrameworkDisplayName = ".NET Framework 4.8")]
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache b/invoice_total3/InvoiceTotal/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache
new file mode 100644
index 0000000..4ea7442
Binary files /dev/null and b/invoice_total3/InvoiceTotal/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache differ
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.Properties.Resources.resources b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.Properties.Resources.resources
new file mode 100644
index 0000000..6c05a97
Binary files /dev/null and b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.Properties.Resources.resources differ
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.AssemblyReference.cache b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.AssemblyReference.cache
new file mode 100644
index 0000000..b3072eb
Binary files /dev/null and b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.AssemblyReference.cache differ
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.CoreCompileInputs.cache b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.CoreCompileInputs.cache
new file mode 100644
index 0000000..6621da8
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.CoreCompileInputs.cache
@@ -0,0 +1 @@
+ddd884c7cc4fbc526b3c79f739672bb101481755939ee83704695fd42ac85f71
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.FileListAbsolute.txt b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.FileListAbsolute.txt
new file mode 100644
index 0000000..e18563a
--- /dev/null
+++ b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.FileListAbsolute.txt
@@ -0,0 +1,10 @@
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.csproj.AssemblyReference.cache
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.frmInvoiceTotal.resources
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.Properties.Resources.resources
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.csproj.GenerateResource.cache
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.csproj.CoreCompileInputs.cache
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\bin\Debug\InvoiceTotal.exe.config
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\bin\Debug\InvoiceTotal.exe
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\bin\Debug\InvoiceTotal.pdb
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.exe
+C:\Users\User\Documents\cs\Exercise Starts\Chapter 07\InvoiceTotal\InvoiceTotal\obj\Debug\InvoiceTotal.pdb
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.GenerateResource.cache b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.GenerateResource.cache
new file mode 100644
index 0000000..2f304b5
Binary files /dev/null and b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.csproj.GenerateResource.cache differ
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.exe b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.exe
new file mode 100644
index 0000000..d59aa71
Binary files /dev/null and b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.exe differ
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.frmInvoiceTotal.resources b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.frmInvoiceTotal.resources
new file mode 100644
index 0000000..6c05a97
Binary files /dev/null and b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.frmInvoiceTotal.resources differ
diff --git a/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.pdb b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.pdb
new file mode 100644
index 0000000..32609a8
Binary files /dev/null and b/invoice_total3/InvoiceTotal/obj/Debug/InvoiceTotal.pdb differ
-- 
cgit 1.4.1