<br><br>tirsdag den 30. oktober 2012 skrev Daniel Calviño Sánchez :<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">2012/10/29 Aleix Pol <<a href="javascript:;" onclick="_e(event, 'cvml', 'aleixpol@kde.org')">aleixpol@kde.org</a>>:<br>

> Hi!<br>
> First of all, cool stuff! :)<br>
<br>
Thanks :)<br>
<br>
> It might be interesting to integrate it with the language Problems? I<br>
> don't really like the idea of having another toolview for finding<br>
> problems.<br>
<br>
When I started writing the plugin my idea was to integrate it with the<br>
language Problems. But after giving it a thought I realized that I had<br>
not enough time to properly integrate it with the language Problems,<br>
and that a custom view was better than nothing.<br>
<br>
The main reason is that Krazy2 needs a lot more time to analyze a<br>
project than the time needed by the current problem providers. For<br>
example, it takes around 14-15 minutes to analyze KTutorial (other of<br>
my projects ;) ), which contains around 450 files. And that only with<br>
the default checkers, with no extra checker. I felt that such a wait<br>
didn't fit with the rest of language Problems, which are analyzed<br>
quite fast.<br>
<br>
Of course, that wait might only happen the first time the project was<br>
analyzed. A cache could be used so the next analysis would only check<br>
the files that changed since the last analysis. But even if there was<br>
a caching system already available in KDevelop, I felt that making<br>
everything work together would have taken me more time than what I had<br>
available. Besides, there would have been other things to tackle, like<br>
how to configure the Krazy2 analysis when using the language Problems.<br>
<br>
> Maybe you can create an ILanguageChecksProvider plugin there? This<br>
> could start bringing the pieces together...<br>
<br>
I'm afraid that I don't have time right now for further development of<br>
this plugin :(<br>
<br>
<br>
<br>
2012/10/29 Andreas Pakulat <<a href="javascript:;" onclick="_e(event, 'cvml', 'apaku@gmx.de')">apaku@gmx.de</a>>:<br>
> Hi,<br>
><br>
> On Mon, Oct 29, 2012 at 9:30 PM, Daniel Calviño Sánchez<br>
> <<a href="javascript:;" onclick="_e(event, 'cvml', 'danxuliu@gmail.com')">danxuliu@gmail.com</a>> wrote:<br>
>> That is pretty much what the plugin does. Not very impressive, I know<br>
>> :P<br>
><br>
> I think its impressive enough, in particular knowing the scarceness of<br>
> our API docs and the steep learning curve to understand how the<br>
> plugins work and finding how to write one.<br>
<br>
Thanks, although it was just a matter of taking a look to some plugins<br>
whose code I was already familiar with ;)<br>
<br>
>> Besides those ideas, there is a problem that should also be tackled:<br>
>> if a directory with a lot of files (hundreds of thousands) happens to<br>
>> be selected to be analyzed, the KDevelop GUI will freeze while the<br>
>> plugin is getting the list of files. Probably no one would need to run<br>
>> a Krazy2 analysis from KDevelop on a directory with hundreds of<br>
>> thousands of files, but even if it is selected by mistake, a freezed<br>
>> GUI does not look good from a user perspective :)<br>
><br>
> Sounds like that task is currently triggered from a UI element, i.e. a<br>
> button or so and then directly executed inside the function. Instead<br>
> you could run the "fetch the list of files" in a separate thread,<br>
> either by utilizing the ThreadWeaver API or QtConcurrent.<br>
<br>
Thanks for the advice. I'll take that into account for the future.<br>
<br>
> If possible<br>
> it would be good to have all the code that is executed to fetch files,<br>
> run them through krazy and generate the analysis data inside of a KJob<br>
> subclass and make it cancellable as far as possible so such long runs<br>
> can be aborted if done by mistake. Thats just guesswork on my part, so<br>
> if thats already whats happening just ignore me :)<br>
<br>
The code to fetch the files is not in a KJob, although the analysis<br>
and the parsing of the results are ;) And it even has a<br>
KDevelop::IStatus to show the progress! :P<br>
<br>
<br>
<br>
2012/10/30 Allen Winter <<a href="javascript:;" onclick="_e(event, 'cvml', 'winter@kde.org')">winter@kde.org</a>>:<br>
> On Monday 29 October 2012 09:30:52 PM Daniel Calviño Sánchez wrote:<br>
>> Hi all,<br>
>><br>
>> I would like to inform you about a GPLv2+ licensed Krazy2 plugin for<br>
>> KDevelop that I have been working on.<br>
>><br>
> Neat stuff.  I look forward to seeing improvements in the future.<br>
<br>
Thanks :)<br>
<br>
> I cheat.  I have an extension (that can run only 1 file at a time)<br>
> From my kdeveloprc:<br>
> [External Scripts][script 15]<br>
> command=krazy2 --export=textedit %n<br>
> errorMode=0<br>
> inputMode=0<br>
> name=krazy2<br>
> outputMode=0<br>
> saveMode=0<br>
> shortcuts=<br>
> showOutput=true<br>
></blockquote><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
> But it doesn't let me select a line in the results output and have the editor jump to that line in the code.</blockquote><div><br></div><div>Actally, the code in master (what at some point will become kdevelop 4.5) will let you do that. You just need to choose the right filtering strategy for the output of your job.<span></span></div>
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
> Other than that, it's easy enough to use :)<br>
<br>
That's a good trick, though :)<br>
<br>
--<br>
KDevelop-devel mailing list<br>
<a href="javascript:;" onclick="_e(event, 'cvml', 'KDevelop-devel@kdevelop.org')">KDevelop-devel@kdevelop.org</a><br>
<a href="https://barney.cs.uni-potsdam.de/mailman/listinfo/kdevelop-devel" target="_blank">https://barney.cs.uni-potsdam.de/mailman/listinfo/kdevelop-devel</a><br>
</blockquote><br><br>-- <br>- When the split is pulled, mr. Grenade is no longer our friend<br>