GCC源码自动编译-python脚本
一、前言
目前因机器OS GCC版本太老,导致无法编译一些新版本软件,所以写了一个自动编译GCC的python脚本,操作系统是比较老的suse 10, 很多系统自动软件版本都很低,所以此脚本一般可适用目前比较流行的OS,大家可多尝试一下
二、机器环境
OS: SUSE 10 Bit: 64-bit python: 2.6
三、依赖软件
gmp: 4.3.2 mpc: 0.8.1 mpfr: 2.4.2 gcc: 4.4.0
四、安装脚本
1 目录结构
InstallGcc ---bin -----install_gcc.py ---conf ---tmp ---src -----gcc -------gmp-4.3.2.tar.gz -------mpc-0.8.1.tar.gz -------mpfr-2.4.2.tar.gz -------gcc-4.4.0.tar.gz
2 脚本如下:
#!/usr/bin/env python
import sys,os,time,commands
import logging,logging.handlers class InstallGcc(object):
def __init__(self):
self.base_dir=os.path.abspath(os.path.join(os.path.dirname(__file__),os.pardir))
self.logger = self.get_logger()
self.install_pardir='/usr/local'
self.tmp_dir = '%s/tmp' % self.base_dir
self.install_srcdir='%s/src/gcc' % self.base_dir
self.dependList={'gmp':{'version':'4.3.2','srcfile':'gmp-4.3.2.tar.bz2'},'mpc':{'version':'0.8.1','srcfile':'mpc-0.8.1.tar.gz'},'mpfr':{'version':'2.4.2','srcfile':'mpfr-2.4.2.tar.bz2'},'gcc':{'version':'4.4.0','srcfile':'gcc-4.4.0.tar.gz'}}
self.process_num = self.get_process_num() def get_logger(self):
logname = '%s/log/install_gcc.log' % self.base_dir
logger=logging.getLogger('install_mysql')
logger.setLevel(logging.DEBUG)
handler=logging.handlers.RotatingFileHandler(logname,maxBytes=4194304,backupCount=100)
formatter = logging.Formatter('%(asctime)s %(filename)s:%(lineno)d [%(levelname)s] %(message)s')
handler.setFormatter(formatter)
logger.addHandler(handler)
return logger
def get_process_num(self):
cmd="cat /proc/cpuinfo |grep processor|wc -l"
ret = self.get_exec_result(cmd)
return ret[1]
def get_exec_result(self,cmd):
ret = commands.getstatusoutput(cmd)
if ret[0] != 0:
self.logger.error("%s:%s",cmd,ret[1])
sys.exit(1)
return ret
def decompress_soft(self,name):
try:
srcfile=self.dependList[name]['srcfile']
if srcfile.endswith('bz2'):
cmd = "tar -jxvf %s/%s -C %s" % (self.install_srcdir,srcfile,self.tmp_dir)
elif srcfile.endswith('gz'):
cmd = "tar -zxvf %s/%s -C %s" % (self.install_srcdir,srcfile,self.tmp_dir)
ret = self.get_exec_result(cmd)
untar_dir = "%s/%s-%s" % (self.tmp_dir,name,self.dependList[name]['version'])
os.chdir(untar_dir)
except Exception,e:
self.logger.error("decompress error:%s",e)
sys.exit(1)
def install_gmp(self):
try:
install_dir='%s/gmp-%s' % (self.install_pardir,self.dependList['gmp']['version'])
if os.path.isdir(install_dir):
msg = "gmp has been existed,continuing next step"
print msg
self.logger.error(msg)
else:
self.decompress_soft('gmp')
cmd = "./configure --prefix=%s" % install_dir
ret = self.get_exec_result(cmd)
cmd = "make -j %s && make install" % (self.process_num)
ret = self.get_exec_result(cmd)
msg = "gmp installed ok,continuing next step"
print msg
self.logger.debug(msg)
except Exception,e:
self.logger.error("install gmp error:%s",e)
sys.exit(1)
def install_mpfr(self):
try:
install_dir = '%s/mpfr-%s' % (self.install_pardir,self.dependList['mpfr']['version'])
if os.path.isdir(install_dir):
msg = "mpfr has been existed,continuing next step"
print msg
self.logger.error(msg)
else:
self.decompress_soft('mpfr')
cmd = "./configure --prefix=%s --with-gmp=%s/gmp-%s" % (install_dir,self.install_pardir,self.dependList['gmp']['version'])
ret = self.get_exec_result(cmd)
cmd = "make -j %s && make install" % self.process_num
ret = self.get_exec_result(cmd)
msg = "mpfr installed ok,continuing next step"
print msg
self.logger.debug(msg)
except Exception,e:
self.logger.error("install mpfr error:%s",e)
sys.exit(1)
def install_mpc(self):
try:
install_dir = '%s/mpc-%s' % (self.install_pardir,self.dependList['mpc']['version'])
if os.path.isdir(install_dir):
msg = "mpc has been existed,continuing next step"
print msg
self.logger.error(msg)
else:
self.decompress_soft('mpc')
cmd = " ./configure --prefix=%s --with-gmp=%s/gmp-%s --with-mpfr=%s/mpfr-%s" % (install_dir,self.install_pardir,self.dependList['gmp']['version'],self.install_pardir,self.dependList['mpfr']['version'])
ret = self.get_exec_result(cmd)
cmd = "make -j %s && make install" % self.process_num
ret = self.get_exec_result(cmd)
msg = "mpc installed ok,continuing next step"
print msg
self.logger.debug(msg)
except Exception,e:
self.logger.error("install mpc error:%s",e)
sys.exit(1)
def install_gcc(self):
try:
install_dir = '%s/gcc-%s' % (self.install_pardir,self.dependList['gcc']['version'])
if os.path.isdir(install_dir):
msg = "gcc has been existed,continuing next step"
print msg
self.logger.error(msg)
else:
self.decompress_soft('gcc') gmp_dir= "%s/gmp-%s" % (self.install_pardir,self.dependList['gmp']['version'])
mpfr_dir = "%s/mpfr-%s" % (self.install_pardir,self.dependList['mpfr']['version'])
mpc_dir = "%s/mpc-%s" % (self.install_pardir,self.dependList['mpc']['version'])
enable_con = "--enable-shared --enable-threads=posix --enable-languages=c,c++,objc,obj-c++"
cmd = "export LD_LIBRARY_PATH=%s/lib:%s/lib:%s/lib:$LD_LIBRARY_PATH" % (gmp_dir,mpfr_dir,mpc_dir)
ret = self.get_exec_result(cmd)
cmd = "./configure --prefix=%s --with-gmp=%s --with-mpfr=%s --with-mpc=%s %s" % (install_dir,gmp_dir,mpfr_dir,mpc_dir,enable_con)
ret = self.get_exec_result(cmd)
cmd = "make -j %s && make install" % self.process_num
ret = self.get_exec_result(cmd)
msg = "gcc installed ok,work done"
print msg
self.logger.debug(msg)
except Exception,e:
self.logger.error("install gcc error:%s",e)
sys.exit(1)
def print_start(self,obj):
msg="%s install........[START]" % obj
self.logger.debug(msg)
print msg
def print_end(self,obj):
msg="%s install.......[DONE]" % obj
self.logger.debug(msg)
print msg
def run_install(self):
self.print_start('gmp')
self.install_gmp()
self.print_end('gmp')
self.print_start('mpfr')
self.install_mpfr()
self.print_end('mpfr')
self.print_start('mpc')
self.install_mpc()
self.print_end('mpc')
self.print_start('gcc')
self.install_gcc()
self.print_end('gcc')
if __name__ == '__main__':
obj = InstallGcc()
obj.run_install()
GCC源码自动编译-python脚本的更多相关文章
- Python 一键拉取Git分支源码自动解析并执行SQL语句
基于Python实现自动拉取Git分支源码自动解析并执行SQL语句 by:授客 QQ:1033553122 1.代码用途 开发过程中,研发人员会提交SQL更新脚本到Git源码库,然后测试负责去拉取这些 ...
- 鸿蒙内核源码分析(编译脚本篇) | 如何防编译环境中的牛皮癣 | 百篇博客分析OpenHarmony源码 | v58.01
百篇博客系列篇.本篇为: v58.xx 鸿蒙内核源码分析(环境脚本篇) | 编译鸿蒙原来如此简单 | 51.c.h.o 本篇用两个脚本完成鸿蒙(L1)的编译环境安装/源码下载/编译过程,让编译,调试鸿 ...
- 鸿蒙内核源码分析(编译过程篇) | 简单案例窥视GCC编译全过程 | 百篇博客分析OpenHarmony源码| v57.01
百篇博客系列篇.本篇为: v57.xx 鸿蒙内核源码分析(编译过程篇) | 简单案例窥视编译全过程 | 51.c.h.o 编译构建相关篇为: v50.xx 鸿蒙内核源码分析(编译环境篇) | 编译鸿蒙 ...
- GCC源码编译
1. gcc源码下载 ftp://gcc.gnu.org/pub/gcc/releases/ [yhwang@yhwang ~] wget ftp://gcc.gnu.org/pub/gcc/rele ...
- 【Android 系统开发】CyanogenMod 13.0 源码下载 编译 ROM 制作 ( 手机平台 : 小米4 | 编译平台 : Ubuntu 14.04 LTS 虚拟机)
分类: Android 系统开发(5) 作者同类文章X 版权声明:本文为博主原创文章 ...
- 深入理解Faiss 原理&源码 (一) 编译
目录 深入理解Faiss 原理&源码 (一) 编译 mac下安装 安装mac xcode工具包 安装 openblas 安装swig 安装libomp 编译faiss 附录 深入理解Faiss ...
- 使用 IntelliJ IDEA 导入 Spark 最新源码及编译 Spark 源代码
前言 其实啊,无论你是初学者还是具备了有一定spark编程经验,都需要对spark源码足够重视起来. 本人,肺腑之己见,想要成为大数据的大牛和顶尖专家,多结合源码和操练编程. 准备工作 1.sca ...
- Redis源码学习:Lua脚本
Redis源码学习:Lua脚本 1.Sublime Text配置 我是在Win7下,用Sublime Text + Cygwin开发的,配置方法请参考<Sublime Text 3下C/C++开 ...
- MySQL源码包编译安装
+++++++++++++++++++++++++++++++++++++++++++标题:MySQL数据库实力部署时间:2019年3月9日内容:MySQL源码包进行编译,然后部署MySQL单实例重点 ...
随机推荐
- Oracle基础 各种语句的定义格式
Oracle内建数据类型 一. 字符数据 1. char(size) 2. varchar2(size) 最常用,最大长度4000字节 3. nvhar(size).nvarchar(size) 4. ...
- c#调用Aspose.Word组件操作word 插入文字/图片/表格 书签替换套打
由于NPOI暂时没找到书签内容替换功能,所以换用Apose.Word组件. using System; using System.Collections.Generic; using System.C ...
- linux下安装或升级GCC4.8,以支持C++11标准
C++11标准在2011年8月份获得一致通过,这是自1998年后C++语言第一次大修订,对C++语言进行了改进和扩充.随后各编译器厂商都各自实现或部分实现了C++中的特性. 如需查看各编译器对C++1 ...
- 从苹果apns的feedback服务器获取推送失败的token
在开发自己的苹果推送服务时候,要合理的控制ios设备的Token,而这个Token是由苹果服务器Apns产生的,就是每次app问Apns要Token,由苹果服务器产生的Token会记录到Apns里面, ...
- 股票投资组合-前进优化方法(Walk forward optimization)
code{white-space: pre;} pre:not([class]) { background-color: white; }if (window.hljs && docu ...
- 快速设置超炫banner,js插件
http://www.themepunch.com/codecanyon/revolution_wp/ 记录一下以后用 //出自http://www.cnblogs.com/ahjesus 尊重作者辛 ...
- mysql=null的优雅解决方法
对于不是采用所有字段都是not null的mysql表设计而言,mysql提供了一个<=>操作符. 在oracle中我们的处理方式通常类似: where a = #{var} or #{v ...
- PlayFramework 1 自定义标签 -- FastTags http://unmi.cc/category/javajee/playframework/
最早是用 HTML 来自定义标签,现在觉得 HTML 写有关逻辑的代码就有点不伦不类了,HTML 里着重是显示代码.前有一篇 PlayFramework 1 模板应用 -- Java 对象扩展 学习 ...
- ASP.NET MVC自定义AuthorizeAttribute篇知识点讲解—登录限制
1.前言 a.微软对ASP.NET的开发从WebForm到MVC的转变,已经正式过去5,6个年头,现在WebForm和MVC也都越来越完善,小小算来我也已经工作了将近三年,从大学的时候学习ASP.NE ...
- 【基础】PHP变量及变量作用域
新学PHP,比较有意思的语法,记录下. 1. 变量的作用域 作用域只分两个Global和Local,Global相对于整个.php文件来讲,Local是本地最小范围,是距离变量最近的范围,如:在函数中 ...