Path.IsPathFullyQualified Method

Definition

Returns a value that indicates whether a file path is fully qualified.

Overloads

IsPathFullyQualified(ReadOnlySpan<Char>)

Returns a value that indicates whether the file path represented by the specified character span is fixed to a specific drive or UNC path.

IsPathFullyQualified(String)

Returns a value that indicates whether the specified file path is fixed to a specific drive or UNC path.

Remarks

The overloads of the IsPathFullyQualified method handle paths that use both the DirectorySeparatorChar and the AltDirectorySeparatorChar characters. It does not perform any validation on the path that is passed to it as an argument. As a result, URIs are interpreted as relative paths and return false.

There is a difference between a fully qualified path (as indicated by the IsPathFullyQualified method) and a rooted path (as indicated by the IsPathRooted method). A fully qualified path or absolute path always defines an exact path from a particular drive or device to a target file or directory, and does not depend on the current drive or current directory. For example, on Windows systems, C:/users/user1/documents/reports/2019/january/highlights.pdf defines an absolute path from the root of the C: drive to the target file, highlights.pdf. A rooted path specifies either a starting drive or root directory, but depends on either the current directory (if it is rooted by a specified drive) or the current drive (if it is rooted by the root directory). The following example illustrates the difference between fully qualified paths and rooted paths.

using System;
using System.IO;

class Program
{
    static void Main()
    {
        string relative1 = "C:Documents"; 
        ShowPathInfo(relative1);

        string relative2 = "/Documents";
        ShowPathInfo(relative2);

        string absolute = "C:/Documents";
        ShowPathInfo(absolute);
    }

    private static void ShowPathInfo(string path)
    {
        Console.WriteLine($"Path: {path}");
        Console.WriteLine($"   Rooted: {Path.IsPathRooted(path)}");
        Console.WriteLine($"   Fully qualified: {Path.IsPathFullyQualified(path)}");
        Console.WriteLine($"   Full path: {Path.GetFullPath(path)}");
        Console.WriteLine();
    }
}
// The example displays the following output when run on a Windows system:
//    Path: C:Documents
//        Rooted: True
//        Fully qualified: False
//        Full path: c:\Users\user1\Documents\projects\path\ispathrooted\Documents
//
//    Path: /Documents
//       Rooted: True
//       Fully qualified: False
//       Full path: c:\Documents
//
//    Path: C:/Documents
//       Rooted: True
//       Fully qualified: True
//       Full path: C:\Documents

IsPathFullyQualified(ReadOnlySpan<Char>)

Source:
Path.cs
Source:
Path.cs
Source:
Path.cs

Returns a value that indicates whether the file path represented by the specified character span is fixed to a specific drive or UNC path.

public static bool IsPathFullyQualified (ReadOnlySpan<char> path);

Parameters

path
ReadOnlySpan<Char>

A file path.

Returns

true if the path is fixed to a specific drive or UNC path; false if the path is relative to the current drive or working directory.

See also

Applies to

.NET 9 and other versions
Product Versions
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

IsPathFullyQualified(String)

Source:
Path.cs
Source:
Path.cs
Source:
Path.cs

Returns a value that indicates whether the specified file path is fixed to a specific drive or UNC path.

public static bool IsPathFullyQualified (string path);

Parameters

path
String

A file path.

Returns

true if the path is fixed to a specific drive or UNC path; false if the path is relative to the current drive or working directory.

Exceptions

path is null.

Remarks

This method handles paths that use the alternate directory separator. It's a frequent mistake to assume that rooted paths (IsPathRooted(String)) aren't relative. For example, "C:a" is drive relative, that is, it's resolved against the current directory for C: (rooted, but relative). "C:\a" is rooted and not relative, that is, the current directory isn't used to modify the path.

See also

Applies to

.NET 9 and other versions
Product Versions
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1