Модераторы: Partizan, gambit
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> как посмотреть что выводит на консоль dll 
:(
    Опции темы
kh93b
Дата 23.6.2010, 12:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 1.4.2008

Репутация: нет
Всего: нет



есть библиотека написанная на C, вызываю метод из нее через pinvoke, как посмотреть что пишет библиотека в stdout\stderr ?
код вызова:
Код

[DllImport("mydll.dll", EntryPoint = "#1")]
private static extern IntPtr callmydll(string ConfigPath);
 static void Main(string[] args)
        {
IntPtr OOPtr = callmydll(@"C:\conf.xml");
            
}


вот так библиотека пишет логи
Код

fprintf(stderr, " --  reading config file \"%s\"...\n", filename);




PM MAIL   Вверх
jonie
Дата 24.6.2010, 00:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 5613
Регистрация: 21.8.2005
Где: Владимир

Репутация: 22
Всего: 118



kh93b, ну если у вас консоль, тогда она пишет стандартно собственно на косоль.
Иначе в файл например так:
Код

    class Program
    {
        [DllImport("../Debug/CSharpSTDERR.dll")]
        private static extern int fnCSharpSTDERR();

        [DllImport("Kernel32.dll", SetLastError = true)]
        public static extern int SetStdHandle(int device, IntPtr handle);


        static void Redirect()
        {
            int status;
            IntPtr handle;
            var filestream = new FileStream("logfile.txt", FileMode.Create);
            var streamwriter = new StreamWriter(filestream);
            streamwriter.AutoFlush = true;
            Console.SetOut(streamwriter);
            Console.SetError(streamwriter);

            handle = filestream.Handle;
            status = SetStdHandle(-11, handle); // set stdout
            // Check status as needed
            status = SetStdHandle(-12, handle); // set stderr
            // Check status as needed
        }

        static void Main(string[] args)
        {
            Redirect();

            fnCSharpSTDERR();
        }
    }

(с) http://stackoverflow.com/questions/1579074...windows-service
почитайте ссылку(!)

насчет -11 и -12 -- где-то мы на C++ форуме тоже такое делали (поищи) и там выясняли эти магические числа как раз ...но на память не вспомню.

Это сообщение отредактировал(а) jonie - 24.6.2010, 00:33


--------------------
Что-то не поняли? -> Напейтесь до зеленых человечков... эта сверхцивилизация Вам поможет...
PM MAIL Jabber   Вверх
kh93b
Дата 24.6.2010, 12:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 6
Регистрация: 1.4.2008

Репутация: нет
Всего: нет



jonie
Цитата

kh93b, ну если у вас консоль, тогда она пишет стандартно собственно на косоль.



если консольный проект то да, пишет как надо, но у меня оконное приложение

Цитата

Иначе в файл например так:

попробовал пример, из C# весь вывод переводится, а вот то что DLL пишет не появляется (

попробовал сделать еще через

Код

[DllImport("kernel32.dll", EntryPoint = "AllocConsole", SetLastError = true,
    CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)]
        private static extern int AllocConsole();

консоль появляется, из C# вывод идет,а из DLL также глухо (

PM MAIL   Вверх
jonie
Дата 25.6.2010, 09:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 5613
Регистрация: 21.8.2005
Где: Владимир

Репутация: 22
Всего: 118



kh93b, дамс, оказывается прикольно достаточно. std::cerr перенаправляется.
Ну тогда никто не мешает сделать
Код

freopen( "file.txt", "w", stderr ); 

....ну или посмотреть внутрь std::cerr как там сделан operator<<


--------------------
Что-то не поняли? -> Напейтесь до зеленых человечков... эта сверхцивилизация Вам поможет...
PM MAIL Jabber   Вверх
Nickname
Дата 5.7.2010, 17:34 (ссылка)  | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 246
Регистрация: 24.10.2006
Где: Санкт-Петербург

Репутация: нет
Всего: 1



а если попробовать переименовать dll в exe?
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Прежде чем создать тему, посмотрите сюда:
mr.DUDA
THandle

Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов.
Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :)
Так же не забывайте отмечать свой вопрос решенным, если он таковым является :)


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, THandle.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Общие вопросы по .NET и C# | Следующая тема »


 




[ Время генерации скрипта: 0.0693 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.