windows-nt/Source/XPSP1/NT/admin/pchealth/authtools/prodtools/common/rutinaslib.bas

330 lines
9.5 KiB
QBasic
Raw Normal View History

2020-09-26 03:20:57 -05:00
Attribute VB_Name = "RutinasLib"
'===========================================================================================
' Rutinas de Libreria
'
'===========================================================================================
' SubRoutine : vntGetTok
' Author : Pierre Jacomet
' Version : 1.1
'
' Description : Devuelve un Token tipado extrayendo el mismo del String de origen
' sobre la base de un separador de Tokens pasado como argumento.
'
' Called by : Anyone, utility
'
' Environment data:
' Files that it uses (Specify if they are inherited in open state): NONE
' Parameters (Command Line) and usage mode {I,I/O,O}:
' Parameters (inherited from environment) :
' Public Variables created:
' Environment Variables (Public or Module Level) modified:
' Environment Variables used in coupling with other routines:
' Local variables :
' Problems detected :
' Request for Modifications:
' History:
' 1999-08-01 Added some routines for Skipping Whites, and File Management
'===========================================================================================
Option Explicit
Public Function vntGetTok(ByRef sTokStrIO As String, Optional ByVal iTipDatoIN = vbString, Optional ByVal sTokSepIN As String = ":") As Variant
Dim iPosSep As Integer
sTokStrIO = Trim$(sTokStrIO)
If Len(sTokStrIO) > 0 Then
iPosSep = InStr(1, sTokStrIO, sTokSepIN, 0)
Select Case iTipDatoIN
Case vbInteger To vbDouble, vbCurrency, vbDecimal
vntGetTok = IIf(iPosSep > 0, Val(SubStr(sTokStrIO, 1, iPosSep - 1)), _
Val(sTokStrIO))
Case vbString
vntGetTok = IIf(iPosSep > 0, SubStr(sTokStrIO, 1, iPosSep - 1), sTokStrIO)
Case vbBoolean
vntGetTok = IIf(iPosSep > 0, SubStr(sTokStrIO, 1, iPosSep - 1) = "S", _
sTokStrIO = "S")
End Select
If iPosSep > 0 Then
sTokStrIO = SubStr(sTokStrIO, iPosSep + Len(sTokSepIN))
Else
sTokStrIO = ""
End If
Else
Select Case iTipDatoIN
Case vbInteger
vntGetTok = 0
Case vbString
vntGetTok = ""
Case vbBoolean
vntGetTok = False
End Select
End If
End Function
Function SubStr(ByVal sStrIN As String, ByVal iPosIn As Integer, _
Optional ByVal iPosFin As Integer = -1) As String
On Local Error GoTo SubstrErrHandler
If iPosFin = -1 Then iPosFin = Len(sStrIN)
SubStr = Mid$(sStrIN, iPosIn, iPosFin - iPosIn + 1)
Exit Function
SubstrErrHandler:
SubStr = vbNullString
Resume Next
End Function
Public Function SkipWhite(ByRef strIn As String)
While " " = Left$(strIn, 1)
strIn = Right$(strIn, Len(strIn) - 1)
Wend
SkipWhite = strIn
End Function
' Aun no anda, el Dir no funciona sobre shares pareciera.
Public Function bIsDirectory(ByVal sDirIN As String) As Boolean
On Local Error GoTo ErrHandler
bIsDirectory = True
Dir sDirIN
Exit Function
ErrHandler:
bIsDirectory = False
Resume Next
End Function
Function FileExists(strPath) As Boolean
Dim Msg As String
' Turn on error trapping so error handler responds
' if any error is detected.
On Error GoTo CheckError
FileExists = False
If "" = strPath Then Exit Function
FileExists = (Dir(strPath) <> "")
' Avoid executing error handler if no error
' occurs.
Exit Function
CheckError: ' Branch here if error occurs.
' Define constants to represent intrinsic Visual
' Basic error codes.
Const mnErrDiskNotReady = 71, _
mnErrDeviceUnavailable = 68
' vbExclamation, vbOK, vbCancel, vbCritical, and
' vbOKCancel are constants defined in the VBA type
' library.
If (Err.Number = mnErrDiskNotReady) Then
Msg = "Put a floppy disk in the drive "
Msg = Msg & "and close the door."
' Display message box with an exclamation mark
' icon and with OK and Cancel buttons.
If MsgBox(Msg, vbExclamation & vbOKCancel) = _
vbOK Then
Resume
Else
Resume Next
End If
ElseIf Err.Number = mnErrDeviceUnavailable Then
Msg = "This drive or path does not exist: "
Msg = Msg & strPath
MsgBox Msg, vbExclamation
Resume Next
Else
Msg = "Unexpected error #" & Str(Err.Number)
Msg = Msg & " occurred: " & Err.Description
' Display message box with Stop sign icon and
' OK button.
MsgBox Msg, vbCritical
Stop
End If
Resume
End Function
Function Max(ByVal f1 As Double, ByVal f2 As Double) As Double
Max = IIf(f1 > f2, f1, f2)
End Function
' dirname: Returns the Parent Directory Pathname of a Pathname
Public Function Dirname(ByVal sPath As String) As String
Dirname = ""
If "" = sPath Then Exit Function
Dim bDQ As Boolean
bDQ = (Left$(sPath, 1) = Chr(34))
Dim iDirWack As Long
iDirWack = InStrRev(sPath, "\")
iDirWack = Max(iDirWack, InStrRev(sPath, "/"))
If iDirWack = 0 Then Exit Function
Dirname = Left$(sPath, iDirWack - 1) & IIf(bDQ, Chr(34), "")
End Function
' Basename: Returns only the FileName Entry component of a Pathname
Public Function Basename(ByVal sPath As String) As String
Basename = sPath
If "" = sPath Then Exit Function
Dim bDQ As Boolean
bDQ = (Left$(sPath, 1) = Chr(34))
Dim iDirWack As Long
iDirWack = InStrRev(sPath, "\")
If iDirWack = 0 Then iDirWack = InStrRev(sPath, "/")
If iDirWack = 0 Then Exit Function
Basename = IIf(bDQ, Chr(34), "") & Right$(sPath, Len(sPath) - iDirWack)
End Function
Public Function FilenameNoExt(ByVal sPath As String) As String
FilenameNoExt = sPath
If "" = sPath Then Exit Function
Dim bDQ As Boolean
bDQ = (Left$(sPath, 1) = Chr(34))
Dim iDot As Long
iDot = InStrRev(sPath, ".")
If iDot > 0 Then
FilenameNoExt = Left$(sPath, iDot - 1) & IIf(bDQ, Chr(34), "")
End If
End Function
Public Function FileExtension(ByVal sPath As String) As String
FileExtension = ""
If "" = sPath Then Exit Function
Dim bDQ As Boolean
bDQ = (Right$(sPath, Len(sPath) - 1) = Chr(34))
If bDQ Then sPath = Left$(sPath, Len(sPath) - 1)
Dim iDot As Long
iDot = InStrRev(sPath, ".")
If iDot > 0 Then
FileExtension = UCase$(Right$(sPath, Len(sPath) - iDot))
End If
End Function
Public Function Rel2AbsPathName(ByVal sPath As String) As String
Rel2AbsPathName = sPath
If "" = sPath Then Exit Function
sPath = Trim$(sPath)
If sPath = Basename(sPath) Then
Rel2AbsPathName = CurDir() + "\" + sPath
ElseIf Left$(sPath, 2) = ".\" Then
Rel2AbsPathName = CurDir() + Mid$(sPath, 2, Len(sPath) - 1)
ElseIf Left$(sPath, 3) = """.\" Then
Rel2AbsPathName = """" + CurDir() + Mid$(sPath, 3, Len(sPath) - 2)
End If
End Function
Public Function UnQuotedPath(sPath As String, Optional bIsQuoted As Boolean = False) As String
UnQuotedPath = Trim$(sPath)
If "" = UnQuotedPath Then Exit Function
If Left$(UnQuotedPath, 1) = """" Then
bIsQuoted = True
UnQuotedPath = Mid$(UnQuotedPath, 2, Len(UnQuotedPath) - 1)
If Right$(UnQuotedPath, 1) = """" Then
UnQuotedPath = Left$(UnQuotedPath, Len(UnQuotedPath) - 1)
End If
End If
End Function
Public Function QuotedPath(sPath As String) As String
QuotedPath = """" + Trim$(sPath) + """"
End Function
Public Function ChangeFileExt(sPath As String, sExt As String) As String
Dim bIsQuoted As Boolean
bIsQuoted = False
ChangeFileExt = UnQuotedPath(Trim$(sPath), bIsQuoted)
If "" = ChangeFileExt Then Exit Function
If (bIsQuoted) Then
ChangeFileExt = QuotedPath(FilenameNoExt(ChangeFileExt) + sExt)
Else
ChangeFileExt = FilenameNoExt(ChangeFileExt) + sExt
End If
End Function
Public Function IsFullPathname(ByVal strPath As String) As Boolean
strPath = Trim$(strPath)
IsFullPathname = (Left$(strPath, 2) = "\\" Or Mid$(strPath, 2, 2) = ":\")
End Function
#If NEEDED Then
Sub DumpError(ByVal strFunction As String, ByVal strErrMsg As String)
MsgBox strFunction & " - Failed " & strErrMsg & vbCrLf & _
"Error Number = " & Err.Number & " - " & Err.Description, _
vbCritical, "Error"
' Err.Clear
End Sub
#End If
Function Capitalize(strIn As String) As String
Capitalize = UCase$(Left$(strIn, 1)) + Mid$(strIn, 2)
End Function
Function KindOfPrintf(ByVal strFormat, ByVal args As Variant) As String
If (Not IsArray(args)) Then
args = Array(args)
End If
Dim iX As Integer, iPos As Integer
KindOfPrintf = ""
For iX = 0 To UBound(args)
iPos = InStr(strFormat, "%s")
If (iPos = 0) Then Exit For
strFormat = Mid$(strFormat, 1, iPos - 1) & args(iX) & Mid$(strFormat, iPos + 2)
Next iX
KindOfPrintf = strFormat
End Function
Function ShowAsHex(ByVal strHex As String) As String
Dim iX As Integer
Dim byteRep() As Byte
byteRep = strHex
ShowAsHex = "0x"
For iX = 1 To UBound(byteRep)
ShowAsHex = ShowAsHex + Hex(byteRep(iX))
Next iX
End Function
Function Null2EmptyString(ByVal vntIn) As String
If (IsNull(vntIn)) Then
Null2EmptyString = vbNullString
Else
Null2EmptyString = vntIn
End If
End Function
Function Null2Number(ByVal vntIn) As Long
If (IsNull(vntIn)) Then
Null2Number = 0
Else
Null2Number = vntIn
End If
End Function