-
Content Count
1497 -
Joined
-
Last visited
-
Days Won
152
Posts posted by Stefan Glienke
-
-
That it what I looked into some years ago and started refactoring out some for me unnecessary code and cruft.
You have to know that a coverage profiler is basically a debugger that puts a breakpoint into every single executable line (or at least those where you specified you are interested in).
Now finding out what lines that are is the interesting part - the other is presenting the data nicely inside the IDE when executed under TestInsight (at least for me).
-
1
-
-
1 hour ago, Alexander Pustotin said:getting details is too time consuming process
And not your job but Embarcadero's :)
-
Looks to me very much like a timing problem on shutdown. As soon as I debug or cause some slight delay before the end the AV disappears.
-
-
On 2/1/2019 at 6:06 PM, Uwe Raabe said:Probably because in the second case "[10]" is seen as a set constant by the compiler.
This clearly seems to be a glitch in the compiler when doing the operator/overload resolution where it does find a proper match for Equal/NotEqual (did not test all possible operator combinations but those two).
-
System.Generics.Collections does not cause that much of a code bloat since the refactorings in XE7 - however it still causes more than it should but that is the limitation of the compiler.
I did some tests with Rapid.Generics and while they are optimized for some scenarios it was not a stellar improvement over System.Generics.Collections in 10.3.
And while I was doing benchmarks of those and Spring4D collections I saw that isolated benchmarks are often very much affected by certain CPU specifics - on different CPUs depending on their (non documented) behavior of the branch predictor and of course in a microbenchmark chances are high that all code fits into at least L2 cache.
-
5
-
-
Sorry I meant
startIndex + Length(searchText) - 1
because the method simply works as follows: it starts to search at startIndex but does not consider any character in the string after that. That causes it not finding any searched text that extends beyond that index.
So as Christian already stated it basically works as if you cut the string after startIndex.
So what the documentation is simply missing is the fact that it would not find any occurence that extends past startIndex when you use any of those overloads, that's all.
-
The documentation is not precise enough - but fwiw the implementation as in Delphi is the same as it is in .NET or Java. The startindex actually also limits the length of the searched string. So any search text longer than 1 will only be found at startIndex - (Length(searchText) - 1) or left to that. And when Cristian said "first occurence" he actually meant "first occurence from the right" of course.
-
When used in a set, the ordinal value of the enum is basically the index of the bit used within the set and as they can only be 256 bit in size any ordinal value above 255 prevents an enum being used as a set.
Personally I think you should rather avoid giving enums any ordinal values and only ever use them when using some interop with another system where they are used for.
-
1
-
-
32 minutes ago, David Heffernan said:There are plenty of libraries that ostensibly have test suites but are full of bugs because the test suites are incomplete.
If we just had some easy to use and nicely integrated into the IDE way to measure code coverage ...
-
1
-
1
-
-
Among a few minor things it allows for a more declarative approach of writing tests by using attributes to provide the test data.
In a classic DUnit test if you have to test an algorithm with 20 different value combinations you need to write 20 tests (either as different methods or by putting them into one test).
However DUnit can be pimped to allow the same so you don't need to migrate (*) - since DUnit is kinda abandoned development wise Vincent decided to roll his own library instead of modifying and possibly cleaning up the code from DUnit which dates way back.
(*) I did that way back even before DUnitX existed: https://stackoverflow.com/a/9006662/587106 and later also put that into a unit of Spring4D. As you can see in the screenshot you have multiple tests shown although there is only one method declared the extension takes care of producing them so you can run them individually (if for example certain data produces a failure) while you are fixing it.
Another thing (which personally never bothered me much) is that with DUnitX you can write testcase classes without inheriting from a base class (this can also be done with an extension for DUnit - did it but never put it anywhere because it was not useful for me).
The last thing that I remember is the fact that DUnitX can do is have fixture setup/teardown - they only run once even if there are multiple tests in the class - classic DUnit runs Setup/TearDown methods before and after every single test - guess what? You can also plug that onto DUnit.
My personal opinion: do automated unit tests but it does not matter what framework you are using. I use DUnit with the before mentioned extensions and we do so at work because its powerful and compact. And regardless which one you are using - use them with TestInsight and make them part of your CI. 😉
-
6
-
-
Wasted effort imo - the fundamental design and architecture of the IDE and how (designtime)packages work is flawed to get something like this working properly.
Unloading of packages often does not work properly because they are not written for that or some things that happen during loading cannot be easily undone (sloppy developer or simply because the API might be missing).
Adding component/library to the IDE is not just loading a module but adding paths in numerous places, like library path for each supported platform, browsing path for stepping into code or even special debug DCU path.
And last but not least because there is no strict rule how packages and files should be structured and if the library path should only point to DCUs or to pas files which often causes vendors to place their stuff all over the place and even require modifying the windows path variable (OMG how I hate that!)
-
Just now, Lars Fosdal said:Wow, I didn't notice that! And it is not related to declaration order, nor ordinal value. That is a bit disturbing.
You should take a break - because it in fact is related to the ordinal value. The order is wtf, plough, foo, bar - but your array was wtf, plough, bar, foo
-
1 minute ago, Lars Fosdal said:Or pitfall 😛
Confusing sets with arrays because they look similar is the pitfall
15 minutes ago, Lars Fosdal said:Edit
Change the declaration to TEnum = (plough = 5, foo = 9, bar = 14, wtf = 1);
Now the set behaves just like the array.
It does not, bar and foo are still reversed 😉
-
That is why I wrote "strictly speaking" because there is always a difference between a formal language or syntax specification and its implementation based on its actual type.
Currently probably every language that has some kind of for-in or foreach loop of course operates an array in order but that does not mean that you can assume this for every type operable with such loops.
And when we are talking about "just for arrays" this is what is called "implementation detail".
-
AFAIK you cannot inline declare an array in a for in loop so having some elements in between square brackets will always be a set.
You can see it in your very own code on your blog article where you had to put them into an array variable first to then process them in the loop.
The point I agree with though is that the fact that sets and arrays share its syntax might be confusing sometimes.
-
1
-
-
Just now, Lars Fosdal said:For a list or any other object enumeration interface, I'd agree - but for an open array or a TArray?
I could answer that by quoting your previous comment 😉
-
Strictly speaking assuming a specific order in a for-in loop is wrong to begin with.
-
4
-
-
2 hours ago, Lars Fosdal said:You would expect to see x vary in the order of the values in the list.
No I would not because its not a list but a set which are implemented as bitmask and thus have a fixed order.
-
4
-
1
-
-
I just noticed yet another time that selecting text from a post contains invisible characters - in this particular case I selected the URL from this post:
by selecting from the starting h of http and moved the mouse a bit to the right and down so it selected the entire rest of the line.
When I then clicked "go to" in my context menu (using Chrome) I got a 404 which confused me because the url is valid. I eventually found out that the selected text contained some UTF-8 BOM bytes at the end.
Also when inspecting the elements it showed this:
which according to a google search is a zero width no-break space - turning off JS makes them disappear.
The weird spans are also shown with Firefox however selecting the text does not cause it to contain garbage.
Edit: I found what is causing the spans with the ZWNBSP - its the "quote selection" popup that leaves them there. So the issue I am describing here only happens when you selected the text, deselected and then selected again to contain the hidden ZWNBSP character.
-
There is no such function in the RTL, its called UIntToStr and has two overloads for Cardinal and UInt64 - it's there at least since Delphi XE and works there as far as I can tell.
I don't immediately remember a bug with that function (which does not mean anything) - but I know there was a bug with the opposite related to System.Val which was fixed in XE4 - see https://stackoverflow.com/q/6077258/587106
-
6 hours ago, Remy Lebeau said:Now, why TValue.AsType<TWndMethod> fails to compile, I don't know. Sounds like a bug.
It probably is lacking the `()` there which it sometimes needs when invoking a method that returns an invokable type.
-
3
-
-
Just now, John Kouraklis said:When you run the tests from TI, does it use the selected platform or only Win32?
It basically does what "Run" does.
-
There is the IDE plugin that listens on the TCP port(range) specified in its settings and the client that is compiled into the test projects sends its result to it. What exactly should not work about that on any platform that can do TCP/IP?
Rapid generics
in RTL and Delphi Object Pascal
Posted · Edited by Stefan Glienke
Google for C++ template code bloat and you see that they also suffer from the very same problem including ridiculously long compile times and memory consumption. The suggested approach is very similar to what has been done in System.Generics.Collections.
Delphi however adds some more problems into the mix like having RTTI turned on by default which is extremely problematic if you have extensive generic class hierarchies. For generic fluent APIs that return generic type which have many different type parameters because of the way the API is being used this can turn a few hundred lines unit into several megabytes dcu monsters (the size itself is not the problem but the compiler churning on them for a long time). If you multiply that with other factors it turns compiling a 330K LOC application into a minute or more while consuming close to 2 GB RAM and producing 250MB of dcus and 70MB exe. These are real numbers from our code and an ongoing refactoring of both sides - library code that contains generics (Spring4D) and calling side reduces this significantly.