Overview
Examples
Screenshots
Comparisons
Applications
Download
Documentation
Tutorials
Bazaar
Status & Roadmap
FAQ
Authors & License
Forums
Funding Ultimate++
Search on this site
Search in forums












SourceForge.net Logo
Home » Developing U++ » U++ Developers corner » theide with libclang
Re: theide with libclang, first milestone finished [message #58785 is a reply to message #58784] Wed, 31 August 2022 10:13 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14271
Registered: November 2005
Ultimate Member
Tom1 wrote on Wed, 31 August 2022 10:00
Hi Mirek,

Each time I have e.g.:
	void LeftDown(Point p, dword keyflags) override {

I get a row: "WARNING: EMIT" in my Navigator. If I remove the override, it goes away. (I do not think this is anything new, but it shows up in the latest version too.)


I have to say I am a bit confused here... Smile

Can you post a screenshot? (full window so that I can see the source etc.. too)
Re: theide with libclang, first milestone finished [message #58786 is a reply to message #58785] Wed, 31 August 2022 10:50 Go to previous messageGo to next message
Tom1
Messages: 1305
Registered: March 2007
Ultimate Contributor
Hi,

Sorry. This must be caused by something strange deeper in my own code, since creating a simple test case does not seem to trigger showing it.
index.php?t=getfile&id=6653&private=0
Anyway, I will stop wasting your time on this one for now. (I bet you have something better to do... Smile

Thanks and best regards,

Tom

Re: theide with libclang, first milestone finished [message #58787 is a reply to message #58786] Wed, 31 August 2022 11:37 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14271
Registered: November 2005
Ultimate Member
Tom1 wrote on Wed, 31 August 2022 10:50
Hi,

Sorry. This must be caused by something strange deeper in my own code, since creating a simple test case does not seem to trigger showing it.
index.php?t=getfile&id=6653&private=0
Anyway, I will stop wasting your time on this one for now. (I bet you have something better to do... Smile

Thanks and best regards,

Tom



Ah, ok, by the screenshot I immediatelly see this non-clang version anyway Smile (new theide has arrow instead of ":")

Mirek
Re: theide with libclang, first milestone finished [message #58788 is a reply to message #58787] Wed, 31 August 2022 12:33 Go to previous messageGo to next message
Tom1
Messages: 1305
Registered: March 2007
Ultimate Contributor
mirek wrote on Wed, 31 August 2022 12:37
Tom1 wrote on Wed, 31 August 2022 10:50
Hi,

Sorry. This must be caused by something strange deeper in my own code, since creating a simple test case does not seem to trigger showing it.
index.php?t=getfile&id=6653&private=0
Anyway, I will stop wasting your time on this one for now. (I bet you have something better to do... Smile

Thanks and best regards,

Tom



Ah, ok, by the screenshot I immediatelly see this non-clang version anyway Smile (new theide has arrow instead of ":")

Mirek


Thanks Mirek!

For some reason my upp.src had slipped back to master branch. Anyway, I switched back to clang and now all my problems are gone. Arrows are shown instead of colon and there are no more "WARNING: EMIT" for overrides. Thanks!

Best regards,

Tom
Re: theide with libclang, first milestone finished [message #58824 is a reply to message #58788] Thu, 15 September 2022 08:31 Go to previous messageGo to next message
Tom1
Messages: 1305
Registered: March 2007
Ultimate Contributor
Mirek,

Would it be possible to add support for working with git branches in TheIDE menu?

Support for 'switching branch' for any git repository currently in use would be most useful, but possibly also support for creating and merging of branches.

Best regards,

Tom
Re: theide with libclang, first milestone finished [message #58826 is a reply to message #58824] Thu, 15 September 2022 09:48 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14271
Registered: November 2005
Ultimate Member
Tom1 wrote on Thu, 15 September 2022 08:31
Mirek,

Would it be possible to add support for working with git branches in TheIDE menu?

Support for 'switching branch' for any git repository currently in use would be most useful, but possibly also support for creating and merging of branches.

Best regards,

Tom


I would like to, I just do not quite know how to do it right. So far "Terminal at file directory" was my favorite tool in this regard...

Plus it is not quite related to Assist/clang, correct?

I plan a batch of another theide improvements after libclang is merged. Which now seems will be quite soon.

Mirek
Re: theide with libclang, first milestone finished [message #58828 is a reply to message #58826] Thu, 15 September 2022 14:10 Go to previous messageGo to next message
Tom1
Messages: 1305
Registered: March 2007
Ultimate Contributor
mirek wrote on Thu, 15 September 2022 10:48
Tom1 wrote on Thu, 15 September 2022 08:31
Mirek,

Would it be possible to add support for working with git branches in TheIDE menu?

Support for 'switching branch' for any git repository currently in use would be most useful, but possibly also support for creating and merging of branches.

Best regards,

Tom


I would like to, I just do not quite know how to do it right. So far "Terminal at file directory" was my favorite tool in this regard...

Plus it is not quite related to Assist/clang, correct?

I plan a batch of another theide improvements after libclang is merged. Which now seems will be quite soon.

Mirek


Yes, sorry. This is not the place for this discussion. Anyway, I'm looking forward to progress on this too.

Best regards,

Tom
Re: theide with libclang, first milestone finished [message #58836 is a reply to message #58828] Fri, 16 September 2022 11:28 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14271
Registered: November 2005
Ultimate Member
Merged...
Re: theide with libclang, first milestone finished [message #58842 is a reply to message #58836] Sat, 17 September 2022 05:54 Go to previous messageGo to next message
Novo is currently offline  Novo
Messages: 1430
Registered: December 2006
Ultimate Contributor
Merged version. Linux.
libclang: crash detected during reparsing
libclang: crash detected during parsing: {
  'source_filename' : '(null)'
  'command_line_args' : ['clang', '-I/home/ssg/dvlp/cpp/sergey/upp', '-I/home/ssg/dvlp/cpp/code/upp/git/uppsrc', '-I/home/ssg/dvlp/cpp/code/upp/git/bazaar', '-I/home/ssg/.local/tmp/dvlp/cpp/code/upp/.config/u++/ide/UppHub/SysExec', '-I/home/ssg/.local/tmp/dvlp/cpp/code/upp/.config/u++/ide/UppHub/Updater', '-I/usr/include/freetype2', '-I/usr/include/libpng16
', '-I/usr/include/freetype2', '-I/usr/include/libpng16
', '-I/usr/include/freetype2', '-I/usr/include/libpng16
', '-I/usr/include/gtk-3.0', '-I/usr/include/at-spi2-atk/2.0', '-I/usr/include/at-spi-2.0', '-I/usr/include/dbus-1.0', '-I/usr/lib64/dbus-1.0/include', '-I/usr/include/gtk-3.0', '-I/usr/include/gio-unix-2.0', '-I/usr/include/cairo', '-I/usr/include/pango-1.0', '-I/usr/include/harfbuzz', '-I/usr/include/pango-1.0', '-I/usr/include/fribidi', '-I/usr/include/harfbuzz', '-I/usr/include/atk-1.0', '-I/usr/include/cairo', '-I/usr/include/pixman-1', '-I/usr/include/freetype2', '-I/usr/include/libpng16', '-I/usr/include/gdk-pixbuf-2.0', '-I/usr/include/libpng16', '-I/usr/include/libmount', '-I/usr/include/blkid', '-I/usr/include/glib-2.0', '-I/usr/lib64/glib-2.0/include
', '-I/usr/include/gdk-pixbuf-2.0', '-I/usr/include/libpng16', '-I/usr/include/libmount', '-I/usr/include/blkid', '-I/usr/include/glib-2.0', '-I/usr/lib64/glib-2.0/include
', '-I/usr/include/libpng16
', '-I/usr/include/c++/10.2', '-I/usr/include/c++/10.2/x86_64-unknown-linux-gnu', '-I/usr/include/c++/10.2/backward', '-I/usr/local/include', '-I/usr/lib/clang/12.0.1/include', '-I/usr/include', '-I/usr/include/c++/10.2', '-I/usr/include/c++/10.2/x86_64-unknown-linux-gnu', '-I/usr/include/c++/10.2/backward', '-I/usr/local/include', '-I/usr/lib/clang/12.0.1/include', '-I/usr/include', '-DflagGUI', '-DflagPOSIX', '-DflagLINUX', '-DCLANG', '/home/ssg/dvlp/cpp/code/upp/git/uppsrc/Core/lheap.cpp', '-DflagDEBUG', '-DflagDEBUG_FULL', '-DflagMAIN', '-DflagCLANG', '-xc++', '-std=c++17', '-Dlint'],
  'unsaved_files' : [],
  'options' : -2147483136,
}


Regards,
Novo
Re: theide with libclang, first milestone finished [message #58843 is a reply to message #58842] Sat, 17 September 2022 06:44 Go to previous messageGo to next message
Novo is currently offline  Novo
Messages: 1430
Registered: December 2006
Ultimate Contributor
Is it possible to disable libclang support during compilation?
I'm having troubles trying to cross-compile Clang. Actually, I couldn't compile it at all.
I'm trying to cross-compile TheIDE for Windows on Linux.


Regards,
Novo
Re: theide with libclang, first milestone finished [message #58844 is a reply to message #58843] Sat, 17 September 2022 11:04 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14271
Registered: November 2005
Ultimate Member
What is your HW configuration?

I am setting some defaults for assist config, but the lowest HW I can test with is Ryzen 2400G 8GB Linux - they seems to work fine.

Check Setup BTW, I would start with disabling automatic indexer... BTW, I might be wrong, but I think for theide, every "indexer thread" and "autocomplete file cache" is about 200MB of memory.

Mirek
Re: theide with libclang, first milestone finished [message #58845 is a reply to message #58844] Sat, 17 September 2022 12:23 Go to previous messageGo to next message
Novo is currently offline  Novo
Messages: 1430
Registered: December 2006
Ultimate Contributor
mirek wrote on Sat, 17 September 2022 05:04
What is your HW configuration?

Intel(R) Core(TM) i7-3720QM CPU @ 2.60GHz (4 cores / 8 threads)
16GM RAM
It is a Lenovo W530. (I also have a T530 Smile )
I like the keyboard on these models Smile


Regards,
Novo

[Updated on: Sat, 17 September 2022 12:41]

Report message to a moderator

Re: theide with libclang, first milestone finished [message #58846 is a reply to message #58844] Sat, 17 September 2022 12:37 Go to previous messageGo to next message
Novo is currently offline  Novo
Messages: 1430
Registered: December 2006
Ultimate Contributor
mirek wrote on Sat, 17 September 2022 05:04

Check Setup BTW, I would start with disabling automatic indexer... BTW, I might be wrong, but I think for theide, every "indexer thread" and "autocomplete file cache" is about 200MB of memory.

Opening a project and closing it in a couple of seconds leads to "Invalid memory access" ...
EDIT: Happens after full rebuild.


Regards,
Novo

[Updated on: Sat, 17 September 2022 12:44]

Report message to a moderator

Re: theide with libclang, first milestone finished [message #58847 is a reply to message #58845] Sat, 17 September 2022 12:48 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14271
Registered: November 2005
Ultimate Member
Novo wrote on Sat, 17 September 2022 12:23
mirek wrote on Sat, 17 September 2022 05:04
What is your HW configuration?

Intel(R) Core(TM) i7-3720QM CPU @ 2.60GHz (4 cores / 8 threads)
16GM RAM
It is a Lenovo W530. (I also have a T530 Smile )
I like the keyboard on these models Smile


That is strange, that is about the same or better than my linux machine....

Maybe your libclang is somehow deffective?

Mirek
Re: theide with libclang, first milestone finished [message #58848 is a reply to message #58847] Sat, 17 September 2022 12:57 Go to previous messageGo to next message
Novo is currently offline  Novo
Messages: 1430
Registered: December 2006
Ultimate Contributor
mirek wrote on Sat, 17 September 2022 06:48

Maybe your libclang is somehow deffective?

I'm using "Void Linux". Its default clang version is 12.0.1.
Void Linux is like a stable version of Arch.
I do not have any problems with ccls on these machines ...


Regards,
Novo
Re: theide with libclang, first milestone finished [message #58849 is a reply to message #58848] Sat, 17 September 2022 13:01 Go to previous messageGo to next message
Novo is currently offline  Novo
Messages: 1430
Registered: December 2006
Ultimate Contributor
I'm getting weird error messages in console on exit.
/usr/include/glib-2.0/glib/gtypes.h:32:10: error: 'glibconfig.h' file not found
/usr/include/glib-2.0/glib/gversionmacros.h:375:2: error: "GLIB_VERSION_MIN_REQUIRED must be >= GLIB_VERSION_2_26"
/usr/include/glib-2.0/glib/gtypes.h:548:2: error: unknown ENDIAN type
/usr/include/glib-2.0/glib/garray.h:49:3: error: unknown type name 'guint8'
/usr/include/glib-2.0/glib/garray.h:75:36: error: unknown type name 'gsize'
...
/home/ssg/dvlp/cpp/sergey/upp/amap/amap.cpp:81:2: error: cannot initialize object parameter of type 'Upp::TopWindow' with an expression of type 'amap'
/home/ssg/dvlp/cpp/sergey/upp/amap/amap.cpp:83:2: error: no matching member function for call to 'Icon'
/home/ssg/dvlp/cpp/code/upp/git/uppsrc/CtrlCore/TopWindow.h:174:13: note: candidate function not viable: no known conversion from 'amap' to 'Upp::TopWindow' for object argument
/home/ssg/dvlp/cpp/code/upp/git/uppsrc/CtrlCore/TopWindow.h:176:13: note: candidate function not viable: requires 2 arguments, but 1 was provided
...
fatal error: too many errors emitted, stopping now [-ferror-limit=]


Regards,
Novo
Re: theide with libclang [message #58856 is a reply to message #58579] Sun, 18 September 2022 12:22 Go to previous messageGo to next message
jjacksonRIAB is currently offline  jjacksonRIAB
Messages: 227
Registered: June 2011
Experienced Member
Seemed OK at first but:

- Include file completion doesn't work (you're probably already aware of this)
- Alt+C works in .cpp files (only one direction though, from inner class scope to outer) but not .h files. It also appears to sometimes get the outer class name wrong.

Biggest issue thus far is 100% CPU and memory exhaustion. Before indexing, TheIDE uses around 50 megabytes, after first indexing it goes up to around 150, then eventually libclang breaks, autocomplete stops working for some symbols, then all - a second indexing increases memory usage until it reaches around 1.8 gig. This is with only one core enabled. With all cores, it uses all available system memory and freezes the OS... typically when compiling.

[Updated on: Sun, 18 September 2022 12:23]

Report message to a moderator

Re: theide with libclang [message #58857 is a reply to message #58856] Sun, 18 September 2022 13:05 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14271
Registered: November 2005
Ultimate Member
jjacksonRIAB wrote on Sun, 18 September 2022 12:22
Seemed OK at first but:

- Include file completion doesn't work (you're probably already aware of this)


I went really far to make it work (is not really simple with libclang), so that is unpleasant surprise.

Quote:

Biggest issue thus far is 100% CPU and memory exhaustion. Before indexing, TheIDE uses around 50 megabytes, after first indexing it goes up to around 150, then eventually libclang breaks, autocomplete stops working for some symbols, then all - a second indexing increases memory usage until it reaches around 1.8 gig. This is with only one core enabled. With all cores, it uses all available system memory and freezes the OS... typically when compiling.


Can you please tell me details about the machine? Smile

I was mostly testing / using in Windows; there with 32 indexing threads the memory goes to somewhere like 6GB.
Re: theide with libclang [message #58858 is a reply to message #58857] Sun, 18 September 2022 13:27 Go to previous messageGo to next message
jjacksonRIAB is currently offline  jjacksonRIAB
Messages: 227
Registered: June 2011
Experienced Member
Linux mint, it's an older machine with 8 cores and 16 gig of memory, libclang should be version 12 IIRC. If 6 gig is common I'll probably have to turn it off because the compiler causes a lot of memory pressure as is, oh well Very Happy
Re: theide with libclang [message #58859 is a reply to message #58858] Sun, 18 September 2022 16:57 Go to previous messageGo to previous message
Novo is currently offline  Novo
Messages: 1430
Registered: December 2006
Ultimate Contributor
In my case (Lenovo ThikPad T530 8GB RAM, 2 cores (4 threads), indexer is using 4 threads) when indexing TheIde itself:

- 1.3GB when reindexing all src. Memory usage doesn't go down after reindexing.
- 300MB when opening an already indexed TheIde project.

I guess, memory allocation strategy is inefficient.


Regards,
Novo
Previous Topic: Impressive improvement in stl::vector when dealing with raw memory.
Next Topic: about unicode supporting
Goto Forum:
  


Current Time: Sun Oct 26 11:52:23 CET 2025

Total time taken to generate the page: 0.05107 seconds