PathRelativePathToA 함수(shlwapi.h)
한 파일 또는 폴더에서 다른 파일로의 상대 경로를 만듭니다.
통사론
BOOL PathRelativePathToA(
[out] LPSTR pszPath,
[in] LPCSTR pszFrom,
[in] DWORD dwAttrFrom,
[in] LPCSTR pszTo,
[in] DWORD dwAttrTo
);
매개 변수
[out] pszPath
형식: LPTSTR
상대 경로를 받는 문자열에 대한 포인터입니다. 이 버퍼의 크기는 최소 MAX_PATH 문자여야 합니다.
[in] pszFrom
형식: LPCTSTR
상대 경로의 시작을 정의하는 경로가 포함된 최대 길이 MAX_PATH null로 끝나는 문자열에 대한 포인터입니다.
[in] dwAttrFrom
형식: DWORD
pszFrom
[in] pszTo
형식: LPCTSTR
상대 경로의 엔드포인트를 정의하는 경로가 포함된 최대 길이 MAX_PATH null로 끝나는 문자열에 대한 포인터입니다.
[in] dwAttrTo
형식: DWORD
pszTo파일 특성입니다. 이 값에 FILE_ATTRIBUTE_DIRECTORY 포함된 경우
반환 값
형식: BOOL
성공하면
발언
이 함수는 한 쌍의 경로를 사용하고 한 쪽에서 다른 경로로 상대 경로를 생성합니다. 경로를 정규화할 필요는 없지만 공통 접두사를 가져야 합니다. 그렇지 않으면 함수가 실패하고 FALSE
예를 들어 pszFrom
예제
#include <windows.h>
#include <iostream.h>
#include "Shlwapi.h"
void main(void)
{
char szOut[MAX_PATH] = "";
char szFrom[ ] = "c:\\a\\b\\path";
char szTo[ ] = "c:\\a\\x\\y\\file";
cout << "The relative path is relative from: ";
cout << szFrom;
cout << "\n";
cout << "The relative path is relative to: ";
cout << szTo;
cout << "\n";
PathRelativePathTo(szOut,
szFrom,
FILE_ATTRIBUTE_DIRECTORY,
szTo,
FILE_ATTRIBUTE_NORMAL);
cout << "The relative path is: ";
cout << szOut;
cout << "\n";
}
OUTPUT:
==================
The relative path is relative from: c:\a\b\path
The relative path is relative to: c:\a\x\y\file
The relative path is: ..\..\x\y\file
메모
shlwapi.h 헤더는 PATHRelativePathTo를 UNICODE 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입대한
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000 Professional, Windows XP [데스크톱 앱만 해당] |
지원되는 최소 서버 | Windows 2000 Server [데스크톱 앱만 해당] |
대상 플랫폼 | Windows |
헤더 | shlwapi.h |
라이브러리 | Shlwapi.lib |
DLL | Shlwapi.dll(버전 4.71 이상) |