|
UNICODE в WinAVR |
|
|
|
Aug 1 2008, 14:14
|

фанат дивана
     
Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684

|
У меня на -finput-charset ругается более определённо: Код error: no iconv implementation, cannot convert from UTF-8 to CP866 То же самое и с CP1251. Тогда я сделал проще. 1. Написал строчку в main.c: Код int Name[] PROGMEM = L"Супер-пупер"; 2. Открыл main.c в блокноте, и сохранил его в формате UTF-8 (под именем main.txt, чтобы остальные строковые константы не испортить). 3. Открыл main.txt в обычном ascii-редакторе (у меня это редактор FAR-а) и скопировал получившуюся строчку (она выглядит примерно так): Код int Name[] PROGMEM = L"РЎС_РїРчС_-РїС_РїРчС_"; в мой main.c. И телемаркет ©
--------------------
Если бы я знал, что такое электричество...
|
|
|
|
|
Aug 1 2008, 19:45
|
Знающий
   
Группа: Свой
Сообщений: 601
Регистрация: 22-09-05
Из: Kharkov
Пользователь №: 8 847

|
Цитата(777777 @ Jul 31 2008, 15:55)  Ведь кто-то из здесь присутствующих наверняка делал устройства, работающие через USB, неужени вы набивали имя шестнадцатеричными числами? Код #define UNICODE(x) (x), 0x00
const struct USB_STRING_DESCRIPTOR usb_mfg_desc = { .bLength = 2 + 17 * 2, .bDescriptorType = USB_DESC_STRING, .bString = { UNICODE('D'), UNICODE('A'), UNICODE('C'), UNICODE(' '), UNICODE('I'), UNICODE('n'), UNICODE('t'), UNICODE('e'), UNICODE('r'), UNICODE('n'), UNICODE('a'), UNICODE('t'), UNICODE('i'), UNICODE('o'), UNICODE('n'), UNICODE('a'), UNICODE('l') } }; Думаю модифицировать макрос для нужного языка неслжоно. PS: Желание использовать какой-либо иной язык, кроме английского, в дескрипторах было напрочь отбито, когда устройство через 2 года производства вставили в ПК с Milenium (помните такую версию винды?) и ее разнесло в "дребезги-пополам" ((С) Жванецкий). Пришлось отзывать 100000 устройств и перешивать дескрипторы. Возможно в XP или Vista дело улучшилось, но предпочитаю не рисковать. Цитата(AHTOXA @ Aug 1 2008, 21:27)  2. Открыл main.c в блокноте, и сохранил его в формате UTF-8 А разве UTF-8 катит для дескриптора? Разве там не UTF-16? Цитата Мне категорически не надо, чтобы мои исходники были в UTF-8. Мои исходники всегда в UTF-8. И чем это мешае компилятору? Он соответствует ASCII относительно собственно кода.
--------------------
- А мораль отсюда такова: всякому овощу свое время. Или, хочешь, я это сформулирую попроще: никогда не думай, что ты иная, чем могла бы быть иначе, чем будучи иной в тех случаях, когда иначе нельзя не быть. © Lewis Carroll. Alice's adventures in wonderland.
|
|
|
|
|
Aug 1 2008, 21:40
|

фанат дивана
     
Группа: Свой
Сообщений: 3 387
Регистрация: 9-08-07
Из: Уфа
Пользователь №: 29 684

|
Цитата(amw @ Aug 2 2008, 01:45)  А разве UTF-8 катит для дескриптора? Разве там не UTF-16? Компилятору нужна была исходная строка в UTF-8. А он её преобразовал в юникод. (я в bin-файле посмотрел) Цитата(amw @ Aug 2 2008, 01:45)  Мои исходники всегда в UTF-8. И чем это мешае компилятору? Он соответствует ASCII относительно собственно кода. А русские строчки? Ну, строковые константы? А таблицы перекодировки для вывода на ЖКИ? А шрифты? Да ну их, эти геморрои с преобразованием, лучше уж я буду точно знать, что у меня и где
--------------------
Если бы я знал, что такое электричество...
|
|
|
|
|
Aug 4 2008, 09:42
|

Профессионал
    
Группа: Участник
Сообщений: 1 091
Регистрация: 25-07-07
Из: Саратов
Пользователь №: 29 357

|
Цитата(AHTOXA @ Aug 1 2008, 18:14)  1. Написал строчку в main.c: Код int Name[] PROGMEM = L"Супер-пупер"; 2. Открыл main.c в блокноте, и сохранил его в формате UTF-8 (под именем main.txt, чтобы остальные строковые константы не испортить). 3. Открыл main.txt в обычном ascii-редакторе (у меня это редактор FAR-а) и скопировал получившуюся строчку в мой main.c. В общем, я сделал примерно так же за следующими исключениями: 1. создал файл с единственной строкой int Name[] PROGMEM = L"имя"; и #include'ил ее в нужном месте в программу. 2. файл создавал редактором Visal Studio, так как блокнот создает utf-8 с сигнатурой в начале файла, а компилятор на эти символы ругается; у Visal Studio больше возможностей редактирования и им можно создать файл в utf-8 без сигнатуры, даже когда открываешь этот файл повторно, он догадывается о его кодировке (несмотря на отсутствие сигнатуры) и предлагает открыть именно как utf-8 Цитата(amw @ Aug 1 2008, 23:45)  Код #define UNICODE(x) (x), 0x00 Думаю модифицировать макрос для нужного языка неслжоно. А я думаю что сложновато. Цитата(amw @ Aug 1 2008, 23:45)  PS: Желание использовать какой-либо иной язык, кроме английского, в дескрипторах было напрочь отбито, когда устройство через 2 года производства вставили в ПК с Milenium (помните такую версию винды?) Я знаю людей, которые до сих пор пишут комментари по-русски латинскими буквами на том основании, что когда они работали в ДОСе (!) то там было много кодировок и их комментарий мог где-то не прочитаться. Вы чем-то на него похожи: миллениум всеми успешно забыт, а вы все боитесь русских букв. Хотя юникод придуман как раз для того, чтобы он был единственной кодировкой. Хорошо известно, что юникод поддерживают только NT-based системы; вместо того, чтобы отзывать 1(0...) устройств, следовало бы в инстукции перечислить ОС с которыми ваше устройство работает. Цитата(amw @ Aug 1 2008, 23:45)  Мои исходники всегда в UTF-8. И чем это мешае компилятору? Он соответствует ASCII относительно собственно кода. Тем, что его не понимает редактор AVR-студии. Впрочем, если в нем нет русских букв, то несколько странно утверждать, что он в utf-8
Сообщение отредактировал 777777 - Aug 4 2008, 09:44
|
|
|
|
|
Aug 4 2008, 18:24
|
Знающий
   
Группа: Свой
Сообщений: 601
Регистрация: 22-09-05
Из: Kharkov
Пользователь №: 8 847

|
Цитата(AHTOXA @ Aug 2 2008, 00:40)  Компилятору нужна была исходная строка в UTF-8. А он её преобразовал в юникод. (я в bin-файле посмотрел) А русские строчки? Ну, строковые константы? А таблицы перекодировки для вывода на ЖКИ? А шрифты? Да ну их, эти геморрои с преобразованием, лучше уж я буду точно знать, что у меня и где  А, понял. Я пишу коментарии на английсом, а строчки всегда в файлах перевода. Ну в общем в отдельных файлах находятся все сообщения для пользователя. В общем используем подход по аналогии QT Linguist. И переводчикам легче. Цитата(777777 @ Aug 4 2008, 12:42)  Я знаю людей, которые до сих пор пишут комментари по-русски латинскими буквами на том основании, что когда они работали в ДОСе (!) то там было много кодировок и их комментарий мог где-то не прочитаться. Вы чем-то на него похожи: миллениум всеми успешно забыт, а вы все боитесь русских букв. Хотя юникод придуман как раз для того, чтобы он был единственной кодировкой. Можно и меня причислить к ним, хотя и по другой причине. Иногда исходники пытаются скомпилить на виндовс машине, и тогда возникают проблемы с не-латиницей. Цитата Хорошо известно, что юникод поддерживают только NT-based системы; вместо того, чтобы отзывать 1(0...) устройств, следовало бы в инстукции перечислить ОС с которыми ваше устройство работает. Такого подхода я непонимаю. Мои устройства конечно не рботают в ДОС, Вин 3.11 им подобными, но Linux, FreeBSD, Solaris, MacOS 9+, Win98 - NT4 2000 - Vista - обязательны. Цитата Тем, что его не понимает редактор AVR-студии. Впрочем, если в нем нет русских букв, то несколько странно утверждать, что он в utf-8  Иногда все же бывают строки на не-английском языке прямо в коде. Про avr-gcc ничего не могу сказать, но по крайней мере i686, x86_64, arm, и под некоторые специфические архитектуры проблем это не вызывает.
--------------------
- А мораль отсюда такова: всякому овощу свое время. Или, хочешь, я это сформулирую попроще: никогда не думай, что ты иная, чем могла бы быть иначе, чем будучи иной в тех случаях, когда иначе нельзя не быть. © Lewis Carroll. Alice's adventures in wonderland.
|
|
|
|
|
Aug 9 2008, 22:56
|
Участник

Группа: Свой
Сообщений: 37
Регистрация: 13-05-07
Из: Minsk, Belarus
Пользователь №: 27 694

|
Цитата(777777 @ Aug 5 2008, 08:30)  Запусти какую-нибудь юникодную программу под Win98 и прочитай что она тебе напишет. 4.2 Если *некоторые* недопрограммы под недоОС, написанные недопрограммистами, не умеют пользоваться тем, что есть, это их индивидуальные интимные проблемы. Кроме того, никто не отменял независящие от вендора реализации работы с Unicode. Вещи, которые, насколько я знаю, *невозможно* сделать в 9х, — это юникодные заголовки окон, юникодный ввод с клавиатуры (без использования "кодовых страниц"), юникод в терминале. Всё остальное можно либо реализовать самому, используя имеющееся API, либо положиться на реализацию от кого-либо ещё, а таких немало: MSLU (от вендора), GLib и компания, Qt. -- WBR, Andrew
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|