chipper 0 12 декабря, 2013 Опубликовано 12 декабря, 2013 · Жалоба Всех приветствую! Учусь программировать, опыта мало совсем Пишу программку наподобие гипрертерминала виндоус или putty. Пишу в с++ builder проблема с выводом полученных данных в мемо, никак не догоню как это сделать подсоединяюсь к девайсам через UART, разные девайсы выводят инфу в разном формате данные принимаются в буфер и дальше оттуда их надо выводить в мемо формат данных от разных устройств разный, выводить надо в аски вместо ... идет какой-то текст проблема, как распознавать переводы строк ниже приведенные примеры, это вывод данных в хексе принтер 1 0D 0A 0D 0A ... 0D 0A 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... 0D 0A 0D ... принтер 2 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D ... 0D 0A ... 0D 0A ... 0D 0A ... 0D 0A 0D ... 0D 0A 0D ... спутниковый тюнер на линуксе 00 0D ... 00 ... 0D 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D 0A 0D ... 0A 0D ... 0A 0D ... 0A 0D с принтерами проблема, что нет конца строки у последних данных на девайсе на линуксе еще проблема, что он шлет 00 байтики, с ними то же что-то надо делать Для тестирования проги использовал строку вида ...\r\n...\r\n с эти проблем нет, все работает на реальных девайсах оказалось все не так. вот полностью пример, что приходит от принтера 2 0A 0D 5B 48 57 49 43 5D 0A 0D 31 50 4C 4C 0A 0D ..[HWIC]..1PLL.. 32 49 4F 43 0A 0D 33 53 44 52 41 4D 0A 0D 34 47 2IOC..3SDRAM..4G 50 49 4F 0A 0D 35 41 48 42 0A 0D 5B 45 4E 44 5D PIO..5AHB..[END] 5B 59 5D [Y] 0D 0A 44 65 63 6F 6D 70 72 65 73 73 69 6F 6E 20 ..Decompression 2A 2A 2A 2A 2A 2A 2A 2A 2A 2A 2A 0D 0A 2D 2D 3E ***********..--> 3E 3E 3E 20 47 4F 20 4B 65 72 6E 65 6C 0D 0A 6A >>> GO Kernel..j 75 6D 70 5F 45 78 65 63 43 6F 64 65 28 29 20 3A ump_ExecCode() : 20 75 6C 5F 61 64 64 72 20 2D 20 30 78 30 32 30 ul_addr - 0x020 30 38 30 30 30 0D 0A 0D 20 49 6E 69 74 69 61 6C 08000... Initial 69 7A 65 57 44 54 0D 0A 0D 5B 30 78 32 30 37 38 izeWDT...[0x2078 35 36 34 5D 564] вот ф-ция, которая выводит данные в мемо //--------------------------------------------------------------------------- void __fastcall TForm1::ProcessPortData( ) { if( !Port->Recv_Buff_Ex( 50 ) ) { Form1->PrintText( (char*)Port->rd_buff ); Port->ClearRecvData(); Form1->PrintText( Port->LastErrorStr ); } else { if( strstr( (char*)( Port->rd_buff + Port->CountRecv - 2 ), "\r\n" ) ) { Port->rd_buff[ Port->CountRecv - 2 ] = '\0'; Form1->PrintText( (char*)Port->rd_buff ); Port->ClearRecvData(); } } return; } //--------------------------------------------------------------------------- идея была вот такая так как мы не знаем, что нам придет в порт и что мы будем считывать, то я ориентировался на то, что при выводе аски, строки должны заканчиваться на перевод строки или окончание строки попало сколько то байт в внутренний буфер порта, проверяем есть ли перевод строки, если есть выводим данные, чистим буфер если нет, снова вызывается ф-ция читающая буфер ... на самом деле она вызывается постоянно в цикле в другом потоке и постепенно наполняет буфер затем происходит, проверка, и если есть перевод строки, то вывод если буфер переполняется, то выводится весь буфер и очищается в общем помогите, кто чем может, а то уже месяц туплю Спасибо! Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
smalcom 0 12 декабря, 2013 Опубликовано 12 декабря, 2013 · Жалоба чтото непонятно в чём проблема(( Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
chipper 0 12 декабря, 2013 Опубликовано 12 декабря, 2013 (изменено) · Жалоба есть буфер с постоянно пополняющимися данными приходящими из ком порта, его надо вывести в мемо т.е. визуально должен быть вот такой вывод [HWIC] 1PLL 2IOC 3SDRAM 4GPIO 5AHB [END][Y] Decompression*********** -->>>> GO Kernel jump_ExecCode() : ul_addr - 0x02008000 InitializeWDT [0x2078564] в общем надо написать терминал для связи с девайсами они же что-то отвечают, вот это что-то и надо выводить в мемо т.е. то же самое что делает и виндовый терминал Изменено 12 декабря, 2013 пользователем Lodyr Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
toweroff 1 12 декабря, 2013 Опубликовано 12 декабря, 2013 · Жалоба отмена, не так понял :) в чем проблема-то? парсить на предмет 0x0A, если оно - следующее состояние, ждем 0x0D. Если не оно - оба символа в мемо и опять ждем 0x0A. Если был 0x0D - начинаем новую строку в мемо и ждем 0x00 или как там если не 0 - выводим в строку мемо и опять ждем 0x0A там же можно всякие тайм-ауты ловить и их в логику обработки вкручивать (это к теме "нет перевода строки"). Нет передачи там 50-100мс - сами генерим перевод строки а вообще неплохо бы автоматы почитать... Мура, Мили.. сразу логика работы построится и все будет очень просто Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
chipper 0 12 декабря, 2013 Опубликовано 12 декабря, 2013 (изменено) · Жалоба парсить на предмет 0x0A, если оно - следующее состояние, ждем 0x0D. так вот как раз проблема с определением перевода строки чуть выше приведены ответы от трех разных девайсов и все по-разному переводят строки да вот даже в этом примере, который чуть выше, если обратите внимание, аппарат шлет три разных вида перевода строки 0A0D 0D0A 0D0A0D почему так? Оба примера с принтеров самсунг. а вообще неплохо бы автоматы почитать... Мура, Мили.. сразу логика работы построится и все будет очень просто спасибо, поищу Изменено 12 декабря, 2013 пользователем Lodyr Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
Палыч 10 13 декабря, 2013 Опубликовано 13 декабря, 2013 · Жалоба аппарат шлет три разных вида перевода строки 0A - LF - Line Feed 0D - CR - Carriage return Почему-то некоторые считают, что перевод строки - пара приведенных выше кодов. Для классических терминалов: Символ LF (код 0A) собственно и есть "перевод строки" - курсор остаётся в той же позиции, но на строке ниже. Символ CR (код 0D) оставляет курсор в той же строке, где он находился, но курсор передвигается на начало строки (в первую позицию строки). В своей программе сделайте реакцию на эти символы в соответствии с их назначением, и - будет Вам счастье :rolleyes: Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
toweroff 1 13 декабря, 2013 Опубликовано 13 декабря, 2013 · Жалоба Для классических терминалов: Символ LF (код 0A) собственно и есть "перевод строки" - курсор остаётся в той же позиции, но на строке ниже. Символ CR (код 0D) оставляет курсор в той же строке, где он находился, но курсор передвигается на начало строки (в первую позицию строки). у меня знакомый, старичок уже, до сих пор называет клавиши "Ввод" и "Enter" не иначе, как "Возврат каретки" :) Принтеру действительно нужно два кода - вернуть головку в начало и провернуть барабан Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
chipper 0 13 декабря, 2013 Опубликовано 13 декабря, 2013 (изменено) · Жалоба Спасибо, Вам! Действительно рассматривал эти символы как пару. Попробую переделать с учетом, что каждый символ отвечает за свое. Так же попробую пересмотреть таймауты. У меня они сейчас выставлены на максимуме. Порт читаю в синхронном режиме, а время чтения задается при вызове ф-ции Recv_Buff_Ex( timeout ). Спасибо! Изменено 13 декабря, 2013 пользователем Lodyr Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
Палыч 10 13 декабря, 2013 Опубликовано 13 декабря, 2013 · Жалоба он шлет 00 байтики, с ними то же что-то надо делать О назначении управляющих символов можно прочитать, например, в Викопедии. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
chipper 0 13 декабря, 2013 Опубликовано 13 декабря, 2013 · Жалоба Спасибо! у меня еще вопрос будет, по установке контроля потока: аппаратный, программный, нет. Пока чего-то то же не догоняю. Но это позже, с выводом разберусь-) Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться