![]() |
|
|
|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
|
|
#1
|
||||
|
||||
|
доброе время суток.
вот возник вопрос как перехватить консоль суть в том чтоб memo полностью стало консолью каторую я хочу перехватить и реализовать работу с файломи консоль это colinux запускающийся с параметром Код:
colinux-daemon.exe -t nt @server/server.conf fastboot nogui Скрин работы с файломи: http://s012.radikal.ru/i321/1107/5a/13387010e367.jpg =================================== ======================= Открытие архива .img нужно открыть файл из этого образа 123.img и отредактировать строки в нём чтоб они выводились в Edit1,Edit2,Edit3 и т.п место расположение файла мне изветно если это чтото изменит скрин консоли colinux при запуски http://s015.radikal.ru/i332/1107/7d/26ac1525ecf8.jpg и скрин файла http://s014.radikal.ru/i326/1107/9c/20c6905b07ca.jpg Если вам нетрудно поделитесь исходником или кодом=( За рание спосибо. |
|
#2
|
||||
|
||||
|
Лови модуль, буквально вчера писал. Точно знаю что работает на Delphi XE, про остальные версии 100% утверждать не берусь, но теоретически работать должно.
Код:
unit ConsoleAppRunner;
interface
uses
Classes;
procedure RunConsoleApplication(CmdLine,Params:AnsiString;OutStrings:TStrings);
implementation
uses
Windows,AnsiStrings;
procedure RunConsoleApplication(CmdLine,Params:AnsiString;OutStrings:TStrings);
var
securityattributes: TSecurityAttributes;
startupinfo: TStartupInfoA;
processinformation: TProcessInformation;
hPipeInputRead: THandle;
hPipeInputWrite: THandle;
hPipeOutputRead: THandle;
hPipeOutputWrite: THandle;
WaitResult:Cardinal;
buf: array [0..1023] of AnsiChar;
dummy: Cardinal;
begin
OutStrings.Append(#13#10);
securityattributes.nLength:=SizeOf(TSecurityAttributes);
securityattributes.lpSecurityDescriptor:=nil;
securityattributes.bInheritHandle:=True;
CreatePipe(hPipeInputRead, hPipeInputWrite, @securityattributes, 0);
CreatePipe(hPipeOutputRead, hPipeOutputWrite, @securityattributes, 0);
ZeroMemory(@startupinfo, SizeOf(TStartupInfo));
ZeroMemory(@processinformation, SizeOf(TProcessInformation));
startupinfo.cb:=SizeOf(TStartupInfo);
startupinfo.dwFlags:=STARTF_USESHOWWINDOW or STARTF_USESTDHANDLES;
startupinfo.wShowWindow:=SW_HIDE;
startupinfo.hStdInput:=hPipeInputRead;
startupinfo.hStdOutput:=hPipeOutputWrite;
startupinfo.hStdError:=hPipeOutputWrite;
OutStrings.BeginUpdate;
OutStrings.Append(CmdLine+' '+Params);
OutStrings.EndUpdate;
if CreateProcessA(nil, PAnsiChar(CmdLine+' '+Params), nil, nil, True, CREATE_NEW_CONSOLE,
nil, PAnsiChar(AnsiStrings.ExtractFileDir(CmdLine)), startupinfo, processinformation) then
begin
repeat
WaitResult:=WaitForSingleObject(processinformation.hProcess, 100);
if ReadFile(hPipeOutputRead, buf, Length(buf), dummy, nil) then
begin
OemToAnsiBuff(buf, buf, dummy);
OutStrings.BeginUpdate;
OutStrings.Text:=OutStrings.Text+Copy(buf, 1, dummy);
OutStrings.EndUpdate;
end;
until WaitResult<>WAIT_TIMEOUT;
CloseHandle(processinformation.hProcess);
end;
CloseHandle(hPipeInputWrite);
CloseHandle(hPipeInputRead);
CloseHandle(hPipeOutputWrite);
CloseHandle(hPipeOutputRead);
end;
end.CmdLine - exe-файл (указываем полный путь, далее этот путь будет использоваться как рабочий каталог) Params - параметры OutStrings - объект для вывода результатов (в самом простом варианте это Memo1.Lines) |
|
#3
|
||||
|
||||
|
Код:
procedure RunConsoleApplication(CmdLine,Params:AnsiString;OutStrings:TStrings);
var
securityattributes: TSecurityAttributes;
startupinfo: TStartupInfoA;//тут ругается и после этого на всё остальное
processinformation: TProcessInformation;
hPipeInputRead: THandle;
hPipeInputWrite: THandle;
hPipeOutputRead: THandle;
hPipeOutputWrite: THandle;
WaitResult:Cardinal;
buf: array [0..1023] of AnsiChar;
dummy: Cardinal;
begin
OutStrings.Append(#13#10);
securityattributes.nLength:=SizeOf(TSecurityAttributes);
securityattributes.lpSecurityDescriptor:=nil;
securityattributes.bInheritHandle:=True;
CreatePipe(hPipeInputRead, hPipeInputWrite, @securityattributes, 0);
CreatePipe(hPipeOutputRead, hPipeOutputWrite, @securityattributes, 0);
ZeroMemory(@startupinfo, SizeOf(TStartupInfo));
ZeroMemory(@processinformation, SizeOf(TProcessInformation));
startupinfo.cb:=SizeOf(TStartupInfo);
startupinfo.dwFlags:=STARTF_USESHOWWINDOW or STARTF_USESTDHANDLES;
startupinfo.wShowWindow:=SW_HIDE;
startupinfo.hStdInput:=hPipeInputRead;
startupinfo.hStdOutput:=hPipeOutputWrite;
startupinfo.hStdError:=hPipeOutputWrite;
OutStrings.BeginUpdate;
OutStrings.Append(CmdLine+' '+Params);
OutStrings.EndUpdate;
if CreateProcessA(nil, PAnsiChar(CmdLine+' '+Params), nil, nil, True, CREATE_NEW_CONSOLE,
nil, PAnsiChar(AnsiStrings.ExtractFileDir(CmdLine)), startupinfo, processinformation) then
begin
repeat
WaitResult:=WaitForSingleObject(processinformation.hProcess, 100);
if ReadFile(hPipeOutputRead, buf, Length(buf), dummy, nil) then
begin
OemToAnsiBuff(buf, buf, dummy);
OutStrings.BeginUpdate;
OutStrings.Text:=OutStrings.Text+Copy(buf, 1, dummy);
OutStrings.EndUpdate;
end;
until WaitResult<>WAIT_TIMEOUT;
CloseHandle(processinformation.hProcess);
end;
CloseHandle(hPipeInputWrite);
CloseHandle(hPipeInputRead);
CloseHandle(hPipeOutputWrite);
CloseHandle(hPipeOutputRead);
end;
end.вот=\ |
|
#4
|
||||
|
||||
|
Замени TStartupInfoA на TStartupInfo
|
|
#5
|
||||
|
||||
|
http://i027.radikal.ru/1107/78/80f1409ff0e2.jpg
вот чё выдаёт щяс |
|
#6
|
||||
|
||||
|
Убери AnsiStrings из Uses, он мне только для XE нужен был.
|