home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Chip Hitware 2
/
Chip_Hitware_Vol_02.iso
/
chiphit2
/
tools
/
system
/
winfree
/
winfree.ms_
/
winfree.ms
Wrap
Text File
|
1995-01-03
|
22KB
|
614 lines
'**************************************************************************
'* Marwin Consulting WinFree Setup
'**************************************************************************
''$DEFINE DEBUG ''Define for script development/debugging
'$INCLUDE 'setupapi.inc'
'$INCLUDE 'msdetect.inc'
''Dialog ID's
CONST WELCOME = 100
CONST PROGMANGROUP = 101
CONST ASKQUIT = 200
CONST DESTPATH = 300
CONST EXITFAILURE = 400
CONST EXITQUIT = 600
CONST EXITSUCCESS = 700
CONST APPHELP = 900
CONST CHECK = 2500
CONST CUSTINST = 6200
CONST BADPATH = 6400
''Bitmap ID
CONST LOGO = 1
''Files Sections in SETUP.INF
''Definitions for CUSTINST-DlgBox
''Checkbox indices for CUSTINST-DlgBox
CONST CHK_INDEX_WINFREE = 1
CONST CHK_INDEX_PROGMANGROUP = 2
CONST CHK_INDEX_HELPFILES = 3
''List of Checkboxes (IDC_B1..n)
GLOBAL CUSTINST_CHECKSTATES$
''List of Statictext (IDC_STATUS1..n)
GLOBAL CUSTINST_STATUSTEXT$
''List of Drivetext (IDC_TEXT1..n)
GLOBAL CUSTINST_DRIVETEXT$
''Indices of CUSTINST_DRIVETEXT list elements
CONST DRIVETEXT_INDEX_DESTDRIVE = 1
CONST DRIVETEXT_INDEX_DESTSPACENEED = 2
CONST DRIVETEXT_INDEX_DESTSPACEFREE = 3
CONST DRIVETEXT_INDEX_WINDRIVE = 4
CONST DRIVETEXT_INDEX_WINSPACENEED = 5
CONST DRIVETEXT_INDEX_WINSPACEFREE = 6
CONST DRIVETEXT_INDEX_DESTPATH = 7
''Definitions for CHECK-DlgBox
''Checkbox indices for CHECK-DlgBox
CONST CHK_INDEX_HELPFILE_HLP = 1
CONST CHK_INDEX_HELPFILE_DOC = 2
CONST CHK_INDEX_HELPFILE_WRI = 3
CONST CHK_INDEX_HELPFILE_TXT = 4
'' Indices in SETUP.INF
CONST SETUP_INF_HELPFILE_HLP$ = "1"
CONST SETUP_INF_HELPFILE_DOC$ = "2"
CONST SETUP_INF_HELPFILE_WRI$ = "3"
CONST SETUP_INF_HELPFILE_TXT$ = "4"
''List of Checkboxes (IDC_B1..n)
GLOBAL CHECK_CHECKSTATES_OPENDLG$ '' state of checkboxes when opening the dialog
GLOBAL CHECK_CHECKSTATES_CLOSEDLG$ '' state of checkboxes when closing the dialog '' actual value
''Definitions for PROGMANGROUP-DlgBox
GLOBAL PROGMANGROUP_TEXT$ '' text set in the dialog
''Definitions for DESTPATH-DlgBox
''Destination Path where to install WinFree
GLOBAL DESTPATH_TEXT$ ''Default destination directory.
'' Drive where WINDOWS directory resides
GLOBAL WINDRIVE$ ''Windows drive letter.
DECLARE SUB AddOptFilesToCopyList (ftype%)
DECLARE SUB RecalcOptFiles (ftype%)
DECLARE SUB RecalcPath
DECLARE SUB SetDriveStatus
DECLARE FUNCTION MakePath (szDir$, szFile$) AS STRING
DECLARE FUNCTION GetNthFieldFromIniStringEx (szLine$, iField%) AS STRING
INIT:
CUIDLL$ = "mscuistf.dll" ''custom user interface dll
HELPPROC$ = "FHelpDlgProc" ''Help dialog procedure
'' SetBitmap CUIDLL$, LOGO
SetTitle "Marwin Consulting Setup WinFree"
szInf$ = GetSymbolValue("STF_SRCINFPATH")
IF szInf$ = "" THEN
szInf$ = GetSymbolValue("STF_CWDDIR") + "SETUP.INF"
END IF
ReadInfFile szInf$
''*****************************************************************************
''PROGMANGROUPDlgBox initialisation
''*****************************************************************************
PROGMANGROUP_TEXT$ = "WinFree"
''*****************************************************************************
''DESTPATHDlgBox initialisation
''*****************************************************************************
WINDRIVE$ = MID$(GetWindowsDir, 1, 1)
DESTPATH_TEXT$ = WINDRIVE$ + ":\WINFREE"
''*****************************************************************************
''CUSTINSTDlgBox initialisation
''*****************************************************************************
CUSTINST_CHECKSTATES$ = "CheckItemsState" '' as defined in mscuistf.dll -> dlgprocs.c
CUSTINST_STATUSTEXT$ = "StatusItemsText" '' as defined in mscuistf.dll -> dlgprocs.c
CUSTINST_DRIVETEXT$ = "DriveStatusText" '' as defined in mscuistf.dll -> dlgprocs.c
FOR i% = 1 TO 3 STEP 1
AddListItem CUSTINST_CHECKSTATES$, "ON"
NEXT i%
FOR i% = 1 TO 3 STEP 1
AddListItem CUSTINST_STATUSTEXT$, ""
NEXT i%
FOR i% = 1 TO 7 STEP 1
AddListItem CUSTINST_DRIVETEXT$, ""
NEXT i%
ReplaceListItem CUSTINST_DRIVETEXT$, DRIVETEXT_INDEX_DESTPATH, DESTPATH_TEXT$ '' set the destination field
''*****************************************************************************
''CHECKDlgBox initialisation
''*****************************************************************************
CHECK_CHECKSTATES_OPENDLG$ = "CheckItemsIn" '' as defined in mscuistf.dll -> dlgprocs.c
AddListItem CHECK_CHECKSTATES_OPENDLG$, "ON"
FOR i% = 2 TO 4 STEP 1
AddListItem CHECK_CHECKSTATES_OPENDLG$, "OFF"
NEXT i%
CHECK_CHECKSTATES_CLOSEDLG$ = "CheckItemsOut" '' actual value
AddListItem CHECK_CHECKSTATES_CLOSEDLG$, "ON"
FOR i% = 2 TO 4 STEP 1
AddListItem CHECK_CHECKSTATES_CLOSEDLG$, "OFF"
NEXT i%
WELCOME:
sz$ = UIStartDlg(CUIDLL$, WELCOME, "FInfoDlgProc", APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
UIPop 1
GOTO CUSTINST_DLG
ELSE
GOSUB ASKQUIT
GOTO WELCOME
END IF
CUSTINST_DLG:
sz$ = UIStartDlg(CUIDLL$, CUSTINST, "FCustInstDlgProc", APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
GOTO INSTALL
ELSEIF sz$ = "PATH" THEN
GOTO DESTPATH_DLG
ELSEIF sz$ = "CHK1" THEN
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_WINFREE) = "ON" THEN
ReplaceListItem CUSTINST_CHECKSTATES$, CHK_INDEX_WINFREE, "OFF"
ELSE
ReplaceListItem CUSTINST_CHECKSTATES$, CHK_INDEX_WINFREE, "ON"
END IF
GOTO CUSTINST_DLG
ELSEIF sz$ = "CHK2" THEN
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_PROGMANGROUP) = "ON" THEN
ReplaceListItem CUSTINST_CHECKSTATES$, CHK_INDEX_PROGMANGROUP, "OFF"
ELSE
ReplaceListItem CUSTINST_CHECKSTATES$, CHK_INDEX_PROGMANGROUP, "ON"
END IF
GOTO CUSTINST_DLG
ELSEIF sz$ = "CHK3" THEN
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_HELPFILES) = "ON" THEN
ReplaceListItem CUSTINST_CHECKSTATES$, CHK_INDEX_HELPFILES, "OFF"
ELSE
ReplaceListItem CUSTINST_CHECKSTATES$, CHK_INDEX_HELPFILES, "ON"
END IF
GOTO CUSTINST_DLG
ELSEIF sz$ = "BTN2" THEN
GOTO PROGMANGROUP_DLG
ELSEIF sz$ = "BTN3" THEN
GOTO CHECK_DLG
ELSEIF sz$ = "REACTIVATE" THEN
GOTO CUSTINST_DLG
ELSE '' EXIT
GOSUB ASKQUIT
GOTO CUSTINST_DLG
END IF
DESTPATH_DLG:
SetSymbolValue "EditTextIn", DESTPATH_TEXT$
DESTPATH_DLG_OPEN:
sz$ = UIStartDlg(CUIDLL$, DESTPATH, "FEditDlgProc", APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
olddest$ = DESTPATH_TEXT$
DESTPATH_TEXT$ = GetSymbolValue("EditTextOut")
''Validate new path.
IF IsDirWritable(DESTPATH_TEXT$) = 0 THEN
GOSUB BADPATH
GOTO DESTPATH_DLG_OPEN
END IF
UIPop 1
''Truncate display if too long.
IF LEN(DESTPATH_TEXT$) > 23 THEN
ReplaceListItem CUSTINST_DRIVETEXT$, DRIVETEXT_INDEX_DESTPATH, MID$(DESTPATH_TEXT$, 1, 23)+"..."
ELSE
ReplaceListItem CUSTINST_DRIVETEXT$, DRIVETEXT_INDEX_DESTPATH, DESTPATH_TEXT$
END IF
olddest$ = ""
GOTO CUSTINST_DLG
ELSEIF sz$ = "BACK" THEN '' undo all changes in the checkboxes. set the closing list correctly
UIPop 1
GOTO CUSTINST_DLG
ELSEIF sz$ = "REACTIVATE" THEN
GOTO DESTPATH_DLG_OPEN
ELSE '' EXIT
SetSymbolValue "EditTextIn", GetSymbolValue ("EditTextOut")
UIPop 1
GOSUB ASKQUIT
GOTO DESTPATH_DLG_OPEN
END IF
PROGMANGROUP_DLG:
SetSymbolValue "EditTextIn", PROGMANGROUP_TEXT$
PROGMANGROUP_DLG_OPEN:
sz$ = UIStartDlg(CUIDLL$, PROGMANGROUP, "FEditDlgProc", APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
PROGMANGROUP_TEXT$ = GetSymbolValue ("EditTextOut")
UIPop 1
GOTO CUSTINST_DLG
ELSEIF sz$ = "BACK" THEN '' undo all changes in the checkboxes. set the closing list correctly
UIPop 1
GOTO CUSTINST_DLG
ELSEIF sz$ = "REACTIVATE" THEN
GOTO PROGMANGROUP_DLG_OPEN
ELSE '' EXIT
SetSymbolValue "EditTextIn", GetSymbolValue ("EditTextOut")
UIPop 1
GOSUB ASKQUIT
GOTO PROGMANGROUP_DLG_OPEN
END IF
CHECK_DLG:
sz$ = UIStartDlg(CUIDLL$, CHECK, "FCheckDlgProc", APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
FOR i% = 1 TO 4 STEP 1
ReplaceListItem CHECK_CHECKSTATES_OPENDLG$, i%, GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, i%)
NEXT i%
UIPop 1
GOTO CUSTINST_DLG
ELSEIF sz$ = "BACK" THEN '' undo all changes in the checkboxes. set the closing list correctly
FOR i% = 1 TO 4 STEP 1
ReplaceListItem CHECK_CHECKSTATES_CLOSEDLG$, i%, GetListItem (CHECK_CHECKSTATES_OPENDLG$, i%)
NEXT i%
UIPop 1
GOTO CUSTINST_DLG
ELSEIF sz$ = "REACTIVATE" THEN
GOTO CHECK_DLG
ELSE '' EXIT
GOSUB ASKQUIT
GOTO CHECK_DLG
END IF
INSTALL:
SetRestartDir DESTPATH_TEXT$
SrcDir$ = GetSymbolValue("STF_SRCDIR")
ClearCopyList
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_WINFREE) = "ON" THEN
AddSectionFilesToCopyList "Files", SrcDir$, DESTPATH_TEXT$
AddSectionFilesToCopyList "System", SrcDir$, GetWindowsSysDir
END IF
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_HELPFILES) = "ON" THEN
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_HLP) = "ON" THEN
AddSectionKeyFileToCopyList "Optional Helpfiles", SETUP_INF_HELPFILE_HLP$, SrcDir$, DESTPATH_TEXT$
END IF
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_DOC) = "ON" THEN
AddSectionKeyFileToCopyList "Optional Helpfiles", SETUP_INF_HELPFILE_DOC$, SrcDir$, DESTPATH_TEXT$
END IF
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_WRI) = "ON" THEN
AddSectionKeyFileToCopyList "Optional Helpfiles", SETUP_INF_HELPFILE_WRI$, SrcDir$, DESTPATH_TEXT$
END IF
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_TXT) = "ON" THEN
AddSectionKeyFileToCopyList "Optional Helpfiles", SETUP_INF_HELPFILE_TXT$, SrcDir$, DESTPATH_TEXT$
END IF
END IF
CreateDir DESTPATH_TEXT$, cmoNone
CopyFilesInCopyList
'' after successfully copying the files, now we remove any unneeded files
ClearCopyList
AddSectionFilesToCopyList "Remove Files", SrcDir$, DESTPATH_TEXT$
CopyFilesInCopyList
'' create Progman Group
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_PROGMANGROUP) = "ON" THEN
'' Create Progman Group
CreateProgmanGroup PROGMANGROUP_TEXT$, "", cmoNone
ShowProgmanGroup PROGMANGROUP_TEXT$, 1, cmoNone
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_WINFREE) = "ON" THEN
CreateProgmanItem PROGMANGROUP_TEXT$, "WinFree", MakePath(DESTPATH_TEXT$,"WINFREE.EXE"), "", cmoOverwrite
END IF
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_HELPFILES) = "ON" THEN
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_HLP) = "ON" THEN
CreateProgmanItem PROGMANGROUP_TEXT$, "WinFree Help", MakePath(DESTPATH_TEXT$,"WINFREE.HLP"), "", cmoOverwrite
END IF
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_DOC) = "ON" THEN
CreateProgmanItem PROGMANGROUP_TEXT$, "WinFree WinWord Help Document", MakePath(DESTPATH_TEXT$,"WINFREE.DOC"), "", cmoOverwrite
END IF
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_WRI) = "ON" THEN
CreateProgmanItem PROGMANGROUP_TEXT$, "WinFree Write Help Document", MakePath(DESTPATH_TEXT$,"WINFREE.WRI"), "", cmoOverwrite
END IF
IF GetListItem (CHECK_CHECKSTATES_CLOSEDLG$, CHK_INDEX_HELPFILE_TXT) = "ON" THEN
CreateProgmanItem PROGMANGROUP_TEXT$, "WinFree ASCII Help Document", MakePath(DESTPATH_TEXT$,"WINFREE.TXT"), "", cmoOverwrite
END IF
END IF
END IF
'' Update WIN.INI, Section [Windows] key load=
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_WINFREE) = "ON" THEN
keyString$ = GetIniKeyString ("WIN.INI", "WINDOWS", "LOAD")
IF keyString$ = "" THEN
CreateIniKeyValue "WIN.INI", "WINDOWS", "load", RTRIM$ (LTRIM$ (MakePath(DESTPATH_TEXT$,"WINFREE.EXE"))), cmoOverwrite
ELSE
keyString$ = LTRIM$ (RTRIM$ (keyString$))
IF INSTR (UCASE$ (keyString$), "WINFREE") = 0 THEN ''winfree not in entry
keyString$ = RTRIM$ (LTRIM$ (MakePath(DESTPATH_TEXT$,"WINFREE.EXE"))) + " " + RTRIM$ (LTRIM$ (keyString$))
CreateIniKeyValue "WIN.INI", "WINDOWS", "load", keyString$, cmoOverwrite
ELSE '' keyString$ not empty and winfree is in keyString$ -> remove winfree-entry
keyVal$ = ""
nextVal$ = GetNthFieldFromIniStringEx (keyString$, 1)
i% = 2
WHILE nextVal$ <> "" '' search for an already existing winfree -> remove it
IF INSTR (UCASE$ (nextVal$), "WINFREE") = 0 THEN ''not found
IF keyVal$ = "" THEN
keyVal$ = RTRIM$ (LTRIM$ (nextVal$))
ELSE
keyVal$ = RTRIM$ (LTRIM$ (keyVal$)) + " " + RTRIM$ (LTRIM$ (nextVal$))
END IF
END IF
nextVal$ = GetNthFieldFromIniStringEx (keyString$, i%)
i% = i% + 1
WEND
keyVal$ = MakePath(DESTPATH_TEXT$,"WINFREE.EXE") + " " + keyVal$
CreateIniKeyValue "WIN.INI", "WINDOWS", "load", keyVal$, cmoOverwrite
END IF
END IF
END IF
'' Update WIN.INI, Section [Windows] key run=; remove any winfree entry in the list
IF GetListItem (CUSTINST_CHECKSTATES$, CHK_INDEX_WINFREE) = "ON" THEN
keyString$ = GetIniKeyString ("WIN.INI", "WINDOWS", "RUN")
IF keyString$ <> "" THEN
keyString$ = LTRIM$ (RTRIM$ (keyString$))
IF INSTR (UCASE$ (keyString$), "WINFREE") <> 0 THEN '' keyString$ not empty and winfree is in keyString$ -> remove winfree-entry
keyVal$ = ""
nextVal$ = GetNthFieldFromIniStringEx (keyString$, 1)
i% = 2
WHILE nextVal$ <> "" '' search for an already existing winfree -> remove it
IF INSTR (UCASE$ (nextVal$), "WINFREE") = 0 THEN ''not found
IF keyVal$ = "" THEN
keyVal$ = RTRIM$ (LTRIM$ (nextVal$))
ELSE
keyVal$ = RTRIM$ (LTRIM$ (keyVal$)) + " " + RTRIM$ (LTRIM$ (nextVal$))
END IF
END IF
nextVal$ = GetNthFieldFromIniStringEx (keyString$, i%)
i% = i% + 1
WEND
CreateIniKeyValue "WIN.INI", "WINDOWS", "run", keyVal$, cmoOverwrite
END IF
END IF
END IF
'' if winfree is already running and can't be overwritten, windows must be exited
IF RestartListEmpty = 0 THEN
k% = DoMsgBox("WinFree Setup has to exit Windows to finish the installation properly", "Marwin Consulting Setup", MB_OK+MB_TASKMODAL+MB_ICONHAND)
i% = ExitExecRestart ()
END IF
GOTO QUIT
BADPATH:
sz$ = UIStartDlg(CUIDLL$, BADPATH, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO BADPATH
END IF
UIPop 1
RETURN
ASKQUIT:
sz$ = UIStartDlg(CUIDLL$, ASKQUIT, "FQuitDlgProc", 0, "")
IF sz$ = "EXIT" THEN
UIPopAll
ERROR STFQUIT
ELSEIF sz$ = "REACTIVATE" THEN
GOTO ASKQUIT
ELSE
UIPop 1
END IF
RETURN
QUIT:
ON ERROR GOTO ERRQUIT
IF ERR = 0 THEN
dlg% = EXITSUCCESS
ELSEIF ERR = STFQUIT THEN
dlg% = EXITQUIT
ELSE
dlg% = EXITFAILURE
END IF
QUITL1:
sz$ = UIStartDlg(CUIDLL$, dlg%, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
GOTO QUITL1
END IF
UIPop 1
END
ERRQUIT:
i% = DoMsgBox("Setup sources were corrupted!", "Setup Message", MB_OK+MB_TASKMODAL+MB_ICONHAND)
END
'**
'** Purpose:
'** Adds the specified option files to the copy list.
'** Arguments:
'** ftype% - type of files to add, one of the following:
'** FILES, OPTIONAL_HELPFILES
'** Returns:
'** none.
'*************************************************************************
SUB AddOptFilesToCopyList (ftype%) STATIC
IF GetListItem(CHECKSTATES$, ftype%) = "ON" THEN
SrcDir$ = GetSymbolValue("STF_SRCDIR")
IF ftype% = FILES THEN
AddSectionFilesToCopyList "Files", SrcDir$, DEST$
ELSEIF ftype% = OPTIONAL_HELPFILES THEN
AddSectionKeyFileToCopyList "Optional Helpfiles", HELPFILES_SELECTIONLIST$, SrcDir$, DEST$
END IF
SrcDir$ = ""
END IF
END SUB
'**
'** Purpose:
'** Recalculates disk space for the given option files and sets
'** the status info symbol "StatusItemsText".
'** Arguments:
'** ftype% - type of files to add, one of the following:
'** FILES, OPTIONAL_HELPFILES
'** Returns:
'** none.
'*************************************************************************
SUB RecalcOptFiles (ftype%) STATIC
CursorSave% = ShowWaitCursor()
ClearCopyList
AddOptFilesToCopyList ftype%
fExtra% = 0
IF ftype% = FILES THEN
ListSym$ = APPNEEDS$
IF GetListItem(CHECKSTATES$, FILES) = "ON" THEN
''Add extra cost to Windows drive for ini/progman, etc.
ndrive% = ASC(ucase$(WINDRIVE$)) - ASC("A") + 1
ReplaceListItem EXTRACOSTS$, ndrive%, "10240"
fExtra% = 1
END IF
ELSEIF ftype% = OPTIONAL_HELPFILES THEN
ListSym$ = HELPFILES_SELECTIONLIST$
END IF
StillNeed& = GetCopyListCost(EXTRACOSTS$, ListSym$, "")
cost& = 0
FOR i% = 1 TO 26 STEP 1
cost& = cost& + VAL(GetListItem(ListSym$, i%))
NEXT i%
ReplaceListItem STATUSTEXT$, ftype%, STR$(cost& / 1024) + " K"
IF StillNeed& > 0 THEN
ReplaceListItem BIGLIST$, ftype%, "YES"
ELSE
ReplaceListItem BIGLIST$, ftype%, ""
END IF
IF fExtra% THEN
ReplaceListItem EXTRACOSTS$, ndrive%, "0"
END IF
RestoreCursor CursorSave%
ListSym$ = ""
END SUB
'**
'** Purpose:
'** Recalculates disk space and sets option status info according
'** to the current destination path.
'** Arguments:
'** none.
'** Returns:
'** none.
'*************************************************************************
SUB RecalcPath STATIC
CursorSave% = ShowWaitCursor()
RecalcOptFiles FILES
RecalcOptFiles OPTIONAL_HELPFILES
RestoreCursor CursorSave%
END SUB
'**
'** Purpose:
'** Sets drive status info according to latest disk space calcs.
'** Arguments:
'** none.
'** Returns:
'** none.
'*************************************************************************
SUB SetDriveStatus STATIC
drive$ = MID$(DEST$, 1, 1)
ndrive% = ASC(ucase$(drive$)) - ASC("A") + 1
cost& = VAL(GetListItem(APPNEEDS$, ndrive%)) + VAL(GetListItem(HELPFILESNEEDS$, ndrive%))
free& = GetFreeSpaceForDrive(drive$)
ReplaceListItem DRIVETEXT$, 1, drive$ + ":"
ReplaceListItem DRIVETEXT$, 2, STR$(cost& / 1024) + " K"
ReplaceListItem DRIVETEXT$, 3, STR$(free& / 1024) + " K"
IF drive$ = WINDRIVE$ THEN
ReplaceListItem DRIVETEXT$, 4, ""
ReplaceListItem DRIVETEXT$, 5, ""
ReplaceListItem DRIVETEXT$, 6, ""
ELSE
ndrive% = ASC(ucase$(WINDRIVE$)) - ASC("A") + 1
cost& = VAL(GetListItem(APPNEEDS$, ndrive%)) + VAL(GetListItem(HELPFILESNEEDS$, ndrive%))
IF cost& = 0 THEN
ReplaceListItem DRIVETEXT$, 4, ""
ReplaceListItem DRIVETEXT$, 5, ""
ReplaceListItem DRIVETEXT$, 6, ""
ELSE
free& = GetFreeSpaceForDrive(WINDRIVE$)
ReplaceListItem DRIVETEXT$, 4, WINDRIVE$ + ":"
ReplaceListItem DRIVETEXT$, 5, STR$(cost& / 1024) + " K"
ReplaceListItem DRIVETEXT$, 6, STR$(free& / 1024) + " K"
END IF
END IF
END SUB
'**
'** Purpose:
'** Appends a file name to the end of a directory path,
'** inserting a backslash character as needed.
'** Arguments:
'** szDir$ - full directory path (with optional ending "\")
'** szFile$ - filename to append to directory
'** Returns:
'** Resulting fully qualified path name.
'*************************************************************************
FUNCTION MakePath (szDir$, szFile$) STATIC AS STRING
IF szDir$ = "" THEN
MakePath = szFile$
ELSEIF szFile$ = "" THEN
MakePath = szDir$
ELSEIF MID$(szDir$, LEN(szDir$), 1) = "\" THEN
MakePath = szDir$ + szFile$
ELSE
MakePath = szDir$ + "\" + szFile$
END IF
END FUNCTION
'*************************************************************************
FUNCTION GetNthFieldFromIniStringEx (szLine$, iField%) STATIC AS STRING
IF iField% < 1 THEN
'$ifdef DEBUG
StfApiErr saeFail, "GetNthFieldFromIniStringEx", szLine$+", "+STR$(iField%)
'$endif ''DEBUG
ERROR STFERR
END IF
szStart$ = szLine$
IF iField% <> 1 THEN
FOR i% = 2 TO iField% STEP 1
iNew% = INSTR(szStart$, ",")
IF iNew% = 0 THEN
iNew% = INSTR(szStart$, " ")
IF iNew% = 0 THEN
GetNthFieldFromIniStringEx = ""
GOTO _GNFFIS_END
END IF
END IF
szStart$ = LTRIM$ (MID$(szStart$, (iNew% + 1)))
NEXT
END IF
iNew% = INSTR(szStart$, ",")
IF iNew% <> 0 THEN
szStart$ = LTRIM$ (MID$(szStart$, 1, (iNew% - 1)))
ELSE
iNew% = INSTR(szStart$, " ")
IF iNew% <> 0 THEN
szStart$ = LTRIM$ (MID$(szStart$, 1, (iNew% - 1)))
END IF
END IF
GetNthFieldFromIniStringEx = LTRIM$(RTRIM$(szStart$))
_GNFFIS_END:
END FUNCTION