Can't delete a compiled file -  "file in use"

Posted on 2008-10-23
Last Modified: 2012-05-05
I'm running the code below that compiles and runs a dll. It works great - except when the program loops back around it can't delete the existing dll because "file is in use"
Once the dll below is created and run, how can i released it so i can then delete it?

            If m_Code.Trim <> "" Then

                If m_Namespace.Trim <> "" Then

                    If m_ClassName.Trim <> "" Then



                            If File.Exists(m_AppPath & "\" & m_Namespace & ".dll") Then File.Delete(m_AppPath & "\" & m_Namespace & ".dll")

                            If File.Exists("c:\windows\system32\" & m_Namespace & ".dll") Then File.Delete("c:\windows\system32\" & m_Namespace & ".dll")


                        End Try


                        Dim VBP As New VBCodeProvider()

                        Dim CVB As System.CodeDom.Compiler.ICodeCompiler

                        CVB = VBP.CreateCompiler

                        Dim PM As New System.CodeDom.Compiler.CompilerParameters()

                        PM.GenerateInMemory = False

                        PM.OutputAssembly = m_Namespace & ".dll"

                        PM.MainClass = m_ClassName

                        PM.IncludeDebugInformation = True


                        'Add assemblies

                        Dim ASM As System.Reflection.Assembly

                        For Each ASM In AppDomain.CurrentDomain.GetAssemblies()



                        PM.ReferencedAssemblies.Add(m_AppPath & "\ActiveReports.dll")

                        PM.ReferencedAssemblies.Add(m_AppPath & "\ActiveReports.XlsExport.dll")

                        PM.ReferencedAssemblies.Add(m_AppPath & "\ActiveReports.PdfExport.dll")

                        PM.ReferencedAssemblies.Add(m_AppPath & "\ActiveReports.Viewer.dll")

                        PM.ReferencedAssemblies.Add(m_AppPath & "\")


                        'here we do the deed

                        Dim Results As System.CodeDom.Compiler.CompilerResults

                        Results = CVB.CompileAssemblyFromSource(PM, m_Code)


                        'this is just to list out all the errors if any

                        Dim Err As System.CodeDom.Compiler.CompilerError

                        For Each err In Results.Errors

                            m_Results &= "Number " & err.ErrorNumber & " Text " & err.ErrorText & " Line " & err.Line & VbCrLf



                        Dim RunObj As New Object()

                        Dim vArgs() As Object

                        RunObj = Results.CompiledAssembly.CreateInstance(m_Namespace & "." & m_ClassName, False, Reflection.BindingFlags.CreateInstance, Nothing, vArgs, Nothing, Nothing)

                        If RunObj Is Nothing Then

                            m_Results &= "Unable to run dll - failed." & VbCrLf

                        End If



                        m_Results &= "No class name found." & VbCrLf

                    End If


                    m_Results &= "No namespace found." & VbCrLf

                End If


                m_Results &= "No code found." & VbCrLf

            End If


            If Len(m_Results) = 0 Then m_Results = "OK"

        Catch err As Exception

            m_Results &= "ERROR: " & err.Message & " " & err.StackTrace & VbCrLf

        End Try

Open in new window

Question by:LosBear
LVL 11

Accepted Solution

melmers earned 250 total points
ID: 22892996
You can only unload an assembly if it is in another appdomain.
So you must create an appdomain which loads the compiled assembly and when it should unload you must unload the whole appdomain.

Here is an MSDN Magazine Article about it.

Author Closing Comment

ID: 31509268

Featured Post

Threat Intelligence Starter Resources

Integrating threat intelligence can be challenging, and not all companies are ready. These resources can help you build awareness and prepare for defense.

Join & Write a Comment

Well, all of us have seen the multiple EXCEL.EXE's in task manager that won't die even if you call the .close, .dispose methods. Try this method to kill any excels in memory. You can copy the kill function to create a check function and replace the …
A while ago, I was working on a Windows Forms application and I needed a special label control with reflection (glass) effect to show some titles in a stylish way. I've always enjoyed working with graphics, but it's never too clever to re-invent …
This video gives you a great overview about bandwidth monitoring with SNMP and WMI with our network monitoring solution PRTG Network Monitor ( If you're looking for how to monitor bandwidth using netflow or packet s…
This video shows how to remove a single email address from the Outlook 2010 Auto Suggestion memory. NOTE: For Outlook 2016 and 2013 perform the exact same steps. Open a new email: Click the New email button in Outlook. Start typing the address: …

708 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now