home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
On Hand
/
On_Hand_From_Softbank_1994_Release_2_Disc_1_1994.iso
/
00224
/
s
/
xwire.ms_
/
xwire.ms
Wrap
Text File
|
1994-02-06
|
5KB
|
201 lines
'**************************************************************************
'* MSSetup Toolkit Sample 1
'**************************************************************************
'$DEFINE DEBUG ''Define for script development/debugging
'$INCLUDE 'setupapi.inc'
'$INCLUDE 'msdetect.inc'
''Dialog ID's
CONST ASKQUIT = 200
CONST DESTPATH = 300
CONST EXITFAILURE = 400
CONST EXITQUIT = 600
CONST EXITSUCCESS = 700
CONST APPHELP = 900
CONST TOOBIG = 6300
CONST BADPATH = 6400
''Bitmap ID
CONST LOGO = 1
GLOBAL DEST$ ''Default destination directory.
GLOBAL OPTCUR$ ''Option selection from option dialog.
GLOBAL EXTRA$ ''List of extra costs to add per drive
GLOBAL COSTS$ ''List of extra costs to add per drive
DECLARE SUB Install
DECLARE FUNCTION MakePath (szDir$, szFile$) AS STRING
INIT:
CUIDLL$ = "mscuistf.dll" ''Custom user interface dll
HELPPROC$ = "FHelpDlgProc" ''Help dialog procedure
EXTRA$ = "Extra"
COST$ = "Cost"
SetBitmap CUIDLL$, LOGO
SetTitle "CrossWire Setup Program"
szInf$ = GetSymbolValue("STF_SRCINFPATH")
IF szInf$ = "" THEN
szInf$ = GetSymbolValue("STF_CWDDIR") + "XWIRE.INF"
END IF
ReadInfFile szInf$
OPTCUR$ = "1"
DEST$ = "C:\XWIRE"
'$IFDEF DEBUG
' i% = SetSizeCheckMode(scmOnIgnore) '' could use scmOff; def = scmOnFatal
' WinDrive$ = MID$(GetWindowsDir, 1, 1)
' IF IsDriveValid(WinDrive$) = 0 THEN
' i% = DoMsgBox("Windows drive ('"+WinDrive$+"') is not a valid drive.", "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
' GOTO QUIT
' END IF
'$ENDIF ''DEBUG
GETPATH:
SetSymbolValue "EditTextIn", DEST$
SetSymbolValue "EditFocus", "END"
GETPATHL1:
sz$ = UIStartDlg(CUIDLL$, DESTPATH, "FEditDlgProc", APPHELP, HELPPROC$)
DEST$ = GetSymbolValue("EditTextOut")
IF sz$ = "CONTINUE" THEN
IF IsDirWritable(DEST$) = 0 THEN
GOSUB BADPATH
GOTO GETPATHL1
END IF
UIPop 1
ELSEIF sz$ = "REACTIVATE" THEN
GOTO GETPATHL1
ELSE
GOSUB ASKQUIT
GOTO GETPATH
END IF
SrcDir$ = GetSymbolValue("STF_SRCDIR")
CreateDir DEST$, cmoNone
AddSectionKeyFileToCopyList "Files", "Play", SrcDir$, DEST$
AddSectionKeyFileToCopyList "Files", "Executable", SrcDir$, DEST$
AddSectionKeyFileToCopyList "Files", "Wave", SrcDir$, DEST$
AddSectionKeyFileToCopyList "Files", "Readme", SrcDir$, DEST$
AddSectionKeyFileToCopyList "Files", "Instruct", SrcDir$, DEST$
StillNeed& = GetCopyListCost( EXTRA$, COSTS$, "" )
IF StillNeed& > 0 THEN
sz$ = UIStartDlg(CUIDLL$, TOOBIG, "FInfo0DlgProc", 0, "")
GOTO GETPATHL1
END IF
Install
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, please contact your software supplier for assistance.", "Setup Message", MB_OK+MB_TASKMODAL+MB_ICONHAND)
END
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
'**
'** Purpose:
'** Builds the copy list and performs all installation operations.
'** Arguments:
'** none.
'** Returns:
'** none.
'*************************************************************************
SUB Install STATIC
' OpenLogFile MakePath(DEST$, "LOGFILE.OUT"), 0
' WriteToLogFile ""
' WriteToLogFile " User chose as destination directory: '" + DEST$ + "'"
' WriteToLogFile " User chose option: '" + OPTCUR$ + "'"
' WriteToLogFile ""
' WriteToLogFile "May have had to create the directory: " + DEST$
' WriteToLogFile ""
CopyFilesInCopyList
CreateProgmanGroup "CrossWire", "", cmoNone
ShowProgmanGroup "CrossWire", 1, cmoNone
CreateProgmanItem "CrossWire", "CrossWire", MakePath(DEST$,"xwire.exe"), "", cmoOverwrite
' CloseLogFile
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