Article: Q28445
Product(s): See article
Version(s): 6.00 6.00b 7.00 | 6.00 6.00b 7.00
Operating System(s): MS-DOS | OS/2
Keyword(s): ENDUSER | | mspl13_basic
Last Modified: 2-FEB-1990
Below is a sample program that makes OS/2 calls to DOSSetFSInfo and
DOSQFSInfo.
' The function declarations are found in file BSEDOSFL.BI
TYPE FSAllocate1
Filesysid AS LONG
SecPerUnit AS LONG
NumUnits AS LONG
AvailUnits AS LONG
ByteSec AS INTEGER
END TYPE
TYPE FSAllocate2
VolumeDate AS INTEGER
VolumeTime AS INTEGER
VLen AS STRING*1
VLabel AS STRING*11
END TYPE
TYPE SetInfo2
Vlen AS STRING*1
VLabel AS STRING*11
END TYPE
DECLARE FUNCTION DOSSetFSInfo%(_
BYVAL P1 AS INTEGER,_
BYVAL P2 AS INTEGER,_
BYVAL P3s AS INTEGER,_
BYVAL P3o AS INTEGER,_
BYVAL P4 AS INTEGER)
DECLARE FUNCTION DOSQFSInfo%(_
BYVAL P1 AS INTEGER,_
BYVAL P2 AS INTEGER,_
BYVAL P3s AS INTEGER,_
BYVAL P3o AS INTEGER,_
BYVAL P4 AS INTEGER)
'Routine to Shift and Print Information
DECLARE FUNCTION wdate$(p1 as integer)
DECLARE FUNCTION wtime$(p1 as integer)
DECLARE FUNCTION RightShift%(P1 as LONG,P2 as Integer)
DECLARE FUNCTION LeftShift%(P1 as LONG, P2 as Integer)
DECLARE FUNCTION unsigned&(P1 as integer)
DEFINT a-z
DIM info1 AS FSAllocate1
DIM info2 AS FSAllocate2
DIM info3 AS SetInfo2
cls
Input "Enter Drive Number (0=default, 1=A, etc) : ",drivenumber
level = 1
bufsize=18
x = DosQFSInfo%(drivenumber,level,varseg(info1),varptr(info1),bufsize)
print
Print "Level One Information"
print
IF (x) THEN
Print "An error occurred. The number is : ";x
ELSE
print "File System ID : ";info1.Filesysid
print "Number of sectors per allocation unit : ";info1.secperunit
print "Number of allocation units : ";info1.numunits
print "Available allocation units : ";info1.availunits
print "Bytes per sector : ";info1.bytesec
END IF
level=2
bufsize=16
print
Print "Level Two Information"
print
x = DosQFSInfo%(drivenumber,level,varseg(info2),varptr(info2),bufsize)
IF (x) THEN
Print "An error occurred. The number is : ";x
ELSE
PRINT "Volume Creation Date : ";wdate$(info2.VolumeDate)
PRINT "Volume Creation Time : ";wtime$(info2.VolumeTime)
PRINT "Length of Label : ";asc(info2.Vlen)
PRINT "Volume Label : ";info2.Vlabel
END IF
print
input "Enter the new VOLUME name : ";info3.Vlabel
info3.vlen=chr$(len(info3.vlabel))
info3.vlabel=info3.vlabel+chr$(0)
level=2
bufsize=12
x = DosSetFSInfo%(drivenumber,level,varseg(info3),varptr(info3),bufsize)
IF (x) THEN
Print "An error occurred. The number is : ";x
ELSE
Print "The volume label is changed."
level=2
bufsize=16
print
Print "Level Two Information"
print
x = DosQFSInfo%(drivenumber,level,varseg(info2),varptr(info2),bufsize)
IF (x) THEN
Print "An error occurred. The number is : ";x
ELSE
PRINT "Volume Creation Date : ";wdate$(info2.VolumeDate)
PRINT "Volume Creation Time : ";wtime$(info2.VolumeTime)
PRINT "Length of Label : ";asc(info2.Vlen)
PRINT "Volume Label : ";info2.Vlabel
END IF
END IF
END
FUNCTION wdate$(d%) static
DIM dl AS LONG
dl=unsigned&(d%)
mn=(RightShift%(dl,5)) AND (&h0f)
IF mn < 10 THEN
mn$="0"+ltrim$(str$(mn))
ELSE
mn$=ltrim$(str$(mn))
END IF
dy= dl AND (&h1f)
IF dy < 10 THEN
dy$="0"+ltrim$(str$(dy))
ELSE
dy$=ltrim$(str$(dy))
END IF
yr$=str$(RightShift(dl,9)+1980)
wdate$=mn$+"/"+dy$+"/"+ltrim$(yr$)
END FUNCTION
FUNCTION wtime$(d%)
DIM dl AS LONG
dl=unsigned&(d%)
hr=RightShift%(dl,11) AND (&h1f)
IF hr < 10 THEN
hr$="0"+ltrim$(str$(hr))
ELSE
hr$=ltrim$(str$(hr))
END IF
mt=(RightShift%(dl,5) AND (&h3f))
IF mt < 10 THEN
mt$="0"+ltrim$(str$(mt))
ELSE
mt$=ltrim$(str$(mt))
END IF
wtime$=ltrim$(hr$)+":"+mt$+string$(5,32)
END FUNCTION
FUNCTION RightShift%(number&,amount)
Rightshift=number&\2^amount
END FUNCTION
FUNCTION LeftShift%(number&,amount)
LeftShift=number&*(2^amount)
END FUNCTION
FUNCTION unsigned&(num)
IF num >=0 THEN
unsigned&=num
ELSE
unsigned&=65536+num
END IF
END FUNCTION