CodeRunner 介绍
CodeRunner 是 Mac 上一款功能强大但使用简单代码工具,官方介绍支持几乎所有语言(20种语言),同时支持语法高亮、代码提示和多种界面主题,在学习新的语言或编写简单测试代码时非常实用。
我常常用它来管理一些代码片段和测试不确定的语言特性以及测试第三方开发包的接口行为。但 CodeRunner 并不是一个完整的 IDE,仅仅只能编译和运行单个文件,很多时候我们可能需要用编写并编译多个源文件或包含第三方库,这时候 CodeRunner 就完成不了了。所幸,CodeRunner 支持语言扩充,下面我们以 Java 为例,介绍支持多个 java 文件并导入第三方 jar 包。
扩充Java支持
首先,打开 CodeRunner 点击菜单 Preferences -> Languages ,从左侧列表中找到 Java,点击下面的齿轮按钮,选择 Duplicate ,将其命名为Java Ext。
这样我们就复制了一份 Java 语言支持,在此基础上我们修改使其支持多个源文件和包含 jar 包。点击右侧的 Edit Script... 按钮,此时会在 CodeRunner 的编辑器内打开编译脚本 compile.sh ,这个脚本定义了如何编译 java 文件。我们只需要修改该脚本文件使其按我们期望的方式编译源文件并正确运行即可,我们的期望是--编译文件所在目录下面所有的源文件,并链接该目录下所有的 jar 包。
-
首先,我们需要指示编译脚本编译所有 java 文件。
最简单的处理方法是使用通配符*.java
,我们只需找到下列行:CR_FILENAME="$packageDirectory"/"$CR_FILENAME"
替换为:
CR_FILENAME="$packageDirectory"/*.java
这样,编译时就会将源文件所在目录下的所有 java 文件都编译了。
-
接下来我们需要链接目录下面所有的 jar 文件。
我们只需要搜索当前目录下所有的jar 文件,并把他加到 classpath 中(在 java 执行时,如需要引用 jar 包,同时必须将.
加入到 classpath 中),下面的脚本可以完成这件事:find . "(" -name "." -or -name "*.jar" ")" | sed '$!N;s/\n/:/g'
我们把他添加到脚本中,找到下面这行:
javac "$CR_FILENAME" -encoding ${enc[$CR_ENCODING]} "${@:1}"
在之前添加 CLASSPATH 变量,并添加编译参数:
CLASSPATH=`find . "(" -name "." -or -name "*.jar" ")" | sed '$!N;s/\n/:/g'` javac "$CR_FILENAME" -encoding ${enc[$CR_ENCODING]} -classpath "$CLASSPATH" "${@:1}"
-
同样,在编译完成后执行时,也需要引用 CLASSPATH。
因此,我们找到下面这行:echo "cd \"$PWD\"; java $out"
添加
-classpath
参数:echo "cd \"$PWD\"; java -classpath $CLASSPATH $out"
保存并关闭脚本编辑,完成。
此时,我们就已经建立一个新的语言支持 Java Ext,它能够编译同一文件夹内的多个源文件并自动链接该文件夹下的 jar 文件。
测试
我们以 fastjson 为例测试 Java Ext 的支持。
新建一个文件夹
TestFastjson
,将下载的 fastjson 包复制到文件夹内。打开 CodeRunner 新建一个文件,选择语言
Java Ext
,将生成模版的类名改为FTClass
,command+s
将文件命名为FTClass.java
保存到刚刚新建的目录下。-
新建另一个文件,改为
User
类,内容如下:import com.alibaba.fastjson.annotation.JSONField; class User { @JSONField(name = "USER_ID") private String userId; @JSONField(name = "USER_NAME") private String userName; public String getUserId() { return userId; } public void setUserId(String userId) { this.userId = userId; } public String getUserName() { return userName; } public void setUserName(String userName) { this.userName = userName; } }
同样保存到新建的目录下,这里我们已经 import 了 fastjson 的包。
-
回到
FTClass.java
文件,我们添加一些简单的测试代码:import com.alibaba.fastjson.*; import java.util.*; class FTClass { public static void main(String[] args) { User user = new User(); user.setUserId("admin"); user.setUserName("Creaman Xu"); System.out.print(JSON.toJSONString(user)); } }
command+s
保存。 -
现在我们的测试文件夹应该有三个文件:
img_02.png
点击运行,命令行能够正确的输出:
img_03.png
说明 Java Ext 可以正常工作了。
I/O Encoding
如果产生错误,有时候命令行会打印乱码,那是因为 java 默认输出是 UTF8 编码,但 CodeRunner 使用的默认编码格式不是 UTF8,我们可以在设置中将其改为 UTF8,这样就不会产生乱码了。
后记
CodeRunner 仅仅是一个非常方便的代码测试和学习的工具,它并不是一个完整的 IDE,在功能上还不是十分的完整,例如不支持 package,但仅仅作为一个代码测试工具真的是非常易用和方便了,而且,价格也不贵。