AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

Bug in QuickLib

Ein Thema von PeterPanino · begonnen am 24. Dez 2020 · letzter Beitrag vom 30. Dez 2020
Antwort Antwort
Seite 1 von 2  1 2   
PeterPanino

Registriert seit: 4. Sep 2004
1.472 Beiträge
 
Delphi 10.4 Sydney
 
#1

Bug in QuickLib

  Alt 24. Dez 2020, 17:53
QuickLib ist eine umfangreiche MultiPurpose-Library, die in der aktuellen Version 2.1 mit GetIt heruntergeladen werden kann.

Leider hat die Unit Quick.Commons einen Bug:

Code:
//checks if need include signs
if pfIncludeNumbers in Complexity then
// QuickLib 2.1
Das bedeutet, dass beim Aufruf von
Code:
RandomPassword(10, [pfIncludeSigns]);
keine Sonderzeichen eingefügt werden!

Sowie beim Aufruf von
Code:
RandomPassword(10, [pfIncludeNumbers]);
SOWOHL Sonderzeichen als auch Ziffern eingefügt werden!

Hat jemand noch andere Bugs in QuickLib bemerkt?

Hier ist ein kleines Projekt, mit dem der Bug reproduziert werden kann:

QuickTest.zip

Und hier ist der Bug-Fix:

bugfix.png
Geändert von PeterPanino, damit der Platz auf dem Bildschirm nicht so leer aussieht.

Geändert von PeterPanino (25. Dez 2020 um 09:52 Uhr)
  Mit Zitat antworten Zitat
PeterPanino

Registriert seit: 4. Sep 2004
1.472 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: Bug in QuickLib

  Alt 24. Dez 2020, 20:53
Weiterer Bug gefunden:

Code:
Quick.Process.GetProcessList
erzeugt ein Memory-Leak. Es scheint keine Möglichkeit zu geben, das Gedächtnis-Loch zu vermeiden:

Code:
procedure TForm1.tsProcessListsShow(Sender: TObject);
var
  sl: TStringList;
begin
  sl := TStringList.Create;
  try
    sl.Sorted := True;
    sl.Duplicates := dupIgnore;
    sl.AddStrings(Quick.Process.GetProcessList); // bug: Creates memory-leak
    //CodeSite.Send('TForm1.tsProcessListsShow: sl', sl);
    lstProcesses.Items.Assign(sl);
  finally
    sl.Free;
  end;
end;
Dies scheint ein konzeptioneller Fehler zu sein: Quick.Process.GetProcessList gibt ein Ergebnis vom Typ TStringList zurück. Aber wie soll man den Speicher dieser StringList wieder freigeben? Besser wäre es, der Funktion Quick.Process.GetProcessList eine existierende StringList als var-Parameter zu übergeben, die man dann nachher selbst freigeben kann, z.B.:

Code:
Quick.Process.GetProcessList(sl);
Geändert von PeterPanino, damit der Platz auf dem Bildschirm nicht so leer aussieht.

Geändert von PeterPanino (25. Dez 2020 um 09:38 Uhr)
  Mit Zitat antworten Zitat
Andreas13

Registriert seit: 14. Okt 2006
Ort: Nürnberg
721 Beiträge
 
Delphi XE5 Professional
 
#3

AW: Bug in QuickLib

  Alt 25. Dez 2020, 10:06
Lieder läßt sich die Bibliothek QuickLib mit Delphi XE5 nicht kompilieren, weil sie neuere Sprachelemente wie Inline-Deklarationen etc. verwendet.
Euch allen schöne Weihnachten & gute Gesundheit!
Gruß, Andreas
Grüße, Andreas
Wenn man seinem Nächsten einen steilen Berg hinaufhilft, kommt man selbst dem Gipfel näher. (John C. Cornelius)
  Mit Zitat antworten Zitat
PeterPanino

Registriert seit: 4. Sep 2004
1.472 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: Bug in QuickLib

  Alt 25. Dez 2020, 18:22
Euch allen schöne Weihnachten & gute Gesundheit!
Gruß, Andreas
Alles Gute!
Geändert von PeterPanino, damit der Platz auf dem Bildschirm nicht so leer aussieht.
  Mit Zitat antworten Zitat
generic

Registriert seit: 24. Mär 2004
Ort: bei Hannover
2.416 Beiträge
 
Delphi XE5 Professional
 
#5

AW: Bug in QuickLib

  Alt 30. Dez 2020, 12:41
Lieder läßt sich die Bibliothek QuickLib mit Delphi XE5 nicht kompilieren, weil sie neuere Sprachelemente wie Inline-Deklarationen etc. verwendet.
Das lässt sich aber mit wenigen Handgriffen beheben.
Ich wollte den Logger mal probieren und da war ich nach 5 Minuten mit durch, dass es für mein XE5 kompiliert.

Ich finde nur Schade, dass die Macher das nicht berücksichtigen und nur die neuen Delphi's unterstützen.
Coding BOTT - Video Tutorials rund um das Programmieren - https://www.youtube.com/@codingbott
  Mit Zitat antworten Zitat
Andreas13

Registriert seit: 14. Okt 2006
Ort: Nürnberg
721 Beiträge
 
Delphi XE5 Professional
 
#6

AW: Bug in QuickLib

  Alt 30. Dez 2020, 16:47
Ja, das ist wirklich schade, denn die älteren Delphi-Versionen bleiben dadurch ausgesperrt. Andererseits muß man auch nicht alle neuen Feautres unbedingt benutzen, denn nicht alles ist ein echter Fortschritt. Gerade die in QuickLib verwendeten Inline-Deklarationen tragen nicht gerade zur Übersichtlichkeit bei, und erinnern eher an alte Basic-Manieren, wo Variablen undeklariert (oder durch Tippfehler) aus dem Nichts auftauchen durften. Gerade die prägnanteste Eigenschaft von Pascal – seine Klarheit und Diszipliniertheit – leidet darunter. Schade, in doppelter Hinsicht…

Das lässt sich aber mit wenigen Handgriffen beheben.
Ich wollte den Logger mal probieren und da war ich nach 5 Minuten mit durch, dass es für mein XE5 kompiliert.
Deine Mühe in Ehren, aber Deine ganze Arbeit wird beim nächsten Update zunichte gemacht. Und dieses ist gerade wegen der hier aufgezählten Bugs bestimmt demnächst fällig.
Vielleicht "verirrt sich" der Entwickler von in QuickLib auch mal nach Delphi-Praxis-Land und liest unsere Anregungen.

Gruß, Andreas
PS:
Euch allen einen guten Rutsch in ein gesundes, glückliches und hoffentlich besseres Neues Jahr 2021!
Grüße, Andreas
Wenn man seinem Nächsten einen steilen Berg hinaufhilft, kommt man selbst dem Gipfel näher. (John C. Cornelius)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.874 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Bug in QuickLib

  Alt 30. Dez 2020, 16:49
Einfach Repository klonen und Änderungen pushen.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.340 Beiträge
 
Delphi 12 Athens
 
#8

AW: Bug in QuickLib

  Alt 25. Dez 2020, 11:47
Aber wie soll man den Speicher dieser StringList wieder freigeben?
Indem man Free benutzt?

Delphi-Quellcode:
procedure TForm1.tsProcessListsShow(Sender: TObject);
var
  sl: TStringList;
begin
  sl := Quick.Process.GetProcessList;
  try
    sl.Sort;
    //CodeSite.Send('TForm1.tsProcessListsShow: sl', sl);
    lstProcesses.Items.Assign(sl);
  finally
    sl.Free;
  end;
end;
Dies scheint ein konzeptioneller Fehler zu sein
Aber wenn eine Funktion etwas "erstellt" und der Aufrufer es wieder freigeben muß, dann würde ich soeine Funktion eher "Create" nennen, anstatt "Get",
oder mir einen anderen Typen als Result raussuchen, bzw. wie beim Assign/AddStrings die StringList nicht erstellen, sondern nur befüllen.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (25. Dez 2020 um 11:51 Uhr)
  Mit Zitat antworten Zitat
PeterPanino

Registriert seit: 4. Sep 2004
1.472 Beiträge
 
Delphi 10.4 Sydney
 
#9

AW: Bug in QuickLib

  Alt 25. Dez 2020, 18:46
Indem man Free benutzt?

Delphi-Quellcode:
procedure TForm1.tsProcessListsShow(Sender: TObject);
var
  sl: TStringList;
begin
  sl := Quick.Process.GetProcessList;
  try
    sl.Sort;
    //CodeSite.Send('TForm1.tsProcessListsShow: sl', sl);
    lstProcesses.Items.Assign(sl);
  finally
    sl.Free;
  end;
end;
Leider kann man bei dieser Konstruktion nicht die Duplikate entfernen, so wie ich es in meinem Code gemacht habe. Dazu müsste man wahrscheinlich erst wieder mehrere StringList-Objekte erstellen.

Wie gesagt, besser wäre es zu diesem Zweck, wenn man der Funktion GetProcessList eine existierende StringList als var-Parameter übergeben könnte.
Geändert von PeterPanino, damit der Platz auf dem Bildschirm nicht so leer aussieht.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.340 Beiträge
 
Delphi 12 Athens
 
#10

AW: Bug in QuickLib

  Alt 25. Dez 2020, 21:13
Das ist doch eine firsche Liste?

Dann sollte doch eh jeder Prozess nur einmal drin sein.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2   

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 03:33 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-2025 by Thomas Breitkreuz