您提出的两个问题是齐头并进的。让我们从元数据开始。弄清楚如何跟踪 IDE 的项目元数据的最佳方法是查看已建立的项目如何尝试执行此操作。
Eclipse 和 Netbeans 都使用在项目根目录中创建的项目文件夹来保存元数据(Eclipse 中的.settings,Netbeans 中的.nbproject)。源文件夹、编译器目标目录、源级别等元数据保存在元数据文件中,主要是 XML。
您可能希望遵循类似的内容,然后考虑添加常见的项目原型,例如 /src 和 /classes 或 /src/main/java 和 /target。这导致您的问题的第二部分,编译。
Netbeans 本身并不直接使用编译器。 Eclipse 可以,但这是因为 Eclipse 有自己的内部编译器实现来提供默认编译器中不可用的额外警告和配置。对于您的 IDE,我将看看 Netbeans 如何管理其项目并对其进行编译。 Netbeans 没有调用javac,而是使用Ant 和一个内部build.xml 文件。如果您不熟悉 Ant,它只是一个工具,允许您在 XML 中设置由 Ant 解释和运行的任务。例如,您可以使用 Ant 编译 Java 源代码、生成文档和创建分发 JAR。这是一个非常强大的工具,可让您将整个构建过程作为一种脚本自动化。
你可以遵循同样的想法。您的 IDE 中的新项目将有一个默认的 build.xml 文件,该文件将使用一些默认的 Ant 目标构建他们的项目。您也可以从build.xml 访问属性文件,因此您可以将有关源目录的信息以及您想在构建脚本中使用的任何其他可定制信息存储在属性文件中,并将它们导入构建脚本中。这是一个示例设置。
文件结构:
| Project root/
| .myideproject/
| build.xml
| project.properties
| ui.properties
| classes/
| <compiled .class files>
| doc/
| <generated javadoc files>
| lib/
| <3rd-party .jar files needed for compilation>
| src/
| <user .java files>
build.xml 文件是 IDE 用来编译的文件。您可以要求用户安装 Ant(一个快速而轻松的过程),也可以像 Netbeans 那样捆绑它(为您做更多的工作)。无论哪种情况,如果您将build.xml 嵌套在.myideproject 目录中,您的构建文件将如下所示:
<project name="<User's project name>" default="compile" basedir="..">
<!-- ... -->
</project>
注意两件事:
- “用户的项目名称”由用户在创建项目时提供。
- “默认”属性将指向构建文件中的目标。
- “basedir”属性将使构建过程变基,使其指向项目根目录中的目录,而不是
.myideproject中的目录。
接下来您需要导入您的project.properties 文件(ui.properties 用于保存与 UI 相关的数据,而不用于构建脚本,project.properties 包含构建脚本正常运行所需的所有内容)。这是您将属性导入 Ant 项目的方式:
<project ... >
<import file=".myideproject/project.properties" />
<!-- ... -->
</project>
这将使用指令${propname} 使project.properties 中的所有属性可用。现在,src 和classes 是project.properties 文件中的可配置目录,我们可以在compile 目标中使用它们,如下所示:
<target name="compile">
<javac srcdir="${src}"
destdir="${target}"
classpath="${classpath}"
source="${src.jdk}"
target="${target.jdk}"
debug="on"
debugLevel="lines,vars,source" />
</target>
对于上述目标,属性文件可能如下所示:
# delimits source directories containing .java files using ':'
src=src1:src2
# only 1 directory, it's where the .class files go
target=classes
# ':'-delimited list of jars or globs which are needed for compilation
classpath=lib/*
# Determines the -source value on the javac process
src.jdk=1.6
# Determines the -target value on the javac process
target.jdk=1.6
为了清楚起见,cmets 就在那里。此属性文件将使用用户输入从您的 IDE 的 UI 构建,因此如果他们添加或删除源文件夹,属性文件中的 src 值会自动更改,然后他们可以重建该过程。
这应该足以让您入门。需要考虑的一些事项:
- 您将需要一个
run 目标,它使用 java 任务以及 IDE 设置的属性来告诉它哪个类用于 main 方法。
- 您可能还需要考虑支持 Maven 项目,这有助于用户自动解决依赖关系。这对你来说会做更多的工作,你可能应该等到你完成 Ant 支持
- 您需要将标准输出/错误/输入从 Ant 进程重定向到用户可以与之交互的东西。您不必支持标准输入,但您至少应该支持标准输出/错误
根据您的评论的最后一句话:您需要使用带有扩展 DefaultMutableTreeNode 的自定义节点类的 JTree 来创建视图,但它不必是文件结构的视图,因此只是项目的一个视图,所以也许它可能是这样的:
+ Project 1 Name
| + Source Folder 1
| <.java files>
| + Source Folder 2
| <.java files>
| + Source Folder 3
| <.java files>
+ Project 2 Name
| + Source Folder 1
| <.java files>
| + Source Folder 2
| <.java files>
| + Source Folder 3
| <.java files>
结构可以基于文件系统,但只显示用户需要的信息,比如他的源目录。你可以从那里扩展这个想法。
祝你好运,听起来是个有趣的项目。希望我的建议有一定的意义,可以帮助你。如果有任何需要澄清的地方,请告诉我。