From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Eric Ludlam Newsgroups: gmane.emacs.devel Subject: Re: IDE Date: Wed, 21 Oct 2015 18:52:55 -0400 Message-ID: <56281747.9050305@gmail.com> References: <83bncf3f9k.fsf@gnu.org> <5610E0BC.8090902@online.de> <83si5r106e.fsf@gnu.org> <831td9z18h.fsf@gnu.org> <5612E996.7090700@yandex.ru> <83bnc7tavr.fsf@gnu.org> <5618C92A.3040207@yandex.ru> <83a8rrt9ag.fsf@gnu.org> <871tcyexa9.fsf@fimbulvetr.bsc.es> <87612a7my2.fsf@fencepost.gnu.org> <561DC925.5050001@siege-engine.com> <561E32D2.4060501@yandex.ru> <83wpum3ozk.fsf@gnu.org> <87si59ln6u.fsf@isaac.fritz.box> <56224B63.3010803@yandex.ru> <562592ED.1070104@siege-engine.com> <56262577.70107@yandex.ru> <562702C2.6070505@gmail.com> <56276ECE.3090508@yandex.ru> NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit X-Trace: ger.gmane.org 1445467996 18737 80.91.229.3 (21 Oct 2015 22:53:16 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Wed, 21 Oct 2015 22:53:16 +0000 (UTC) Cc: John Wiegley , emacs-devel@gnu.org To: Dmitry Gutov , Eric Ludlam , David Engster Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Thu Oct 22 00:53:08 2015 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 1Zp2Fl-00055G-Us for ged-emacs-devel@m.gmane.org; Thu, 22 Oct 2015 00:53:06 +0200 Original-Received: from localhost ([::1]:54768 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Zp2Fl-0001Sa-AI for ged-emacs-devel@m.gmane.org; Wed, 21 Oct 2015 18:53:05 -0400 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:43899) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Zp2Fh-0001Rz-88 for emacs-devel@gnu.org; Wed, 21 Oct 2015 18:53:02 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Zp2Fd-0001yz-VR for emacs-devel@gnu.org; Wed, 21 Oct 2015 18:53:01 -0400 Original-Received: from mail-yk0-x231.google.com ([2607:f8b0:4002:c07::231]:34271) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Zp2Fd-0001yn-PZ for emacs-devel@gnu.org; Wed, 21 Oct 2015 18:52:57 -0400 Original-Received: by ykdr3 with SMTP id r3so65568954ykd.1 for ; Wed, 21 Oct 2015 15:52:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=subject:to:references:cc:from:message-id:date:user-agent :mime-version:in-reply-to:content-type:content-transfer-encoding; bh=yzlH+HZpnilbWAogzSkXU2Q4S4EbuVwOgzjaPSM09Pw=; b=w0M0EdhvpmnyGsZ+CKGqwRvCeyDb51Bl9GfOQBVWMVKDTsT9FYtnY+GAGumTlFuX+P usNn5CXNy5ZXzdIk1LhZzObImbqVY+Ag66l7gxJzl7bs9y0lE6XC3YipvGNkj6jol57c p7n/E+gAcFZbR0TKJ+H0svW2Got9WgK5dRQ+qYEubHu3s3yLiiPldlAQQJLtb1l3mMKF TKG6JRHqI2H/lN+34y6cpqrezXiXZ56GhlcXdb6WXEyJSlnIH9urCZ4ufjUFPKDKVGMg 8eGN7jZyaeq/dY80SgVMhKdowr3SbapDHX9H3fpuagSdKQjrVo0nCss928/QwPlbPAsP 40Ug== X-Received: by 10.129.72.71 with SMTP id v68mr8719576ywa.14.1445467977414; Wed, 21 Oct 2015 15:52:57 -0700 (PDT) Original-Received: from [192.168.1.202] (pool-71-184-198-118.bstnma.fios.verizon.net. [71.184.198.118]) by smtp.googlemail.com with ESMTPSA id x3sm1348528ywb.9.2015.10.21.15.52.56 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 21 Oct 2015 15:52:56 -0700 (PDT) User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.3.0 In-Reply-To: <56276ECE.3090508@yandex.ru> X-detected-operating-system: by eggs.gnu.org: Error: Malformed IPv6 address (bad octet value). X-Received-From: 2607:f8b0:4002:c07::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:192333 Archived-At: On 10/21/2015 06:54 AM, Dmitry Gutov wrote: > On 10/21/2015 06:13 AM, Eric Ludlam wrote: > >> Ruby support tooling itself would not benefit from CEDET integration, >> but tools built on CEDET would gain Ruby support, and that improves the >> diversity of Ruby related tools available. > > If CEDET support won't improve Robe, and if the said support will > amount to writing a Wisent grammar, it just becomes a separate task. > > Which I don't object to doing, in principle, but it'll go to the > bottom of the pile, in terms of priority. I don't think it is about if CEDET improves ROBE. I looked at ROBE on github, and think there is some core piece of it regarding talking to ruby that can be integrated as an extension of CEDET. You could then use the company-mode, auto-complete, plus many other tools that already use CEDET APIs, and could delete that code from robe. In other words, your ruby experience would have more options without having to add them to robe yourself. It is speculative to suggest that writing a ruby wisent parser would take less time than to write all the same types of extensions already on top of CEDET in Robe since I'm not sure which subset of features is the useful subset for something like ruby. >> Inside this feature you must have a way to query for the location of a >> particular symbol, and convert a symbol into a doc reference. > > In both cases, I often have to prompt the user (with completing-read) > to disambiguate between classes that define the method with the given > name. > In this case, things like semantic-complete-jump you could use the TAB technique to disambiguate, and semantic-ia-complete-jump might be able to distinguish depending on what sort of type information is available. There is at least one contribution on top of cedet that do similar disambiguation using fancy uis. I think it copied a textmate feature. >> The output is a list of matches as faux tags. If an application wanted >> to know more about the symbol, it would pull in the reference file, and >> extract real tag data using whatever parser is available. > > So as faux tags, I could return all methods with the same name from > different classes? Yes. You would provide what you do know (full class names, fields, methods, different file locations, etc) which could be initially reasoned on. Sometimes no more is needed. Other times those files might be opened to get more data using a better wisent parser. The semantic javap extension pulls java tags from Jar files, and does not need to claim they are temporary tags because the data provided is as-good as the java parser. If your ruby system is similar, then the system would not need to extract additional data from the source file. >> This would enable Semantic's jump to tag system to be as accurate as >> yours. > > Would that be semantic-complete-jump or semantic-ia-fast-jump? > Both, plus other similar functions different people have written. >> An EDE type project for ruby (whatever that looks like) would provide a >> place to hang project specific REPL buffers as needed. > > How? Using which major mode? I current use inf-ruby for that (not > available in Emacs, for copyright assignment reasons). So it seems I'd > have to add multi-REPL support for it first. > > The conceptually hard question is what do you do with external files > that can be referenced from different projects? Suppose you have two > open projects, each with its own REPL, you made a jump to an external > file from project1. The you want to "jump to definition" on some > method call in there. How do you pick the right REPL to ask for info? > In C++ and Java, the common files would be 'system' includes. The naming is a bit C centric, but the basic idea is that there are system includes projects refer to, and those in turn aren't in a project, but refer to system paths to continue navigating between themselves. If you instead refer to a library of files unrelated to the system, then ideally those would have their own project structure around them to enable correct navigation. Of course, the above examples for C don't have external REPL buffers to maintain, but might use independent GNU Global databases which are less heavy weight than an external process-per-project. > Suppose, after the first jump, you saved the reference to the right > project in a buffer-local variable, so you can refer to it for the > second jump. What if I want to do the next jump not from the same > exact file, but from its neighbor? As a user, I can be confident that > both files must be referenced by the project, but there will be no > buffer-local value to use. > I'm not sure I followed this. The shared code refers back to project1 in some way? This sounds like messy code you wouldn't want to write so I'm not sure I understand what you are trying to do. Standard emacs mark-ring stuff is usually sufficient for traveling back. > Finding an idiomatic approach to that would be great. > >>> - It misses some trivial opportunities to infer the type of a local >>> variable. That would be my first priority to work on... when I deal >>> with all that project and xref stuff in the core, I guess. >> >> I'm not sure which code bit you are referencing here. If you do your >> tag parsing with a semantic grammar, then you can optionally use that >> same grammar to parse function bodies, and thus make detecting local >> variable types a bit easier. I'm speculating however as I am not >> familiar with Ruby. > > I don't know how much work would that be. Ruby doesn't have anything > close to official, up-to-date BNF grammar. And it's pretty complex. > > At the moment, I'm doing context parsing in Elisp, so fix for the > "trivial opportunities" might also be in Elisp, at first, with a few > simple regexp searches. > > However, I'm seriously considering moving that part (and more) to > Ruby, so that authors of integration with other editors won't have to > redo that work: > > - There's a feature request for Vim support. > - Someone actually implemented an Atom plugin already (not at all > popular so far, but that doesn't matter). > > I'd also be able to reuse an existing parser. There is one that's been > gaining in popularity over the last years. > Semantic doesn't demand it's parsers be in wisent, or even in Emacs at all. If you have a nice Ruby grammar in Ruby, and you can convert it's internal data into lisp-like syntax, pulling it into the Semantic system is pretty easy. What you would loose is dynamic reparsing without having to save, thus it may be a bit quirky. >> There is a wisent based grammar for Ruby in the 'contrib' area that >> seems straightforward. It would probably not be much of a stretch to >> build one with the right releases to include in Emacs, solve this one >> problem, and then get support from other CEDET tools. > > Since that grammar has been outside of Emacs for so long, I always > assumed that the author vanished, and obtaining the release is > impossible. > Indeed, I suggested it to simply show someone made a useful grammar that looks relatively simple. Eric