Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ ОС и ПО _ Консоль

Автор: hardcase 27.04.2006 13:30

Перенаправляю ввод\вывод с консоли в безымянные программные каналы (anonymous pipes) - "святая троица" соответственно StdIn, StdOut, StdErr. И показываю всё это добро на текстарии.
Вот ситуация: cmd.exe возвращает свой вывод в OEM-кодировке с псевдографикой, но проблема не в этом, проблема в том, что некоторые программы, запущенные из под cmd-шника выводят в в нормальной кодировке 1251 (или какая там CP). Кроме того, cmd почему-то ДУБЛИРУЕТ input и выбрасывает его в output.
Кто может подсказать, как с этим броться?
Я так думаю, нужно ловить дебаг-событие запуска программы из cmd и в какой-то форме спрашивать пользователя, нужно ли показывать input юзверя в текстарии (или может прога дублирует input в output) а также какую CP использовать для отображения текста - ANSI или OEM.

Автор: Призрак 27.04.2006 13:51

Цитата(hardcase @ 27.04.2006 9:30) *

Перенаправляю ввод\вывод с консоли в безымянные программные каналы (anonymous pipes) - "святая троица" соответственно StdIn, StdOut, StdErr. И показываю всё это добро на текстарии.
Вот ситуация: cmd.exe возвращает свой вывод в OEM-кодировке с псевдографикой, но проблема не в этом, проблема в том, что некоторые программы, запущенные из под cmd-шника выводят в в нормальной кодировке 1251 (или какая там CP). Кроме того, cmd почему-то ДУБЛИРУЕТ input и выбрасывает его в output.
Кто может подсказать, как с этим броться?
Я так думаю, нужно ловить дебаг-событие запуска программы из cmd и в какой-то форме спрашивать пользователя, нужно ли показывать input юзверя в текстарии (или может прога дублирует input в output) а также какую CP использовать для отображения текста - ANSI или OEM.

Если честно ничего не понял...Подробнее обьясни..

Автор: hardcase 27.04.2006 19:38

Так, с дублированием input-a в cmd я разобрался - ключ /q позволяет отключать это безобразие (/q - echo off)

Объясняю подробнее (а чего конкренто не понятно?). Написал программу (вернее это только небольшой кусок большей) которая перенаправляет стандартный ввод/вывод у порождаемого дочернего процесса, коим является cmd.exe. Ввод/вывод отображаю не в текстовом режиме, а в графическом - на текстарии (конкретне - на SynEdit"е - он с OEM дружит и псевдографику отображает). Cmd возвращает результаты своих встроенных команд в OEM кодировке, поэтому я и ставлю OEM_CHARSET на контроле.

Проблемы начинаются когда в cmd запускаются консольные программы, которые возвращают текст (русский) в нормальной кодировке. Если в системном окне консоли они неким волшебным образом отображаются корректно, то у меня абракадарба. Например ipconfig /all возвращает у меня дату выдачи IPшника с названием месяца по русски. В консоли написано - апрель, а в моём контроле - чертечто.

Автор: Призрак 28.04.2006 3:25

Вот с этого и надо было начинать что ты написал прогу smile.gif...я так понял проблемы у тя с кодировкой..??попробуй в свойствах программы покопаться там много чего интересного есть...иметься ввиду правой клавишей на екзешник и свойства...smile.gif

Автор: GoodWind 28.04.2006 10:16

почему-то мне кажется, что теме место либо в Теории, либо в Задачах....

Автор: hardcase 28.04.2006 13:18

Да, проблемы - с кодировкой. Вернее не совсем с кодировкой.
Мне нужно как-то отличать программы, которые могут выбрасывать в стандартный поток ANSI-символы.
Это можно выяснить анализируя исполняемый файл (язык и т.д.) или придётся спрашивать пользователя?

P.S. Как поймать запуск приложения из cmd - я знаю.

Автор: GoodWind 28.04.2006 13:31

я вот что думаю... ведь есть же программы (текстовые редакторы), которые сами определяют кодировку....
может тебе стоит копать в эту сторону ?

Автор: GoodWind 28.04.2006 13:47

http://denisov.i2x2.ru/delphi/bibl/Algoritm/AutoSelect.htm
здесь есть краткое описание алгоритма...
наверное можно пропустить выходной поток через "фильтр", который будет определять кодировку, преобразовывать в нужную тебе и передавать его дальше.

вот нашел модуль, может пригодится. Прикрепленный файл  xlat.zip ( 1.85 килобайт ) Кол-во скачиваний: 414

Автор: hardcase 28.04.2006 19:50

Ооо. Пасиб за ценные ссылки.
Сейчас попробую прикрутить к программе.

>добавлено позже:

Впихнул xlat. Он в принципе работает, но и заменяет символы псевдографики.
Вообщем, я так решил - к чёрту кодировки. Прога и так справляется со всем, что нужно.