The following is frequently used ant script, compile some java source codes with a libary path, then copy all non-java files to compiled folder:

<property name="src.dir" value="${basedir}/src" />

<property name="src.class.dir" value="${webroot.dir}/web-inf/classes" />

<path id="lib.path">

    <fileset dir="${webroot.dir}/web-inf/lib">

        <include name="**/*.jar" />

    </fileset>

</path>

<target name="compile-src" depends="init" description="compile java sources">

    <javac srcdir="${src.dir}" destdir="${src.class.dir}" encoding="utf-8"

            debug="true" classpathref="lib.path" failonerror="false"/>

    <copy todir="${src.class.dir}">

        <fileset dir="${src.dir}">

            <exclude name="**/*.java" />

        </fileset>

    </copy>

</target>

The corresponding shell script is:

src_dir=/vagrant/codes/GCP6.1/src

web_build=/vagrant/codes/web_build

class_dir=$web_build/web_server/webapps/GCP6.1/WEB-INF/classes

lib_dir=/vagrant/codes/GCP6.1/WebRoot/WEB-INF/lib

find $src_dir -type f -name "*.java" -exec javac -cp "$lib_dir/*:$src_dir" -d $class_dir {} \;

rsync -auC --exclude='*.java' $src_dir/ $class_dir/

Take care there's no folder named "core" in $src_dir, or it will be excluded by the "-C" option of rsync command.

A Test Case

$ tree

.

├── classes

├── lib

│   ├── libadd.jar

│   └── libmul.jar

├── libadd

│   └── com

│       └── boco

│           └── gcp

│               └── add

│                   ├── MyAdd.class

│                   └── MyAdd.java

├── libmul

│   └── com

│       └── boco

│           └── gcp

│               └── mul

│                   ├── MyMul.class

│                   └── MyMul.java

└── main

    └── com

        └── boco

            └── gcp

                ├── Test.java

                └── util

                    └── MyUtil.java

17 directories, 8 files

$ find . -name '*.java' -exec cat {} \; -exec echo "--------" \;

package com.boco.gcp.util;

import com.boco.gcp.add.MyAdd;

import com.boco.gcp.mul.MyMul;

public class MyUtil {

    public int newadd(int x, int y) {

        MyAdd add = new MyAdd();

        MyMul mul = new MyMul();

        return add.myadd(3,5) + mul.mymul(3,5);

    }

}

--------

package com.boco.gcp;

import com.boco.gcp.mul.MyMul;

import com.boco.gcp.add.MyAdd;

import com.boco.gcp.util.MyUtil;

public class Test {

    public static void main(String[] args) {

        MyMul mul = new MyMul();

        MyAdd add = new MyAdd();

        System.out.println(mul.mymul(3,5));

        System.out.println(add.myadd(3,5));

        MyUtil util = new MyUtil();

        System.out.println(util.newadd(3,5));

    }

}

--------

package com.boco.gcp.mul;

public class MyMul {

    public int mymul(int x, int y) {

        return 10*x*y;

    }

    public static void main(String[] args) {

        MyMul mul = new MyMul();

        System.out.println(mul.mymul(3,5));

    }

}

--------

package com.boco.gcp.add;

public class MyAdd {

    public int myadd(int x, int y){

        return 10*x+y;

    }

    public static void main(String[] args) {

        MyAdd add = new MyAdd();

        System.out.println(add.myadd(3,5));

    }

}

--------

$ find main -name '*.java' -exec javac -cp 'lib/*:main' {} -d classes \;

$ tree classes/

classes/

└── com

    └── boco

        └── gcp

            ├── Test.class

            └── util

                └── MyUtil.class

Compile Java Codes in Linux Shell instead of Ant Script的更多相关文章

  1. java代码运行linux shell操作

    1.Java调用shell  Java语言以其跨平台性和简易性而著称,在Java里面的lang包里(java.lang.Runtime)提供了一个允许Java程序与该程序所运行的环境交互的接口,这就是 ...

  2. Java 连接远程Linux 服务器执行 shell 脚本查看 CPU、内存、硬盘信息

    pom.xml jar 包支持 <dependency> <groupId>com.jcraft</groupId> <artifactId>jsch& ...

  3. java使用Runtime.exec()运行windwos dos或linux shell命令

    使用Runtime.exec()运行windwos dos或linux shell命令,按实际情况具体测试     实例代码: package com.bookoo.test.command; imp ...

  4. Java文件操作API功能与Windows DOS命令和Linux Shell 命令类比

    Java文件操作API功能与Windows DOS命令和Linux Shell 命令类比: Unix/Linux (Bash) Windows(MS-DOS) Java 进入目录 cd cd - 创建 ...

  5. java远程调用linux的命令或者脚本

    转载自:http://eksliang.iteye.com/blog/2105862 Java通过SSH2协议执行远程Shell脚本(ganymed-ssh2-build210.jar) 使用步骤如下 ...

  6. java classpath批量设置shell脚本

    java classpath批量设置shell脚本   注意:linux bash jar文件之间的分隔符是':'    export JAR_HOME=path to directory which ...

  7. linux shell 使用总结

    为什么执行脚本要使用./ +脚本名来执行脚本理解:因为如果直接使用脚本名,那么linux 系统会去path 路径查找如去/bin usr/bin 等查找,这个时候会找不到这个脚本名字,就会报错.使用. ...

  8. paip.注册java程序为LINUX系统服务的总结。

    paip.注册java程序为LINUX系统服务的总结. ////////////////实现开机启动. 标准方法是按照/etc/init.d/下面的文件,修改一下:然后chkconfig xxx on ...

  9. linux shell 流程控制

    导读 和Java.PHP等语言不一样,linux shell有一套自己的流程控制语句,其中包括条件语句(if),循环语句(for,while),选择语句(case).下面我将通过例子介绍下,各个语句使 ...

随机推荐

  1. Python中任务队列-芹菜celery的使用

    一.关于celery 芹菜celery是一个python实现的异步任务队列,可以用于爬虫.web后台查询.计算等等.通过任务队列,当一个任务来临时不再傻傻等待. 他的架构如下: Broker 我们的生 ...

  2. AcWing 204. 表达整数的奇怪方式

    #include<bits/stdc++.h> using namespace std; typedef long long LL; LL exgcd(LL a,LL b,LL & ...

  3. SpringCloud:Eureka 配置心跳机制

    Server服务端 server:   port: 8761 eureka:   client:     #实例是否在eureka服务器上注册自己的信息以提供其他服务发现,默认为true     re ...

  4. 构建自己的dockerfile

    一)创建自己的CentOS 构建dockerfile的原理图 Docker Hub中99%的镜像都是从FROM scratch这个基础镜像过来的.然后配置需要的软件和配置来进行构建. FROM #基础 ...

  5. postgresql安装及配置

    目录 1. 安装 2. PostgrepSQL的简单配置 2.1 修改监听的ip和端口 2.2 修改数据库log相关的参数 2.3 内存参数 3. 数据库的基础操作 3.1 连接数据库控制台 3.2 ...

  6. C++ 继承及委托

    从内存角度看继承和多重继承 http://www.doc88.com/p-9075148832569.html 在C++中实现委托(Delegate) https://blog.csdn.net/jf ...

  7. win10 删除WPS提示存在wpsupdate.exe进程

    这个进程在:WIN10  任务管理器  的"详细列表"查找可能有1-2个类似的,全部关闭才能删除

  8. python 遍历字典中的键和值

    #遍历字典中的所有键和值 zd1={"姓名":"张三","年龄":20,"性别":"女"} zd2= ...

  9. 团队开发day10

    项目整合成功,测试功能基本达到,目标完成!

  10. clickhouse分布式集群

    一.环境准备: 主机 系统 应用 ip ckh-01 centos 8 jdk,zookeeper,clickhouse 192.168.205.190 ckh-02 centos 8 jdk,zoo ...