随手写的自动批量编译部署NativeAndroid程序Python脚本
背景
有一堆工程NativeAndroid程序,要一一编译部署编译测试,手头只有AndroidManifest和Makefile,需要一个个Update,Ndk-build,和发包安装测试,很是头疼,也没搜到和我类似需求的,用batch各种问题,只好换路,Python花了一上午临时抱佛脚的,如有建议欢迎指教。
使用环境
-- Python3.x
-- AndroidNDK
-- AndroidSDK
-- Ant
并确保配置好在Path中
说明
看注释
- Code
#!/usr/bin/python
# -*- coding: utf-8 -*-
#用于批量编译NativeAndroid程序
#AutoBuild all sub native android projects
#Zephyr 20141203
import os
import sys #指定编译目录名
targetBuildDir = 'jni' #'Android'
#指定目标Android版本
targetVersion = 'android-18'
#Build Configuration调试模式 debug/release
Configuration= 'debug'
#是否输出详细编译信息
VerbosBuildInfo = 1
#黑名单,如果遇到以下目录,就不再予以遍历
blackList = ['obj','res','libs','bin','iOS','src'] #全局变量
curRootDir = os.getcwd()
dirVec=[] def GetProcessorCount():
try:
platform = sys.platform
if platform == 'win32':
if 'NUMBER_OF_PROCESSORS' in os.environ:
return int(os.environ['NUMBER_OF_PROCESSORS'])
else:
return 8
else:
from numpy.distutils import cpuinfo
return cpuinfo.cpu._getNCPUs()
except Exception:
print('Cannot know cpuinfo, use default 4 cpu')
return 8 def WalkDir(rootDir, level=1):
if level==1: print rootDir
for lists in os.listdir(rootDir):
path = os.path.join(rootDir, lists)
if os.path.isdir(path):
print '│ '*(level-1)+'│--'+lists
if not lists in blackList:
if lists == targetBuildDir:
#print('-----path: '+path)
#取得父级目录
parentDir = os.path.dirname(path)
#print('-----parentDir: '+parentDir)
dirVec.append(parentDir)
print('-----添加编译目录:'+parentDir)
else:
WalkDir(path, level+1) def DoBuild():
print('---------开始DoBuild---------')
numProcessor = GetProcessorCount()
UpdateCMD = 'android update project -p . -s -t %s' % (targetVersion)
print('UpdateCMD: '+UpdateCMD)
isDebug = ( Configuration == 'debug' )
NDKBuildCMD = 'ndk-build V=%d -j%d NDK_DEBUG=%d' % (VerbosBuildInfo, numProcessor, isDebug)
print('NDKBuildCMD: '+NDKBuildCMD)
AntCMD = 'ant %s install' % (Configuration)
print('AntCMD: '+AntCMD)
projectCount = 0
if 1:
for dir in dirVec:
androidDir = dir
print('---------开始Update---------')
print('所在目录:'+androidDir)
projectCount += 1
if 1:
os.chdir(androidDir)
os.system(UpdateCMD)
#依据mk文件相对路径决定是否要进入jni目录
os.chdir('jni')
print('==========开始编译')
os.system(NDKBuildCMD)
os.chdir('../')
print('==========装包APK')
os.system(AntCMD)
print('==========当前处理完成:'+androidDir)
#os.chdir(curRootDir)
#print('---------切回主目录---------')
projectCount += 1
print('---------恭喜,完成%d个工程编译,已安装到设备---------' %(projectCount)) #MAIN
WalkDir(curRootDir)
DoBuild()
Code EN
-
#!/usr/bin/python
# -*- coding: utf-8 -*-
#Batch compileNativeAndroid
#AutoBuild all sub native android projects
#Zephyr 20141203
import os
import sys #Target compile directory
targetBuildDir = 'jni'
#Target Android version
targetVersion = 'android-19'
#Build Configuration: debug/release
Configuration= 'debug'
#Will output detail compile info
VerbosBuildInfo = 0
#Blacklist for skip-directory
blackList = ['obj','res','libs','bin','iOS','src'] #Global
curRootDir = os.getcwd()
dirVec=[] def GetProcessorCount():
try:
platform = sys.platform
if platform == 'win32':
if 'NUMBER_OF_PROCESSORS' in os.environ:
return int(os.environ['NUMBER_OF_PROCESSORS'])
else:
return 8
else:
from numpy.distutils import cpuinfo
return cpuinfo.cpu._getNCPUs()
except Exception:
print('Cannot know cpuinfo, use default 4 cpu')
return 8 def WalkDir(rootDir, level=1):
if level==1: print rootDir
for lists in os.listdir(rootDir):
path = os.path.join(rootDir, lists)
if os.path.isdir(path):
print '│ '*(level-1)+'│--'+lists
if not lists in blackList:
if lists == targetBuildDir:
#Get parent directory
parentDir = os.path.dirname(path)
dirVec.append(parentDir)
print('-----add compile directory:'+parentDir)
else:
WalkDir(path, level+1) def DoBuild():
print('---------Begin DoBuild---------')
numProcessor = GetProcessorCount()
UpdateCMD = 'android update project -p . -s -t %s' % (targetVersion)
print('UpdateCMD: '+UpdateCMD)
isDebug = ( Configuration == 'debug' )
NDKBuildCMD = 'ndk-build V=%d -j%d NDK_DEBUG=%d' % (VerbosBuildInfo, numProcessor, isDebug)
print('NDKBuildCMD: '+NDKBuildCMD)
AntCMD = 'ant %s install' % (Configuration)
print('AntCMD: '+AntCMD)
projectCount = 0
if 1:
for dir in dirVec:
androidDir = dir
print('---------Begin Update---------')
print('Current directory:'+androidDir)
projectCount += 1
if 1:
os.chdir(androidDir)
os.system(UpdateCMD)
#Rely on make file to decide whether cd into jni directory
#os.chdir('jni')
print('==========Begin compile')
os.system(NDKBuildCMD)
#os.chdir('../')
print('==========building APK')
os.system(AntCMD)
print('==========work done on:'+androidDir)
#os.chdir(curRootDir)
#print('---------go back directory---------')
projectCount += 1
print('---------Congratulation,%d projects compiled,and deployed on device---------' %(projectCount)) #MAIN
WalkDir(curRootDir)
DoBuild()
-
随手写的自动批量编译部署NativeAndroid程序Python脚本的更多相关文章
- Saltstack批量编译部署nginx(多模块)
最近一直在研究saltstack的同步文件和批量执行命令,随着架构的变大,批量部署的需求也变得明显起来了,我需要用一条命令就部署好nginx和tomcat,并且符合我所有的环境需求,可以直接投入生产环 ...
- 随手写的一个检测php连接mysql的小脚本
最近偶然接触到一点点的php开发,要用到mysql数据库,由于mysql和php版本的关系,php5里面连接函数有mysql_connect(),mysqli_connect()两种,php7中又使用 ...
- ansible批量分发免密钥登陆python脚本
最近看了看强大的号称自动化运维的三大利器之一的--ansible,ok,亲测之后,确实感觉,对于我们这种DBA工作者来说,确实很受益. 值得注意的是ansible要求被管理服务器python版本不低于 ...
- [python] 1、python鼠标点击、移动事件应用——写一个自动下载百度音乐的程序
1.问题描述: 最近百度总爱做一些破坏用户信任度的事——文库金币变券.网盘限速,吓得我赶紧想办法把存在百度云音乐中的歌曲下载到本地. http://yinyueyun.baidu.com/ 可问题是云 ...
- python 3 - 写一个自动生成密码文件的程序
1.你输入几,文件里面就给你产生多少条密码 2.密码必须包括,大写字母.小写字母.数字.特殊字符 3.密码不能重复 4.密码都是随机产生的 5.密码长度6-11 import string,rando ...
- windows中实现python,redis服务自动重启(任务计划程序+bat脚本)
需求:银行电脑无法自动开机,只能 通过 应用相关服务每天自动重启的方式实现 服务更新并且防止服务假死,内存过大 等情况 相关工具:win10系统中,使用windows自带的任务计划程序 和 bat脚本 ...
- 项目上使用的每月1日自动导出Zabbix性能数据的python脚本
基于zabbix-manager python2.7 #!/usr/bin/env python # -*- coding: utf-8 -*- # __author__ = "life&q ...
- 分享一个批量修改文件编码的python脚本
分享一个自己编写的递归查找子目录,将所有cpp文件编码修改为utf-8编码格式的小脚本 #i!/usr/bin/env python3 # -*- coding:utf-8 -*- import os ...
- 用Ant实现Java项目的自动构建和部署
原文地址:http://tech.it168.com/j/2007-11-09/200711091344781.shtml 本文请勿转载! Ant是一个Apache基金会下的跨平台的构 ...
随机推荐
- python脚本实现集群检测和管理
python脚本实现集群检测和管理 场景是这样的:一个生产机房,会有很多的测试机器和生产机器(也就是30台左右吧),由于管理较为混乱导致了哪台机器有人用.哪台机器没人用都不清楚,从而产生了一个想法-- ...
- Node.js 爬虫,自动化抓取文章标题和正文
持续进行中... 目标: 动态User-Agent模拟浏览器 √ 支持Proxy设置,避免被服务器端拒绝 √ 支持多核模式,发挥多核CPU性能 √ 支持核内并发模式 √ 自动解码非英文站点,避免乱码出 ...
- atitit.提升备份文件复制速度(4) ---数据挖掘 获取回收站文件列表
atitit.) ---数据挖掘 获取回收站文件列表 1. 放入回收站的原理and 1 2. info2文件文件结构 1 3. 获得文件列表2个法: 正则表达式or解析 1 4. 路径正则表达式[a- ...
- SSL在https和MySQL中的原理思考
之前对HTTPS通信过程有过了解,HTTPS是应用HTTP协议使用SSL加密的版本,在TCP和HTTP之间增加SSL协议.通过握手阶段认证双方身份,协商对称秘钥对通信信息进行加密.此处只描述常用的服务 ...
- JavaWeb学习总结(十七)——JSP中的九个内置对象
一.JSP运行原理 每个JSP 页面在第一次被访问时,WEB容器都会把请求交给JSP引擎(即一个Java程序)去处理.JSP引擎先将JSP翻译成一个_jspServlet(实质上也是一个servlet ...
- 安装 Autoconf 2.69版
发生错误configure.ac:8: error: Autoconf version 2.64 or higher is required 1.检查版本 [root@localhost Deskto ...
- Android——程序移植 相关知识总结贴
android 移植笔记有感 http://www.apkbus.com/android-11842-1-1.html Android振动器系统结构和移植和调试 http://www.apkbus ...
- java中获取比毫秒更为精确的时间
所以这里提醒做非常精确的时间统计的朋友,谨慎使用System.currentTimeMillis() . 在Java中可以通过System.currentTimeMillis()或者System.na ...
- XMPP系列1:简介
通俗解释其实XMPP 是一种很类似于http协议的一种数据传输协议,它的过程就如同“解包装--〉包装”的过程,用户只需要明白它接收的类型,并理解它返回的类型,就可以很好的利用xmpp来进行数据通讯.系 ...
- 用node-webkit 开发 PC 客户端
7月 3 2013 导言 node-webkit 是一个很神奇的桌面客户端项目,正如这个项目的名字,这个项目是由node 和 webkit 构成,简单来说,就是你可以用HTML 5和 node 进 ...