stringtranslate.com

Длинное имя файла

Поддержка длинных имен файлов ( LFN ) — это обратно совместимое расширение Microsoft для схемы именования имен файлов 8.3 (короткое имя файла), используемой в MS-DOS . Длинные имена файлов могут быть более описательными, включая более длинные расширения имен файлов , такие как .jpeg, .tiff, и , .htmlкоторые распространены в других операционных системах, а не специализированные сокращенные имена, такие как .jpg, .tif, или .htm. Стандарт был распространен в файловых системах File Allocation Table (FAT) с момента его первой реализации в Windows NT 3.5 в 1994 году.

Для поддержания совместимости со старыми операционными системами компания Microsoft разработала метод генерации имени файла 8.3 из длинного имени файла (например, Microsoft.txt) MICROS~1.TXTи связывания его с файлом.

Проблемы совместимости

Microsoft реализовала поддержку LFN в файловой системе FAT, используя скрытые записи каталогов типа метки тома для хранения длинных имен; эта схема известна как VFAT и была выбрана для совместимости, поскольку метки томов обычно игнорируются программами и компонентами операционной системы (ОС). Программы, работающие на старых ОС, по-прежнему могли получать доступ к коротким именам файлов, в то время как более новые ОС и программы, поддерживающие LFN, могли использовать более длинные.

Когда поддержка LFN впервые была введена в операционную систему на базе DOS в виде Windows 95 , это вызвало некоторые проблемы для старых программ. Например, программа DOS, выполняющая операции на уровне секторов каталогов, когда Windows находилась в режиме DOS, могла уничтожить длинную информацию об именах файлов, поэтому по умолчанию доступ на уровне секторов к жестким дискам в этом режиме был запрещен.

При загрузке в простой DOS длинные имена файлов не видны, если не установлен драйвер VFAT LFN. Microsoft не добавила поддержку LFN во многие из своих старых программ, включая File Manager , файловый менеджер Windows 3.1x (Windows for Workgroups), который устарел из-за новой оболочки операционной системы Windows Explorer . Windows NT поддерживала LFN в файловых системах NTFS, начиная с выпуска NT 3.1, и все ее утилиты, включая File Manager, были обновлены для поддержки LFN. NT 3.5 добавила поддержку FAT LFN в рамках подготовки к Windows 95. Однако версия File Manager для Windows 95 появилась в Windows for Workgroups 3.11.

OS/2 хранит LFN для файловых систем FAT в .LONGNAME расширенных атрибутах , которые несовместимы с реализацией Microsoft и видны только инструментам, поддерживающим стандарт OS/2. Многие API, предоставляющие доступ к файлам по имени пути, не могут видеть новые, более длинные имена без поддерживающего драйвера.

Пределы

Поскольку реализация FAT LFN накладывается поверх более старой, более ограниченной системы именования, возникают неизбежные осложнения, например, если будет предпринята попытка создать слишком много файлов с одинаковыми первыми шестью буквами. [1] Кроме того, более вероятно возникновение проблем при создании файлов или папок в корневом каталоге, поскольку FAT12 и FAT16 выделяют место только для 512 записей корневого каталога на жестких дисках. Поскольку длинные имена файлов используют более одной записи каталога, эта проблема может возникнуть при менее чем 512 файлах или папках в корневом каталоге. [2] Есть место только для 24 длинных имен файлов максимальной длины (512/(1+20)). Эта проблема не существует для томов FAT32 .

Система длинных имен файлов допускает максимальную длину 255 символов UCS-2 [3] [4], включая пробелы и не буквенно-цифровые символы (за исключением следующих символов, которые имеют особое значение в командном интерпретаторе COMMAND.COM или ядре операционной системы: \ / : * ? " < > |). Это достигается путем объединения до 20 записей каталога по 13 2-байтовых символов Unicode каждая. [4] Максимальная длина имени пути составляет 256 символов, включая все родительские каталоги и имя файла. Длинное имя файла со смешанным регистром длиной 255 символов возможно только для файлов или папок без подпапок в корневой папке любого диска.

Хотя поддержка длинных имен файлов допускает более длинные имена файлов и каталогов, в системах на базе DOS абсолютный путь к файлу, построенный из соответствующих коротких эквивалентов имен файлов и каталогов, по-прежнему представлен во внутренней структуре данных, называемой структурой текущего каталога (CDS), [5] [6] [7] [8] , которая накладывает ограничение в 66 символов на (короткое) имя пути и тем самым косвенно ограничивает также глубину пути максимум 33 уровнями (с учетом корневого каталога и предполагая только однобуквенные имена). (Это ограничение конструкции отсутствовало в более старых версиях DR DOS (до обновлений DR DOS 6.0 от ноября 1991 г.), которые по-прежнему использовали относительное представление пути внутри себя, [7] [8] [9] однако из-за своих внутренних различий эти версии несовместимы с существующими дополнительными драйверами LFN.) Операционные системы, не основанные на DOS, без CDS не ограничены этим ограничением глубины пути.

Драйверы VFAT LFN

Ниже приведен список драйверов, которые можно использовать для поддержки длинных имен файлов VFAT, используемых в Windows 95. Хотя такие драйверы, как DOSLFN, можно загрузить практически в любую версию DOS, лучше всего они работают в версиях DOS, которые поддерживают LFN, например MS-DOS 7.10 или DR-DOS 7.02 , чтобы такие команды DOS, как , DIRтакже отображали длинные имена файлов.

Команды DOS LFN реального режима без драйвера

Некоторые небольшие программы реального режима DOS также были написаны за эти годы, хотя многие из них были утеряны со временем. Одна из примечательных коллекций программ, которая все еще существует, — это LFN Tools, которая имеет открытый исходный код и включает в себя семь полезных команд LFN, написанных на C++ и ассемблере, с включенной документацией на английском и немецком языках, и доступна на LFNTOOLS на Sourceforge.net.

Другие реализации

До того, как поддержка LFN была реализована в семействе файловых систем FAT, различные файловые менеджеры предоставляли собственные методы для присоединения и сохранения более длинных описаний файлов. Среди первых, кто это сделал, были альтернативные процессоры командной строки 4DOS и NDOS с их внутренними DESCRIBEкомандами и соответствующими DESCRIPT.IONфайлами. Последние представляют собой необязательные скрытые файлы, расположенные в каждом каталоге, хранящие построчный список имен файлов, расположенных в каталоге, вместе с их текстовым описанием и необязательными записями метаданных — например, расширенными атрибутами и данными конфигурации для других программ. [10] Описания могут быть длиной до 511 символов и отображаются вместе с именами файлов примерно так же, как длинные имена файлов указываются рядом с их короткими псевдонимами имен файлов в DIRлистингах. Если запись для файла существует, она будет скопирована и перемещена вместе с файлом до тех пор, пока эти процессоры командной строки используются для выполнения операции. [9] Эта схема все еще поддерживается преемниками, такими как 4OS2 , 4NT / Take Command . Его также использовали другие программы, такие как Volkov Commander (VC), DOS Navigator (DN), Open DOS Navigator (ODN), Necromancer's DOS Navigator (NDN), Windows Commander , Total Commander , Double Commander , 7-Zip , XnView , ACDSee , Newsbin Pro , V, FreeDOS [11] и некоторые приложения на базе CUI_LIB [12] .

Human68K , операционная система компьютеров X68000 с 1986 года, основана на расширенной файловой системе FAT. Она допускает до 18,3 символов в имени файла (вместо 8,3 в FAT) и допускает также символы верхнего и нижнего регистра (а также кандзи в коде Shift JIS ), которые все рассматриваются как отличительные. Если ограничиться использованием имен файлов в формате 8,3 только с символами верхнего регистра, дискеты Human68K полностью совместимы с японским стандартным форматом дискет FAT 1232 КиБ (77 цилиндров, 2 головки, 8 секторов, 1024 байта/сектор). Этот формат используется компьютерами серий NEC PC-9800 , Fujitsu FMR и FM Towns . [ необходима цитата ]

Тома Novell NetWare версий 3.x и 4.x также могут поддерживать длинные имена файлов, совместимые с Microsoft, путем загрузки дополнительного загружаемого модуля NetWare (NLM). [13]

Для поддержки приложений Java без реализации схемы, совместимой с VFAT , в операционной системе IBM 4690 версии 2 на базе FlexOS была введена собственная архитектура виртуальной файловой системы (VFS) для хранения длинных имен файлов в файловой системе FAT в обратно совместимом режиме. Если эта опция включена, виртуальные имена файлов (VFN) доступны под отдельными буквами логических дисков, тогда как реальные имена файлов (RFN) остаются доступными под исходными буквами дисков. [14]

Смотрите также

Ссылки

  1. ^ "MSDOSFileSystem". CocoaDev . 2005-09-12. Архивировано из оригинала 2006-10-18.
  2. ^ «Ошибки создания файлов или папок в корневом каталоге». Microsoft . 120138.
  3. ^ Winnick Cluts, Nancy (август 1996) [январь 1995]. "Making Room for Long Filenames". Технические статьи Files and I/0. Microsoft Corporation . 810456. Архивировано из оригинала 2008-04-23 . Получено 2007-04-19 .
  4. ^ ab Dobiash, Jack "vinDaci", ред. (1998-01-06) [1996-11-18]. "Long Filename Specification" (4-е изд.). Гранд-Ронд, Орегон, США. Архивировано из оригинала 2015-10-25 . Получено 2013-05-22 .
  5. ^ Шульман, Эндрю; Браун, Ральф Д .; Макси, Дэвид; Михельс, Рэймонд Дж.; Кайл, Джим (1994) [ноябрь 1993]. Недокументированная DOS: руководство программиста по зарезервированным функциям и структурам данных MS-DOS — расширено для включения MS-DOS 6, Novell DOS и Windows 3.1 (2-е изд.). Reading, Массачусетс: Addison Wesley . ISBN 0-201-63287-X. ISBN 978-0-201-63287-3(xviii+856+vi страниц, 3,5-дюймовая дискета) Опечатки: [1][2]
  6. ^ Браун, Ральф Д. и др., ред. (2000-07-16). "Список прерываний Ральфа Брауна" (61-е изд.). INTER61 .
  7. ^ аб Пол, Матиас Р. (30 июля 1997 г.) [1 мая 1994 г.]. NWDOS-TIPs — советы и подсказки для Novell DOS 7, с просмотром недокументированных подробностей, ошибок и обходных путей. MPDOSTIP (на немецком языке) (3-е изд.). Архивировано из оригинала 10 сентября 2017 г. Проверено 6 августа 2014 г.(Примечание. NWDOSTIP.TXT — это комплексная работа по Novell DOS 7 и OpenDOS 7.01, включающая описание многих недокументированных функций и внутренних компонентов. Она является частью еще более обширной MPDOSTIP.ZIPколлекции автора, которая поддерживалась до 2001 года и распространялась на многих сайтах в то время. Приведенная ссылка указывает на более старую версию файла, преобразованную в HTML NWDOSTIP.TXT.) [3]
  8. ^ аб Пол, Матиас Р. (1997-06-07) [апрель 1994 г.]. «Глава 1.3.xi: Überlange Pfade». NWDOS7UN.TXT — Zusammenfassung der dokumentierten und undocumentierten Fähigkeiten von Novell DOS 7. MPDOSTIP (на немецком языке). Архивировано из оригинала 07.11.2016 . Проверено 7 ноября 2016 г.
  9. ^ ab Brothers, Hardin; Rawson, Tom ; Conn, Rex C .; Paul, Matthias R.; Dye, Charles E.; Georgiev, Luchezar I. (2002-02-27). Онлайн-справка по 4DOS 8.00 .
  10. ^ "Техническое примечание -- Использование DESCRIPT.ION". Честертаун, Мэриленд, США: JP Software Inc. 1989. Архивировано из оригинала 2016-03-18.(Примечание. Известные идентификаторы включают 0x23('#'), используемые различными утилитами, написанными Маттиасом Р. Полом для разделенных пробелами списков текстовых пар ключ=значение, содержащих свойства файла в виде расширенных атрибутов , таких как CP (кодовые страницы), PC (коды языков), CW (битовая ширина), XS (ширина страницы), YS (длина страницы), XO (смещение по оси x печати), YO (смещение по оси y печати), CR (авторское право), URL (исходная ссылка) и т. д., 0x25('%') используется программами, использующими CUI_LIB для хранения переменных псевдосреды , 0xEDзарезервировано для Digital Research / Novell / Caldera и 0xFDдля FreeDOS .)
  11. ^ Дэвис, Джереми. "FreeCom и 4DOS DESCRIPT.ION файлы" (техническая заметка FreeDOS). FreeDOS . Архивировано из оригинала 2016-11-11 . Получено 2016-11-11 .
  12. ^ Пол, Матиас Р. (1 мая 1997 г.) [1 марта 1995 г.]. «Подсказки по JPSofts 4DOS 5.5b/c, 5.51, 5.52a и NDOS». МПДОСТИП (на немецком языке). Архивировано из оригинала 4 ноября 2016 г. Проверено 8 мая 2015 г.(Примечание. Приведенная ссылка указывает на преобразованную в HTML версию файла 4DOS5TIP.TXT, которая является частью коллекции MPDOSTIP.ZIP.) [4]
  13. ^ Novell (11.02.1999). "TID1002030 Windows NT, длинные имена файлов в NetWare". Архивировано из оригинала 06.06.2011 . Получено 03.12.2007 .
  14. ^ 4690 OS Programming Guide Version 5.2 (PDF) . IBM . 2007-12-06. Документ IBM SC30-4137-01. Архивировано (PDF) из оригинала 2022-01-25 . Получено 2018-09-03 .

Внешние ссылки