我在做这个(我认为会是)一个小而简单的任务时正在学习powershell。我真的不知道我哪里出错了,所以希望有人能指出我正确的方向。我只是想将一些项目添加到一个名为“All.sln”的解决方案中。我有以下代码:
[string]$slnName = "All"
[string]$baseDir = "SOMEDIR_OF_PROJECTS"
[string]$slnPath = (Join-Path $baseDir 'All.sln')
$dteObj = New-Object -ComObject "VisualStudio.DTE.10.0"
$solution = $dteObj.Solution
$solution.Create($baseDir, $slnName)
Write-Output "Solution Path: " $slnPath
(ls $baseDir -Recurse *.vbproj) | % {
Write-Output $_.FullName
$solution = $dteObj.Solution
$solution.AddFromFile($_.FullName, $false)
$solution.SaveAs( $slnPath )
}
Write-Output ( $slnPath )
$dteObj.Solution.SaveAs( $slnPath )
$dteObj.Quit()
我不断收到各种不同的错误,所以我的想法是我肯定在这里做错了什么,但对我来说我做错了什么并不明显。
我有时会收到此错误(通常在我尝试添加的第一个项目文件中):
WARNING: System.Runtime.InteropServices.COMException (0x80010001): Call was rejected by callee. (Exception from HRESULT: 0x80
010001 (RPC_E_CALL_REJECTED))
at System.Runtime.InteropServices.ComTypes.ITypeInfo.GetTypeAttr(IntPtr& ppTypeAttr)
at System.Management.Automation.ComTypeInfo.GetTypeAttr(ITypeInfo typeinfo)
at System.Management.Automation.ComTypeInfo.Initialize()
at System.Management.Automation.ComTypeInfo.GetDispatchTypeInfo(Object comObject)
at System.Management.Automation.PSObject.GetMappedAdapter(Object obj, TypeTable typeTable)
at System.Management.Automation.PSObject.get_InternalAdapterSet()
at System.Management.Automation.PSObject.get_InternalTypeNames()
at System.Management.Automation.CmdletParameterBinderController.BindPipelineParametersPrivate(PSObject inputToOperateOn)
at System.Management.Automation.CmdletParameterBinderController.BindPipelineParameters(PSObject inputToOperateOn)
at System.Management.Automation.CommandProcessor.Read()
at System.Management.Automation.CommandProcessor.ProcessRecord()
at System.Management.Automation.CommandProcessorBase.DoExecute()
at System.Management.Automation.EnumerableOps.WriteEnumerableToPipe(IEnumerator enumerator, Pipe pipe, ExecutionContext co
ntext, Boolean dispose)
at System.Dynamic.UpdateDelegates.UpdateAndExecuteVoid3[T0,T1,T2](CallSite site, T0 arg0, T1 arg1, T2 arg2)
at System.Management.Automation.Interpreter.ActionCallInstruction`5.Invoke(Object arg0, Object arg1, Object arg2, Object a
rg3, Object arg4)
at System.Management.Automation.Interpreter.CallInstruction.InvokeInstance(Object instance, Object[] args)
at System.Management.Automation.Interpreter.DynamicInstructionN.Run(InterpretedFrame frame)
at System.Management.Automation.Interpreter.EnterTryCatchFinallyInstruction.Run(InterpretedFrame frame)
或者有时我得到(空??):
You cannot call a method on a null-valued expression.
At C:\DevHome\TFS\VCore\Scripts\BuildScripts\CreateMasterSolution.ps1:25 char:32
+ $solution.AddFromFile($_.FullName)
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (:) [], RuntimeException
+ FullyQualifiedErrorId : InvokeMethodOnNull
或者有时我得到(MethodNotFound??):
Method invocation failed because [System.__ComObject] does not contain a method named 'SaveAs'.
At C:\DevHome\VCore\VCore\Scripts\BuildScripts\CreateMasterSolution.ps1:27 char:32
+ $solution.SaveAs( $slnPath )
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (SaveAs:String) [], RuntimeException
+ FullyQualifiedErrorId : MethodNotFound
或者有时我得到(MethodNotFound??):
Method invocation failed because [System.__ComObject] does not contain a method named 'AddFromFile'.
At C:\DevHome\TFS\VCore\Scripts\BuildScripts\CreateMasterSolution.ps1:18 char:32
+ $solution.AddFromFile($_.FullName)
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (AddFromFile:String) [], RuntimeException
+ FullyQualifiedErrorId : MethodNotFound
或者有时我得到:
Call was rejected by callee. (Exception from HRESULT: 0x80010001 (RPC_E_CALL_REJECTED))
At C:\DevHome\TFS\VCore\Scripts\BuildScripts\CreateMasterSolution.ps1:18 char:32
+ $solution.AddFromFile($_.FullName)
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : OperationStopped: (:) [], COMException
+ FullyQualifiedErrorId : System.Runtime.InteropServices.COMException