[Latex] Travis-CI与Latex构建开源中文PDF
博主有一本开源书籍,用 latex 排版,托管在Github上。但用 latex 不像是 Markdown,当tex文本更新时,用于最终浏览的PDF文件很难得到及时的更新, 所以博主一直想找到一套工具,实现以下两点愿望:
- 自动构建以测试是否可以成功编译生成PDF文件。
- 始终都能有一个最新版的PDF版本可供下载。
博主之前曾使用过Travis-CI进行单元测试的自动运行,所以猜测它能够实现博主的小心愿。最后一探索,果然可以,但网上相关的中文资料较少,遂自己摸索写下这一篇博客。主要的资料来源于Travis-CI官方文档。
自动构建第一步,安装latex环境
由于Travis-CI
不再对 public repository 提供 Caching Dependencies , 所以我们针对 latex 的每次自动构建都需要下载texlive-full
包。不过博主发现,在配置好后,自动构建的时间一般在 8 分钟左右,时间还是相当可以的。
首先创建一个.travis.yml
文件,在文件中填入以下两行
sudo: required
dist: trusty
其中 dist: trusty
是指定ubuntu版本为14.04
。
为了能够成功编译中文PDF,我们可以使用xelatex
。在这里博主直接下载了texlive-full
包环境用于编译。所以我们在.travis.yml
文件中加入环境配置的代码:
before_install:
- sudo apt-get update
- sudo apt-get -y install texlive-full
由于在服务器端一个中文字体都没有,博主建议开源书籍可以有一个fonts
目录用于存放编译所用字体。如果在 ubuntu 下使用 xelatex ,默认字体是 Adobe的四款开源字体。接下来我们将仓库里的字体安装在服务器的环境下。Linux系统中安装字体很简单,将字体文件只需要放在usr/share/fonts
文件目录下即可。这里有个小坑在于,服务器上没有usr/share/fonts
目录,需要自己新建一个。博主安装字体的代码如下,opentype目录表示.otf格式字体。:
- sudo mkdir -p /usr/share/fonts/opentype/
- sudo mv ./guide-book/fonts/AdobeFangsongStd-Regular.otf /usr/share/fonts/opentype/
- sudo mv ./guide-book/fonts/AdobeHeitiStd-Regular\ \(v5.010\).otf /usr/share/fonts/opentype/
- sudo mv ./guide-book/fonts/AdobeKaitiStd-Regular\ \(v5.010\).otf /usr/share/fonts/opentype/
- sudo mv ./guide-book/fonts/AdobeSongStd-Light\ \(v5.010\).otf /usr/share/fonts/opentype/
- sudo mkfontscale
- sudo mkfontdir
- sudo fc-cache -fv
括号需要进行转义,并且需要使用sudo fc-cache -fv
对字体列表进行更新。
如果在编译latex时出现The font "Adobe Song Std" cannot be found.
,可以在 .travis.yml 中加入fc-list :lang=zh
打印字体信息以进行 debug 。
自动构建第二步,编译生成PDF
在安装完 latex 环境后,我们接下来就可以使用xelatex
进行编译了。
一般对于 latex 稍微熟悉一些的朋友应该都没有问题。将编译的指令写在scripts:
下即可自动运行。
现在博主的.travis.yml
长这样:
sudo: required
dist: trusty
before_install:
- sudo apt-get update
...
- sudo fc-cache -fv
script:
- cd guide-book
- make
在这里博主有两个小建议:
- latex 使用
nonstopmode
模式。在编译时,如果不加任何选项,出错时latex
会等待用户输入一个新的tex
文件名进行重新编译。但是自动构建并没有人帮我们输入,所以在前期摸索试错时,如果加上这个编译选项,可以更快地看到自动构建的结果,否则就需要等待较长时间(这时候是超时错误)。使用的方法如下:
xelatex SAMPLE.tex -interaction=nonstopmode
- 可以写个 Makefile 文件,只需要 make 即可一步编译。博主就将 xelatex 执行的脚本写在了 Makefile 文件中。
自动构建第三步,PDF自动上传到Github
我们已经生成了PDF文件,下面我们来一步一步把它上传到Github上。
首先,执行sudo gem install travis
安装travis.
如果没有gem
的话,首先需要安装gem
,安装方法请自行寻找。
如果在安装
travis
时失败了,可能是因为网络原因。博主推荐使用ruby淘宝源,淘宝源已经不再支持http
,之前配置成http
的朋友记得更换。如果是第一次配置,使用gem sources -a https://ruby.taobao.org/ --remove http://rubygems.org/
即可替换源。
安装信息如下:
Fetching: ethon-0.8.1.gem (100%)
Successfully installed ethon-0.8.1
Fetching: typhoeus-0.8.0.gem (100%)
Successfully installed typhoeus-0.8.0
Fetching: travis-1.8.2.gem (100%)
Successfully installed travis-1.8.2
Parsing documentation for ethon-0.8.1
Installing ri documentation for ethon-0.8.1
Parsing documentation for typhoeus-0.8.0
Installing ri documentation for typhoeus-0.8.0
Parsing documentation for travis-1.8.2
Installing ri documentation for travis-1.8.2
Done installing documentation for ethon, typhoeus, travis after 10 seconds
3 gems installed
在成功下载了travis
后,我们首先要登录,进入你要自动构建的git 仓库目录下,使用sudo travis login --auto
进行登录。
qian@thinkpad:~/BUAAOS-guide-book# sudo travis login --auto
We need your GitHub login to identify you.
This information will not be sent to Travis CI, only to api.github.com.
The password will not be displayed.
Try running with --github-token or --auto if you don't want to enter your password anyway.
Username: SivilTaram
Password for SivilTaram: ****************
Successfully logged in as SivilTaram!
博主在这里一开始遇到了坑。在windows下使用cmd
,在输入密码时都显示明文密码,并且回车后无响应,如果有朋友知道解决方法或者原因,烦请赐教。最后博主用ubuntu,在shell里成功登录。
登录后,我们来使用travis setup releases
来指定要上传的文件
sudo travis setup releases
[sudo] password for qian:
Detected repository as SivilTaram/BUAAOS-guide-book, is this correct? |yes| yes
Username: SivilTaram
Password for SivilTaram: ***************
File to Upload: guide-book/guide-book.pdf
Deploy only from SivilTaram/BUAAOS-guide-book? |yes| yes
Encrypt API key? |yes| yes
其中Encrypt API key
是用于加密的,建议选择 yes。
在完成这一步后,我们可以发现我们的.travis.yml
文件中多了几行,博主的文件增加内容如下:
deploy:
provider: releases
api_key:
secure: xxxxxxxx
file: guide-book/guide-book.pdf
on:
repo: SivilTaram/BUAAOS-guide-book
但是注意,deploy 设置还没有结束!根据官方文档,Travis-CI会在script
执行结束后,默认清除所有生成的文件,所以一定要加上一句skip_cleanup: true
。现在我们完整的.travis.yml
文件应该类似于下面的结构:
sudo: required
dist: trusty
before_install:
- sudo apt-get update
- sudo apt-get -y install texlive-full
- sudo tex -v
script:
- cd guide-book
- make
deploy:
provider: releases
api_key:
secure: xxxxx
file: guide-book/guide-book.pdf
skip_cleanup: true
on:
repo: SivilTaram/BUAAOS-guide-book
如果想添加多个上传文件,将 file:
的选项更改成:
file:
- "FILE 1"
- "FILE 2"
当我们在某次 commit 时已经预先知道本次 commit 无法通过编译,不想自动构建时,可以使用git commit -m "[ci skip] xxxx"
跳过自动构建。
如果想触发自动构建并上传的话,需要打tag,如果不打tag,在realese里的名字会很难看。打的tag
将成为最新版本的名字。可以按照如下步骤进行push。注意commit中不要使用[ci skip]
。
git tag -a v1.1.1 -m "tags content"
git push --tags
git push
其中 v1.1.1即版本号
如果自动构建成功的话,你将在仓库的releases
中看到刚刚自动构建的成果,比如博主的仓库。
如果有遗漏与错误之处还望各位指出~
[Latex] Travis-CI与Latex构建开源中文PDF的更多相关文章
- Travis-CI与Latex构建开源中文PDF
博主有一本开源书籍,用 latex 排版,托管在Github上.但用 latex 不像是 Markdown,当tex文本更新时,用于最终浏览的PDF文件很难得到及时的更新, 所以博主一直想找到一套工具 ...
- GitHub搭配使用Travis CI 进行自动构建服务
Travis CI (Continuous Integration)持续集成服务 用处:自动监控软件仓库,可以在代码提交后立刻执行自动测试或构建 1.在Github自己的仓库根目录里添加.travis ...
- 使用Travis CI自动部署Hexo博客
自从使用GitHub Pages和Hexo来发布博客之后,不得不说方便了许多,只需要几个简单的命令博客就发布了.但在不断的使用中发现每次的发布操作也挺耗时的. 我一般的操作是将平时整理好的md文件放到 ...
- 使用Travis CI自动部署Hexo到GitHub
原文链接(转载请注明出处):使用Travis CI自动部署Hexo到GitHub 前言 使用 hexo + gitPages 搭建个人博客的人都知道,每当要发表一篇博文,第一步得手动使用 hexo g ...
- Travis CI Build Continuous Integration
什么是持续集成 持续集成(Continuous Integration)是经常合并小的代码更改的实践,而不是在开发周期结束时合并大的更改.目的是通过以较小的增量开发和测试来构建更健康的软件.这就是Tr ...
- 【Hexo】使用Hexo+github pages+travis ci 实现自动化部署
目录 一.说明 二.成品展示 三.前期准备 本地安装 node.js 本地安装 git github 账号 创建仓库 travis ci 账号 四.安装 Hexo 五.使用 hexo 搭建博客 六.部 ...
- [转]Travis Ci的最接底气的中文使用教程
相信大家对Travis Ci已经不再陌生了,Github上已经有大部分的项目已经采用了它. Travis Ci是一个基于晕的持续集成项目,目前已经支持大部分主流语言了,如:C.PHP.Ruby.Pyt ...
- 利用Travis CI 让你的github项目持续构建
Travis CI 是目前新兴的开源持续集成构建项目,它与jenkins,GO的很明显的特别在于采用yaml格式,简洁清新独树一帜.目前大多数的github项目都已经移入到Travis CI的构建队列 ...
- Travis CI用来持续集成你的项目
这里持续集成基于GitHub搭建的博客为项目 工具: zqz@ubuntu:~$ node --version v4.2.6 zqz@ubuntu:~$ git --version git versi ...
随机推荐
- 3.Solr4.10.3目录结构
转载请出自出处:http://www.cnblogs.com/hd3013779515/ 1.整个目录结构 (1)bin:是脚本的启动目录 (2)contrib:第三方包存放的目录 (3)dist:编 ...
- CentOs7 编译安装PHP7.1.5
1 创建php用户和用户组,并在github下载php7源码 #######新建php用户和php组 [root@typecodes ~]# groupadd -r www && us ...
- error occurred at recursive SQL level 1
ORA-00604: error occurred at recursive SQL level 1出现的错误:java.sql.SQLException: ORA-00604: error occu ...
- WorldWind源码剖析系列:四元数类Quaternion
PluginSDK中的Quaternion4d类可能是感觉Microsoft.DirectX. Quaternion类不太实用或不够用,自己有重新写的. 四元数是英国数学家哈密顿(W.R.Hamilt ...
- gettimeofday()函数来得到时间
gettimeofday()函数的使用方法: 1.简介: 在C语言中可以使用函数gettimeofday()函数来得到时间.它的精度可以达到微妙 2.函数原型: #include<sys/tim ...
- Android 一s个相对完整的自动升级功能实现代码
由于项目的需要最近做了一个关于Android自动升级的功能,下面将贴出Android手机客户端的完整代码.这段代码参考别的代码居多,由于不满足需求,所以自己仅仅改了一些需要变动的内容,其他功能都是按照 ...
- ORA-02291: 违反完整约束条件 - 未找到父项关键字
由于大意,在设置数据库表时将外键字段的类型与外键表的主键字段类型不一致,造成此错误. 我的情况是: 1.将一个为number(10)的外键设置成了number(19) 2.将外键字段对应的主键表设置成 ...
- 50Hz工频干扰消除
50Hz工频干扰消除 今天整理工频干扰消除算法. 我们知道,设计数字滤波器,和模拟滤波器的实质,其实就是求一组系数,逼近要求的频率响应. 模拟滤波器已经很成熟,因此,数字滤波器的设计,将S平面映射到Z ...
- 【MongoDB】MongoDB的下载 安装 配置及使用
windows系统 教程 1.下载地址 (官方提供根据系统位数选择对应的bit.exe下载) 由于自己win32系统不支持该官方版本,在网上又找了个 mongodb-win32-i386版本 p ...
- 【转】从Shell脚本内部将所有标准输出及标准错误显示在屏幕并同时写入文件的方法
如果全部都要重定向的话每一条命令后面>>并不方便,可以这么做.在开头就声明 exec 1>>$log_file表示将脚本中所有的正确输出全部追加到$log_file,错误信息会 ...