Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > ОС и железо
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 25.04.2011, 13:49
nikcpp nikcpp вне форума
Прохожий
 
Регистрация: 13.04.2011
Сообщения: 22
Репутация: 10
Лампочка Создание log файла в сервисе

Помогите не могу понять когда пишу программу в VCL все нормально работает, а когда переписываю в сервис перестает создаваться файл
Вот код сервиса

Код:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, SvcMgr, Dialogs,
  ExtCtrls, ComCtrls, StdCtrls;

type
  TLurking_software = class(TService)
    Timer1: TTimer;
    procedure ServiceStart(Sender: TService; var Started: Boolean);
    procedure Timer1Timer(Sender: TObject);
  private
    { Private declarations }
  public
    function GetServiceController: TServiceController; override;
    { Public declarations }
  end;

  procedure AddToLog(s:string);
  function GetFileSize(FileName: string): integer;

var
  Service1: TLurking_software;
  f : boolean;


implementation

{$R *.DFM}
procedure ServiceController(CtrlCode: DWord); stdcall;
begin
  Service1.Controller(CtrlCode);
end;

function TLurking_software.GetServiceController: TServiceController;
begin
  Result := ServiceController;
end;

procedure TLurking_software.ServiceStart(Sender: TService;
  var Started: Boolean);
begin

  f:=true;

end;

procedure AddToLog(s:string);
var
fn:string;
F:TextFile;
begin

Fn:='D:\'+'log.txt';
if (GetFileSize(FN)div 1024)>=2 then
 begin

  assignFile(f,fn);
  RenameFile('D:\'+'log.txt',
   'D:\'+FormatDateTime('dd', Now)+ FormatDateTime('mm', Now)
   +FormatDateTime('yyyy', Now)+FormatDateTime('hh', Now)+FormatDateTime('nn', Now)+
   FormatDateTime('ss', Now));

 end;

  assignFile(f,fn);
  if FileExists(fn) then Append(f) else Rewrite(f);
  Writeln(f,s);
  Flush(f);
  Closefile(f);

  end;

function GetFileSize(FileName: string): integer;
var F: TMemoryStream;
begin
  try
    F:=TMemoryStream.Create;
    F.LoadFromFile(FileName);
    Result:=F.Size;
  finally
    F.Free;
  end;
end;

procedure TLurking_software.Timer1Timer(Sender: TObject);

begin
if f=true then
 begin
   AddToLog('test');
 end;

end;

end.
Ответить с цитированием
  #2  
Старый 25.04.2011, 14:01
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Для начала вдумчиво курить вот этот мануал
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #3  
Старый 25.04.2011, 14:28
nikcpp nikcpp вне форума
Прохожий
 
Регистрация: 13.04.2011
Сообщения: 22
Репутация: 10
По умолчанию

Цитата:
Сообщение от Aristarh Dark
Для начала вдумчиво курить вот этот мануал

Это я знаю
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 09:20.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter