239
回編集
編集の要約なし |
(「masme版」追加。概要を変更。目次を表示。) |
||
1行目: | 1行目: | ||
インデント位置<カーソル位置の場合は、インデント位置に、<br> | |||
カーソル位置≦インデント位置の場合は、(表示)行頭に移動します。<br> | |||
「Home」キーなどに割り当ててご利用ください。 | |||
「shift」変数を「true」に書き換えると、選択しながら移動します。<br> | |||
「Shift + Home」キーなどに割り当ててご利用ください。 | |||
<div>__TOC__</div> | |||
= Kuro 版 = | |||
<source lang="javascript"> | <source lang="javascript"> | ||
53行目: | 60行目: | ||
else | else | ||
document.selection.SetActivePoint(mePosView, i + 1, y1, shift); | document.selection.SetActivePoint(mePosView, i + 1, y1, shift); | ||
</source> | |||
= masme 版 (2014/02) = | |||
* 論理行での移動に対応しました。「isLogic」変数を「true」に書き換えてください。 | |||
* 折り返し行頭の空白は無視する仕様に変更しました。インデントとみなされるのは論理行頭の空白のみとなります。<br>Mery の「インデント/逆インデント」機能が論理行単位であるため、仕様を合わせました。<br>Kuro 版と同様、表示行単位で判定したい場合は、「igWrap」変数を「false」に書き換えてください。 | |||
<source lang="javascript"> | |||
//■行頭に移動(インデント対応) | |||
// 2014/02/06 | |||
//■範囲選択(true:する/false:しない) | |||
var shift = false; | |||
//■論理行の行頭に移動(true:する/false:しない) ●標準=false (表示行) | |||
var isLogic = false; | |||
//■折り返し行頭の空白は無視(true:する/false:しない) ●標準=true (論理行単位) | |||
var igWrap = true; | |||
//■インデントの定義 ●初期値=/^[ \t]+/ (半角空白/全角空白/水平タブ) | |||
var indent = /^[ \t]+/; | |||
(function(){ | |||
var sel = Document.Selection; | |||
var meP = isLogic? mePosLogical: mePosView; | |||
var meGL = isLogic? 0: meGetLineView; | |||
var px = sel.GetActivePointX(meP); | |||
var py = sel.GetActivePointY(meP); | |||
var ly = sel.GetActivePointY(mePosLogical); | |||
var line = Document.GetLine(py, meGL); | |||
//インデント位置を探索 | |||
var ix = 1+ (line.match(indent)||{lastIndex:0}).lastIndex; | |||
if (px<=ix || (igWrap && py!=ly)) | |||
//◆px<=ix カーソル位置≦インデント位置の場合 or 折り返し行の場合 | |||
sel.StartOfLine(shift, meP); //行頭へ | |||
else | |||
//◆ix<px インデント位置<カーソル位置の場合 | |||
sel.SetActivePoint(meP, ix, py, shift); //インデント位置へ | |||
})(); | |||
</source> | </source> |
回編集