Skip to content

mpwang/hexo-renderer-org

 
 

Repository files navigation

https://github.com/coldnew/hexo-renderer-org/raw/master/icon.png

Hexo renderer plugin for emacs org-mode.

Table of Contents

Installation

Switch to your hexo blog directory and run:

npm install https://github.com/mpwang/hexo-renderer-org#master --save

Then restart your hexo server.

Modify By MephistoMMM

Now, hexo-renderer-org won’t start a new emacs server process in daemonize mode. It will use the activing one by connecting the exist emacs server socket file. You can use this codes to config the address of emacs server socket file.

org:
  server_file: "~/.emacs.d/server/server"  # <----- this is default value

notes

For MacOS user, you may need to check $TMPDIR

echo $TMPDIR
/var/folders/q0/3jxnq5cj6dz7j8szf1h5hjsc0000gn/T/

and set server_file to something like:

org:
  server_file: "/var/folders/q0/3jxnq5cj6dz7j8szf1h5hjsc0000gn/T/emacs501/server"

Options

You can configure this plugin in _config.yml according to the backend you want to use.

For highlight.js user

If highlight.js is enough for you, here’s the minimal config:

org:
  emacs: 'emacs'
  emacsclient: 'emacsclient'

For htmlize user

If you want to use emacs’s htmlize to syntax highlight your code block, you can use this config instead:

org:
  emacs: 'emacs'
  emacsclient: 'emacsclient'
  htmlize: true       # <--- for htmlize user, this MUST set true
  theme: 'leuven'

Full options documentation

Some options may not uesed on above example, here’s the doc:

configdescriptiondefault value
emacsexecutable file of emacsemacs
emacsclientexecutable file of emacsclientemacsclient
commoncommon org content you’ll use#+OPTIONS: toc:nil num:nil\n#+BIND: org-html-postamble nil
cachedirwhere cache file located./hexo-org-cache/
clean_cacheset true to clean cache by ‘hexo clean’false
themeemacs’s theme you want to use
htmlizeuse emacs’s htmlize to syntax highlightfalse
line_numberEnable line-number globally on src-blockfalse
debugShow more debug messagefalse
daemonizeEnable/Disable use emacs servertrue
server_filesocket file of emacs server~/.emacs.d/server/server

Create Post

Create source/_posts/foobar.org with followin content:

#+TITLE: Hello World
#+DATE: <2017-03-05 Sun 08:52>
#+LAYOUT: post
#+CATEGORIES: org-mode
#+TAGS: hexo, org-mode

Welcome to [[https://github.com/coldnew/hexo-renderer-org][coldnew/hexo-renderer-org]]!

#+HTML: <!-- more -->

You also can add some code block:

#+BEGIN_SRC js
  console.log("hi");
#+END_SRC

Front-matters

org-mode has it’s own way to describe the front-matter.

Front-matterorg-modevalue
layout#+LAYOUTpost/page
title#+TITLEstring
date#+DATE<2017-04-15 Sat 12:30>, use M-x org-time-stamp to insert
updated#+UPDATED<2017-04-15 Sat 12:30>, use M-x org-time-stamp to insert
comments#+COMMENTSyes/no
tags#+TAGStag1, tag2, tag3
categories#+CATEGORIESstring

To insert date in org-mode, the default keybinding is C-c ., you can also use C-u C-c . instead.

Tutorials

For more tutorials, please see:

Q & A

Which org-mode version do you use ?

This renderer ONLY support org-mode 9.x syntax, be careful there’s some conflict with org-mode 9.x and 8.x.

If you really want to use org-mode 8.x, here’s the guide.

How to add Read more button ?

Place #+HTML: <!-- more --> in where you would like to add a Read more.

How to install my emacs theme

If the emacs theme you want to use is not installed by default, you can setup the _config.yml

For example, if we want to use moe-theme for your code block, we need to edit _config.yml like this:

org:
  # skip ...
  theme: 'moe-dark'
  user_config: './emacs/init.el'

Then add following code to your ./emacs/init.el.

;; install moe-theme and use it
(package-install 'moe-theme)
(require 'moe-theme)

Can I clean cachedir when use hexo clean ?

If you want to make hexo clean work with hexo-renderer-org, you can setup your _config.yml.

org:
  # skip ...
  clean_cache: true

Note that the emacs-lisp cache in cachedir will be kept after hexo clean, you can manually remove it if you want to re-fetch all emacs-lisp plugin.

How can I add line-number on src-block ?

You can add following to your _config.yml to make line-number display on your src-block globally:

org:
  # Make src-block has line-number (this won't make effect on example-block)
  line_number: true

Or use org-mode’s standard method to add line-number manually:

#+BEGIN_SRC js -n
   console.log("This is line 1")
#+END_SRC

I don’t want to use emacs daemon

If you still want to use CodeFalling/hexo-renderer-org method, which start emacs process to render post instead of using emacs daemon, you can switch to emacs process by setting _config.xml

org:
  # disable use emacs server by set 'false'
  daemonize: false

Can I drag and drop image to org files ?

Yes, first you need to install org-download to your emacs.

Then add following to .dir-locals.el at the top of your hexo project:

((nil .
      ((eval .
             (progn

               ;; make drag-and-drop image save in the same name folder as org file
               ;; ex: `aa-bb-cc.org' then save image test.png to `aa-bb-cc/test.png'
               (defun my-org-download-method (link)
                 (let ((filename
                        (file-name-nondirectory
                         (car (url-path-and-query
                               (url-generic-parse-url link)))))
                       (dirname (file-name-sans-extension buffer-file-name) ))
                   ;; if directory not exist, create it
                   (unless (file-exists-p dirname)
                     (make-directory dirname))
                   ;; return the path to save the download files
                   (expand-file-name filename dirname)))

               ;; only modify `org-download-method' in this project
               (setq-local org-download-method 'my-org-download-method)

               )))))

How to use drag and drop image together with hexo config post_asset_folder: true

By default, drag&drop feature of org-download will insert org file link like `file://....`.

Image will display correctly as inline image inside org-mode and article page, but exported html image link is incorrect on archive or index pages.

turn on post_asset_folder in _config.yml

post_asset_folder: true

using following as you .dir-locals.el at the top of your hexo project:

((nil .
   ((eval .
          (progn

            ;; make drag-and-drop image save in the same name folder as org file
            ;; ex: `aa-bb-cc.org' then save image test.png to `aa-bb-cc/test.png'
            (defun my-org-download-method (link)
              (let ((filename
                     (file-name-nondirectory
                      (car (url-path-and-query
                            (url-generic-parse-url link)))))
                    (dirname (file-name-sans-extension buffer-file-name ) ))
                ;; if directory not exist, create it
                (unless (file-exists-p dirname)
                  (make-directory dirname))
                ;; return the path to save the download files
                (expand-file-name filename dirname)))

            ;; only modify `org-download-method' in this project
            (setq-local org-download-method 'my-org-download-method)

            ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
            ;; for using hexo config post_asset_folder: true             ;;
            ;; https://hexo.io/docs/asset-folders.html#Post-Asset-Folder ;;
            ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

            ;; only modify `org-download-link-format' in this project
            (setq-local org-download-link-format "{%% asset_img %s %%}")

            ;; only modify `org-download-abbreviate-filename-function' in
            ;; this project
            (setq-local org-download-abbreviate-filename-function #'file-name-nondirectory)
            )))))

This will give your correct exported html image link, but image will not show inside org-mode as inline image.

About

Hexo renderer plugin for emacs org-mode

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Emacs Lisp 50.2%
  • JavaScript 49.8%