zoukankan      html  css  js  c++  java
  • gitbook安装与使用

    废话不说,直接主题:


    gitbook安装

    ===========


    1. 安装npm 
    从站点 https://nodejs.org/#download 下载node.js源码(点击绿色的INSTALL),
    解压
    ./configure
    make
    make install 
    成功运行后。npm就被安装好了。


    2. gitbook 安装
    npm install -g gitbook-cli


    gitbook -V 
    查看gitbook是否成功安装。


    ref
    ===
    1. wanqingwong.com/gitbook-zh/index.html


    gitbook使用
    ===========
    1. 依据文件夹生成图书结构 


    1.1 README.md 与 SUMMARY编写
    README.md
    这个文件相当于一本Gitbook的简单介绍。


    $ mkdir test_gitbook
    $ touch README.md


    SUMMARY.md
    这个文件是一本书的文件夹结构,使用Markdown语法。
    如我们这本书的SUMMARY.md:
    $ touch SUMMARY.md
    $ vim SUMMARY.md


    输入


    * [简单介绍](README.md)
    * [第一章](chapter1/README.md)
     - [第一节](chapter1/section1.md)
     - [第二节](chapter1/section2.md)
    * [第二章](chapter2/README.md)
     - [第一节](chapter2/section1.md)
     - [第二节](chapter2/section2.md)
    * [结束](end/README.md)


    1.2 生成图书结构
    当这个文件夹文件创建好之后,我们能够使用Gitbook
    的命令行工具将这个文件夹结构生成对应的文件夹及文件:
    $ gitbook init
    $ tree . #查看建立的文件夹和文件
    .
    ├── chapter1
    │   ├── README.md
    │   ├── section1.md
    │   └── section2.md
    ├── chapter2
    │   ├── README.md
    │   ├── section1.md
    │   └── section2.md
    ├── end
    │   └── README.md
    ├── README.md
    └── SUMMARY.md


    我们能够看到,gitbook给我们生成了与SUMMARY.md所
    相应的文件夹及文件。


    每一个文件夹中,都有一个README.md文件,相当于一章的说明。






    2. 生成图书


    2.1 输出为静态站点
    你有两种方式输出一个静态站点:
    2.1.1 本地预览时自己主动生成
    当你在自己的电脑上编辑好图书之后,你能够使用Gitbook
    的命令行进行本地预览:


    $ gitbook serve .


    然后浏览器中输入 http://localhost:4000 就能够预览生
    成的以网页形式组织的书籍。
    这里你会发现。你在你的图书项目的文件夹中多了一个名为
    _book的文件文件夹,而这个文件夹中的文件,即是生成的静态
    站点内容。
    使用build參数生成到指定文件夹
    与直接预览生成的静态站点文件不一样的是,使用这个命令,
    你能够将内容输入到你所想要的文件夹中去:
    $ mkdir /tmp/gitbook
    $ gitbook build --output=/tmp/gitbook


    2.2 输出PDF
    输入为PDF文件。须要先使用NPM安装上gitbook pdf:
    $ sudo npm install gitbook-pdf -g
    我在运行上面这条命令的时候出现了以下的错误:
    ***************************************************
    Downloading http://cdn.bitbucket.org/ariya/phantomjs/downloads/phantomjs-1.9.7-linux-i686.tar.bz2
    Saving to /usr/local/lib/node_modules/gitbook-pdf/node_modules/phantomjs/phantomjs/phantomjs-1.9.7-linux-i686.tar.bz2
    Error: connect ETIMEDOUT
        at exports._errnoException (util.js:746:11)
        at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1010:19)
    npm ERR! Linux 3.2.0-4-686-pae
    npm ERR! argv "/usr/local/bin/node" "/usr/local/bin/npm" "install" "gitbook-pdf" "-g"
    npm ERR! node v0.12.7
    npm ERR! npm  v2.11.3
    npm ERR! code ELIFECYCLE


    npm ERR! phantomjs@1.9.7-5 install: `node install.js`
    npm ERR! Exit status 1
    npm ERR!
    npm ERR! Failed at the phantomjs@1.9.7-5 install script 'node install.js'.
    npm ERR! This is most likely a problem with the phantomjs package,
    npm ERR! not with npm itself.
    npm ERR! Tell the author that this fails on your system:
    npm ERR!     node install.js
    npm ERR! You can get their info via:
    npm ERR!     npm owner ls phantomjs
    npm ERR! There is likely additional logging output above.


    npm ERR! Please include the following file with any support request:
    npm ERR!     /home/wangxq/repository/phantomjs/npm-debug.log


    ***************************************************
    由错误报告内容的第一行能够知道。错误发生的原因是下载
    phantomjs发生了错误。因此我们须要手动下载和安装。


    解决方法:[1]
    $ git clone git://github.com/ariya/phantomjs.git
    $ sudo apt-get install build-essential g++ flex bison gperf ruby perl
      libsqlite3-dev libfontconfig1-dev libicu-dev libfreetype6 libssl-dev
      libpng-dev libjpeg-dev python libx11-dev libxext-dev       #安装编译须要的工具和依赖
    $ cd phantomjs
    $ git checkout 1.9.7  #注意:这里的1.9.7是phantom的版本。能够由错误报告的第一行找出 
    $ ./build.sh --jobs 4
    $ sudo cp bin/phantomjs /bin/
    $ sudo npm install gitbook-pdf -g  #又一次进行安装


    然后。使用以下的命令,要PDF文件。首先安装依赖库:


    $ sudo apt-get install calibre  
    $ gitbook -v 2.1.0 pdf .
    错误发生:
    *****************************************************
    info: start conversion to pdf ....ERROR


    Error: Command failed: /bin/sh -c ebook-convert /tmp/tmp-29384ctltwbk/SUMMARY.html /tmp/tmp-29384ctltwbk/index.pdf --title="" --comments="这本书是gitbook的一个样例" --language="en" --book-producer="GitBook" --publisher="GitBook" --chapter="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter ')]" --chapter-mark="pagebreak" --page-breaks-before="/" --level1-toc="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter-1 ')]" --level2-toc="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter-2 ')]" --level3-toc="descendant-or-self::*[contains(concat(' ', normalize-space(@class), ' '), ' book-chapter-3 ')]" --no-chapters-in-toc --max-levels="1" --breadth-first --margin-left="62" --margin-right="62" --margin-top="56" --margin-bottom="56" --pdf-default-font-size="12" --pdf-mono-font-size="12" --paper-size="a4" --pdf-header-template="<p class='header'><span></span></p>" --pdf-footer-template="<p class='footer'><span>_SECTION_</span> <span style='float:right;'>_PAGENUM_</span></p>"
    Usage: ebook-convert input_file output_file [options]


    Convert an ebook from one format to another.


    input_file is the input and output_file is the output. Both must be specified as the first two arguments to the command.


    The output ebook format is guessed from the file extension of output_file. output_file can also be of the special format .EXT where EXT is the output file extension. In this case, the name of the output file is derived the name of the input file. Note that the filenames must not start with a hyphen. Finally, if output_file has no extension, then it is treated as a directory and an "open ebook" (OEB) consisting of HTML files is written to that directory. These files are the files that would normally have been passed to the output plugin.


    After specifying the input and output file you can customize the conversion by specifying various options. The available options depend on the input and output file types. To get help on them specify the input and output file and then use the -h option.


    For full documentation of the conversion system see
    http://manual.calibre-ebook.com/conversion.html


    Whenever you pass arguments to ebook-convert that have spaces in them, enclose the arguments in quotation marks.


    ebook-convert: error: no such option: --pdf-default-font-size


    *****************************************************
    解决方法[2]
    $ sudo -v && wget -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py | sudo python -c "import sys; main=lambda:sys.stderr.write('Download failed '); exec(sys.stdin.read()); main()"


    $ gitbook -v 2.1.0 pdf .  # 又一次运行命令生成pdf,目标文件为book.pdf


    ref
    ===
    1. http://phantomjs.org/build.html
    2. http://calibre-ebook.com/download_linux


    问题
    ===
    1. 假设输入gitbook init命令。出现Installing version 2.1.0,
    须要耐性等待安装。


  • 相关阅读:
    疯狂Java讲义-Java基础类库
    第十一届软件类校内模拟赛本科组Java软件开发
    疯狂Java讲义
    疯狂Java讲义-面向对象(下)
    疯狂Java讲义-面向对象(上)
    疯狂Java讲义-流程控制与数组
    疯狂Java讲义-数据类型和运算符
    数据结构-图和图遍历(DFS、BFS)
    A1034 Head of a Gang (30分)
    A1098 Insertion or Heap Sort (25分)
  • 原文地址:https://www.cnblogs.com/yangykaifa/p/6707728.html
Copyright © 2011-2022 走看看