-
Content Count
267 -
Joined
-
Last visited
-
Days Won
2
Posts posted by Jacek Laskowski
-
-
I don't make any logs either. I don't have a CodeSite installed, is it necessary?
-
-
I use Firebird and I use domains in databases.Â
CREATE TABLE RESOURCE ( IDRESOURCE D_PRIMARY_KEY, IDCUSTOMER D_FOREIGN_KEY NOT NULL, LASTUSED D_DATETIME, RESOURCEIDENTIFIER D_VARCHAR120, FRIENDLYRESOURCENAME D_VARCHAR250);
Â
How to use Firedac to read the domain names used for the columns in the table?
I try use TFDMetaInfoQuery but without success (ExtendedMetadata enabled).
Â
ps. Â How to use TFDMetaInfoQuery.MetaInfoKind with value set to mkTableTypeFields? There is no description in the documentation and TFDMetaInfoQuery does not return anything.
Â
-
Yes, despite the exclusion of the pointed modules, I have the IDE suspension
Â
Â
But it is worth adding that I have a suspension after I modify the interface method and then I try to edit (ctrl+E) the method in the class that corresponds to the modified interface method.
This is probably the only (certainly the main >90%) case of suspension.
-
Yuuppii! 🙂
I will try this workaround and test behaviour, thanks for effort and for support MMX!
Â
From the more complicated code I use Spring4D, FireDAC and mORMot, did you check them?
-
Some time ago I discovered that GExperts in "Uses Clause Manager" module has a parser that works in the background and creates files from the cache on the disk. Previously I suspected that MMX suspensions occur when accessing source files, so I thought GExperts might interfere with MMX somehow. I completely disabled "Uses Clause Manager" and since then the number of IDE suspensions when using MMX has dropped dramatically. It still happens, but this is maybe 10% of the previous state.
I hope this helps a little bit.
Â
-
I think you mean this piece of code (from the SelectEligibleConstructor method):
Â
end).TakeWhile( function(const injection: IInjection): Boolean begin if maxCount = -1 then maxCount := injection.DependencyCount; if targetType = nil then targetType := injection.Target.Parent; Result := (injection.DependencyCount = maxCount) and (targetType = injection.Target.Parent); end).Where(...
But how (at this point) to get to the list of arguments and their types to choose the right constructor?
Â
-
What is ConstructorSelector?
I didn't find anything in Spring4D sources or google.
Give me a simple example, please. -
Your example works, my code doesn't. It's identical*.
I spent a lot of hours and energy modifying the code from left to right... I finally found it!Please add a line in your example before registering classes in the container:
Â
globalContainer.AddExtension<TActivatorContainerExtension>;
Â
and then check it out... 🙂
Â
I'm very tired of it... give me a tip how to fix it, please.
Â
* - almost
-
When I comment on one of the constructors, then the factory was working properly.
Â
TSQLDataSuite = class(TInterfacedObject, ISQLDataSuite) [...] public // constructor Create(const aTableName: RawByteString; // const aSQLKind: TModifyingSQLKind; // const aProcessSQL : Boolean = True; // const aBeforeWorkerMethod: TSQLDataSuiteWorkerMethod = nil; // const aAfterWorkerMethod: TSQLDataSuiteWorkerMethod = nil); overload; constructor Create(const aTableName: RawByteString; const aSQLKind: TModifyingSQLKind; const aProcessSQL : Boolean); overload; end;
Â
There is a problem with factory when a class has two active constructors. But I can't understand it.
-
I add new constructor to TSQLDataSuite:
Â
constructor Create(const aTableName: RawByteString; const aSQLKind: TModifyingSQLKind; const aProcessSQL : Boolean); overload;
Â
And new factory:
Â
ISQLDataSuiteFactory = interface(IInvokable) ['{A101FA06-ED33-478A-9066-821BC8C5E2AE}'] function Create(const aTableName: RawByteString; const aSQLKind: TModifyingSQLKind; const aProcessSQL : Boolean ): ISQLDataSuite; overload; function Create(const aTableName: RawByteString; const aSQLKind: TModifyingSQLKind; const aProcessSQL : Boolean; const aBeforeWorkerMethod: TSQLDataSuiteWorkerMethod; const aAfterWorkerMethod: TSQLDataSuiteWorkerMethod): ISQLDataSuite; overload; end;
Â
but after call:
Âvar fSQLDataSuiteFactory : ISQLDataSuiteFactory; [...] lData := fSQLDataSuiteFactory.Create('TableName', TModifyingSQLKind.SQLInsert, True);
I stiil get exception:
Unsatisfied constructor on type: TSQLDataSuite
Â
How to do it right?
-
I have problem with one factory.
Â
definitionTSQLDataSuiteWorkerMethod = procedure(const aDataSuite : ISQLDataSuite) of object; TSQLDataSuite = class(TInterfacedObject, ISQLDataSuite) [...] public constructor Create(const aTableName: RawByteString; const aSQLKind: TModifyingSQLKind; const aProcessSQL : Boolean = True; const aBeforeWorkerMethod: TSQLDataSuiteWorkerMethod = nil; const aAfterWorkerMethod: TSQLDataSuiteWorkerMethod = nil); reintroduce; end; {$M+} TSQLDataSuiteFactory = reference to function(const aTableName: RawByteString; const aSQLKind: TModifyingSQLKind; const aProcessSQL : Boolean = True; const aBeforeWorkerMethod: TSQLDataSuiteWorkerMethod = nil; const aAfterWorkerMethod: TSQLDataSuiteWorkerMethod = nil): ISQLDataSuite; {$M-}
Â
container registration ÂÂ
aContainer.RegisterType<TSQLDataSuite>.Implements<ISQLDataSuite>; aContainer.RegisterFactory<TSQLDataSuiteFactory>;
Â
Â
resolve in code:fSQLDataSuiteFactory : TSQLDataSuiteFactory; var Data: ISQLDataSuite; begin Data := fSQLDataSuiteFactory('TableName', TModifyingSQLKind.SQLInsert, True, nil, nil);
Â
And after last l get exception from Spring4D:
Â
Unsatisfied constructor on TSQLDataSuite
Â
What have I forgotten?
Â
I use in the program dozens of factories, classes and interfaces, all based on the spring container, everything works correctly, only this case I cannot understand.
ps. maybe it's worth opening a subforum for Spring4D?Â
Â
-
I have a spring collection, like a IList<T>.
I need to remove all items from it that meet the condition:
Â
type TFoo = interface function Value : Integer; end; var List : IList<TFoo>; begin i := 0; while i < List.Count do begin if List[i].Value < 100 then List.Delete(i) else Inc(i); end; end;
Can it be done faster, better?Â
And how can I do that for IDictionary<K, V>?
-
I use this option for years, without problems.
-
Â
Please add:
Â
"
Windows Registry Editor Version 5.00 [HKEY_CURRENT_USER\Software\Embarcadero\BDS\19.0\Editor] "DefaultFileFilter"="Borland.FileFilter.UTF8ToUTF8"
After setting this value Delphi will encode new units in UTF-8 with BOM."
-
Maybe you're using automatic inline?
Â
{$INLINE AUTO}
Â
from docs:
Â
"Behaves like {$INLINE ON}, with the addition that routines not marked with inline will be inlined if their code size is less than or equal to 32 bytes."
-
This is Spar.... Embarcadero! 😉
Â
Â
-
I downloaded hcldemo.zip again, but db still not found.
Â
--- after some time ---
Now is ok, thanks.
-
-
Then you may want to consider creating a mailing queue based on e.g. pipes (or tcp/ip). So the DLL would be a server reading the queue/pipe, and the application in the Cobol would work as a client? I don't know what possibilities Cobol has and if it supports pipes api.
Â
-
Very interesting tool!
Â
Â
Maybe Emba should consider writing a plugin to support Delphi?
-
I don't think there is a specification of this format anywhere described (I haven't met it).
But from what I understood you want to write data to XML in order to read them in the DLL, so why do you need to know the format?
If you want to have XML for another purpose then you can create it yourself using any XML library. -
-
WinRT is dead
MMX for Delphi 10.3 Rio
in MMX Code Explorer
Posted
Yes, now logs working! I wait for freeze 😉