Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
File attribute constants define metadata values stored by the file system on disk and are used by the system and available to developers via various file I/O APIs. These constants allow developers to check and set file properties such as read-only, hidden, or compressed attributes. For a list of related APIs and topics, see the See also section.
Example
FILE_BASIC_INFO basicInfo;
    BOOL result;
    result = GetFileInformationByHandleEx( hFile,
                                               FileBasicInfo,
                                               &basicInfo,
                                               sizeof(basicInfo));
\\...
printf("  File Attributes: ");
    PrintFileAttributes(basicInfo.FileAttributes);
\\...
VOID
PrintFileAttributes(
    ULONG FileAttributes
    )
{
    
    if (FileAttributes & FILE_ATTRIBUTE_ARCHIVE) {
        printf("Archive ");
    }
    if (FileAttributes & FILE_ATTRIBUTE_DIRECTORY) {
        printf("Directory ");
    }
    if (FileAttributes & FILE_ATTRIBUTE_READONLY) {
        printf("Read-Only ");
    }
}
Example taken from a Windows Classic Sample on GitHub.
| Constant/value | Description | 
|---|---|
| 
 | A file that is read-only. Applications can read the file, but cannot write to it or delete it. This attribute is not honored on directories. | 
| 
 | The file or directory is hidden. It is not included in an ordinary directory listing. | 
| 
 | A file or directory that the operating system uses a part of, or uses exclusively. | 
| 
 | The handle that identifies a directory. | 
| 
 | A file or directory that is an archive file or directory. Applications typically use this attribute to mark files for backup or removal. | 
| 
 | This value is reserved for system use. | 
| 
 | A file that does not have other attributes set. This attribute is valid only when used alone. | 
| 
 | A file that is being used for temporary storage. File systems avoid writing data back to mass storage if sufficient cache memory is available, because typically, an application deletes a temporary file after the handle is closed. In that scenario, the system can entirely avoid writing the data. Otherwise, the data is written after the handle is closed. | 
| 
 | A file that is a sparse file. | 
| 
 | A file or directory that has an associated reparse point, or a file that is a symbolic link. | 
| 
 | A file or directory that is compressed. For a file, all of the data in the file is compressed. For a directory, compression is the default for newly created files and subdirectories. | 
| 
 | The data of a file is not available immediately. This attribute indicates that the file data is physically moved to offline storage. This attribute is used by Remote Storage, which is the hierarchical storage management software. Applications should not arbitrarily change this attribute. | 
| 
 | The file or directory is not to be indexed by the content indexing service. | 
| 
 | A file or directory that is encrypted. For a file, all data streams in the file are encrypted. For a directory, encryption is the default for newly created files and subdirectories. | 
| 
 | The directory or user data stream is configured with integrity (only supported on ReFS volumes). It is not included in an ordinary directory listing. The integrity setting persists with the file if it's renamed. If a file is copied the destination file will have integrity set if either the source file or destination directory have integrity set. Windows Server 2008 R2, Windows 7, Windows Server 2008, Windows Vista, Windows Server 2003 and Windows XP: This flag is not supported until Windows Server 2012. | 
| 
 | This value is reserved for system use. | 
| 
 | The user data stream not to be read by the background data integrity scanner (AKA scrubber). When set on a directory it only provides inheritance. This flag is only supported on Storage Spaces and ReFS volumes. It is not included in an ordinary directory listing. Windows Server 2008 R2, Windows 7, Windows Server 2008, Windows Vista, Windows Server 2003 and Windows XP: This flag is not supported until Windows 8 and Windows Server 2012. | 
| 
 | A file or directory with extended attributes. IMPORTANT: This constant is for internal use only. | 
| 
 | This attribute indicates user intent that the file or directory should be kept fully present locally even when not being actively accessed. This attribute is for use with hierarchical storage management software. | 
| 
 | This attribute indicates that the file or directory should not be kept fully present locally except when being actively accessed. This attribute is for use with hierarchical storage management software. | 
| 
 | This attribute only appears in directory enumeration classes (FILE_DIRECTORY_INFORMATION, FILE_BOTH_DIR_INFORMATION, etc.). When this attribute is set, it means that the file or directory has no physical representation on the local system; the item is virtual. Opening the item will be more expensive than normal, e.g. it will cause at least some of it to be fetched from a remote store. | 
| 
 | When this attribute is set, it means that the file or directory is not fully present locally. For a file that means that not all of its data is on local storage (e.g. it may be sparse with some data still in remote storage). For a directory it means that some of the directory contents are being virtualized from another location. Reading the file / enumerating the directory will be more expensive than normal, e.g. it will cause at least some of the file/directory content to be fetched from a remote store. Only kernel-mode callers can set this bit. File system mini filters below the 180000 – 189999 altitude range (FSFilter HSM Load Order Group) must not issue targeted cached reads or writes to files that have this attribute set. This could lead to cache pollution and potential file corruption. For more information, see Handling placeholders. | 
Requirements
| Requirement | Value | 
|---|---|
| Minimum supported client | Windows XP [desktop apps only] | 
| Minimum supported server | Windows Server 2003 [desktop apps only] | 
| Header | WinNT.h (include Windows.h) |