- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我和几个人一起有一个项目,我们有一个 README.md
文件,其中包含在我们的 GitHub 页面上呈现的一堆 GitHub 风格的 Markdown。我们还设置了一个 GitHub Pages 分支,托管在我们 GitHub 组织的子域下,并使用 Automatic Page Generator创建页面时,只需加载我们的 README.md
文件即可。但是,我注意到当我更新我们的 README.md
文件时,它不会更新项目页面。相反,我们必须转到 GitHub 设置选项卡并重新创建项目页面,并在执行此操作时重新加载 README.md
文件。
此外,在阅读了关于 relative linking 的内容之后在 GitHub 项目目录页面上的文档文件之间工作。我非常喜欢 markdown,因为它可以节省大量时间,而不必为我们的文档手动编写所有 HTML。然而,我想要的是能够拥有一个 README.md
文件,该文件能够包含指向位于 docs/*.md
的其他文档文件的相关链接。我希望有一个简单的解决方案,以便我的其他文档文件也可以包含在我的 gh-pages 分支中并托管在我的 GitHub Pages 子域下并进行渲染和/或主题化。
换句话说,我的问题是:
/docs/*.md
同步到我的 Github 页面并以某种方式渲染和/或主题化它们?
最佳答案
我将发布一个我设置的解决方案,它利用了 GitHub Pages 使用 Jekyll 已经使用自动页面生成器这一事实。
git checkout gh-pages
mkdir _layouts
mv index.html _layouts
git checkout master -- README.md
mv README.md index.md
index.md
---
layout: index
---
您还需要打开 index.html
文件并进行以下更改:
从 README.md
的 markdown 中移除呈现的 HTML文件。这通常介于 <section>
之间。或 <article>
标签。将此 HTML 替换为文本 {{ content }}
这将允许我们将此文件用作 jekyll。我们应用布局的文件将放置在内容标签所在的位置。
找到项目页面主题的 CSS。对我来说,这是如下一行:
<link rel='stylesheet' href='stylesheets/stylesheet.css' />
这里需要改成
<link rel='stylesheet' href='{{ site.path }}/stylesheets/stylesheet.css' />
{{ site.path }}
为前缀.通过这样做,Jekyll 会将 markdown 文件呈现为 index.html
的内容。 _layouts
中的布局目录。为了不仅对 README.md 文件,而且对您的 master 分支中可能拥有的其他文档自动执行此过程,我采取了以下步骤:
创建了名为 post-commit
的文件包含以下内容:
#!/bin/bash
###
### The following block runs after commit to "master" branch
###
if [ `git rev-parse --abbrev-ref HEAD` == "master" ]; then
# Layout prefix is prepended to each markdown file synced
###################################################################
LAYOUT_PREFIX='---\r\nlayout: index\r\n---\r\n\r\n'
# Switch to gh-pages branch to sync it with master
###################################################################
git checkout gh-pages
# Sync the README.md in master to index.md adding jekyll header
###################################################################
git checkout master -- README.md
echo -e $LAYOUT_PREFIX > index.md
cat README.md >> index.md
rm README.md
git add index.md
git commit -a -m "Sync README.md in master branch to index.md in gh-pages"
# Sync the markdown files in the docs/* directory
###################################################################
git checkout master -- docs
FILES=docs/*
for file in $FILES
do
echo -e $LAYOUT_PREFIX | cat - "$file" > temp && mv temp "$file"
done
git add docs
git commit -a -m "Sync docs from master branch to docs gh-pages directory"
# Uncomment the following push if you want to auto push to
# the gh-pages branch whenever you commit to master locally.
# This is a little extreme. Use with care!
###################################################################
# git push origin gh-pages
# Finally, switch back to the master branch and exit block
git checkout master
fi
编辑: 我为 README.md
更新了上面的脚本文件和 docs/*
中的 Markdown 两者都使用相同的布局文件。这比我以前的设置要好得多。这个脚本进入你的 .git/hooks/
目录。 bash 必须在您的路径中。
创建文件 _config.yml
与以下
markdown: redcarpet
path: http://username.github.io/reponame
上述脚本还同步了在 docs/*
中找到的 Markdown 文件master
的目录分支,以便它们也可以在 GitHub Pages 站点上查看。如果您包含以下 jQuery 函数以去除 .md
,则这些文档的相对链接有效。从 gh-pages
上的 anchor 延伸分支。您可以将以下脚本添加到 index.html
在_layouts
目录:
$(document).on('ready', function () {
$('a').each(function (i, e) {
var href = e.href;
if (href.search('.md') > 0)
$(this).attr('href', href.split('.md')[0]);
});
});
编辑: 我在我的存储库中更改了上面的代码,这是一种快速而肮脏的方法,但如果你明白我的意思,它并不是在所有情况下都能正常工作。例如 Markdown 文件 company.mdata.md
不会被正确处理。为了解决这个问题,我将其更新为以下脚本,该脚本更仔细地检查 href 并在找到时删除扩展名。我还使脚本更通用,允许它用于通过更改 ext
来删除其他扩展。多变的。这是代码:
$(function () {
$('a').each(function () {
var ext = '.md';
var href = $(this).attr('href');
var position = href.length - ext.length;
if (href.substring(position) === ext)
$(this).attr('href', href.substring(0, position));
});
});
我在 CoryG89/docsync 设置了一个示例仓库,它有一个 project page here ,如果您想了解所有这些是如何协同工作的。
关于git - 如何将文档与 Github Pages 同步?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15214762/
我有一个 .sln 文件,里面有几个项目。为了简单起见,让我们称它们为... 项目A 项目B 项目C ...其中 A 是引用 B 和 C 的主要项目。我的目标是更新我的构建脚本,为 ProjectA
我安装了 Magento,我想知道如何生成完整的 API 文档,例如 http://docs.magentocommerce.com/ 上的文档是使用 phpdoc 生成的。 Magento 中是否包
我通常使用jetbrains family ide。在为函数创建文档时非常有用,只需输入 /** 如何在创建文档时创建自定义标签,例如@date标签。 最佳答案 JavaScript、Java: st
我正在尝试使用 jOpenDocument library创建文档。我已经执行了创建电子表格的示例 - 代码编译并运行正常,但当我尝试使用 Excel Office 2012 或 Google Doc
如标题。 有没有介绍HTML DOM构造的图片? 最佳答案 DOM(文档 对象模型)从文档 节点开始。它被称为“根节点”。 观察下面的树(括号中对应的nodeType): [HTMLDocument]
我喜欢 ColdFusion Builder。但我不喜欢帮助只有 CF9 文档。有什么方法可以将其更改为拥有 ColdFusion 8 文档? 最佳答案 http://livedocs.adobe.c
这个问题在这里已经有了答案: What is the consequence of this bit of javascript? (4 个答案) 关闭 9 年前。 我看到一些 jQuery 脚本嵌
我有一个 XML 文件,其中包含需要在 Word 文档中填充的数据。 我需要找到一种方法来定义一个模板,该模板可用作从 XML 文件填充数据并创建输出文档的基线。 我相信有两种方法可以做到这一点。 创
我正在尝试查找有关如何使用 AVAudioEngine 的详细文档。有谁知道我在哪里可以找到它? 我找到了这个,但与文档丰富的 UI 内容相比,它似乎非常简陋。 https://developer.a
我对 Tensorflow 文档越来越感到恼火和沮丧。我在谷歌上搜索了有关 的文档 tf.reshape 我被定向到一个通用页面,例如 here 。我想查看 tf.reshape 的详细信息,而不是整
我正在学习本教程:http://moxleystratton.com/clojure/clojure-tutorial-for-the-non-lisp-programmer 然后遇到了这个片段: u
如何在 swagger 中为对象数组编写文档。这是我的代码,但我不知道如何访问对象数组中的数据。 { "first_name":"Sam", "last_name":"Smith",
是否有针对 Javascript 的 JavaDocs 之类的东西?当我在 netbeans IDE 中按 ctrl+space 时 写javascript,指定对象的javascript文档就出来了
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
我需要 JavaScript 中的 heredoc 之类的东西。你对此有什么想法吗?我需要跨浏览器功能。 我发现了这个: heredoc = '\ \ \ zzz\ \
WSDL 文档是包含一系列的,可描述某个 web service 的定义的,简单的 XML 文档 WSDL 文档结构 WSDL 文档用下表这些主要的元素来描述某个 web service 的
是否有 ocropus 的文档? 我正在寻找对以下功能的解释: make_SegmentPageByRAST(): segment() RegionExtractor(): setPageLines(
这个问题在这里已经有了答案: Understanding events and event handlers in C# (13 个回答) 4年前关闭。 我正在使用 NRECO 和 ffmpeg 对视
我正在尝试访问工作服务器以与名为 Spotfire 的应用程序一起使用。我的同事把这个传给我,现在已经休息了几个星期,我对他的建议有意见。 实际上,当我通过 localhost 运行我的 Web 应用
Elm 文档没有给出示例用法,因此很难理解类型规范的含义。在几个地方,我看到“a”用作参数标识符,例如 Platform.Cmd : map : (a -> msg) -> Cmd a -> Cmd
我是一名优秀的程序员,十分优秀!