Total Commander Forum Index Total Commander
Форум поддержки пользователей Total Commander
Сайты: Все о Total Commander | Totalcmd.net | Ghisler.com | RU.TCKB
 
 RulesRules   SearchSearch   FAQFAQ   MemberlistMemberlist   UsergroupsUsergroups   RegisterRegister 
 ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

Single Post  Topic: Иконка на тулбаре из "недоступного" файла 
Author Message
CaptainFlint



PostPosted: Wed Apr 18, 2012 15:26    Post subject: Reply with quote

Flasher
Остаётся. Confused
Вообще, занятно: если открыть диалог настройки панели инструментов, там значка нет ни в области набора кнопок, ни в поле "Значок". Но при нажатии OK на самой панели значок исправно отображается. ProcMon показывает, что Тотал сначала пытается открыть msconfig.exe из каталога SysWOW64, не находит файла, после чего открывает msconfig.exe из System32 и, судя по всему, считывает значок оттуда.

Добавлено спустя 1 час 58 минут:

Похоже, это особенность самой винды. Я помониторил, какие API-функции использует Тотал для загрузки значков: это LoadLibraryEx с флагом LOAD_LIBRARY_AS_DATAFILE. Так вот, оказывается, что если я в 32-битном приложении загружаю библиотеку из system32 с этим флагом, она подгружается нормально. Без этого
флага возвращает ошибку, что файл не найден.

То есть, получается, что редирект файловой системы в виндах построен сложнее, чем тупое перенаправление абсолютно всех запросов в другую папку. Перенаправляются только те запросы, которые потенциально приведут к ошибке (типа загрузки 64-битной библиотеки в память 32-битного процесса), а если из библиотеки вытаскиваются только ресурсы (которые от битности не зависят), то сначала проверяется каталог syswow64, а если вернулась ошибка, то выполняется попытка обработать тот же путь, но без редиректа.

Последнее, кстати, легко проверяется: если в каталоге SysWOW64 скопировать какой-нибудь mspaint.exe под именем msconfig.exe, удалить BR2-файл и перезапустить 32-битный Тотал, то у кнопки в панели инструментов окажется значок mspaint.
_________________
Почему же, ё-моё, ты нигде не пишешь "ё"?
View user's profile Send private message Visit poster's website


Powered by phpBB © 2001, 2005 phpBB Group