From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: "Eric M. Ludlam" Newsgroups: gmane.emacs.devel Subject: Re: Is intellisense features integration in Emacs technically possible? Date: Wed, 22 Jan 2014 21:22:50 -0500 Message-ID: <52E07CFA.2090206@siege-engine.com> References: <1390269670.2888.14.camel@localhost.localdomain> <83zjmpf80o.fsf@gnu.org> <877g9shqms.fsf@newcastle.ac.uk> NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit X-Trace: ger.gmane.org 1390443784 26756 80.91.229.3 (23 Jan 2014 02:23:04 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Thu, 23 Jan 2014 02:23:04 +0000 (UTC) To: emacs-devel@gnu.org Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Thu Jan 23 03:23:11 2014 Return-path: Envelope-to: ged-emacs-devel@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1W69wk-0003tC-Sj for ged-emacs-devel@m.gmane.org; Thu, 23 Jan 2014 03:23:11 +0100 Original-Received: from localhost ([::1]:38512 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1W69wk-0007W7-CT for ged-emacs-devel@m.gmane.org; Wed, 22 Jan 2014 21:23:10 -0500 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:47109) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1W69wc-0007Vv-QW for emacs-devel@gnu.org; Wed, 22 Jan 2014 21:23:08 -0500 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1W69wX-0006XJ-EU for emacs-devel@gnu.org; Wed, 22 Jan 2014 21:23:02 -0500 Original-Received: from mail-qc0-x231.google.com ([2607:f8b0:400d:c01::231]:56107) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1W69wX-0006Wn-89 for emacs-devel@gnu.org; Wed, 22 Jan 2014 21:22:57 -0500 Original-Received: by mail-qc0-f177.google.com with SMTP id i8so1688335qcq.36 for ; Wed, 22 Jan 2014 18:22:56 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=sender:message-id:date:from:user-agent:mime-version:to:subject :references:in-reply-to:content-type:content-transfer-encoding; bh=hQLx+Vmto5wpo44vX3PEAWh3xnudKlO0ILZw2x13rjk=; b=E4nJ9WkngBjuIK0LsNvgC25KwID7LgbMHSQ9MaB5bGYSqM/QaakxRoj/g2fou3CiXt oTkJEKgY6JNCKYj6r1pk7Jc9sV7/nnMtv/uVp/BcXVU1cukjrAB4vwseryfQfza8qTvX Oa5+hj2ihZtN6PdOyEZYfmiXoUV37OHbuoib8SAWGd5WRZbqDHRSkP9s6iu2vblY0nfR IbP88zOBVU2snUKgrxCmsBQpePlx2Xzl3vzX5PWMeGEL6ka+Z/LpLSiBhfyTBB6vAMjs hZ/Lu3yv2JCSEQOQq3qhuAmrya9ujXsgTbEaP/HTHq69h/7OJnQeh6qgOnBKVZOcbzmX cPbA== X-Received: by 10.229.251.7 with SMTP id mq7mr7797686qcb.18.1390443776342; Wed, 22 Jan 2014 18:22:56 -0800 (PST) Original-Received: from [192.168.1.201] (pool-71-184-209-46.bstnma.fios.verizon.net. [71.184.209.46]) by mx.google.com with ESMTPSA id g52sm6181356qgg.9.2014.01.22.18.22.54 for (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Wed, 22 Jan 2014 18:22:55 -0800 (PST) User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.3a1pre) Gecko/20091222 Shredder/3.1a1pre In-Reply-To: <877g9shqms.fsf@newcastle.ac.uk> X-detected-operating-system: by eggs.gnu.org: Error: Malformed IPv6 address (bad octet value). X-Received-From: 2607:f8b0:400d:c01::231 X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.devel:168924 Archived-At: On 01/22/2014 12:29 PM, Phillip Lord wrote: > Eli Zaretskii writes: >>> A better way is to build on the hard work of other and interface >>> emacs with an external tool. >> >> Personally, I think implementing such features via external programs >> is a terrible design. It will never be smooth and responsive enough, >> and on top of that you'd need to track development of those other >> tools. And what if they become abandoned some day? > > > I think that it depends on the language. Introspecting over, for > example, Java would require an awful of elisp, which would be difficult > to write. Getting Java to do this work is quite a lot less effort. > Hence, the JDEEs use of Java for this (via bsh). Likewise, Clojure and > Scala both of which use their own language to do much of the work. Or > for that matter, common lisp with slime/swank. Or even, for that matter, > English with aspell. I didn't have a problem with responsiveness with > any of these. I don't think it is a good idea to consider the problem of doing smart completion in Emacs as "Emacs Lisp VS External library". It is much more advantageous to figure out what each is best at and do that instead. There are certainly examples on both extremes. CEDET and Semantic by themselves can parse surprisingly large C++ code bases and provide smart completion quite accurately, but as the code base grows, it gets slower. It also took a really long time to implement in my spare time in spite of the vast amount of help I've gotten from its users. There are also completion you can implement by passing entire buffers into an external parser as explained by Jorgen for Python, and I think clang could do something similar. These were coded more quickly, and can provide rapid results. I think it would be better to have a strong mix between the two. I am of course a bit biased since I've put support for this in CEDET quite a while ago. The premise for those who haven't studied how the smart completion engine in CEDET works is pretty simple. Emacs is in charge of basic buffer parsing. As David explained, it is a simple tagging parser, but unlike etags/ctags, it collects much more detailed information. It also has a local context parser, allowing it to find local variables, and identify the kind of command the cursor is sitting on, such as an assignment, struct dereferences, etc. Once that basic part is done, the smart completion engine starts looking up symbols. It does this via a series of 'semanticdb' EIEIO objects that are associated with the buffer. With no external program support, it uses an all Emacs solution to lookup header files or whatever that language uses. Alternately, there are external programs wrapped up in this EIEIO class that can provide the same services. Thus for Java there is a 'javap' service that can find symbols in .jar files to provide the answer. There are many external programs such as GNU Global, idutils, cscope, and javap that are already supported, and each provides different levels of support based on what they can do. They all make CEDET faster or more accurate when in use. It is tempting to go with an entirely external solution. They can usually be wrapped up by Emacs in pretty quickly. There are additional advantages aside from smart completion to adding parsing support for a language directly to Emacs however. What CEDET does is place overlays in the buffer identifying the tags and their nesting. Simple queries can tell you exactly where you are structurally in a program with no regexp calls, searching, or other time-consuming activities. You can use this for breadcrumbs, decorations, named bookmarks, navigation, and any kind of function that needs to know where you are by name. Semantic also can provide access to the current buffer tag-list at next to 0 cost when asked (assuming the idle timers have had a chance to run) making think like imenu, which-func, speedbar, and ECB very fast. It seems unlikely an external tool could do all that without quite a bit of effort. Lastly, most parts of CEDET/Semantic's parsing and completion engines can be replaced per-mode at almost any level, not just at the database level. As such, if someone really wants to use an external tool to parse a buffer or provide completion (2 different operations), it will let you do it, and all the existing CEDET tools will then work just fine on top of the result. Eric