AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Projekte Unit für Verknüpfung von Dateierweiterungen
Thema durchsuchen
Ansicht
Themen-Optionen

Unit für Verknüpfung von Dateierweiterungen

Ein Thema von Codewalker · begonnen am 13. Apr 2010 · letzter Beitrag vom 11. Mai 2010
Antwort Antwort
Seite 2 von 3     12 3      
Benutzerbild von Codewalker
Codewalker
Registriert seit: 18. Nov 2005
Hallo zusammen.

Nachdem ich auch nach längerem Suchen keine wirklich brauchbare Lösung gefunden habe, eine Dateiendung in der Registry mit meinem Programm zu verknüpfen, habe ich kurzerhand eine eigene Klasse dafür gestrickt. Jede Methode enthält eine kurze Beschreibung, so dass es eigentlich selbsterklärend sein sollte. Ich werde aber noch eine kleine Demo nachliefern. Die Unit ist jetzt mit Compilerschaltern gespickt und sollte auch mit Delphi-Versionen ohne Generics funktionieren (noch ungetestet). Da außer dynamischen Arrays keine großen Spezialitäten verwendet werden, wäre es theoretisch bis Delphi 3 verwendbar.
Würde mich über Feedback jeder Art sehr freuen.

Noch geplante Features:
  • Verknüpfungen in XML-Dateien exportieren und später wiederherstellen können

Grüße
Codewalker
Angehängte Dateien
Dateityp: pas fileassoc_542.pas (12,8 KB, 36x aufgerufen)
 
Benutzerbild von uligerhardt
uligerhardt

 
Delphi 2007 Professional
 
#11
  Alt 13. Apr 2010, 21:35
Zitat von BUG:
Und letztlich bewirkt
Delphi-Quellcode:
if Assigned(FActions) then
    FActions.Free;
das gleich wie:FActions.Free;
Schon. Ebenso wie
Delphi-Quellcode:
if Assigned(FActions) and Assigned(FActions) or Assigned(FActions) then
    FActions.Free;
(ungetestet). Ich bevorzuge hier trotzdem den Einzeiler.
Uli Gerhardt
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

 
Delphi 2007 Professional
 
#12
  Alt 13. Apr 2010, 21:37
Zitat von himitsu:
Zitat von uligerhardt:
SetLength(FActions, Length(FActions)); bewirkt nichts.
Das würde ich so nicht direkt unterschreiben.
Vermutlich bewirkt es bei ihm nichts,
aber dieses wäre praktisch die Entsprechung von UniqueString für dynamische Arrays
und sorgt quasi dafür, daß es nur eine Referenz gibt und daß diese Variable als einzige Referenz für dieses Array existiert.
Also gut: Ich habe den Verdacht, SetLength(FActions, Length(FActions) + 1); wäre angemessener.
Uli Gerhardt
  Mit Zitat antworten Zitat
Benutzerbild von BUG
BUG
 
#13
  Alt 13. Apr 2010, 22:00
Zitat von uligerhardt:
Ich bevorzuge hier trotzdem den Einzeiler.
Ich auch, deshalb hab ich mich ja gewundert, das du die längere Form mit if vorgeschlagen hast, anstatt gleich nur Free
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

 
Delphi 2007 Professional
 
#14
  Alt 13. Apr 2010, 22:17
Zitat von BUG:
Zitat von uligerhardt:
Ich bevorzuge hier trotzdem den Einzeiler.
Ich auch, deshalb hab ich mich ja gewundert, das du die längere Form mit if vorgeschlagen hast, anstatt gleich nur Free
Mit meinem Doppel-if-Konstrukt wollte ich eigentlich den Einzeiler vorschlagen. Kam wohl nicht sooo deutlich rüber.
Uli Gerhardt
  Mit Zitat antworten Zitat
Benutzerbild von mleyen
mleyen

 
FreePascal / Lazarus
 
#15
  Alt 14. Apr 2010, 07:37
Zitat von unreal:
Echt tolle Unit für Dateiverknüpfungen!?!
Ich war am Anfang auch verwirrt. Sogar als ich den TE-Post gelesen hatte war mir noch unklar worum es sich handelt.
Nachdem ich mir dann den Quelltext runtergeladen und angeschaut habe, habe ich dann aber begriffen, dass es sich nicht um den "Umgang mit Dateiverknüpfungen" sondern um die "Verknüpfungen von Dateierweiterungen" handelte.
Danke für die Unit.
  Mit Zitat antworten Zitat
Benutzerbild von Codewalker
Codewalker

 
Delphi XE2 Professional
 
#16
  Alt 14. Apr 2010, 08:51
Erstmal danke für die vielen Postings. Teilweise habe ich es schon anpassen können. Im Detail (Download im ersten Posting):

Version 0.1.1:
[*] Unnötiges if-assigned im Destructor von TFileType entfernt
[-] In der Berechnung von ActionCount -1 entfernt
[-] Vergrößerung der Arraygröße war fehlerhaft

@mleyen: Guter Vorschlag, habe den Thread umbenannt

Zitat von himitsu:
Vermutlich bewirkt es bei ihm nichts,
aber dieses wäre praktisch die Entsprechung von UniqueString für dynamische Arrays
und sorgt quasi dafür, daß es nur eine Referenz gibt und daß diese Variable als einzige Referenz für dieses Array existiert.
Kannst du das noch etwas genauer erklären? Ich kann Dir da nicht 100%ig folgen.

@uligerhardt: Erbsenzählermodus ist schon okay, hab ja danach gefragt . Was deinen Vorschlag mit dem TStringPair angeht: Klingt sehr gut und werde ich vermutlich auch so umsetzen - alleine weil die Compiler-Ifs den Quelltextformatierer (JCF) aus dem Tritt bringen. Das schaffe ich aber vermutlich frühestens morgen.
Thomas
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

 
Delphi 2007 Professional
 
#17
  Alt 14. Apr 2010, 11:49
Zitat von Codewalker:
Zitat von himitsu:
Vermutlich bewirkt es bei ihm nichts,
aber dieses wäre praktisch die Entsprechung von UniqueString für dynamische Arrays
und sorgt quasi dafür, daß es nur eine Referenz gibt und daß diese Variable als einzige Referenz für dieses Array existiert.
Kannst du das noch etwas genauer erklären? Ich kann Dir da nicht 100%ig folgen.
Dynamische Array-Variablen sind nur Referenzen auf den echten Array-Speicherbereich. In folgendem Code (courtesy of http://www.hsg-kl.de/faecher/inf/mat...rray/index.php)
Delphi-Quellcode:
procedure Test;
var
  A, B: array of Integer;
begin
  SetLength(A, 1);
  A[0] := 1;
  B := A;
  B[0] := 2; // ***
end;
ist vor Zeile *** A[0] = 1, danach A[0] = 2, obwohl doch auf B[0] zugeweisen wurde. Das liegt daran, das die Zuweisung B := A dafür sorgt, dass B auf den gleichen Speicherbereich wie A zeigt. Das ändert, sich wenn du
Delphi-Quellcode:
B := A;
SetLength(B, Length(B)); // ###
oder einfacherB := Copy(A); schreibst. Die Variante mit ### meint himitsu.
Uli Gerhardt
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

 
Delphi 12 Athens
 
#18
  Alt 14. Apr 2010, 12:24
Zitat von Codewalker:
Kannst du das noch etwas genauer erklären? Ich kann Dir da nicht 100%ig folgen.
Delphi-Quellcode:
Var S: String;

S[123] := 'a';
Bei diesem Code macht Delphi intern
Delphi-Quellcode:
UniqueString(S);
S[123] := 'a';
daraus, somit ist sichergestellt, daß bei mehreren Referenzen nur der Stringinhalt der aktuellen "Variable" verändert wird.

Delphi-Quellcode:
Var S, S2: String;

S := '123';
S2 := S;
S[2] := 'X';

// S = '1X3'
// S2 = '123'
Bei dynamischen Arrays ist das leider anders , denn es gibt blöder Weise kein UniqueArray
und Delphi paßt auch nicht auf, daß hier nicht mehrere Referenzen überschrieben werden.
Delphi-Quellcode:
Var A, A2: Array of Integer;

SetLength(A, 3);
A[0] := 11;
A[1] := 22;
A[2] := 33;

A2 := A;

A[1] := 88;

// A = (11, 88, 33)
// A2 = (11, 88, 33)
Also muß man dieses unter Umständen selber einfügen:
Delphi-Quellcode:
Var A, A2: Array of Integer;

SetLength(A, 3);
A[0] := 11;
A[1] := 22;
A[2] := 33;

A2 := A;

SetLength(A, Length(A)); // oder eben A := Copy(A);
A[1] := 88; // aber bei RefCount=1 wäre SetLength effektiver
                          // und sonst gibt es keinen großen Unterschied

// A = (11, 88, 33)
// A2 = (11, 22, 33)
Normaler Weise fällt dieses Verhalten vielen nicht auf, da selbst bei mehreren referenzvariablen viele eigentlich nur ein Array benötigen ... wie z.B. bei dir.

Es sieht quasi so aus, als wenn ein Array keine Referenzzählung hätte
und ebenso, wie dein Ersatzobjekt (z.B. bei TFileTypeActions) wie ein "einfacher" Pointer reagiert.

Bei meinem Hier im Forum suchenTDynamicCharSet oder meinen BigMathTypen ist es aber so, daß jede Referenz ihre eigenen Daten besitzt
(selbst wenn sich mehrere Referenzen die Daten teilen, wenn der Inhalt gleich bleibt),
aber dennoch Änderungen nur in der eigenen Referenz vorgenommen werden dürfen.

hier wird ja nur X verändert:
Delphi-Quellcode:
Var X, X2: Set of AnsiChar;

X2 := X;
X := ['a'];
Wenn ich das Standardverhalten der dynamischen Arrays (mein Typ nutzt intern Soeines) nicht ändern würde, dann könnte hier quasi auch der Inhalt von X2 geändert werden.
Delphi-Quellcode:
Var X, X2: TDynamicCharSet;

X2 := X;
X := ['a'];
Darum sorge ich hier also manuell für eine Single-Referenz, wärend es in deinem Code nicht nötig ist.


PS:
Was würdest du hier erwarten?
Delphi-Quellcode:
Procedure Text(X: TIntegerDynArray);
// man beachte, daß hier kein VAR-Parameter vorliegt
Begin
  X[1] := 8888;
End;

Var A: TIntegerDynArray;

A := (11, 22, 33);
Test;
// viele würden wohl (11, 22, 33) erwarten
// aber in Wirklichkeit steckt (11, 8888, 33) in dem A
Ich würde das ja für einen Fehler in Delphi/Pascal erachten, aber auf mich hört ja keiner.
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

 
Delphi 2007 Professional
 
#19
  Alt 14. Apr 2010, 13:48
Zitat von himitsu:
Ich würde das ja für einen Fehler in Delphi/Pascal erachten, aber auf mich hört ja keiner.
ACK. Wer will das Referenz-Verhalten bei den Arrays schon so? Copy-on-write wie bei Strings wäre IMHO auch bei Arrays das nützlichere Verhalten. Von mangelnder Konsistenz zwischen Strings und Arrays ganz zu schweigen.
[OT]Und wenn wir schon beim Thema Konsistenz sind: Warum gibt's eigentlich kein Delete und Insert für Arrays? Sollte für jemanden, der Compiler magic zur Verfügung hat, leicht zu implementieren sein. Aber für den normalsterblichen Programmierer artet's in Arbeit oder Gehacke aus.[/OT]
Uli Gerhardt
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

 
Delphi 12 Athens
 
#20
  Alt 14. Apr 2010, 14:20
[ot]
Zitat von uligerhardt:
[OT]Und wenn wir schon beim Thema Konsistenz sind: Warum gibt's eigentlich kein Delete und Insert für Arrays? Sollte für jemanden, der Compiler magic zur Verfügung hat, leicht zu implementieren sein. Aber für den normalsterblichen Programmierer artet's in Arbeit oder Gehacke aus.[/OT]
Wenn man Record-Helper auch auf normale Typen (wie Integer oder Arrays) anwenden könnte, dann könnte man sich dieses teilweise selber einrichten.

Und mit Class-Operatoren für "Record"-Helper,
sowie Class-Operatoren für IN (if x IN y) würde , zusammen mit dem nächsten Punkt, den Rest machen.

Blöd ist auch, daß man keine Funktionen anderer Units überladen kann.
Wenn man eine Funktion für Include oder Insert erstellt, dann kann man ohne Namespace (System.Include) die System-Funktionen nicht mehr nutzen.

Sooo, genug OT
[/ot]
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 3     12 3      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:52 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz