Windows Script Host \ VBScript Error \ 800704C8

Attached is a script that copies Microsoft Office templates from a server share to a user's computer when they log in.  It is a VB Script that is run during logon via Group Policy.  I am starting to hear reports of user's getting an error message that says:
"The requested operation cannot be performed on a file with a user-mapped section open" (screenshot attached) and mentions line 35, error code 800704C8.

I was able to reproduce the problem once on my laptop, could this possibly be due to roaming profiles and being logged in to two separate PCs at once?

Please let me know if i left out any other important information on my environment and thanks as always!
Option Explicit
 
dim TemplatePath
dim ExcelPath
 
TemplatePath = CreateObject("WScript.Shell").ExpandEnvironmentStrings("%UserProfile%") & ("\Application Data\Microsoft\Templates")
ExcelPath    = CreateObject("WScript.Shell").ExpandEnvironmentStrings("%UserProfile%") & ("\Application Data\Microsoft\Excel\XLSTART")
 
dim objFSO
set objFSO = CreateObject("Scripting.FileSystemObject")
 
CheckAndCreateFolders(TemplatePath)
CheckAndCreateFolders(ExcelPath)
 
Sub CheckAndCreateFolders(sPath)
    Dim arrPath
    Dim strPath
    Dim n
    arrPath = split(sPath,"\")
    for n = LBound(arrPath) to UBound(arrPath)
        if n = LBound(arrPath) then
            strPath = arrPath(n)
        else
            strPath = strPath & "\" & arrPath(n)
        end if
        If Not objFSO.FolderExists(strPath) Then
            'msgbox strPath
            objFSO.CreateFolder strPath
        End If
    next
End Sub
 
Const OverwriteExisting = True
 
objFSO.CopyFile "\\serverpdc\public\Office Management\Corporate Identity & Art Work\Office 2007 Templates\*", TemplatePath & "\", OverwriteExisting
objFSO.CopyFile "\\serverpdc\public\Office Management\Corporate Identity & Art Work\Office 2007 Templates\Excel\*", ExcelPath & "\", OverwriteExisting

Open in new window

6-26-2009-11-54-12-AM.png
LVL 6
zeotechAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Ron MalmsteadInformation Services ManagerCommented:
That basically means the file is "locked" or in-use.  Probably does have something to do with Roaming profile.

Does it only happen when logged on to two different machines ?
0
zeotechAuthor Commented:
I just tried executing the script manually from a laptop while logged in to the desktop as well and I did not receive the error message.
0
Ron MalmsteadInformation Services ManagerCommented:
Try putting in some sleep time before the actual copy operation...

Maybe the profile is still loading after the logon while that file is being copied...
0
boowhupCommented:
On the server it's sitting on, check if anyone has it "open" Computer Managment - Shared Folders - Open Files. It sounds like someone is oopening the source file directly.

Or it may be "contention" - everyone logs in at the same time, and there could be too many people trying to copy it at once. Maybe you could add some conditional statements to your script that check the file is newer on the server than your local one before ti copies it.
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Visual Basic Classic

From novice to tech pro — start learning today.