Type a page name and press Enter. You'll jump to the page if it exists, or you can create it if it doesn't.
To create a page in a module other than shlwapi, prefix the name with the module name and a period.
<DllImport("shlwapi.dll", CharSet:=CharSet.Auto)> _
Public Shared Function PathRelativePathTo( _
ByVal pszPath As StringBuilder, _
ByVal pszFrom As String, _
ByVal dwAttrFrom As Integer, _
ByVal pszTo As String, _
ByVal dwAttrTo As Integer) As Boolean
End Function
User-Defined Types:
None.
VB Signature 2:
''' <summary>
''' Creates a relative path from one file or folder to another.
''' </summary>
''' <param name="pszPath">Receives the relative path</param>
''' <param name="pszFrom">Contains the path that defines the start of the relative path</param>
''' <param name="dwAttrFrom">The file attributes of <paramref name="pszFrom" />. If this value contains Directory, <paramref name="pszFrom" /> is assumed to be a directory; otherwise, <paramref name="pszFrom" /> is assumed to be a file</param>
''' <param name="pszTo">Contains the path that defines the endpoint of the relative path</param>
''' <param name="dwAttrTo">The file attributes of <paramref name="pszTo" />. If this value contains Directory, <paramref name="pszTo" /> is assumed to be a directory; otherwise, <paramref name="pszTo" /> is assumed to be a file</param>
''' <returns>TRUE if successful, or FALSE otherwise</returns>
''' <remarks>
''' This function takes a pair of paths and generates a relative path from one to the other.
''' The paths do not have to be fully qualified, but they must have a common prefix, or the function will fail and return FALSE.
''' For example, let the starting point, pszFrom, be "c:\FolderA\FolderB\FolderC", and the ending point, pszTo, be "c:\FolderA\FolderD\FolderE". PathRelativePathTo will return the relative path from pszFrom to pszTo as: "..\..\FolderD\FolderE". You will get the same result if you set pszFrom to "\FolderA\FolderB\FolderC" and pszTo to "\FolderA\FolderD\FolderE". On the other hand, "c:\FolderA\FolderB" and "a:\FolderA\FolderD do not share a common prefix, and the function will fail. Note that "\\" is not considered a prefix and is ignored. If you set pszFrom to "\\FolderA\FolderB", and pszTo to "\\FolderC\FolderD", the function will fail.
''' </remarks>
<DllImport("shlwapi.dll", CharSet:=CharSet.Auto)> _
Public Shared Function PathRelativePathTo( _
ByVal pszPath As StringBuilder, _
ByVal pszFrom As String, _
ByVal dwAttrFrom As Microsoft.VisualBasic.FileAttribute, _
ByVal pszTo As String, _
ByVal dwAttrTo As Microsoft.VisualBasic.FileAttribute) As Boolean
End Function
User-Defined Types:
None.
Notes:
None.
Tips & Tricks:
The Microsoft.VisualBasic.FileAttribute enumeration can be used to specify the file attribute
public static string GetRelativePath(FileSystemInfo path1, FileSystemInfo path2) {
if (path1 == null) throw new ArgumentNullException("path1");
if (path2 == null) throw new ArgumentNullException("path2");
helpful tips or sample code to share for using this API in managed code?
corrections to the existing content?
variations of the signature you want to share?
additional languages you want to include?
Select "Edit This Page" on the right hand toolbar and edit it! Or add new pages containing supporting types needed for this API (structures, delegates, and more).