CaptainFlint

|
Posted: Wed Apr 18, 2012 15:26 Post subject: |
|
|
Flasher
Остаётся.
Вообще, занятно: если открыть диалог настройки панели инструментов, там значка нет ни в области набора кнопок, ни в поле "Значок". Но при нажатии 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. _________________ Почему же, ё-моё, ты нигде не пишешь "ё"? |
|