Using Win32 functions in Visual FoxPro Image Gallery
Code examples:
Extended OS Version info
High-powered ALLTRIM
How to test file attributes (key method for FileExists and DirectoryExists routines)
Obtaining physical parameters for a drive: sectors, clusters, cylinders...
Opening access to the Microsoft Internet functions for the application
Pocket PC: creating new database in the Object Store and copying Contacts Database records into it
The SQLGetProp() creates a bridge between Visual FoxPro and the ODBC API
Using the GradientFill function
Writing to INI file
Adding printer to the list of supported printers for the specified server
Drawing a rectangle using Windows regular edges and borders
Get the power status of your laptop computer
How to find when the application started
Memory usage info for current VFP session (WinNT only)
Pocket PC: retrieving data from the Contacts Database
Retrieveing general information about the driver and data source associated with an ODBC connection
Retrieving list of available disk drives
Retrieving the interface–to–IP address mapping table
Retrieving the state of your Internet connection
Winsock: changing the byte ordering
Comparing dimensions of the VFP main window with _SCREEN properties
Creating a device context for the specified printer
Creating a mailslot
Enumerating the subkeys for a given registry key
Basic Volume information

User rating: 0/10 (0 votes)
Rate this code sample:
  • ~
More code examples    Listed functions    Add comment     W32 Constants      Translate this page Printer friendly version of this code sample
Versions:
click to open
Before you begin:


See also:
  • Displaying the drive type value
  • Setting the volume label
  • Disk in drive A:
  • Obtaining physical parameters for a drive: sectors, clusters, cylinders...
  •  
    #DEFINE FILE_CASE_SENSITIVE_SEARCH 1
    #DEFINE FILE_CASE_PRESERVED_NAMES 2
    #DEFINE FILE_UNICODE_ON_DISK 4
    #DEFINE FILE_PERSISTENT_ACLS 8
    #DEFINE FILE_FILE_COMPRESSION 16
    #DEFINE FILE_VOLUME_IS_COMPRESSED 0x8000
    #DEFINE MAX_PATH 260
    #DEFINE CRLF CHR(13)+CHR(10)
     
        DO declare
        DO GetVolumeInfo WITH "C:\"
    * end of main
     
    PROCEDURE GetVolumeInfo(cRoot As String)
        LOCAL cVolNameBuffer, nVolSerialNo, nMaxCompLen, nFlags, nError
     
        STORE REPLICATE(CHR(0),MAX_PATH) TO;
            cVolNameBuffer, nFilesysNameBuffer
     
        STORE 0 TO nVolSerialNo, nMaxCompLen, nFlags
     
        nResult = GetVolumeInformation(cRoot, @cVolNameBuffer,;
            MAX_PATH, @nVolSerialNo, @nMaxCompLen, @nFlags,;
            @nFilesysNameBuffer, MAX_PATH)
     
        IF nResult = 0
        * 3=ERROR_PATH_NOT_FOUND
        * 21=ERROR_NOT_READY
        * 87=ERROR_INVALID_PARAMETER
            nError = GetLastError()
            = MESSAGEBOX("GetVolumeInformation() call failed: " +;
                TRANSFORM(m.nError), 48, m.cRoot)
            RETURN
        ENDIF
     
        DO LogInfo WITH "Root", m.cRoot
     
        DO LogInfo WITH "File System Name",;
            LEFT(nFilesysNameBuffer, AT(CHR(0),nFilesysNameBuffer)-1)
     
        DO LogInfo WITH "Volume Name",;
            LEFT(cVolNameBuffer, AT(CHR(0),cVolNameBuffer)-1)
     
        DO LogInfo WITH "Volume Serial No.",;
            TRANSFORM(nVolSerialNo, "@0")
     
        DO LogInfo WITH "Max Filename Length", nMaxCompLen
     
        DO LogInfo WITH "File System Flags", TRANSFORM(nFlags, "@0")
     
        DO LogInfo WITH "Case-sensitive file names support",;
            IIF(BITAND(nFlags, FILE_CASE_SENSITIVE_SEARCH)=0, "No", "Yes")
     
        DO LogInfo WITH "The file system preserves the case of file names",;
            IIF(BITAND(nFlags, FILE_CASE_PRESERVED_NAMES)=0, "No", "Yes")
     
        DO LogInfo WITH "Unicode in file names support",;
            IIF(BITAND(nFlags, FILE_UNICODE_ON_DISK)=0, "No", "Yes")
     
        DO LogInfo WITH "ACLs support",;
            IIF(BITAND(nFlags, FILE_PERSISTENT_ACLS)=0, "No", "Yes")
     
        DO LogInfo WITH "File-based compression support",;
            IIF(BITAND(nFlags, FILE_FILE_COMPRESSION)=0, "No", "Yes")
     
        DO LogInfo WITH "The specified volume is a compressed volume",;
            IIF(BITAND(nFlags, FILE_VOLUME_IS_COMPRESSED)=0, "No", "Yes")
     
        IF USED("csResult")
            SELECT csResult
            GO TOP
            BROWSE NORMAL NOWAIT
        ENDIF
     
    PROCEDURE LogInfo(cName, vValue)
        IF NOT USED("csResult")
            CREATE CURSOR csResult (property_name C(50), property_value C(50))
        ENDIF
     
        INSERT INTO csResult (property_name, property_value);
        VALUES (m.cName, TRANSFORM(m.vValue))
     
    PROCEDURE declare
        DECLARE INTEGER GetLastError IN kernel32
     
        DECLARE SHORT GetVolumeInformation IN kernel32;
            STRING lpRootPathName, STRING @lpVolumeNameBuffer,;
            LONG nVolumeNameSize, LONG @lpVolumeSerialNumber,;
            LONG @lpMaximumComponentLength, LONG @lpFlags,;
            STRING @lpFileSystemNameBuffer, LONG nFilesysNameSize
     
     

    User rating: 0/10 (0 votes)
    Rate this code sample:
    • ~
    2754 bytes  
    Created: 2001-08-10 12:00:00  
    Modified: 2009-02-16 14:55:10  
    Visits in 7 days: 24  
    Listed functions:
    GetLastError
    GetVolumeInformation
    Printer friendly API declarations
    Word Index links for this example:
    Translate this page:
      Spanish    Portuguese    German    French    Italian  
    FreeTranslation.com offers instant, free translations of text or web pages.
    User Contributed Notes:
    There are no notes on this subject.


    Copyright © 2001-2017 News2News, Inc. Before reproducing or distributing any data from this site please ask for an approval from its owner. Unless otherwise specified, this page is for your personal and non-commercial use. The information on this page is presented AS IS, meaning that you may use it at your own risk. Microsoft Visual FoxPro and Windows are trade marks of Microsoft Corp. All other trademarks are the property of their respective owners. 

    Privacy policy
    Credits: PHP (4.4.9), an HTML-embedded scripting language, MySQL (5.6.34), the Open Source standard SQL database, AceHTML Freeware Version 4, freeware HTML Editor of choice.   Hosted by Korax Online Inc.
    Last Topics Visited (54.205.173.230)
    8 sec.
    Function group: 'URL Monikers'
    13 sec.Function: 'EnumPorts'
    24 sec.Function: 'OpenPrinter'
    29 sec.Example: 'Displaying system dialog that selects a folder'
    34 sec.Example: 'How to delete a service object'
    40 sec.Function: 'UpdateResource'
    55 sec.Function: 'ReadProcessMemory'
    1.57 min.Function: 'DeleteFileTransacted'
    Function group: 'File Management'
    1.63 min.Example: 'Retrieving graphic capabilities of your display'
    1.72 min.Function: 'WSACloseEvent'
    Function group: 'Windows Sockets 2 (Winsock)'
    Google
    Advertise here!