windows-nt/Source/XPSP1/NT/admin/pchealth/authtools/prodtools/common/cmdlineoptions.bas
2020-09-26 16:20:57 +08:00

156 lines
4.4 KiB
QBasic

Attribute VB_Name = "CmdLineOptions"
Option Explicit
' i_strCommand is the command line.
' i_strOptionList is a comma separated list of options that we are looking for, eg
' "h,?,help" will look for /h, /?, /help
Public Function OptionExists( _
ByVal i_strCommand As String, _
ByVal i_strOptionList, _
ByVal i_blnIgnoreCase As Boolean _
) As Boolean
Dim arrCmdOptions() As String
Dim arrOptions() As String
Dim intCmdIndex As Long
Dim intOptionIndex As Long
Dim strOption As String
Dim strCmdWord As String
arrCmdOptions = Split(i_strCommand)
arrOptions = Split(i_strOptionList, ",")
For intOptionIndex = LBound(arrOptions) To UBound(arrOptions)
strOption = "/" & arrOptions(intOptionIndex)
If (i_blnIgnoreCase) Then
strOption = LCase$(strOption)
End If
For intCmdIndex = LBound(arrCmdOptions) To UBound(arrCmdOptions)
If (arrCmdOptions(intCmdIndex) <> "") Then
strCmdWord = arrCmdOptions(intCmdIndex)
If (i_blnIgnoreCase) Then
strCmdWord = LCase$(strCmdWord)
End If
If (strOption = strCmdWord) Then
OptionExists = True
Exit Function
End If
End If
Next
Next
OptionExists = False
End Function
' i_strCommand is the command line.
' i_strOptionList is a comma separated list of options that we are looking for, eg
' "i,input" will look for /i or /input. When one is found, the next word from
' the command line is returned. Multiple words enclosed in double quotes are
' considered a single word. The quotes are stripped.
' Eg GetOption("/abc def /ghi ""Hello World""", "ghi", True) returns Hello World
Public Function GetOption( _
ByVal i_strCommand As String, _
ByVal i_strOptionList, _
ByVal i_blnIgnoreCase As Boolean _
) As String
On Error GoTo LErrorHandler
Dim arrOptions() As String
Dim intIndex As Long
Dim strRemainingCmdLine As String
Dim strCurrentChar As String
Dim strCurrentWord As String
Dim strTerminatingChar As String
Dim strOption As String
Dim intPos As Long
Dim blnOptionFound As Boolean
strRemainingCmdLine = Trim$(i_strCommand)
arrOptions = Split(i_strOptionList, ",")
Do While (strRemainingCmdLine <> "")
strCurrentChar = Mid$(strRemainingCmdLine, 1, 1)
Select Case strCurrentChar
Case """"
strTerminatingChar = """"
Case Else
strTerminatingChar = " "
End Select
' Where does this word end? Start is 2, because we don't want
' the search to stop at the current character.
intPos = InStr(2, strRemainingCmdLine, strTerminatingChar)
If intPos = 0 Then
intPos = Len(strRemainingCmdLine) + 1
End If
If (strTerminatingChar = """") Then
' Eat the terminating double quotes too.
intPos = intPos + 1
End If
strCurrentWord = Mid$(strRemainingCmdLine, 1, intPos - 1)
strRemainingCmdLine = Trim$(Mid$(strRemainingCmdLine, intPos))
If blnOptionFound Then
If strCurrentChar = "/" Then
' strCurrentWord represents the next option. The desired option
' was not followed by any non-option word.
GetOption = ""
Else
If (strTerminatingChar = """") Then
' Strip out the enclosing double quotes
GetOption = Mid$(strCurrentWord, 2, Len(strCurrentWord) - 2)
Else
GetOption = strCurrentWord
End If
End If
Exit Function
End If
If (i_blnIgnoreCase) Then
strCurrentWord = LCase$(strCurrentWord)
End If
For intIndex = LBound(arrOptions) To UBound(arrOptions)
strOption = "/" & arrOptions(intIndex)
If (i_blnIgnoreCase) Then
strOption = LCase$(strOption)
End If
If (strOption = strCurrentWord) Then
blnOptionFound = True
End If
Next
Loop
Exit Function
LErrorHandler:
GetOption = ""
End Function