home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Arts On Disk
/
oldtimer.bin
/
pixsetup.mst
< prev
next >
Wrap
Text File
|
1994-10-22
|
24KB
|
873 lines
'**************************************************************************
'* MSSetup Toolkit PSGRFXXX
'**************************************************************************
'$DEFINE DEBUG ''Define for script development/debugging
'$INCLUDE 'setupapi.inc'
'$INCLUDE 'msdetect.inc'
'$INCLUDE 'mscuistf.inc'
''Dialog ID's
CONST WELCOME = 100
CONST ASKQUIT = 200
CONST DESTPATH = 300
CONST EXITFAILURE = 400
CONST EXITQUIT = 600
CONST EXITSUCCESS = 700
CONST EXITREGISTERED= 750
CONST OPTIONS = 800
CONST APPHELP = 900
CONST CUSTHELP = 910
CONST REGHELP = 920
CONST CUSTINST = 6200
CONST TOOBIG = 6300
CONST NOAVI = 6350
CONST NOAPP = 6360
CONST BADPATH = 6400
CONST CDGETNAMEORG = 7500
CONST MODELESS = 5000
CONST QUITWIN = 6500
''Bitmap ID
CONST LOGO = 1
''File Types
CONST APPFILES = 1
CONST OPTFILES1 = 2
CONST OPTFILES2 = 3
CONST OPTFILES3 = 4
CONST SYMFILES = 5
GLOBAL DEST$ ''Default destination directory.
GLOBAL WINDRIVE$ ''Windows drive letter.
GLOBAL OPTCUR$ ''Option selection from option dialog.
GLOBAL CUIDLL$ ''Custom user interface DLL
GLOBAL szTempDir$ ''Working directory
GLOBAL SysDir$ ''Windows System Directory
GLOBAL ini$ ''INI file path
GLOBAL OPT1OPT$ ''Option selection from OptFiles1 option dialog.
GLOBAL OPT2OPT$ ''Option selection from OptFiles2 option dialog.
GLOBAL OPT3OPT$
GLOBAL SYMOPT$ ''Option selection for symbol files.
''CustInst list symbol names
GLOBAL APPNEEDS$ ''Option list costs per drive
GLOBAL OPT1NEEDS$
GLOBAL OPT2NEEDS$
GLOBAL OPT3NEEDS$ ''Multimedia files
GLOBAL SYMNEEDS$
GLOBAL EXTRACOSTS$ ''List of extra costs to add per drive
GLOBAL BIGLIST$ ''List of option files cost calc results (boolean)
''Dialog list symbol names
GLOBAL CHECKSTATES$
GLOBAL STATUSTEXT$
GLOBAL DRIVETEXT$
DECLARE SUB AddOptFilesToCopyList (ftype%)
DECLARE SUB RecalcOptFiles (ftype%)
DECLARE SUB RecalcPath
DECLARE SUB SetDriveStatus
DECLARE SUB Install
DECLARE FUNCTION MakePath (szDir$, szFile$) AS STRING
INIT:
CUIDLL$ = "mscuistf.dll" ''Custom user interface dll
HELPPROC$ = "FHelpDlgProc" ''Help dialog procedure
SetBitmap CUIDLL$, LOGO
SetTitle "PSGRFXXX Setup"
szTempDir$ = GetSymbolValue("STF_CWDDIR")
szInf$ = GetSymbolValue("STF_SRCINFPATH")
IF szInf$ = "" THEN
szInf$ = GetSymbolValue("STF_CWDDIR") + "PIXSETUP.INF"
END IF
ReadInfFile szInf$
WINDRIVE$ = MID$(GetWindowsDir, 1, 1)
'' DEST$ = WINDRIVE$ + ":\PSGRFXXX"
DEST$ = ".............................................................................................................................."
GetPixDir DEST$
if DEST$ = "" THEN
DEST$ = WINDRIVE$ + ":\PSGRFXXX"
END IF
' j% = DoesIniSectionExist("WIN.INI", "PSGRFXXX")
' IF j = 0 THEN
' ini$ = MakePath(DEST$, "PSGRFXXX.INI")
' AddSectionFilesToCopyList "PSGRFXXX INI File", SrcDir$, DEST$
' ELSE
' ini$ = MakePath(GetWindowsDir, "WIN.INI")
' END IF
''CustInst list symbols
CHECKSTATES$ = "CheckItemsState"
STATUSTEXT$ = "StatusItemsText"
DRIVETEXT$ = "DriveStatusText"
' FOR i% = 1 TO 3 STEP 1
AddListItem CHECKSTATES$, "ON" '' Main program files
AddListItem CHECKSTATES$, "OFF" '' Photo CD
AddListItem CHECKSTATES$, "OFF" '' VFW
AddListItem CHECKSTATES$, "OFF" '' Multimedia
AddListItem CHECKSTATES$, "OFF" '' Symbols
' NEXT i%
FOR i% = 1 TO 5 STEP 1
AddListItem STATUSTEXT$, ""
NEXT i%
FOR i% = 1 TO 7 STEP 1
AddListItem DRIVETEXT$, ""
NEXT i%
ReplaceListItem DRIVETEXT$, 7, DEST$
''Disk cost list symbols
APPNEEDS$ = "AppNeeds"
OPT1NEEDS$ = "Opt1Needs"
OPT2NEEDS$ = "Opt2Needs"
OPT3NEEDS$ = "Opt3Needs"
SYMNEEDS$ = "SymNeeds"
EXTRACOSTS$ = "ExtraCosts"
BIGLIST$ = "BigList"
FOR i% = 1 TO 5 STEP 1
AddListItem BIGLIST$, ""
NEXT i%
FOR i% = 1 TO 26 STEP 1
AddListItem EXTRACOSTS$, "0"
NEXT i%
''File Option Variables
OPT1OPT$ = "1"
OPT2OPT$ = "1"
OPT3OPT$ = "1"
SYMOPT$ = "1"
SysDir$ = GetWindowsSysDir()
RecalcPath
'' i% = DoMsgBox("RecalcPath OK", "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
SetDriveStatus
'' i% = DoMsgBox("SetDriveStatus OK", "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
OPTCUR$ = "1"
' DEST$ = "C:\PSGRFXXX"
'$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
WELCOME:
sz$ = UIStartDlg(CUIDLL$, WELCOME, "FInfoDlgProc", APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
UIPop 1
ELSE
GOSUB ASKQUIT
GOTO WELCOME
END IF
'*OPTION:
'* SetSymbolValue "RadioDefault", OPTCUR$
'*OPTL1:
'* sz$ = UIStartDlg(CUIDLL$, OPTIONS, "FRadioDlgProc", APPHELP, HELPPROC$)
'* OPTCUR$ = GetSymbolValue("ButtonChecked")
'* IF sz$ = "CONTINUE" THEN
'* UIPop(1)
'* ELSEIF sz$ = "REACTIVATE" THEN
'* GOTO OPTL1
'* ELSE
'* GOSUB ASKQUIT
'* GOTO OPTION
'* END IF
CUSTINST:
sz$ = UIStartDlg(CUIDLL$, CUSTINST, "FCustInstDlgProc", CUSTHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
''Install only if it will fit.
FOR i% = 1 TO 5 STEP 1
IF GetListItem(BIGLIST$, i%) <> "" THEN
GOSUB TOOBIG
GOTO CUSTINST
END IF
NEXT i%
UIPop 1
GOTO INSTALLIT
ELSEIF sz$ = "PATH" THEN
GOTO GETPATH
ELSEIF sz$ = "CHK1" THEN
IF DoesFileExist(MakePath(DEST$, "PSGRFXXX.EXE"), femReadWrite) = 0 AND GetListItem(CHECKSTATES$, APPFILES) = "OFF" THEN
GOSUB NOAPP
GOTO CUSTINST
END IF
RecalcOptFiles APPFILES
RecalcOptFiles SYMFILES
SetDriveStatus
GOTO CUSTINST
ELSEIF sz$ = "CHK2" THEN
RecalcOptFiles OPTFILES1
RecalcOptFiles SYMFILES
SetDriveStatus
GOTO CUSTINST
ELSEIF sz$ = "CHK3" THEN
IF GetListItem(CHECKSTATES$, OPTFILES2) = "ON" THEN
IF CheckForAVI = 0 THEN
GOSUB NOAVI
ReplaceListItem CHECKSTATES$, OPTFILES2, "OFF"
END IF
END IF
RecalcOptFiles OPTFILES2
RecalcOptFiles SYMFILES
SetDriveStatus
GOTO CUSTINST
ELSEIF sz$ = "CHK4" THEN
RecalcOptFiles OPTFILES3
RecalcOptFiles SYMFILES
SetDriveStatus
GOTO CUSTINST
ELSEIF sz$ = "CHK5" THEN
RecalcOptFiles SYMFILES
SetDriveStatus
GOTO CUSTINST
ELSEIF sz$ = "BTN2" THEN
GOTO OPTFILES1
ELSEIF sz$ = "BTN3" THEN
GOTO OPTFILES2
ELSEIF sz$ = "BTN4" THEN
GOTO OPTFILES3
ELSEIF sz$ = "BTN5" THEN
GOTO SYMFILES
ELSEIF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO CUSTINST
ELSE
GOSUB ASKQUIT
GOTO CUSTINST
END IF
GETPATH:
SetSymbolValue "EditTextIn", DEST$
SetSymbolValue "EditFocus", "END"
GETPATHL1:
sz$ = UIStartDlg(CUIDLL$, DESTPATH, "FEditDlgProc", APPHELP, HELPPROC$)
IF sz$ = "CONTINUE" THEN
olddest$ = DEST$
DEST$ = GetSymbolValue("EditTextOut")
''Validate new path.
IF IsDirWritable(DEST$) = 0 THEN
GOSUB BADPATH
GOTO GETPATHL1
END IF
UIPop 1
''Truncate display if too long.
IF LEN(DEST$) > 23 THEN
ReplaceListItem DRIVETEXT$, 7, MID$(DEST$, 1, 23)+"..."
ELSE
ReplaceListItem DRIVETEXT$, 7, DEST$
END IF
''Recalc if path changed.
IF (olddest$ <> DEST$) AND (olddest$ <> DEST$+"\") AND (olddest$+"\" <> DEST$) THEN
RecalcPath
SetDriveStatus
END IF
olddest$ = ""
GOTO CUSTINST
ELSEIF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO GETPATHL1
ELSEIF sz$ = "EXIT" THEN
GOSUB ASKQUIT
GOTO GETPATHL1
ELSE
UIPop 1
GOTO CUSTINST
END IF
INSTALLIT:
'* SetSymbolValue "SERIAL", "000000000000"
'* SetSymbolValue "OWNER", "Nicht registiert"
SetSymbolValue "SERIAL", "2X00AB001453"
SetSymbolValue "OWNER", "PS Graphics CD"
IF j = 0 THEN
k% = DoesFileExist(MakePath(GetWindowsDir, "PSGRFXXX.INI"), femReadWrite)
if k = 0 THEN
ini$ = MakePath(DEST$, "PSGRFXXX.INI")
SrcDir$ = GetSymbolValue("STF_SRCDIR")
' AddSectionFilesToCopyList "PSGRFXXX INI File", SrcDir$, DEST$
CreateDir DEST$, cmoNone
CreateIniFile ini$
ELSE
ini$ = MakePath(GetWindowsDir, "PSGRFXXX.INI")
ENDIF
ELSE
ini$ = MakePath(GetWindowsDir, "WIN.INI")
END IF
IF DoesFileExist(MakePath(DEST$, "PSGRFXXX.EXE"), femReadWrite) = 1 THEN
'* l& = GetStringTable(DEST$)
IF DoesFileExist(MakePath(DEST$, "PSGRFXXX.INI"), femReadWrite) = 1 THEN
ini$ = MakePath(DEST$, "PSGRFXXX.INI")
END IF
END IF
SERIAL$ = GetSymbolValue("SERIAL")
OWNER$ = GetSymbolValue("OWNER")
SERIAL1$ = GetIniKeyString(ini$, "PSGRFXXX", "Registration Nbr")
OWNER1$ = GetIniKeyString(ini$, "PSGRFXXX", "Registered To")
'* i% = DoMsgBox(SERIAL$+" "+SERIAL1, "Serial Number", MB_OK)
IF ValidateReg(SERIAL1$) = 1 THEN
SERIAL$ = SERIAL1$
OWNER$ = OWNER1$
'* i% = DoMsgBox(SERIAL$+" "+SERIAL1, "Serial Number", MB_OK)
END IF
SetSymbolValue "SERIAL", SERIAL$
SetSymbolValue "OWNER", OWNER$
Install
IF(DoesFileExist(MakePath(DEST$, "PIXPCD.DLL"), femReadWrite) = 1 OR DoesFileExist(MakePath(DEST$, "PIXAVI.DLL"), femReadWrite) = 1) AND MID$(SERIAL$, 6, 1) <> "B" THEN
GOTO GETSERIAL
END IF
IF ValidateReg(SERIAL$) = 1 THEN
GOTO UPDATEIT
END IF
GETSERIAL:
sz$ = UIStartDlg(CUIDLL$, CDGETNAMEORG, "FNameOrgDlgProc", REGHELP, HELPPROC$)
DEST$ = GetSymbolValue("EditTextOut")
IF sz$ = "CONTINUE" THEN
UIPop 1
ELSEIF sz$ = "CANCEL" THEN
UIPop 1
ELSE
GOSUB ASKQUIT
GOTO GETSERIAL
END IF
SERIAL$ = GetSymbolValue("SERIAL")
OWNER$ = GetSymbolValue("OWNER")
UPDATEIT:
IF ValidateReg(SERIAL$) = 1 THEN
'* l& = PutStringTable(DEST$)
CreateIniKeyValue ini$, "PSGRFXXX", "Registration Nbr", SERIAL$, cmoOverwrite
CreateIniKeyValue ini$, "PSGRFXXX", "Registered To", OWNER$, cmoOverwrite
ELSE
CreateProgmanItem "PSGRFXXX", "Register", "notepad.exe "+MakePath(DEST$,"PIXREGST.FRM"), "", cmoOverwrite
END IF
'* Install
QUITWIN:
ii% = RestartListEmpty()
IF ii% = 0 THEN
sz$ = UIStartDlg(CUIDLL$, QUITWIN, "FQuitWinDlgProc", 0, "")
IF sz$ = "CONTINUE" THEN
UIPop 1
ELSEIF sz$ = "REACTIVATE" THEN
GOTO QUITWIN
ELSE
GOSUB ASKQUIT
GOTO QUITWIN
END IF
ij% = ExitExecRestart()
END IF
QUIT:
ON ERROR GOTO ERRQUIT
IF ERR = 0 THEN
IF ValidateReg(SERIAL$) = 1 THEN
dlg% = EXITREGISTERED
ELSE
dlg% = EXITSUCCESS
END IF
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, call (502) 955-7527!", "Setup Message", MB_OK+MB_TASKMODAL+MB_ICONHAND)
END
OPTFILES1:
SetSymbolValue "RadioDefault", OPT1OPT$
OPT1L1:
sz$ = UIStartDlg(CUIDLL$, OPTIONS, "FRadioDlgProc", APPHELP, HELPPROC$)
newopt$ = GetSymbolValue("ButtonChecked")
IF sz$ = "CONTINUE" THEN
UIPop 1
IF newopt$ <> OPT1OPT$ THEN
OPT1OPT$ = newopt$
RecalcOptFiles OPTFILES1
SetDriveStatus
END IF
newopt$ = ""
GOTO CUSTINST
ELSEIF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO OPT1L1
ELSEIF sz$ = "EXIT" THEN
GOSUB ASKQUIT
GOTO OPT1L1
ELSE
UIPop 1
newopt$ = ""
GOTO CUSTINST
END IF
OPTFILES2:
SetSymbolValue "RadioDefault", OPT2OPT$
OPT2L1:
sz$ = UIStartDlg(CUIDLL$, OPTIONS, "FRadioDlgProc", APPHELP, HELPPROC$)
newopt$ = GetSymbolValue("ButtonChecked")
IF sz$ = "CONTINUE" THEN
UIPop 1
IF newopt$ <> OPT2OPT$ THEN
OPT2OPT$ = newopt$
RecalcOptFiles OPTFILES2
SetDriveStatus
END IF
newopt$ = ""
GOTO CUSTINST
ELSEIF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO OPT2L1
ELSEIF sz$ = "EXIT" THEN
GOSUB ASKQUIT
GOTO OPT2L1
ELSE
UIPop 1
newopt$ = ""
GOTO CUSTINST
END IF
OPTFILES3:
SetSymbolValue "RadioDefault", OPT3OPT$
OPT3L1:
sz$ = UIStartDlg(CUIDLL$, OPTIONS, "FRadioDlgProc", APPHELP, HELPPROC$)
newopt$ = GetSymbolValue("ButtonChecked")
IF sz$ = "CONTINUE" THEN
UIPop 1
IF newopt$ <> OPT3OPT$ THEN
OPT3OPT$ = newopt$
RecalcOptFiles OPTFILES3
SetDriveStatus
END IF
newopt$ = ""
GOTO CUSTINST
ELSEIF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO OPT3L1
ELSEIF sz$ = "EXIT" THEN
GOSUB ASKQUIT
GOTO OPT3L1
ELSE
UIPop 1
newopt$ = ""
GOTO CUSTINST
END IF
SYMFILES:
SetSymbolValue "RadioDefault", SYMOPT$
OPTSL1:
sz$ = UIStartDlg(CUIDLL$, OPTIONS, "FRadioDlgProc", APPHELP, HELPPROC$)
newopt$ = GetSymbolValue("ButtonChecked")
IF sz$ = "CONTINUE" THEN
UIPop 1
IF newopt$ <> SYMOPT$ THEN
SYMOPT$ = newopt$
RecalcOptFiles SYMFILES
SetDriveStatus
END IF
newopt$ = ""
GOTO CUSTINST
ELSEIF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO OPTSL1
ELSEIF sz$ = "EXIT" THEN
GOSUB ASKQUIT
GOTO OPTSL1
ELSE
UIPop 1
newopt$ = ""
GOTO CUSTINST
END IF
TOOBIG:
sz$ = UIStartDlg(CUIDLL$, TOOBIG, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO TOOBIG
END IF
UIPop 1
RETURN
NOAVI:
sz$ = UIStartDlg(CUIDLL$, NOAVI, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO NOAVI
END IF
UIPop 1
RETURN
NOAPP:
sz$ = UIStartDlg(CUIDLL$, NOAPP, "FInfo0DlgProc", 0, "")
IF sz$ = "REACTIVATE" THEN
RecalcPath
SetDriveStatus
GOTO NOAPP
END IF
UIPop 1
RETURN
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
lTicks& = 20
SrcDir$ = GetSymbolValue("STF_SRCDIR")
CreateDir DEST$, cmoNone
'* SysDir$ = GetWindowsSysDir()
ClearBillboardList
AddToBillboardList CUIDLL$, MODELESS, "FModelessDlgProc", lTicks&
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 ""
SetRestartDir(szTempDir)
ClearCopyList
AddOptFilesToCopyList APPFILES
AddOptFilesToCopyList OPTFILES1
AddOptFilesToCopyList OPTFILES2
AddOptFilesToCopyList OPTFILES3
AddOptFilesToCopyList SYMFILES
AddSectionFilesToCopyList "Remove List", SrcDir$, DEST$
'* AddSectionFilesToCopyList "PSGRFXXX Files", SrcDir$, DEST$
'* AddSectionKeyFileToCopyList "Options", OPTCUR$, SrcDir$, DEST$
'* AddSectionFilesToCopyList "System Files", SrcDir$, SysDir$
' COMMDLG$ = GetSectionKeyFileName ("COMMDLG", "COMMDLG")
' if DoesFileExist(MakePath(SysDir$, COMMDLG$), femReadWrite) = 1 THEN
' Lang$ = "..........................................."
' GetVersionLanguage MakePath(SysDir$, COMMDLG$), Lang$
''* i% = DoMsgBox(Lang$, "COMMDLG.DLL", MB_OK)
' if Lang$ = "U.S. English" THEN
' AddSectionKeyFileToCopyList "COMMDLG", "COMMDLG", SrcDir$, SysDir$
' else
' AddSectionKeyFileToCopyList "COMMDLG", "COMMDLG", SrcDir$, DEST$
' END IF
' ELSE
' AddSectionKeyFileToCopyList "COMMDLG", "COMMDLG", SrcDir$, SysDir$
' END IF
CopyFilesInCopyList
'* ini$ = MakePath(DEST$, "PSGRFXXX.INI")
'* CreateIniKeyValue "WIN.INI", "PSGRFXXX", "Option", OPTCUR$, cmoNone
'* CreateIniKeyValue ini$, "Section 1", "Key 1", "Value 1" , cmoNone
'* CreateIniKeyValue ini$, "Section 2", "Key 2", "Value 2" , cmoNone
'* CreateIniKeyValue ini$, "Section 3", "Key 3", "Value 3" , cmoNone
cat$ = MakePath(SrcDir$, "PSGRFXXX.CAT")
vol$ = " "
GetVolume SrcDir$, vol$
Ext$ = "*.GIF;*.BMP;*.TIF;*.TGA;*.IFF;*.PCX;*.WMF;*.EPS;*.WPG"
i% = DoesFileExist(cat$, femExists)
j% = DoesIniSectionExist(ini$, "PSGRFXXX")
IF i = 1 And j = 0 THEN
CreateIniKeyValue ini$, "PSGRFXXX", "Catalog1", "Default," + cat$ + "," + Ext$ +"," + vol$ + ",READONLY", cmoNone
CreateIniKeyValue ini$, "PSGRFXXX", "Catalogs", "1", cmoNone
END IF
IF DoesFileExist(MakePath(DEST$, "PIXPCD.DLL"), femReadWrite) = 1 THEN
CreateIniKeyValue ini$, "PSGRFXXX", "PCD Resolution", "3", cmoNone
CreateIniKeyValue ini$, "PSGRFXXX", "PCD Format", "2", cmoNone
END IF
CreateProgmanGroup "PSGRFXXX", "", cmoNone
ShowProgmanGroup "PSGRFXXX", 1, cmoNone
CreateProgmanItem "PSGRFXXX", "PSGRFXXX", MakePath(DEST$,"PSGRFXXX")+" psgrfxxx.cat", "", cmoOverwrite
CreateProgmanItem "PSGRFXXX", "Read Me", "notepad.exe "+MakePath(DEST$,"PIXREAD.ME"), "", cmoOverwrite
'* CreateProgmanItem "PSGRFXXX", "User Guide", "Write.exe "+MakePath(DEST$,"UsrGuide.wri"), "", cmoOverwrite
'* CreateProgmanItem "PSGRFXXX", "Clip Art", "notepad.exe "+MakePath(DEST$,"CLIPART.DOC"), "", cmoOverwrite
'* CreateProgmanItem "PSGRFXXX", "License", "notepad.exe "+MakePath(DEST$,"LICENSE.DOC"), "", cmoOverwrite
'* CreateProgmanItem "PSGRFXXX", "RS Offer", "notepad.exe "+MakePath(DEST$,"RSOFFER.DOC"), "", cmoOverwrite
'* AddDos5Help "YOURAPP", "A brief help text for your Windows application."+chr$(10)+"It can be continued on another line with chr$(10).", cmoNone
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
'**
'** Purpose:
'** Adds the specified option files to the copy list.
'** Arguments:
'** ftype% - type of files to add, one of the following:
'** APPFILES, OPTFILES1, OPTFILES2
'** Returns:
'** none.
'*************************************************************************
SUB AddOptFilesToCopyList (ftype%) STATIC
IF GetListItem(CHECKSTATES$, ftype%) = "ON" THEN
SrcDir$ = GetSymbolValue("STF_SRCDIR")
IF ftype% = APPFILES THEN
AddSectionFilesToCopyList "PixFolio Files", SrcDir$, DEST$
AddSectionFilesToCopyList "System Files", SrcDir$, SysDir$
ELSEIF ftype% = OPTFILES1 THEN
AddSectionFilesToCopyList "PCD Files", SrcDir$, DEST$
ELSEIF ftype% = OPTFILES2 THEN
AddSectionFilesToCopyList "VFW Files", SrcDir$, DEST$
ELSEIF ftype% = OPTFILES3 THEN
AddSectionFilesToCopyList "Multimedia Files", SrcDir$, DEST$
ELSEIF ftype% = SYMFILES THEN
'' i% = DoMsgBox("AddOptFiles" + STR$(ftype%), "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
IF GetListItem(CHECKSTATES$, APPFILES) = "ON" THEN
AddSectionFilesToCopyList "PixFolio Symbols", SrcDir$, DEST$
END IF
IF GetListItem(CHECKSTATES$, OPTFILES1) = "ON" THEN
AddSectionFilesToCopyList "PCD Symbols", SrcDir$, DEST$
END IF
IF GetListItem(CHECKSTATES$, OPTFILES2) = "ON" THEN
AddSectionFilesToCopyList "VFW Symbols", SrcDir$, DEST$
END IF
IF GetListItem(CHECKSTATES$, OPTFILES3) = "ON" THEN
AddSectionFilesToCopyList "Multimedia Symbols", SrcDir$, DEST$
END IF
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:
'** APPFILES, OPTFILES1, OPTFILES2
'** Returns:
'** none.
'*************************************************************************
SUB RecalcOptFiles (ftype%) STATIC
CursorSave% = ShowWaitCursor()
ClearCopyList
AddOptFilesToCopyList ftype%
'' i% = DoMsgBox("Added files to copy list " + STR$(ftype%), "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
fExtra% = 0
IF ftype% = APPFILES THEN
ListSym$ = APPNEEDS$
IF GetListItem(CHECKSTATES$, APPFILES) = "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% = OPTFILES1 THEN
ListSym$ = OPT1NEEDS$
ELSEIF ftype% = OPTFILES2 THEN
ListSym$ = OPT2NEEDS$
ELSEIF ftype% = OPTFILES3 THEN
ListSym$ = OPT3NEEDS$
ELSEIF ftype% = SYMFILES THEN
ListSym$ = SYMNEEDS$
END IF
'' i% = DoMsgBox("ListSym$ =" + ListSym$, "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
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$ = ""
'' i% = DoMsgBox("RecalcPath OK" + STR$(ftype%), "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
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 APPFILES
RecalcOptFiles OPTFILES1
RecalcOptFiles OPTFILES2
RecalcOptFiles OPTFILES3
RecalcOptFiles SYMFILES
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(OPT1NEEDS$, ndrive%)) + VAL(GetListItem(OPT2NEEDS$, ndrive%)) + VAL(GetListItem(SYMNEEDS$, 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(OPT1NEEDS$, ndrive%)) + VAL(GetListItem(OPT2NEEDS$, 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