
Jekyllã¯éçãªãµã€ããžã§ãã¬ãŒã¿ãŒã§ãã ããã¯ãå
¥åã§æ
å ±ãæäŸãããåºåãHTMLããŒãžã®ã»ããã§ããããšãæå³ããŸãã ãµã€ããã·ã³ãã«ãªå ŽåãåäžããŒãžã®å Žåã§ãããã¹ãŠãåé¡ãããŸããã ããããããè€éãªãµã€ãã¯ã©ãã§ããããïŒ ãžãã«ã¯å¯ŸåŠããŸããïŒ äŸ¿å©ã«ãªããŸããïŒ
ãã®åºçç©ã¯ãããã€ãã®Webãµã€ããäœæããããšã«ãã£ãŠåŸãããç¥èãèŠçŽããè©Šã¿ã§ãã ãããã£ãŠãå®éã®äŸãžã®ãªã³ã¯ãšGitHubã®å®å
šãªãœãŒã¹ã³ãŒããžã®ãªã³ã¯ãæ®ããŠããŸãã çŽ æã®ã¬ãã«ã¯ãåçŽãªãã®ããè€éãªãã®ã«ãªããŸãã
Jekyllã®ããã«ã¯ãã§ã«ããã€ãã®åºçç©ããããŸããïŒJekyll Practical Guide ã JekyllãšGithubã®ããã° ã Jekyll 2ãGithubã«æ¥ãŠããŸãïŒ ã ãã ãããããã¯ãã¹ãŠãäž»ã«Jekyllã®åºæ¬çãªæ©èœã«ã€ããŠèª¬æããŠããŸãã ããã«ãJekyll 3ã¯ãã§ã«GitHub Pagesã§äœ¿çšãããŠãããGitHub Pagesã«ã¯æ°ããã°ããºãå°å
¥ãããŠããŸãã ããã§ã¯å§ããŸãããïŒ
éçHTML
Github Pagesã¯Jekyllããµã€ããžã§ãã¬ãŒã¿ãŒãšããŠäœ¿çšããŸãã GitHubããŒãžã¯Jekyllãªãã§åç¬ã§äœ¿çšã§ããŸããïŒ ã¯ãïŒ GitHub PagesãåçŽãªHTMLãã¹ãã£ã³ã°ãšããŠäœ¿çšã§ããŸãïŒç¡æïŒïŒã ç¹ã«ããµã€ããæ¢ã«ã©ããã§çæãããŠããå Žåã

ããšãã°ã Winter Novel Webãã¢ã¯Cã¢ããªã±ãŒã·ã§ã³ã§çæãããŸããã ããã¯ãGitHubããŒãžã«ããåçŽãªHTMLããŒãžã®éãŸãã§ãã ãœãŒã¹ã¯ãã¡ãã§ãã
ã«ã¹ã¿ã ãã¡ã€ã³
äžèšã®ããã«ã * .imtqy.comã®ä»£ããã«ãã¡ã€ã³åã䜿çšããããšãå¯èœã§ã ã ãããŠããããè¡ãã®ã¯éåžžã«ç°¡åã§ãã1è¡ã§CNAMEãã¡ã€ã«ãäœæããå¿
èŠããããŸã-ãã¡ã€ã³ïŒ
winternovel.dexp.in
ã³ãããåŸãã€ã³ã¹ããŒã«ããããã¡ã€ã³ã¯ãªããžããªèšå®ã§ã確èªã§ããŸãã

3çªç®ã ãã§ãªããããããã¬ãã«ã®ãã¡ã€ã³ã䜿çšã§ããŸãã ããšãã°ã dexp.in㯠GitHubã§ããã¹ããããŠããŸãã
ã¯ã©ãŠããã¬ã¢
ãã1ã€ã®åªããç¡æãµãŒãã¹ã¯CloudFlareã§ãã çµå±ã®ãšããããããã«ããŠãããã¡ã€ã³ã®DNSãããŒãžã£ãŒãå¿
èŠã§ãã CloudFlareã¯ãDNS管çããŒã«ã ãã§ãªããCDNãµãŒãã¹ãæäŸããŸãã ããã¯ãGitHubããŒãžãå©çšã§ããªãå Žåã§ããCloudFlareãããŒãžããã£ãã·ã¥ããŠè¡šç€ºã§ããããšãæå³ããŸãã

ã¡ã€ã³ãã¡ã€ã³ã¯ãGitHubã«çŽæ¥ãã€ã³ããããIPã§ãã ãµããã¡ã€ã³ã¯ãdexp.imtqy.comã®cname-aliasesãä»ããŠå®è£
ãããŸã ã
ããŒã¯ããŠã³
Jekyllã¯HTMLãšMarkdownã®äž¡æ¹ããµããŒãããŠããŸãã HTMLã¯ããå€ãã®ãªãã·ã§ã³ãæäŸããŸããã人éãæžãã«ã¯ããŸã䟿å©ã§ã¯ãããŸããã Markdownã¯ãæè©ãæžãã®ã«éåžžã«äŸ¿å©ã§ãã
HTMLã®ããã¹ãã®äŸïŒ
<p>Creating a website in Manga Maker Comipo is almost like creating it in Photoshop. That means the program is only responsible for creating the image of the future design. Everything else must be done in other programs and requires skills and knowledge of HTML and CSS.</p> <p>Let's see an example shown below:</p> <p class="centered"><img src="{{ page.linkadd }}pic/tutorials/site/OneMangaDay-site-comipo.png" alt="Website in Comipo" class="imgshad"></p> <p>You can see "Layer List" panel. It already has a stack of layers. You just need to implement this stack in HTML! The most convenient way is exporting each layer as a separate image. Export can be accessed from the menu "File - Export Image File". Also you can press F2. Export options:</p> <p class="centered"><img src="{{ page.linkadd }}pic/tutorials/site/OneMangaDay-branch-export.png" alt="Export parameters for website miking in Comipo"></p>
å°ãªããšãã <p>
ãš</p>
äž¡æ¹ãè¿œå ããå¿
èŠããããŸã...ãããŠã Markdownã®ããã¹ãã®äŸïŒ
Visual novels creating is not such a difficult thing, as it might seem. And RenPy engine will help us: [http://renpy.org](http://renpy.org){:target="_blank"}. On the one hand, the engine is simple and understandable even for beginners. On the other hand, the engine is quite powerful and allows you to create really cool games. You need to download engine and install it. Nothing complicated in this process is not present, the default settings are good. Here is the RenPy main window: {:.imgshad} There is a list of projects on left. And active project options on the right (the active project is highlighted with blue in projects list ). To create your game you need to click "Add New Project" under the list of projects. Further, the engine will ask a few simple questions. Remember the name of the game should be in English (do not use international/unicode symbols).
ããŒã¯ããŠã³ã³ãŒãã®èŠãç®ã¯ã¯ããã«åªããŠããŸãã è©ŠããŠã¿ãŠãã ãããåŸæããããšã¯ãããŸããã
SASS / SCSS
Sassã¯CSSã«åºã¥ãèšèªã§ãã å€æ°ãã³ãŒããããã¯ããã¹ããããã«ãŒã«ãã€ã³ã¯ã«ãŒããªã©ãå€ãã®åªããæ©èœãè¿œå ãããŸããã äžçŽç©ãšå€æ°ãå«ãSCSSã³ãŒãã®äŸïŒ
@mixin border-radius($radius,$border,$color) { -webkit-border-radius: $radius; -moz-border-radius: $radius; -ms-border-radius: $radius; border-radius: $radius; border:$border solid $color } .box { @include border-radius(10px,1px,red); }
ã³ãŒãã¯ä»¥äžã§ãããŒããã£ã¹ããããŸãïŒ
.box { -webkit-border-radius: 10px; -moz-border-radius: 10px; -ms-border-radius: 10px; border-radius: 10px; border: 1px solid red; }
圹ç«ã€ãªã³ã¯ïŒ Sass Basics ã Sass Tutorial
ããŒã¯ã¢ãã
OKãçŽç²ãªHTMLã¯è¯ãã§ãã ãããããžãã«ã«å«ãããããªãã®ããããŸããïŒ ãã®åŸã次ã®ã¹ã¿ã€ã«ã§ããŒãžãæ§ç¯ã§ããŸãã
include header.html { } include footer.html
ã¯ãããžãã«ã«å«ãŸããŠããŸãã ãã ãããã®ãã£ã¬ã¯ãã£ããä»ã®ç®çã«äœ¿çšããããšããå§ãããŸãã å€èŠ³ã«ã€ããŠã¯ããã³ãã¬ãŒãã䜿çšããããšããå§ãããŸãïŒ ã¬ã€ã¢ãŠã ã
ããŒãžã®ãœãŒã¹ã³ãŒãã次ã®ããã«ããŸãã
--- layout: default --- { }
_layouts / default.htmlãã¡ã€ã«ïŒ
<html>... {{ content }} ...</html>
ããŒãžã¯ããã€ãã®ã³ãŒããçæããå€æ°contentã«ä¿åããŸãã ããããŒã®Jekyllã¯ã次ã«åŠçããããã¡ã€ã«ã_layouts / default.htmlã§ããããšã確èªããŸãã 次ã«ããã®å€æ°ã®å
容ãã³ãŒãã®ä»»æã®å Žæã«è¡šç€ºããã ãã§ãã
ãã¡ãããå®éã«ã¯ãã³ãŒãã¯ããè€éã§ãã ããšãã°ã One Manga Dayã® ã¡ã€ã³ããŒãžãš 圌女ã®ã¬ã€ã¢ãŠã ã
å€æ°
å€æ°ã®ãããã¯ã«ã€ããŠã¯ãã§ã«è§ŠããŸããã One Manga Day ããŒã ããŒãžã®ã¿ã€ãã«ã詳ããèŠãŠã¿ãŸãããã
--- layout: default curlang: en title: Home page addcss: badges ---
ã¬ã€ã¢ãŠãå€æ°ã¯ãJekyllã«æ¬¡ã®ãã¡ã€ã«ãåŠçãããããšãäŒããŸãã æ®ãã®å€æ°ã¯ã¬ã€ã¢ãŠãã³ãŒãã§äœ¿çšããã䟿å®äžäœæãããŸãã
<!DOCTYPE html> <html> <head> <title>{{ site.name }} | {{ page.title }}</title>
page.titleå€æ°ã¯ããŒãžããããŒã§èšå®ããã site.nameã¯_config.ymlã«ãããŸãã ç§ã®å Žåããã®è¡ã®çµæã¯æ¬¡ã®ããã«ãªããŸãã One Manga Day | Home page
ã³ã¬ã¯ã·ã§ã³
Jekyllã®ä»¥åã®æ©èœã¯ããã»ã©é«åºŠã§ã¯ãªãããããåºæ¬çãªãã®ã§ããã ãã ããã³ã¬ã¯ã·ã§ã³ã䜿çšãããšãæ¬åœã«åŒ·åãªããšãã§ããŸãã ããšãã°ãã®ã£ã©ãªãŒã ãŸããç¹å®ã®äŸãšããŠã ãã³ã¬ããŒãžããããŸã ã

_data / galleries.ymlããã®å°ããªã¯ãªããã³ã°ïŒ
- id: screenshots description: One Manga Day screenshots imagefolder: pic/scr images: - name: OMD-s0001.png thumb: thumb-1.jpg text: Main menu - name: OMD-s0002.png thumb: thumb-2.jpg text: Instructor
ãã®ã³ãŒãã¯ã site.data.galleriesã³ã¬ã¯ã·ã§ã³ãäœæããŸãã æåã®ãã€ãã¹èšå·ã¯ãã³ã¬ã¯ã·ã§ã³ã¢ã€ãã ã®äœæã瀺ããŸãã images-ãµãã³ã¬ã¯ã·ã§ã³ããã£ãŒã«ãname ã thumb ãããã³textãæã€åèŠçŽ ã
ãããŠããã®ã³ã¬ã¯ã·ã§ã³_includes / mangascript.htmlã䜿çšããæ¹æ³ã®äŸïŒ
<script type="text/javascript"> var imageGallery = [ {% assign gallery = site.data.galleries | where:"id",page.gId | first %} {% for image in gallery.images %} "{{ page.linkadd }}{{ gallery.imagefolder }}/{{ image.name }}", {% endfor %} ]; ... </script>
æåã«ãã³ã¬ã¯ã·ã§ã³site.data.galleriesã¯idãã£ãŒã«ãã§ãã£ã«ã¿ãªã³ã°ãããŸãïŒå€ã¯page.gIdãšçãããªããã°ãªããŸããïŒã whereãã£ã«ã¿ãŒã®çµæã¯è€æ°ã®å€ã«ãªãå¯èœæ§ããããããæåã®å€ã®ã¿ãååŸãããŸãïŒãã®å Žåã®ã³ã¬ã¯ã·ã§ã³IDã¯äžæã§ãããšæ³å®ããããããããã¯èš±å®¹ãããŸãïŒã çµæã¯ã®ã£ã©ãªãŒå€æ°ã«ä¿åãããŸãã
次ã«ã for
ã«ãŒãã§ã®ã£ã©ãªãŒå
šäœã調ã¹ãŸãã
å®è¡ã®çµæã¯æ¬¡ã®ããã«ãªããŸãã
var imageGallery = [ "pic/manga/OneMangaDay_000_001.png", "pic/manga/OneMangaDay_000_002.png", ... "pic/manga/OneMangaDay_999.png" ];
圹ç«ã€ãªã³ã¯ïŒ JekyllïŒLiquidïŒreference ã "Advanced LiquidïŒWhere" ã
ããŒãžã«é
眮ãããã®ã£ã©ãªãŒ
ã®ã£ã©ãªãŒã®ãã1ã€ã®è¯ãæ©äŒã¯ãã³ã¬ã¯ã·ã§ã³ãããŒãžã³ãŒãã«çŽæ¥åã蟌ãããšã§ãã ããšãã°ã ã²ãŒã ããŒãž ïŒ
--- layout: page title: "One Manga Day" gallery: - image_url: omd/OMD-s0001.jpg - image_url: omd/OMD-s0002.jpg - image_url: omd/OMD-s0003.jpg ... buttons: - caption: "Website" url: "http://onemangaday.dexp.in/" class: "warning" - caption: "Steam" url: "http://store.steampowered.com/app/365070/" class: "info" ... --- Manga are... {% include gallery %} ... {% include buttons %}
ãã®ããŒãžã«ã¯ã ã®ã£ã©ãªãŒãšãã¿ã³ã® 2ã€ã®ã³ã¬ã¯ã·ã§ã³ãäžåºŠã«çµã¿èŸŒãŸããŸã ã å€æ°page.galleryããã³page.buttonsã¯ããããã_includes / galleryããã³_includes / buttonsã§äœ¿çšãããŸãã

ãã®æ¹æ³ã¯ããã®ããŒãžã«åºæã®æ
å ±ã®ã¿ã衚瀺ããå Žåã«é©ããŠããŸãã ãµã€ãå
šäœã§ã³ã¬ã¯ã·ã§ã³ã䜿çšããå ŽåïŒé£çµ¡å
/ã¡ãã¥ãŒãªã©ïŒã以åã®æ¹æ³ã䜿çšããŠãã³ã¬ã¯ã·ã§ã³ã_dataãã£ã¬ã¯ããªã«ä¿åããããšããå§ãããŸãã
ãã£ã«ã¿ãŒã»ãã
ãã£ã«ã¿ãŒã®ãããã¯ã«ã€ããŠã¯æ¢ã«è§ŠããŸããã ããã§ãããé«åºŠãªã¿ã¹ã¯ãå®è¡ã§ããŸãã ããã3幎ã§ã幎ããšã«ã°ã«ãŒãåãããLinuxã®æçš¿ããã¹ãŠè¡šç€ºããããšæããŸãã
{% assign cp = site.tags.linux | sort | reverse %} {% assign byYear = cp | group_by_exp:"post", "post.date | date: '%Y'" %} {% for yearItem in byYear limit:3 %} <h4>{{ yearItem.name }}</h4> <ul> {% for post in yearItem.items %} <li><a href="{{ post.url }}">{{ post.title }}</a></li> {% endfor %} </ul> {% endfor %}
ãŸããã¿ã°ãLinuxãã§ãã¹ãŠã®æçš¿ãååŸããå¿
èŠããããŸãïŒ site.tags.linux ã 次ã®è¡ã¯æ¥ä»ããšã«ã°ã«ãŒãåãããŸãã ã°ã«ãŒãåã®ããã«ä»»æã®ãã£ãŒã«ããŸãã¯åœ¢åŒãéžæã§ããŸãã ããŠãæåŸã®æ¡ä»¶ã¯ã for
ã«ãŒãã§ã®å¶éã«ãã£ãŠæºããfor
ãŸãã çµè«ïŒ

å®éã«ã¯ãããã¯ç§ã®ãã©ãã¢ã«ãã ïŒ source ïŒã§äœ¿çšãããŠããŸãã
å€æ°ãæžã
{{ content }}
å€æ°ãããã«åºåããã®ã§ã¯ãªããäœããã®æ¹æ³ã§å€æ°ãå€æŽããŠãããåºåããå¿
èŠãããããã«ããŸãã
å
±éã®å²ãåœãŠïŒ
{% assign someString = "value" %}
åäœããŸããããªããªã çã®ã©ã€ã³ã¯å¿
èŠãããŸãããããžãã«ã§ååŠçãããŸãã
解決çã¯ãã£ããã£ãã£ã¬ã¯ãã£ãã§ãã ãŸããããšãã°ãcompress.htmlã®ãã°ãåé¿ããããã®ããã¯ãæ€èšãããŸãã å
ã®ã³ãŒãã¯æ¬¡ã®ããã«ãªããŸãã
{% highlight AnyLanguage linenos %} Some code {% endhighlight %}
ãã£ããã£ã䜿çšããããã«å€æŽããŸãã
{% capture _code %}{% highlight AnyLanguage linenos %} Some code {% endhighlight %}{% endcapture %}{% include fixlinenos.html %} {{ _code }}
ããã§ã匷調衚瀺ããããã¹ãŠã®ã³ãŒãã_codeå€æ°ã«ãªããŸããã 次ã«ã _include / fixlinenos.htmlã§åŠçãããŸã ã
{% if _code contains '<pre class="lineno">' %} {% assign _code = _code | replace: "<pre><code", "<code" %} {% assign _code = _code | replace: "</code></pre>", "</code>" %} {% endif %}
ã³ãŒãã¯ããµãã¹ããªã³ã°<pre class="lineno">
ã®åºçŸããã§ãã¯ããŸãã ãããèŠã€ãã£ãå Žåãå¥åŠãªHTMLã³ãŒããããããã®ééã£ãéšåã¯åçŽã«æ£ãããã®ã«çœ®ãæããããŸãã
䟿å©ãªãªã³ã¯ïŒ JekyllïŒLiquidïŒæååãã£ã«ã¿ãŒ
ã³ãŒãå§çž®
_config.ymlã® 1è¡ã ãã§ãã¹ãŠã®SASSã³ãŒããå§çž®ã§ããŸãïŒ
sass: style: :compressed
SASSã³ãŒãããªã³ã¶ãã©ã€ã§å§çž®ããå¿
èŠãããå Žåã¯ã scssifyãã£ã«ã¿ãŒã䜿çšã§ããŸãïŒæ§æã®å§çž®ã¹ã¿ã€ã«ããã£ã«ã¿ãŒã«é©çšãããŸãïŒã
{{ some_scss | scssify }}
Jekyllã¯ãHTMLãå§çž®ããããã®æšæºçãªæ¹æ³ãæäŸããŠããŸããã ãµãŒãããŒãã£ã®ãœãªã¥ãŒã·ã§ã³compress.htmlã䜿çšã§ããŸãã ãããã¬ãã«ã®ã¬ã€ã¢ãŠãã« 1è¡ã ãè¿œå ããå¿
èŠããããŸã ã
å§çž®ã¯ãã³ãŒãå
šäœã®çæåŸã«è¡ãããŸãã æçµçã«ãããŒãžã®HTMLã³ãŒãã¯æ¬¡ã®ããã«ãªããŸãã

ã«ã¹ã¿ã æ§æã®åŒ·èª¿è¡šç€º
Jekyllãç¥ããªããšããŸããã¯ãªããã°ã©ãã³ã°èšèªã®æ§æã匷調ããå¿
èŠããããŸãã ããã¯ããã°ã©ã ã§è¡ãããšãã§ããŸãã
ç§ã¯customhighlight.htmlãäœæããŠãRenPyã³ãŒãïŒPythonããŒã¹ïŒã匷調ããŸããã ã¢ã€ãã¢ã¯ã·ã³ãã«ã§ã 眮æãã£ã«ã¿ãŒã«ãåºã¥ããŠããŸãã
{% assign _customtag = "image side hide play show scene" | split: " " %} {% for _element in _customtag %} {% capture _from %}<span class="n">{{ _element }}{% endcapture %} {% capture _to %}<span class="k">{{ _element }}{% endcapture %} {% assign _code = _code | replace: _from, _to %} {% endfor %}
ããã§ã¯ãã¿ã°ã®é
åã圢æããã次ã«ã³ãŒãè¡ã®åèŠçŽ ã®æ€çŽ¢çœ®æã圢æãããŸãã å¯äžã®æ°ããããšã¯ãæååãé
åã«åå²ããããšã§ãã ãã€ã©ã€ããããã³ãŒãã®äŸïŒ

䜿çšäŸã¯ãã¡ã ã ãŸããããã¯ã©ã€ãã¯è±èªã®å
ã®èšäºã®ã³ãŒãã«çµã¿èŸŒãŸããŠããŸãã
ã¿ã°ã¯ã©ãŠã
ã¿ã°ã¯ã©ãŠãã¯ããã«å€§ããªèª²é¡ã§ãã ãŸããåããŒãžãã¿ã°ããšã«æåã§äœæããå¿
èŠããããŸãã 次ã«ã人éãèªããååã§æå¹ãªã¿ã°ã®é
åãäœæããå¿
èŠããããŸãã 第äžã«ãã¹ã¯ãªããã¯åã¿ã°ã®èšäºã®æ°ãèšç®ããå¿
èŠããããŸãã

åºæ¬çãªèšç®ã¯_includes / tagcloud.htmlãã¡ã€ã«ã§è¡ãããŸã ïŒ
<ul id="cloud"> <li style="font-size: 150%"><a href="index.html">All</a></li> {% for tag in site.tags %} {% assign curTag = tag | first | slugize %} {% assign langtag = landat.tags | where:"slug",curTag | first %} <li style="font-size: {{ tag | last | size | times: 100 | divided_by: site.tags.size | plus: 20 }}%"> <a href="{{ curTag }}.html">{{ langtag.name }}</a> </li> {% endfor %} </ul>
site.tagså€æ°ã«ã¯ããã¹ãŠã®èšäºã®äœ¿çšæžã¿ã¿ã°ããã¹ãŠæ ŒçŽãããŸãã langtagå€æ°ã¯ã _data / lang.ymlã§èª¬æãããŠãã人é圢åŒã®çŸåšã®ã¿ã°ã§ã ã
åå埩ã§ã site.tagsã³ã¬ã¯ã·ã§ã³ããååŸãããã¿ã°å€æ°ããããŸãã ã¿ã°å€æ°ã«ã¯ããã®ã¿ã°ãæã€ãã¹ãŠã®èšäºã®ãªã¹ããå«ãŸããŸãã ãããã£ãŠããµã€ãºãä¹ç®ãé€ç®ãªã©ãè¡ãããšãã§ããŸããæå°ã®ã¿ã°ã¯å°ãããããããããã«20ïŒ
ãè¿œå ããŸããã
圹ç«ã€ãªã³ã¯ïŒ JekyllïŒLiquidïŒarray filters
å€èšèªãµã€ã
ãžãã«èªäœã¯åœéåããµããŒãããŠããŸããã ãã®ãããèªåã§å®è£
ããå¿
èŠããããŸãã æãç°¡åãªæ¹æ³ã¯ãææãã«ããŽãªå¥ã«åçŽã«åé¢ããããšã§ãïŒããšãã°ã ãã·ã¢èªã®ææ ïŒã
èšèªããšã«ãµããã¡ã€ã³ã䜿çšããããšãã§ããŸãã ãã ãããã®å Žåã2ã€ã®èšèªã«å¯ŸããŠæ£ç¢ºã«2ã€ã®ãµã€ããååšããŸãã ãŸãã10ã®èšèªã§10ã®ãµã€ãããããŸãããããã¯å¿
ããã䟿å©ã§ã¯ãããŸããã

ãããã³ã¬ã®æ¥ã«ã¯ãèšèªããšã«åå¥ã®ãã©ã«ãããããŸãã ã¢ã€ãã¢ã¯ã·ã³ãã«ã§ãã ããšãã°ãè±èªã®ããŒãžcat/page.html
ãŸãã ãã®ããŒãžã«ãã·ã¢èªçãããå ŽåãURLã¯ru/cat/page.html
ãŸãã ããŒãžãå°ãªãå Žåã¯ããããããã¹ãŠæåã§äœæã§ããŸãã ããããããŒãžãå€ãå Žåã¯ã1ã€ãŸãã¯å¥ã®èšèªã§ããŒãžãååšãããã©ããã確èªããå¿
èŠããããŸãã ãã ããJekyllã«ã¯GitHubãµãŒããŒã®ã»ãã¥ãªãã£ã®ããã®ãã¡ã€ã«æ©èœããŸã£ãããããŸããã
ãã¡ã€ã«ã®ååšã確èªããã«ã¯ã _includes / CHECKEXISTS.htmlã䜿çšã§ããŸãã ããã§ã¯ããµã€ãã®ãã¹ãŠã®ããŒãžãšæçš¿ãåã«å®è¡ãããŸãïŒ
{% assign curUrlExists = false %} {% assign curFUrl = curUrl | remove: ".html" %} {% for curFile in site.pages %} {% assign cFile = curFile.url | remove: ".html" %} {% if cFile == curFUrl %} {% assign curUrlExists = true %} {% endif %} {% endfor %} {% for curFile in site.posts %} {% assign cFile = curFile.url | remove: ".html" %} {% if cFile == curFUrl %} {% assign curUrlExists = true %} {% endif %} {% endfor %}
ãã¡ã€ã«ãèšèªã§ååšããå Žåã¯ãããŒãžã«ãªã³ã¯ãè¿œå ã§ããŸãã
ã³ã¡ã³ãã·ã¹ãã
æåã«æãæµ®ãã¶è§£æ±ºçã¯ã DisqusãŸãã¯AJAXã«åºã¥ãåæ§ã®ã³ã¡ã³ãã·ã¹ãã ã§ãã å°ããªJSã³ãŒããããŒãžã«åã蟌ãŸããŠããã ãã§ããã¹ãŠãããŸãæ©èœããŸãã

ãããå人çã«ã¯ã Staticmanã®æ¹ããã£ãšå¥œãã§ãã ãããã¯ããµã€ããªããžããªãžã®ãã«ãªã¯ãšã¹ãã«åºã¥ãã³ã¡ã³ãã·ã¹ãã ã§ãã ãããã£ãŠãã³ã¡ã³ãããžãã«ã³ã¬ã¯ã·ã§ã³ã§ãïŒ
ããŒãžã«ã³ã¡ã³ãã衚瀺ããããã®ã³ãŒãïŒ
{% capture post_slug %}{{ page.url | slugify }}{% endcapture %} {% if site.data.comments[post_slug] %} {% assign comments = site.data.comments[post_slug] | sort %} {% for comment in comments %} {% assign email = comment[1].email %} {% assign name = comment[1].name %} {% assign url = comment[1].url %} {% assign date = comment[1].date %} {% assign message = comment[1].message %} {% include _post-comment.html index=forloop.index email=email name=name url=url date=date message=message %} {% endfor %} {% endif %}
ã³ã¡ã³ãéä¿¡ãã©ãŒã ãéåžžã«ç°¡åã§ãã

ã³ã¡ã³ãã¢ãã¬ãŒã·ã§ã³ã¯ããã«ãªã¯ãšã¹ãã®ç¢ºèªãéããŠå®è£
ãããŸãã ãªã¯ãšã¹ãã®ç¢ºèªããã€ãã¹ããŠãStaticmanã«ã³ã¡ã³ããçŽæ¥æçš¿ããããã«äŸé Œããããšãã§ããŸãã èŠæ±ãåãå
¥ããåŸããµã€ãå
šäœãåçæããããµã€ãã«ã³ã¡ã³ãã衚瀺ãããŸãã
ãããã«
Jekyllã¯å°ããªãµã€ããããã°ã«ãšã£ãŠéåžžã«ã¯ãŒã«ãªãã®ã§ãã è©ŠããŠã¿ãŠãã ãããããªãã¯ãããæããã§ãããïŒ

䟿å©ãªãªã³ã¯