Под управлением Windows 10 Pro.
Я пытаюсь обойти ограничение MAX_PATH в 260 символов, встроенное в Win32 API.
Я создал серию резервных копий, которые, как мы скажем, предназначены для резервного копирования "TRUNCATED" имен файлов.
Например, мы будем ссылаться на файл с полным именем файла:
D:/Folder1/Folder2/Folder3/Folder4/Folder5/Folder6/Folder7/Folder8/Folder9/file.txt
Для начала я теоретически сократил это имя файла, переместив файл в скрытую папку. Short_Name
ближе к корню, так что файл теперь буквально существует как
D:/Short_Name/Folder9/file.txt
Тем не менее, чтобы сохранить исходную файловую структуру без изменений, чтобы я мог повторно использовать эту тактику для выполнения такого же сокращения пути в другом месте, но при этом использовать те же файлы конфигурации и программное обеспечение для выполнения дублирования и синхронизации файлов В исходной папке (папках). )
( такие как D:/Folder1/.../Folder9/
)
Я включил символическую ссылку с именем " Folder9
"
(достигается с помощью C:\Windows\system32>
mklink
/J
( или же /D
) "D:/Folder1/.../Folder9/"
"D:/Short_Name/Folder9/"
в командной строке)
в
D:/Folder1/Folder2/Folder3/Folder4/Folder5/Folder6/Folder7/Folder8/
такой, что ссылка выглядит
D:/Folder1/.../Folder9/
но указывает на D:/Short_Name/Folder9/
,
СЕЙЧАС, очевидно, я мог бы вместо этого использовать обычный, заурядный
Нажмите правой кнопкой мыши & gt; "Создать ярлык"
но целевой путь ссылки такой символической ссылки будет абсолютным.
(т.е. ярлык на D:
указывая на D:/Short_Name/Folder9/file.txt
будет скопирован в C:
но скопированный ярлык дублирует на C:
все равно будет указывать на D:/Short_Name/Folder9/file.txt
, )
Символические ссылки, с другой стороны ...
(то есть те, которые созданы с помощью C:\Windows\system32>
mklink
...
)
... скопировать относительные ссылки без проблем ...
(т.е. D:/Folder1/.../Folder9/
будет скопирован как C:/Folder1/.../Folder9/
)
... и цель ссылки будет копировать с
D:/Short_Name/Folder9/
в
C:/Short_Name/Folder9/
... НО -
Проблема ЗДЕСЬ заключается в том, что СЕЙЧАС ЛИТЕРАЛЬНЫЕ ИМЕНА ИСПОЛЬЗУЮТСЯ, как их более длинные, НЕРАЗРЕШЕННЫЕ версии, что НЕ произошло бы при использовании
Нажмите правой кнопкой мыши & gt; "Создать ярлык"
метод.
Насколько я могу сказать, при использовании mklink
чтобы создать символическую ссылку на каталог (НЕ файл - я не знаю, работает ли он по-разному для файлов), системное имя файла LITERAL любого файла, размещенного в каталоге, например: D:/Short_Name/Folder9/
кажется, только когда-либо, mklink
символический путь, то есть путь
D:/Folder1/Folder2/Folder3/Folder4/Folder5/Folder6/Folder7/Folder8/Folder9/file.txt
даже если фактическое местоположение файла только
D:/Short_Name/Folder9/file.txt
,
ВОПРОС:
Есть ли ЛЮБОЙ способ создания символической ссылки, которая будет функционировать как стандартная папка, но которая ТАКЖЕ будет поддерживать ОТНОСИТЕЛЬНУЮ, ЛИТЕРАЛЬНУЮ, УСТАНОВЛЕННУЮ версию файла при копировании на новый диск?
Пожалуйста и спасибо.
источник
mklink
с вариантами/J
а также/D
,