<div dir="ltr">Accidently missed the list in reply :( Sent for record.<br><div class="gmail_quote"><div dir="ltr"><div class="gmail_extra"><br><br><div class="gmail_quote"><div class="im">On 29 September 2013 17:23, Павел Рощин <span dir="ltr"><<a href="mailto:roshin@scriptumplus.ru" target="_blank">roshin@scriptumplus.ru</a>></span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><br>
> IIUC what you are seeing here is Scintilla laying out the window for the<br>
> first time, not just the goto.  That still will be done if the<br>
> editor_goto_pos is not called, just from a delayed idle callback IIUC.  If<br>
> its in the order of 3 seconds then I'm not sure delaying it is really going<br>
> to improve the user experience (even though it moves the action out of the<br>
> function you are measuring :)<br>
<br>
</div>Profiling shows that loading time was reduced dramatically. And I feel that<br>
difference as user.<br></blockquote><div><br></div></div><div>Ok, thats good.</div><div class="im"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div><br>
> This now ignores the cl_options settings since it doesn't call<br>
> set_cursor_position() any more :(<br>
<br>
</div>It doesn't _only_ if pos == 0. Go to zero position? Imagine I'm trying to load<br>
project with 1000 files. For each document set_cursor_position(0) will be<br>
called. Why?<br></blockquote><div><br></div></div><div>pos=0 is the default when a new document is opened, only documents in the previous session will be opened with pos != 0.  You need to call set_cursor_position() to see if any command line options requested a position other than zero, or you will break opening new documents from the command line.  Note, since the command line options are line and col they can't be translated into pos until the document is opened, so they can't pass a pos to document_open().</div>
<div class="im">
<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div><br>
> Possibly, but you have to ensure that the actions actually happen at some<br>
> point.  Sure you don't have to layout the hidden windows immediately, but<br>
> does that mean that the first time you swap to a hidden file is slow?<br>
<br>
</div>This is the thing called interface responsiveness. For user it's _much_ better<br>
to wait 0.02 sec 1000 times when clicking on document than wait 20 sec on<br>
loading. Most JIT compilers based on this trick: JIT compiler "delays" hot<br>
loops preferring execution over compiling.<br></blockquote><div><br></div></div><div>Ok, I read your 3s was per file, not the total of 1000 files.  If its 1000 files, well I think there are other things to worry about first.</div>
<div class="im">
<div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div><br>
> It is difficult, it has been discussed many times, but neither Geany, nor<br>
> Ctags, nor tagmanager, nor GTK are thread safe and it would take a major<br>
> re-design to use them from multiple threads.<br>
<br>
</div>I see, but it could be a great improvement. Maybe even make co-routines but in<br>
multicore world it sounds surprisingly.<br></blockquote><div><br></div></div><div>Thats the way it (probably) would be written if it was started now, but Geany is at least seven years old (according to the oldest commits in git, but I bet its much older than that).  Unless a re-organisation occurs we are stuck with the current architecture.  And ATM there is no effort available for re-architecting Geany, its a *totally* volunteer project by people with jobs in the "real" world.</div>

<div><br></div><div>That is not to say that a there could not be a set of small patches that fix things progressively over time, but they must not break stuff in the meantime.</div><div class="im"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


<div><br>
<br>
> Basically the same problem as number 1), plus the difficulty of maintaining<br>
> which tabs are loaded and laid out.<br>
<br>
</div>Same answer: responsiveness and again responsiveness. I'm human, if computer<br>
thinks 0.1 sec - I will even don't notice, if interface holds for 10 sec - it<br>
makes me nervous. Maintaining should simple: just add flag "delayed_load" and<br>
toggle it first time user clicked on document. Of course if there are no<br>
architecture problems.<br></blockquote><div><br></div></div><div>See above :)</div><div class="im"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><br>

> Sad as I am to say it, but maybe those with 1000s of tabs need a different<br>
> editor/ide, Geany's target is "small lightweight and simple" and it is<br>
> important that it maintains its focus on that.<br>
<br>
</div>I tried Eclipse. Without plugins it's functionality is similar to Notepad++ but<br>
it eats 0.5 Gb of memory even without any project. To support all languages I<br>
need  for I should download thousands of plugins and now it eatch 1.5 Gb.<br>
QtCreator is a good but... C++ only. Recently Python was added.<br>
<br>
I need Geany for my work - it's huge project and I should handle over 10 million<br>
of files with different languages - from TeX to C++. Either I have to open 100-s<br>
of IDE or I can use Geany. I know there are much to do, I'm sure I could help<br>
with developing but let's start with this simple improvement? I'll make PR if<br>
it's easier for you.<br></blockquote><div><br></div></div><div>PRs are welcome :)</div><div><br></div><div>Cheers</div><div>Lex</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


<br><span class="HOEnZb"><font color="#888888">
--<br>
Pavel<br>
</font></span></blockquote></div><br></div></div>
</div><br></div>