前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >我的写作工具链

我的写作工具链

原创
作者头像
RiboseYim
修改2018-01-24 09:50:38
1K0
修改2018-01-24 09:50:38
举报
文章被收录于专栏:睿哥杂货铺

工欲善其事,必先利其器

v4:201801

更新内容:

前期需求:

1)源文件持续修改中出现的回归编辑工作,互相引用的链接较多

2)兼容现有的 Blog Generator (Hexo) 便于融合使用

3)支持 command-line 模式便于调用

后续目标:

1)专题模板一次编辑,多处插入

2)主体自动聚合,类似维基(Template talk)

代码语言:js
复制
var fs = require('fs-extra');
var path = require('path');

// All paths are relative to package.json.
var pagesPath = './source/_posts';
var copyFolders = ['./images', './css', './js'];
var outputPath = './tmp';

// First delete everything in the tmp directory.
console.log('Cleaning previous tmp...');
try {
  for (var file of fs.readdirSync(outputPath)){
    fs.removeSync(path.join(outputPath, file));
  }
}
catch (err){
  console.log('Error during cleanup: '+err);
  process.exit(1);
}

// Then read everything in the pages directories.
var pages = {}, pagesMeta = {};

console.log('Loading pages...');
try {
  for(var page of fs.readdirSync(pagesPath)){
    pages[page] = fs.readFileSync(path.join(pagesPath,page),'utf8');
  }
}
catch (err){
  console.log('Error during page loading: '+err);
  process.exit(1);
}

// Generate each page from the data provided, using the template.
console.log('Generating pages...');
try {
  for(var page of Object.entries(pages)) {
    var pageFullName = page[0];
    var pageName = page[0].slice(0, page[0].lastIndexOf('.'));
    var metaData = pagesMeta.hasOwnProperty(pageName+'.json')

    var source_file = pagesPath +'/'+ pageFullName;
    var target_file = outputPath +'/'+ pageFullName;

    //console.log(pageFullName);
    if(source_file.lastIndexOf('.md')>0){

    var source_str = 'http:\\/\\/riboseyim.github.io';
    var target_str = 'https:\\/\\/riboseyim.github.io';

    var exec = require('child_process').exec;
    var cmdStr = 'gsed -e "s/'+source_str+'/'+target_str+'/g" ' + source_file + ' > ' + target_file;
    console.log(cmdStr);

    exec(cmdStr, function(err,stdout,stderr){
      if(err) {
         console.log('exec error:'+stderr);
      } else {
         //console.log(stdout);
      }
      });
    }
  }
}catch (err){
  console.log('Error during page generation: '+err);
  process.exit(1);
}

console.log('--------------Done!--------------------');

v3:201706

v3:201706
v3:201706
更新内容:

OmniFouse: 计划管理、进度提醒

数据容灾:统一使用坚果云

摄影处理:图片像素、大小处理

OmniGraffle:存量数据合并整理,空间布局/样式配色技巧升级

图床:云存储分库、图片命名、批处理

Evernote、Ulysses:一般性创意素材从Evernote迁移到Ulysses

Atom: 发布定稿前版本采用Atom作为编辑器

GitBook: 《Linux Perf Master》 反馈极好

版权骑士: 效果不佳,remove

v2:201701

v2:201701
v2:201701

分享:从Evernote到Ulysses

更新内容:

摄影器材:微单。效果较好的场景:园林、博物馆、航展

OmniGraffle:高级应用技能:图层、统一样式、配色技巧

图床:采用七牛云

Evernote:及时检阅、分类、删除剪辑内容

GitBook: 新手入门

Blog generator(hexo): 优化Markdown-->Html自动生成、发布流程

v1:201606

v1:201606
v1:201606

分享:思维利器OmniGraffle

更新内容:

Evernote:素材仓库

支持所有手机、平板和电脑。在任意一台设备打开Evernote,随时记录一切、轻松收集资料、一键演示笔记、高效协作共享。

MindManager:框架梳理

一般人的大部分思考过程都是杂乱无序的,没有逻辑的,最后也没法形成有效的沉淀,更无法找到清晰的结论。不是所有的人都是天生就有很好的逻辑的,MindManager可以辅助进行思维整理、分析、可视化的工具。比如写这篇的时候,就是现在MindManager梳理了一个概要,之后导出为文本作为底稿。

OmniGraffle:思维可视化

由The Omni Group制作的一款绘图软件,它曾获得苹果设计奖。可以支持流程图、逻辑图、模型设计等,堪称万能绘图神器。这年头大家都挺忙的,能用一张图表达的意图,就不用写一大堆字啦。

Markdown:一次编写,到处发表

Markdown标记语言,我其实很久以前就掌握了,但是使用频率很低,也谈不上什么美感。真正推动我把Markdown纳入个人工具箱的也是写作,可以说是相辅相成吧。它最大的意义在于通过极简的形式,解决了写作成果的移植通用性的问题。

Ulysses:样式精美、版本管理、ZoomIn/ZoomOut

扩展阅读

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • v4:201801
    • 更新内容:
    • v3:201706
      • 更新内容:
      • v2:201701
        • 更新内容:
        • v1:201606
          • 更新内容:
          • 扩展阅读
          相关产品与服务
          图像处理
          图像处理基于腾讯云深度学习等人工智能技术,提供综合性的图像优化处理服务,包括图像质量评估、图像清晰度增强、图像智能裁剪等。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档