![]() |
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
Ich schreibe das self. auch mit weil es einfach wirklich oft viel übersichtlicher ist.
Klar kann man das auch weglassen, funktioniert auch ohne. Ich würde aber auch immer empfehlen es mit hinzuschreiben! |
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
@#8
Ok, aber VID:=VID hiesse es ja nicht, sondern FVID:=VID - aber grundsätzlich verstanden! Danke :hi: |
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
In SetFTPDirectory wird FFTPDirectory nicht verändert.
Hier wäre dann vieleicht auch ein GetFTPDirectory angebracht. OT: Self macht den ganzen Quelltext nur unübersichtlich. Meine persönlichen Style-Regeln: - Parameter heißen bei sämtlichen Set-Methoden "AValue" oder "AIndex". - Wenn Parameter wie Properties heißen müssen, dann bekommen diese einen einheitlichen Präfix ("A"). Ein "constructur" sollte keine lange Parameterliste haben, daß ist unübersichtlich. Dann besser die Properties nach dem Erzeugen einzeln zuweisen. Entsprechende Methoden zum Lesen und Schreiben der Konfiguration zu implementieren ist auch eine gute Idee. |
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
Zitat:
also die Klasse sieht im Moment so aus:
Delphi-Quellcode:
Die Idee mit AValue oder AIndex zur Übergabe ist auch ganz gut, denke aber nicht, dass es sinnvoll ist sie immer so zu nennen.
unit Livetrack;
interface uses IdFTP, IdHTTP, Classes, DateUtils, SysUtils; type TFTP = class(TIDFTP) end; type THTTP = class(TIDHTTP) end; type TLivetrack = class(TObject) private {private Vars} FHTTP : THTTP; FFTP : TFTP; FCacheDirectory : string; FFTPHost : String; FFTPDirectory : String; FFTPLoginName : String; FFTPPassword : String; FHTTPUrl : String; FFileName : String; FVID : String; {Set Procedures} procedure SetFTPHost(Host : String); procedure SetFTPDirectory(Directory : String); procedure SetFTPLoginName(LoginName : String); procedure SetFTPPassword(Password : String); procedure SetVID(VID : String); {get Functions} function GetFTPHost : String; function GetFTPLoginName : String; function GetFTPPassword : String; public {Functions} constructor create(const CacheDirectory : String; const FTPHost : string; const FTPDirectory : string; const FTPLoginName : string; const FTPPassword : string; const HTTPUrl : String; const FileName : String; const VID : string); overload; constructor create(const CacheDirectory : String; const FTPHost : string; const FTPDirectory : string; const FTPLoginName : string; const FTPPassword : string; const HTTPUrl : String; const FileName : String); overload; destructor destroy ; override; {Normal Functions} function download(TimeOut : Integer) : boolean; function upload(TimeOut : Integer) : boolean; function refresh (const RealName : String; const ATC_Position : String; const Tool : String): boolean; {properties} property CacheDirectory : String read FCacheDirectory write FCacheDirectory; property FTPHost : String read GetFTPHost write SetFTPHost; property FTPDirectory : String read FFTPDirectory write SetFTPDirectory; property FTPLoginName : String read GetFTPLoginName write SetFTPLoginName; property FTPPassword : String read GetFTPPassword write SetFTPPassword; property HTTPUrl : String read FHTTPUrl write FHTTPUrl; property FileName : String read FFileName write FFileName; property VID : String read FVID write SetVID; end; implementation {Set Procedures} procedure TLivetrack.SetFTPHost(Host : String); begin self.FFTP.Host := Host; end; procedure TLivetrack.SetFTPDirectory(Directory : String); begin if Directory = '' then exit; if self.FFTP.Connected then self.FFTP.ChangeDir(Directory); end; procedure TLivetrack.SetFTPLoginName(LoginName : String); begin if self.FFTP.Connected then exit; self.FFTP.Username := LoginName; end; procedure TLivetrack.SetFTPPassword(Password : String); begin if self.FFTP.Connected then exit; self.FFTP.Password := Password; end; procedure TLivetrack.SetVID(VID : String); begin self.FVID := VID; end; // Ende Set Procedures //////////////////////////////////////////////////////////////////////////////// {Get Functions} function TLivetrack.GetFTPHost : String; begin result := self.FFTP.Host; end; function TLivetrack.GetFTPLoginName : String; begin result := self.FFTP.Username; end; function TLivetrack.GetFTPPassword : String; begin result := self.FFTP.Password; end; // Ende Get Functions //////////////////////////////////////////////////////////////////////////////// {Normal Functions} function createTimeStamp : string; begin result := inttostr(DateTimeToUnix(now)); end; // *.csv - Aufbau {VID : TimeStamp : RealName : ATC Position : Tool} function TLivetrack.refresh(const RealName : String; const ATC_Position : String; const Tool : String) : boolean; function datainlist(const TList : TStringlist) : integer; var i : Integer; begin result := -1; if TList.Count = 0 then exit; for i := 0 to TList.Count - 1 do if self.FVID = copy(TList.Strings[i],1,pos(':',TList.strings[i]) - 1) then begin result := i; break; end; end; var TList : Tstringlist; Index : integer; FileName : string; TimeStamp : string; begin result := false; TList := TStringlist.Create; FileName := self.FCacheDirectory + '\' + self.FFileName; try if Fileexists(FileName) then Tlist.LoadFromFile(FileName); Index := datainList(TList); TimeStamp := createTimeStamp; if Index = -1 then TList.add(self.FVID + ':' + TimeStamp + ':' + RealName + ':' + ATC_Position + ':' + Tool) else TList.strings[Index] := self.FVID + ':' + TimeStamp + ':' + RealName + ':' + ATC_Position + ':' + Tool; finally result := true; end; TList.SaveToFile(FileName); TList.Free; end; function TLivetrack.upload(TimeOut : Integer) : boolean; begin result := false; self.FFTP.Port := 21; self.FFTP.Connect(true,TimeOut); if self.FFTPDirectory <> '' then self.FFTP.ChangeDir(self.FFTPDirectory); try self.FFTP.Put(self.FCacheDirectory + '\' + self.FFileName , self.FFileName , false); finally result := true; end; self.FFTP.Disconnect; end; function TLivetrack.download(TimeOut : Integer) : boolean; var FileStream : TFileStream; begin result := false; FileStream := TFileStream.create(self.FCacheDirectory + '\' + self.FFileName,fmcreate); self.FHTTP.Connect(TimeOut); try self.FHTTP.Get(self.FHTTPUrl + '/' + self.FFileName , FileStream); finally result := true; end; FileStream.free; self.FHTTP.Disconnect; end; // Ende Normal Functions //////////////////////////////////////////////////////////////////////////////// {Constructor} constructor TLivetrack.create(const CacheDirectory : String; const FTPHost : string; const FTPDirectory : string; const FTPLoginName : string; const FTPPassword : string; const HTTPUrl : String; const FileName : String); begin inherited create; self.FFTP := TFTP.Create(nil); self.FHTTP := THTTP.Create(nil); // Setzen der Parameter für HTTP und FTP self.CacheDirectory := CacheDirectory; self.FTPHost := FTPHost; self.FTPDirectory := FTPDirectory; self.FTPLoginName := FTPLoginName; self.FTPPassword := FTPPassword; self.HTTPUrl := HTTPUrl; self.FileName := FileName; self.VID := 'none'; end; constructor TLivetrack.create(const CacheDirectory : String; const FTPHost : string; const FTPDirectory : string; const FTPLoginName : string; const FTPPassword : string; const HTTPUrl : String; const FileName : String; const VID : string); begin inherited create; self.FFTP := TFTP.Create(nil); self.FHTTP := THTTP.Create(nil); // Setzen der Parameter für HTTP und FTP self.CacheDirectory := CacheDirectory; self.FTPHost := FTPHost; self.FTPDirectory := FTPDirectory; self.FTPLoginName := FTPLoginName; self.FTPPassword := FTPPassword; self.HTTPUrl := HTTPUrl; self.FileName := FileName; self.VID := VID; end; // Ende Constructor //////////////////////////////////////////////////////////////////////////////// {Destructor} destructor TLivetrack.destroy; begin self.FFTP.Free; self.FHTTP.free; inherited destroy; end; // Ende Destructor //////////////////////////////////////////////////////////////////////////////// end. Mit der Namensgebung bei den Übergabeparametern bezwecke ich, dass ich auch in ein paar Monaten noch weiß was ich übergeben soll. Da wäre AValue denke ich net so angebracht... Was die Übergabe beim Erzeugen betrifft, bin ich einfach zu Faul alles danach aufzurufen, zumal ich beim erzeugen sowieso die ganzen parameter kenne und ich diese in der Regel auch nicht mehr verändere. |
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
Zitat:
Wenn du dir mal zB von JEDI anschaust, wie dort gearbeitet wird, kannst du auch deine Quelltexte langzeitlich und für andere verständlich aufbereiten. |
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
@quendolineDD: Das wird zwar jetzt OT aber ich kann nicht anders. In unserem Styleguide ist zum Beispiel erwähnt das Quelltext welcher Kommentiert werden muss schlechter Quelltext ist. Und genau der Meinung bin ich auch. Quelltext sollte so geschrieben werden das er ohne Kommentaare verständlich ist.
|
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
Danke für den Tip Lars, werd ich mir mal ansehen und ggf. auch verbesserungen vornehmen!
|
Re: Stack Überlauf, beim eruezgen der eigenen Klasse! Wieso?
und warum 2x den Constructor
Delphi-Quellcode:
sollte auch gehen.
constructor TLivetrack.create(const CacheDirectory : String; const FTPHost : string; const FTPDirectory : string; const FTPLoginName : string; const FTPPassword : string; const HTTPUrl : String; const FileName : String; const VID : string = 'none');
[edit=mkinzler]Delphi-Tag eingefügt Mfg, mkinzler[/edit] |
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:46 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz