![]() |
|
|
Регистрация | << Правила форума >> | 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 нужен был.
Некоторые программисты настолько ленивы, что сразу пишут рабочий код. Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты. |