職場にいるときだけプロキシを有効にする
プロキシ設定スクリプトを設定して、職場にいるときだけプロキシを有効にする。Windows 10 バージョン。
職場では 123.456.*
から始まる IP が割り当てられるものとし、職場のドメインは hogehoge.com
、プロキシサーバは proxy.hogehoge.com:8080
とする。
(1) ウェブサーバの設定
コントロールパネル → プログラムと機能 → Windows の機能の有効化または無効化 → インターネット インフォメーション サービス
から「Web 管理ツール」と「World Wide Web サービス」を有効に
<再起動>
(2) MIME の種類の追加
スタートボタン → すべてのプログラム → Windows 管理ツール → インターネット インフォメーション サービス(IIS)マネージャー → MIME の種類 → 追加
から以下のように項目を追加。
拡張子:.pac
MIME の種類: application/x-ns-proxy-autoconfig
<サーバーを再起動>
(3) プロキシ設定スクリプトの作成
以下の内容をテキストエディタに貼り付けてファイル名 proxy.pac
に保存。
proxy.pac
を C:\inetpub\wwwroot
にコピーする(要管理者権限)。
補足: PC に IP アドレス 123.456.* が割り当てられているときにプロキシを有効にする(PROXY)。それ以外はプロキシを使わずにアクセス(DIRECT)。
function FindProxyForURL(url, host) { function isLocal(host){ return host == "127.0.0.1" || host == "localhost" || shExpMatch(host, "localhost.*"); } function isShonai(host){ return shExpMatch(host, "*.hogehoge.com") || shExpMatch(host, "123.456.*"); } myip = myIpAddress(); host = host.toLowerCase(); if (isLocal(host)){ return "DIRECT"; } if (shExpMatch(myip, "123.456.*")) { if (isShonai(host)){ return "DIRECT"; } else { return "PROXY proxy.hogehoge.com:8080"; } } return "DIRECT"; }
(4) アクセスできるかチェック
ブラウザから http://localhost/proxy.pac
にアクセスできるか確認。
(5) プロキシの設定
設定 → ネットワークとインターネット → プロキシ
から「スクリプトのアドレス」に http://localhost/proxy.pac
を入力して保存。
おしまい。
PDF に埋め込まれた画像を圧縮
Ghostscript (Windows 版)を使って、重たい PDF ファイルの画像を圧縮して、いくらかスリムにする方法。以下のコマンドを打つべし。
gswin32c.exe -q -dNOPAUSE -dBATCH -sDEVICE=pdfwrite -dAutoFilterColorImages=false -dColorImageFilter=/FlateEncode -sOutputFile=output.pdf -c .setpdfwrite -f input.pdf
/FlateEncode は Zip 圧縮の指定。JPEG 圧縮にする場合は /DCTEncode に変える。
gswin32c.exe -q -dNOPAUSE -dBATCH -sDEVICE=pdfwrite -dAutoFilterColorImages=false -dColorImageFilter=/DCTEncode -sOutputFile=output.pdf -c ".setpdfwrite << /ColorImageDict << /QFactor 0.1 >> >> setdistillerparams" -f input.pdf
/QFactor に画質を 0.0(良い)~1.0(悪い)の範囲で指定する。
ついでに作成者やタイトルなどの情報も埋め込むには、
% Document information [/CreationDate (D:20180112) /Creator (Handmade) /Title (Example) /Subject (Example of how images in a PDF file are compressed with Ghostscript) /Keywords (PDF Ghostscript Compression) /Author (PDF Hanako) /DOCINFO pdfmark
こんなものをテキストエディタで作り、info.ps のような名前を付けて保存する。そんで、gswin32c のオプションに加えてやれば良い。
gswin32c.exe -q -dNOPAUSE -dBATCH -sDEVICE=pdfwrite -dAutoFilterColorImages=false -dColorImageFilter=/FlateEncode -sOutputFile=output.pdf -c .setpdfwrite -f info.ps input.pdf
らしい(大昔に書いたブログの掘り起こしなので確かめていない)。
Inkscape で覚えておくと便利なショートカット
- Ctrl + C … コピー
- Ctrl + X … 切り取り
- Ctrl + V … 貼り付け
Ctrl + Alt + V … 元と同じ位置に貼付け
S … オブジェクトの選択
- T … テキストを作成
- R … 矩形
- B … ベジェ曲線/直線
F2 … パスの編集
Ctrl + G … グループ化
Shift + Ctrl + G … グループ化解除
Shift + Ctrl + F … フィル/ストローク パネルを開く(fill)
- Shift + Ctrl + L … レイヤ パネルを開く(layer)
- Shift + Ctrl + M … 変形 パネルを開く(modify)
Shift + Ctrl + T … テキスト/フォント パネルを開く(text)
テキスト編集中に Alt+ Up … 選択した文字を上へずらす(上付き)
- テキスト編集中に Alt+ Down … 選択した文字を下へずらす(下付き)
パレットを Click … フィルの色を指定
- パレットを Shift + Click … ストロークの色を指定
以前の Inkscape で作った SVG ファイルを Inkscape 0.91 で開くと、ビットマップ画像がおかしなことになる
Inkscape 0.91 がリリースされました ヾ(:3ノシヾ)ノシ
ところが。
以前のバージョンの Inkscape で作成した SVG ファイルを Inkscape 0.91 で開き、EPS や PDF に保存すると、埋め込んであるビットマップ画像がJPEG圧縮されてしまい、しかも元の画像と縦横比を変えて貼り付けていた場合その縦横比もおかしくなるので、その原因を調べていた。
Inkscape 0.91 でビットマップ画像を埋め込んだ SVG ファイルを作ると、それらの画像に対応する image 要素に
- style="image-rendering:optimizeSpeed"
- preserveAspectRatio="none"
という属性がつく。
image-rendering は画像の拡大・縮小時のレンダリング方法を指定するもので、初期値は auto だが、画像を読み込むときのダイアログで auto、optimizeQuality、optimizeSpeed のなかから選択できる。optimizeQuality を指定すると最近接法でレンダリングされるので、ピクセルの境界をシャープに保ったまま拡大するときに適している。optimizeSpeed は補間がおこなわれるので、ピクセルのギザギザ感を無くしたいときに用いる。
preserveAspectRatio は画像の拡大・縮小時に縦横比を制約する設定で、説明しづらいので以下のリンクを参照のこと。
古いバージョンの Inkscape ではこれらの属性がサポートされておらず、SVG ファイルにも記録されない。そのため Inkscape 0.48 で作成した SVG ファイルを Inkscape 0.91 で開いた場合、おそらくデフォルトの値 style="image-rendering:auto" と preserveAspectRatio="xMidYMid" として扱われる。image-rendering:auto のせいで画像に補間がかかり、その効果を反映した画像ファイルを JPEG 圧縮したものが PDF や EPS で使われるようである。しかも xMidYMid のせいで縦横比がおかしなことになる。
image-rendering に関しては Inkscape 0.91 に設定項目がある(画像を右クリックしたときの Object Properties のなかに Image Rendering を指定できる)。しかし preserveAspectRatio を変更する機能はオリジナルのパッケージには無い。拡張機能が launchpad で公開されているので、それらを使えば可能のようだが、まだ試していない。
- Bug #1357808 “trunk, 0.91.x: add extension/feature to fix render...” : Bugs : Inkscape
- Bug #1418038 “Interpolation while viewing in-file bitmap image” : Bugs : Inkscape
いずれにしろ手作業では面倒臭いので、古い Inkscape で作った SVG ファイルにこれらの属性を追加するための python スクリプトを書いたので載せておく。updatesvg.py のような名前で保存しておいて
> python updatesvg.py hoge.svg
のように実行すれば、hoge.update.svg というファイルが生成されるかもしれない。
import os, sys import re from xml.etree.ElementTree import * svg_ns = 'http://www.w3.org/2000/svg' inkscape_ns = 'http://www.inkscape.org/namespaces/inkscape' sodipodi_ns = 'http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd' def main(): argv = sys.argv argc = len(argv) if(argc < 2): print 'Usage: updatesvg.py hoge.svg' quit() path = argv[1] base, ext = os.path.splitext(path) print '<-', path tree = parse(path) count = 0 for image in tree.findall('.//{%s}image' % svg_ns): print image proc = 0 if not 'style' in image.keys(): image.set('style', 'image-rendering:optimizeSpeed') proc = 1 if not 'preserveAspectRatio' in image.keys(): image.set('preserveAspectRatio', 'none') proc = 1 count += proc print count, ' images updated.' output_path = base + '.update.svg' tree.write(output_path, 'UTF-8') main()
あんまりテストしてないので、修正がいるかも。
Markdown 関連
HTML の入力は面倒だし、マークアップされた文書自体はたいへん読みにくい。そこで、あとで HTML に変換することを想定して、プレーンテキストとしても読めるようにマークアップしようってことで生まれた記法が Markdown である(と、とりあえず理解している)。はてなブログも Markdown 記法に対応しており、この記事も Markdown 記法で書いている。
Windows 上で Markdown 文書を書いたり見たりするための道具を探したのでまとめておく。プレビュー表示のあるエディタを利用するより、自分の好きなエディタで編集しながら適当なビューアで表示するほうが良いと感じた。
xyzzy
- 改変 markdown-mode
メジャーモードなので拡張子に対応付けられる。以下の2行を .xyzzy または siteinit.l に加える。
(load-library "markdown-mode") (push '("\\.md$" . markdown-mode) *auto-mode-alist*)
拡張子 *.md のファイルを開くと勝手に markdown-mode になり、色分け表示される。
参考:
xyzzy のデフォルトの文字コードを UTF-8 に
ついでにこれも変えておいた。日本語をふくむ Markdown 文書を Shift-JIS で保存すると、Google Chrome + Markdown Preview Plus で開いたときに文字化けする。
(setq *default-fileio-encoding* *encoding-utf8n*)
これを .xyzzy または siteinit.l に追加。
参考:
ブラウザ表示のためのアドオン
ビューアには普段使っているブラウザを利用することにした。
Markdown Preview Plus
Markdown 文書を表示するための Chrome アドオン。スタイルシートを切替えられる。Markdown Viewer
Markdown 文書を表示するための Firefox アドオン。スタイルシートは切替えられないが、xpi ファイルを展開して(たとえば拡張子を zip に変えてて 7-zip 等で開けばよい)、なかに入っている bootstrapLite.css を好きにいじれば良いのではないか。
はてなブログの Markdown モードでスーパーpre 記法を使う
はてなブログでは Markdown モードというのがある。はてな記法の代わりに Markdown 記法を使える。はてな記法には「スーパー pre 記法」というのがあり、コードを色分け表示してくれて便利なのだが、同様のことを Markdown 記法で実現するには…
こう書く。(行頭のスペースは本来は要らない。うまくエスケープできなかったので。)
```postscr newpath 100 100 moveto 100 0 rlineto 0 100 rlineto -100 0 rlineto closepath stroke show ```
こうなる。
newpath 100 100 moveto 100 0 rlineto 0 100 rlineto -100 0 rlineto closepath stroke show
参考:
Aspell 0.60.6.1 を MinGW でコンパイルする
Win32 版 Aspell バイナリ が古いので、最新版のソースコードをコンパイルしてみた。
MinGW(32bit)と MSYS の最新版がインストールしてあり、それぞれパスが通っている状況で行っている。各バイナリパッケージは MinGW-builds の
あたりから。
- GNU Aspell のウェブサイトから aspell-0.60.6.1.tar.gz をダウンロードし、適当なディレクトリに解凍する。
- 解凍したディレクトリでコマンドラインから
sh configure --enable-win32-relocatable --disable-rpath --prefix="C:/Aspell" --enable-data-dir="C:/Aspell/data" --enable-dict-dir="C:/Aspell/data"
を実行。C:/Aspell がインストール先になる。Makefile が作られる。
- common の中にある file_util.cpp に
#include "asc_ctype.hpp"
を加える。
- mingw32-make を実行すると「CreateProcess(NULL, /usr/bin/mkdir -p common, ...) failed」などというエラーが表示される。Makefile を開いて /usr/bin/ と書かれている部分をすべて削除してみる。再度 mingw32-make するとコンパイルが進む。
- mingw32-make install を実行。
参考:
round の速度
Python で比較。10*1000*1000 回ループさせたらこのぐらい。
cast: 2.792 s floor: 2.524 s ceil: 2.539 s round: 10.761 s pass: 0.472 s
キャストや切り捨てに比べて round は 5 倍ぐらい時間がかかっている。
実行したコードは以下。
import datetime import math n = 10*1000*1000 dummy = 0 dt_1 = datetime.datetime.now() for i in range(n): dummy = int(math.pi) # int -> math.floor, math.ceil, round, pass dt_2 = datetime.datetime.now() dt_delta = dt_2 - dt_1 print 'cast: %2d.%03d s' % (dt_delta.seconds, (dt_delta.microseconds / 1000))