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