Pascal Library of Utilities - Quick development library (AutoMapper, LinQ, IOC Dependency Injection, MemoryCache, Scheduled tasks, Json and Yml Config and Options pattern, Serializers, etc) with crossplatform support for Delphi/Firemonkey (Windows,Linux,OSX/IOS/Android) and freepascal (Windows/Linux).

Unknown 0b2f621aaf First release 7 лет назад
samples 0b2f621aaf First release 7 лет назад
.gitignore 0b2f621aaf First release 7 лет назад
LICENSE.txt 0b2f621aaf First release 7 лет назад
Quick.Amazon.pas 0b2f621aaf First release 7 лет назад
Quick.AppService.pas 0b2f621aaf First release 7 лет назад
Quick.Azure.pas 0b2f621aaf First release 7 лет назад
Quick.Chrono.pas 0b2f621aaf First release 7 лет назад
Quick.Commons.pas 0b2f621aaf First release 7 лет назад
Quick.Config.pas 0b2f621aaf First release 7 лет назад
Quick.Console.pas 0b2f621aaf First release 7 лет назад
Quick.FileMonitor.pas 0b2f621aaf First release 7 лет назад
Quick.Log.pas 0b2f621aaf First release 7 лет назад
Quick.Network.pas 0b2f621aaf First release 7 лет назад
Quick.WebBrowser.pas 0b2f621aaf First release 7 лет назад
README.md 0b2f621aaf First release 7 лет назад

README.md

QuickLib


Small delphi library containing interesting and quick to implement functions, created to simplify application development.


Quick.AppService: Allow a console app to run as console mode or service mode with same code simplifying debug tasks.

if not AppService.IsRunningAsService then
begin
  ...your code running as console
end
else
begin
  AppService.ServiceName := 'MyService';
  AppService.DisplayName := 'MyServicesvc';
  //you can pass an anonymous method to events
  AppService.OnStart := procedure
                        begin
                          ...your start code
                        end;
  AppService.OnExecute := YourExecuteFunction;
  AppService.OnStop := YourStopFunction;
  AppService.CheckParams;
end;

Quick.Azure/Amazon: Simplifies blob iteraction with Azure and Amazon Cloud Storage.

//connect to a Azure blobstorage
QuickAzure := TQuickAzure.Create(AzureAccountName,AzureAccountKey);

//download a blob file to a stream
done := QuickAzure.GetBlob('MyContainer','MyFile.jpg',ResponseInfo,MyStream);

//check if exists a folder
found := ExistFolder('MyContainer','/Public/Documents/Personal');

//list blobs starting with a pattern (recursively or not)
for azBlob in ListBlobs('MyContainer','/Public/Documents',Recursive,ResponseInfo) do
begin
  if azBlob.Size > 1000 then Showmessage(azBlob.Name);
end;

Quick.Network: CIDR and IP Range functions.

//convert ip string to integer
IPv4ToInt('192.168.1.10');

//get first and last ip of a subnet scope
GetIpRange('192.168.100.0','255.255.255.0',LowIp,HighIP);

Quick.Commons: Functions frequently needed in the everyday of a developer.

//coverts UTC time TDateTime to Local date time
UTCToLocalTime(MyUTCTime);

//generate a 10 char length random password with alfanumeric and signs.
RandomPassword(10,[pfIncludeNumbers,pfIncludeSigns]);

//Capitalize every word of a phrase
CapitalizeAll('the grey fox'); //returns "The Grey Fox"

Quick.Chrono: Chronometer and Benchmark a piece of code is simple.

//get elapsed time execution of a code part
Chrono := TChronometer.Create(False);
Chrono.Start;
...code you need benchmark
Chrono.Stop;

//shows elapsed time in LongTime format (2 hour(s) and 10 minute(s))
Showmessage(Chrono.TimeElapsed(True));

//shows elapsed time in ShortTime format (02:10:00)
Showmessage(Chrono.TimeElapsed(False));

Quick.Console: Write log messages to console with colors and more...

//define which level of output needed
Console.Verbose := LOG_DEBUG;

//writes line to console in red color
cout('Error x',etError); 

//writes formatted line in green color
coutFmt('Proccess %s finished',[ProccesName],etSuccess);

//writes integer
cout(12348);

//Connect a QuickLog and write to disk and screen with one line of code (with independent verbose levels)
MyQuickLog := TQuickLog.Create;
MyQuickLog.Verbose := LOG_ALL;
Console.Verbose := LOG_ONLYERRORS;
Console.Log := MyQuickLog;

Quick.Log: Log to disk or memory with verbose levels and daily or max space rotation.

//write a header on start with info as running path, appname, debugmode, user, etc...
Log.ShowHeader := True;

//sets log with rotation at 20MB
Log.SetLog('.\mylog.log',False,20);

//write an error message
Log.Add('Error x',etError);

//write formatted error message
Log.Add('Error is %s',[ErrorStr],etError);

Quick.Config: Load/Save a config as json. Create a descend class from TAppConfig and add private variables will be loaded/saved.

 //create a class heritage
 TMyConfig = class(TAppConfig)
  private
    fName : string;
    fSurname : string;
    fStatus : Integer;
  public
    property Name : string read fName write fName;
    property SurName : string read fSurname write fSurname;
    property Status : Integer read fStatus write fStatus;
  end;

  //save your config to json file
  MyConfig.ConfigFile := '.\config.json';
  MyConfig.Name := 'John';
  MyConfig.Surname := 'Smith';
  MyConfig.Save;

Quick.FileMonitor: Monitorizes a file for changes and throws events.

FileMonitor.Filename := '.\myfile.txt';
//check file changes every 2 seconds
FileMonitor.Interval := 2000;
//watch for deleted or modified file events
FileMonitor.Notifies := [mnFileModified, mnFileDeleted)];
FileMonitor.OnFileChange := MyFileChangeFunction;
FileMonitor.Enabled := True;