一、前言

目前因机器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脚本的更多相关文章

  1. Python 一键拉取Git分支源码自动解析并执行SQL语句

    基于Python实现自动拉取Git分支源码自动解析并执行SQL语句 by:授客 QQ:1033553122 1.代码用途 开发过程中,研发人员会提交SQL更新脚本到Git源码库,然后测试负责去拉取这些 ...

  2. 鸿蒙内核源码分析(编译脚本篇) | 如何防编译环境中的牛皮癣 | 百篇博客分析OpenHarmony源码 | v58.01

    百篇博客系列篇.本篇为: v58.xx 鸿蒙内核源码分析(环境脚本篇) | 编译鸿蒙原来如此简单 | 51.c.h.o 本篇用两个脚本完成鸿蒙(L1)的编译环境安装/源码下载/编译过程,让编译,调试鸿 ...

  3. 鸿蒙内核源码分析(编译过程篇) | 简单案例窥视GCC编译全过程 | 百篇博客分析OpenHarmony源码| v57.01

    百篇博客系列篇.本篇为: v57.xx 鸿蒙内核源码分析(编译过程篇) | 简单案例窥视编译全过程 | 51.c.h.o 编译构建相关篇为: v50.xx 鸿蒙内核源码分析(编译环境篇) | 编译鸿蒙 ...

  4. GCC源码编译

    1. gcc源码下载 ftp://gcc.gnu.org/pub/gcc/releases/ [yhwang@yhwang ~] wget ftp://gcc.gnu.org/pub/gcc/rele ...

  5. 【Android 系统开发】CyanogenMod 13.0 源码下载 编译 ROM 制作 ( 手机平台 : 小米4 | 编译平台 : Ubuntu 14.04 LTS 虚拟机)

                 分类: Android 系统开发(5)                                              作者同类文章X 版权声明:本文为博主原创文章 ...

  6. 深入理解Faiss 原理&源码 (一) 编译

    目录 深入理解Faiss 原理&源码 (一) 编译 mac下安装 安装mac xcode工具包 安装 openblas 安装swig 安装libomp 编译faiss 附录 深入理解Faiss ...

  7. 使用 IntelliJ IDEA 导入 Spark 最新源码及编译 Spark 源代码

    前言   其实啊,无论你是初学者还是具备了有一定spark编程经验,都需要对spark源码足够重视起来. 本人,肺腑之己见,想要成为大数据的大牛和顶尖专家,多结合源码和操练编程. 准备工作 1.sca ...

  8. Redis源码学习:Lua脚本

    Redis源码学习:Lua脚本 1.Sublime Text配置 我是在Win7下,用Sublime Text + Cygwin开发的,配置方法请参考<Sublime Text 3下C/C++开 ...

  9. MySQL源码包编译安装

    +++++++++++++++++++++++++++++++++++++++++++标题:MySQL数据库实力部署时间:2019年3月9日内容:MySQL源码包进行编译,然后部署MySQL单实例重点 ...

随机推荐

  1. jQuery实现星星评分功能

    一.这是我做的调查问卷中的一个功能.(第三方MVC框架) 二.功能说明:1.用户点击星星,将值放到隐藏域中.2.用户可以重新点击星星修改回答. 前台JS代码: <script type=&quo ...

  2. SqlDataReader、SqlDataAdapter與SqlCommand的 区别

    1.SqlDataReader,在线应用,需要conn.open(),使用完之后要关闭. SqlConnection conn = new SqlConnection(connStr); //conn ...

  3. 【AngularJS学习笔记】02 小杂烩及学习总结

    表格示例 <div ng-app="myApp" ng-controller="customersCtrl"> <table> < ...

  4. MySQL更新优化

    通常情况下,当访问某张表的时候,读取者首先必须获取该表的锁,如果有写入操作到达,那么写入者一直等待读取者完成操作(查询开始之后就不能中断,因此允许读取者完成操作).当读取者完成对表的操作的时候,锁就会 ...

  5. 通过代码的方式完成WCF服务的寄宿工作

    使用纯代码的方式进行服务寄宿 服务寄宿的目的是为了开启一个进程,为WCF服务提供一个运行的环境.通过为服务添加一个或者多个终结点,使之暴露给潜在的服务消费,服务消费者通过匹配的终结点对该服务进行调用, ...

  6. 【OpenCV】OpenCV中GPU模块使用

    CUDA基本使用方法 在介绍OpenCV中GPU模块使用之前,先回顾下CUDA的一般使用方法,其基本步骤如下: 1.主机代码执行:2.传输数据到GPU:3.确定grid,block大小: 4.调用内核 ...

  7. emberjs初学记要

    code { margin: 0; padding: 0; white-space: pre; border: none; background: transparent; } code, pre t ...

  8. js 操作ASP.NET服务器控件

    js 操作ASP.NET服务器控件 在ASP.NET中使用js时,js获取DOM元素时,经常获取不到,这是因为获取的方法有误,现在介绍一方法,解决如何使用js获取ASP.NET控件在浏览器端生成htm ...

  9. thinkPHP学习笔记(2)

    1.调试模式 设置调试模式部分代码如下: <?php define('APP_DEBUG',TRUE); // 开启调试模式 常量定义代码 require '/ThinkPHP框架所在目录/Th ...

  10. Thread.CurrentPrincipal & HttpContext.Current.User

    据说要这样写才稳妥 // This principal will flow throughout the request.VoyagerPrincipal principal = new Voyage ...