一、前言

目前因机器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. MVC视图展现模式之移动布局

    参考:http://www.cnblogs.com/dunitian/p/5218140.html 简单点,直接上用法 新建MVC项目,在golbal.asax中添加如下代码 //添加一个自定义后缀 ...

  2. 与众不同 windows phone (36) - 8.0 新的瓷贴: FlipTile, CycleTile, IconicTile

    [源码下载] 与众不同 windows phone (36) - 8.0 新的瓷贴: FlipTile, CycleTile, IconicTile 作者:webabcd 介绍与众不同 windows ...

  3. js 自带的 reduce() 方法

    1.方法说明 , Array的reduce()把一个函数作用在这个Array的[x1, x2, x3...]上,这个函数必须接收两个参数,reduce()把结果继续和序列的下一个元素做累积计算,其效果 ...

  4. CentOS7 Debian 8 安装VMware-tools

    如在安装过程中碰到未找到gcc 或者 kernel headers的可按以下方案解决,适用任意版本 CentOS 7 1. Update the kernel: $ yum update kernel ...

  5. linux多线程-互斥&条件变量与同步

    多线程代码问题描述 我们都知道,进程是操作系统对运行程序资源分配的基本单位,而线程是程序逻辑,调用的基本单位.在多线程的程序中,多个线程共享临界区资源,那么就会有问题: 比如 #include < ...

  6. android的Project has no default.properties file! Edit the project properties to set one. 的解决

    网上找来这种方法基本解决: 在我们导入Android工程时,有时候会出现如题所述的错误,打开工程目录可以看到,目录下的default.properties文件没有了或者多出了一个project.pro ...

  7. Fresco 使用笔记(一):加载gif图片并播放

    项目总结 --------------------------------------------------------------------- 前言: 项目中图文混合使用的太多太多了,但是绝大部 ...

  8. Android PopupWindow使用之地区、学校选择二级联动

    最近在做一个社交类APP时,希望用户在注册时根据地区来选择自己所在的学校,由于用户手动输入学校,可能会出现各种问题,不利于后面对用户信息的统计.于是决定在客户端做好设置,用户只要根据地区来选择就好.第 ...

  9. 【读书笔记】iOS-NSString的length

    NSString的length方法能够准确无误地处理国际字符串,如含有俄文,中文或者日本文字符的字符串,以及使用Unicode国际字符标准的字符串.在C语言中处理这些国际字符串是件令人非常头疼的事情 ...

  10. Masonry第三方代码约束

    #import "RootViewController.h" #import "Masonry.h" @interface RootViewController ...