Level Extreme platform
Subscription
Corporate profile
Products & Services
Support
Legal
Français
Create a form display only drives/attached network folde
Message
From
20/10/2006 10:14:14
 
 
To
20/10/2006 10:08:28
General information
Forum:
Visual FoxPro
Category:
Forms & Form designer
Miscellaneous
Thread ID:
01163638
Message ID:
01163651
Views:
8
Try this one (It displays the information for network drives):
* Constants for drive types.
#DEFINE DRIVE_UNKNOWN 0
#DEFINE DRIVE_NO_ROOT_DIR 1
#DEFINE DRIVE_REMOVABLE 2
#DEFINE DRIVE_FIXED 3
#DEFINE DRIVE_REMOTE 4
#DEFINE DRIVE_CDROM 5
#DEFINE DRIVE_RAMDISK 6
#DEFINE CR CHR(13)

DECLARE INTEGER GetLogicalDrives IN Win32API
DECLARE INTEGER GetDriveType IN Win32API STRING RootPath

PRIVATE lcDrivestring, lcDriveRoot, liDrivelist, lcDrives, i
lcDrives = ""

liDrivelist = GetLogicalDrives()

* Check each of the bits
FOR i = 0 TO 31
	IF BITTEST(liDrivelist, i)
* If the 0th bit is ON, that means drive 'A:',
* the 2nd bit is 'C:", etc.
		lcDriveRoot = CHR(65 + i) + ":\"
* Perform a GetDriveType to determine if it is a floppy, CD, etc.
		lcDrivetype = GetDriveType(lcDriveRoot)
		DO CASE
			CASE lcDrivetype = DRIVE_UNKNOWN
				lcDrivestring = "Cannot be determined"
			CASE lcDrivetype = DRIVE_NO_ROOT_DIR
				lcDrivestring = "Root directory does not exist"
			CASE lcDrivetype = DRIVE_REMOVABLE
				lcDrivestring = "Floppy/removable drive"
			CASE lcDrivetype = DRIVE_FIXED
				lcDrivestring = "Hard drive/nonremovable drive"
			CASE lcDrivetype = DRIVE_REMOTE
				lcDrivestring = "Remote/Network drive"
				lcunc=GetUNCForDriveLetter(LEFT(lcDriveRoot,2))
				IF TYPE('lcunc')="C" .AND. !EMPTY(lcunc)
					lcDrivestring = lcunc
				ENDIF
			CASE lcDrivetype = DRIVE_CDROM
				lcDrivestring = "CD-ROM drive"
			CASE lcDrivetype = DRIVE_RAMDISK
				lcDrivestring = "RAM disk"
		ENDCASE
		lcDrives = lcDrives + lcDriveRoot + " " + lcDrivestring + CR
	ENDIF
NEXT

=MESSAGEBOX(lcDrives, ;
	0 + 64 + 0,'All Drives Listing')
RETURN


FUNCTION GetUNCForDriveLetter
LPARAMETER cDriveLetterToCheck
LOCAL cBuffer, nResult, lcunc
IF TYPE('cDriveLetterToCheck') # 'C' OR ;
		LEN(cDriveLetterToCheck) < 2 OR ;
		SUBSTR(cDriveLetterToCheck,2,1) # ':' OR ;
		! BETWEEN(UPPER(LEFT(cDriveLetterToCheck,1)),'A','Z')
	RETURN ''
ENDIF
DECLARE INTEGER WNetGetConnection IN Win32API ;
	STRING   @cLocalDrive, ;
	STRING   @cRemoteUNCBuffer, ;
	INTEGER  @nSizeOfBuffer
cBuffer = SPACE(511)
nResult = WNetGetConnection(LEFT(cDriveLetterToCheck,2), ;
	@cBuffer, ;
	511)
IF nResult # 0
*  Failed - it's probably not a mapped drive,
*  or nothing is mapped to it
	RETURN ''
ELSE
	lcunc=LEFT(cBuffer,AT(CHR(0),cBuffer)-1)
	RETURN lcunc
*RETURN LEFT(cBuffer,AT(CHR(0),cBuffer)-1)
ENDIF
>Thanks, that would work, the only question is
>
>Is it possible to get name of assocaited with a network drive, for exmaple say drive "R" is "Public on Shared\xxx" would it be possible to say
>
>     R:\ Public on Shared\xx
>
>instead of
>
>     R:\ Remote/Netork Drive
>
>For my drop down list I also assume that RowSourceType is "5 - Array". But what would I put for Rowsource. Would it be "aDrives=Getdrives()", and how would I return the array
>
>RETURN laDrives
>
.·*´¨)
.·`TCH
(..·*

010000110101001101101000011000010111001001110000010011110111001001000010011101010111001101110100
"When the debate is lost, slander becomes the tool of the loser." - Socrates
Vita contingit, Vive cum eo. (Life Happens, Live With it.)
"Life is not measured by the number of breaths we take, but by the moments that take our breath away." -- author unknown
"De omnibus dubitandum"
Previous
Next
Reply
Map
View

Click here to load this message in the networking platform