我正在使用 Eclipse 3.4.2 来开发我的代码。作为我的项目定义的一部分,我引用了一个实用程序库,我已将源代码附加到该库中。到目前为止,一切顺利 - 当我从库中调出类时以及在调试时,我可以看到该源代码。
但是,现在我想对其中一个类进行更改,同时仍保留 Eclipse Java 编辑器的所有功能(特别是工具提示和快速修复等功能)。这些功能在我查看源代码时似乎有效(例如,我可以通过方法名称按 CTRL+LClick),但它是只读的。另一方面,我可以显式打开源文件并进行编辑,但我失去了所有“智能”编辑功能。
我最近从 IntelliJ 切换到 Eclipse,这是可能的,所以我希望它也能在 Eclipse 中使用。请注意,虽然我可以简单地将代码作为项目包含在我的工作区中,但我真的不愿意这样做。工作区已经很大,我不想通过添加我很少接触的项目来进一步降低 Eclipse 的速度。
最佳答案
我不确定我是否正确回答了您的问题。当您将预编译库添加到您的项目构建路径(JAR)并将源代码附加到该 JAR 时,当您单击 JAR 中的 .class 时,Eclipse 将向您显示源代码。调试器也是如此,如果 JAR 中的类是使用行号信息编译的,它还允许您单步执行源代码中的代码行。
现在你似乎想做的是修改 JAR 中的类(源 View 只是一个覆盖层,如果你附加不同版本的源代码,它甚至可以关闭),这是不可能的,因为它们以二进制形式包装在 JAR 存档中 - 尽管 Eclipse 足够智能,可以单独显示它们。
我想您会希望调试器将您的更改热交换到正在运行的程序中。这只能在完成更改后通过重新编译来完成。通常,当您保存 Java 源文件时,Eclipse 会自动执行此操作。然而,由于您的源文件不是工作区的一部分(或明确声明为 Java 源的外部文件夹)——它不会重新编译和交换。
我建议将外部库的源代码作为一个项目包含在 Eclipse 中,而不用太担心性能 - 我每天都使用 3.4.2,我的工作区有大约 45 个打开的项目,其中有几个 10.000 个类和数百万个的代码行。我为 Eclipse VM 分配了 1 GB 的 RAM,并且在 Core2Duo 2.6GHz 机器上没有问题。
关于java - Eclipse:是否可以编辑通过源代码 "attachment"已知的 Java 源代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/830648/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
在rails源中:https://github.com/rails/rails/blob/master/activesupport/lib/active_support/lazy_load_hooks.rb可以看到以下内容@load_hooks=Hash.new{|h,k|h[k]=[]}在IRB中,它只是初始化一个空哈希。和做有什么区别@load_hooks=Hash.new 最佳答案 查看rubydocumentationforHashnew→new_hashclicktotogglesourcenew(obj)→new_has
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
我的主要目标是能够完全理解我正在使用的库/gem。我尝试在Github上从头到尾阅读源代码,但这真的很难。我认为更有趣、更温和的踏脚石就是在使用时阅读每个库/gem方法的源代码。例如,我想知道RubyonRails中的redirect_to方法是如何工作的:如何查找redirect_to方法的源代码?我知道在pry中我可以执行类似show-methodmethod的操作,但我如何才能对Rails框架中的方法执行此操作?您对我如何更好地理解Gem及其API有什么建议吗?仅仅阅读源代码似乎真的很难,尤其是对于框架。谢谢! 最佳答案 Ru