「さいごに閉じたファイル を参照する」の版間の差分
ナビゲーションに移動
検索に移動
細編集の要約なし |
細編集の要約なし |
||
| 1行目: | 1行目: | ||
<div>__TOC__</div> | <div>__TOC__</div> | ||
[[ヘルプ:ファイル#最近のファイル|ファイルメニュー]] | [[ヘルプ:ファイル#最近のファイル|ファイルメニュー]] では「最近開いたファイルの履歴」が表示されますが、タブをたくさん並べているときには「現在開いているファイル」ばかりが表示されがちです。 | ||
このマクロ(組み込み関数)では、Mery.ini ファイルに記録されている「最近開いたファイルの履歴」ではなく、<b style="color:#0000c0;"> Mery.his </b> ファイルに記録されている履歴情報を読み込み、「現在開いているファイル」を除いて、後ろから順にファイルパスを取得します。 | このマクロ(組み込み関数)では、Mery.ini ファイルに記録されている「最近開いたファイルの履歴」ではなく、<b style="color:#0000c0;"> Mery.his </b> ファイルに記録されている履歴情報を読み込み、「現在開いているファイル」を除いて、後ろから順にファイルパスを取得します。 | ||
*<span style="color:#c00;"> Mery の「オプション」設定の「履歴」グループで「'''カーソル位置とブックマークを保存する'''」が無効の場合は、Mery.his ファイルを参照できないので '''""''' を返します。</span> | *<span style="color:#c00;"> Mery の「オプション」設定の「履歴」グループで「'''カーソル位置とブックマークを保存する'''」が無効の場合は、Mery.his ファイルを参照できないので '''""''' を返します。</span> | ||
*通常の操作でタブを閉じず、「[[すべて閉じる]]」マクロなどでタブを閉じた場合、Mery.his ファイルの並び順が「保存された順 または 閉じた順」にならないことがあるので、このマクロで取得できる履歴の順番の正確さについては保証できません。 | *通常の操作でタブを閉じず、「[[すべて閉じる]]」マクロなどでタブを閉じた場合、Mery.his ファイルの並び順が「保存された順 または 閉じた順」にならないことがあるので、このマクロで取得できる履歴の順番の正確さについては保証できません。 | ||
:ロースペックの XP (32bit, CPU 1コア) でテストしたかぎりでは、処理時間はそれほどかからないようでした(0.03 ~ 0.05 秒ぐらい)。 | |||
== 組み込み関数 LatestClosedFile() == | == 組み込み関数 LatestClosedFile() == | ||
[[includeライブラリ]] を導入(#include "include/IO.js" #include "include/MryInfo.js")したマクロで利用する前提なら前半部分「Mery.his をさがす」「Mery.his を読み込む」のコードを圧縮することもできますが、あえて include | [[includeライブラリ]] を導入(#include "include/IO.js" #include "include/MryInfo.js")したマクロで利用する前提なら前半部分「Mery.his をさがす」「Mery.his を読み込む」のコードを圧縮することもできますが、あえて include なしで使えるようにしてあります(処理手続きはおなじなので、動作速度に差はないはず)。 | ||
// #title = "さいごに閉じたファイル" | |||
// #tooltip = "「さいごに閉じたファイル」のフルパスを返す" | |||
/** | |||
* 関数 LatestClosedFile( num ) | |||
* Mery.his を読み込んで「さいごに閉じたファイル」のフルパスを返す | |||
* | |||
* 引数 num: 「さいごに閉じたファイル」の件数を指定 | |||
* 1 を指定した場合または省略した場合は、1件のフルパスを文字列で返す | |||
* 2 以上の数値を指定した場合は、配列で返す | |||
* | |||
* ※ Mery の「オプション」設定で「カーソル位置とブックマークを保存する」 | |||
* が無効(Mery.his がない)なら "" を返す | |||
* ※ Mery.his を下から順にチェックするだけなので | |||
* マクロなどで閉じられたファイルは Mery.his の並び順に反映されていないことがあるかも | |||
*/ | |||
<source lang="javascript"> | <source lang="javascript"> | ||
function LatestClosedFile( num ) { | function LatestClosedFile( num ) { | ||
var start = new Date(); // 所要時間計測(開始) | var start = new Date(); // 所要時間計測(開始) | ||
| 51行目: | 55行目: | ||
var Adodb = new ActiveXObject( "ADODB.Stream" ); | var Adodb = new ActiveXObject( "ADODB.Stream" ); | ||
var adTypeText = 2, adReadAll = -1; | var adTypeText = 2, adReadAll = -1; | ||
Adodb.Type = adTypeText | Adodb.Type = adTypeText, Adodb.Charset = "UTF-8"; | ||
Adodb.Open(); | Adodb.Open(); | ||
Adodb.LoadFromFile( meryhis ); | Adodb.LoadFromFile( meryhis ); | ||
| 90行目: | 93行目: | ||
} | } | ||
Status = " [ " + ( ( new Date() - start ) / 1000 ).toFixed( 3 ) + " 秒 ]" | Status = " [ " + ( ( new Date() - start ) / 1000 ).toFixed( 3 ) + " 秒 ]"; | ||
return num == 1 ? closedFileArray[0] : closedFileArray; | return num == 1 ? closedFileArray[0] : closedFileArray; | ||
} | } | ||
| 100行目: | 103行目: | ||
;例1. 「さいごに閉じたファイル」を3件 取得する | |||
<source lang="javascript"> | <source lang="javascript"> | ||
var _latestClosed3 = LatestClosedFile( 3 ); | var _latestClosed3 = LatestClosedFile( 3 ); | ||
| 110行目: | 112行目: | ||
</source> | </source> | ||
;例2. 「さいごに閉じたファイル」5件 をポップアップメニューに表示する | |||
<source lang="javascript"> | <source lang="javascript"> | ||
var _latestClosed5 = LatestClosedFile( 5 ); | var _latestClosed5 = LatestClosedFile( 5 ); | ||
| 123行目: | 125行目: | ||
} | } | ||
// ※ LatestClosedFile() または LatestClosedFile( 1 ) であれば | // ※ LatestClosedFile() または LatestClosedFile( 1 ) であれば | ||
// | // 戻り値は配列ではなくフルパスの文字列1件だけなので for() 文は無用 | ||
// menu.Add( "&1: " + LatestClosedFile().replace( /(?:.+\\)*([^\\]+\\)([^\\]+)$/, "$1 $2" ), 1 ); | // menu.Add( "&1: " + LatestClosedFile().replace( /(?:.+\\)*([^\\]+\\)([^\\]+)$/, "$1 $2" ), 1 ); | ||
var r = menu.Track( mePosMouse ); | var r = menu.Track( mePosMouse ); | ||
| 132行目: | 134行目: | ||
editor.OpenFile( _latestClosed5[ r - 1 ] ); | editor.OpenFile( _latestClosed5[ r - 1 ] ); | ||
// ※ LatestClosedFile() または LatestClosedFile( 1 ) であれば | |||
// editor.OpenFile( LatestClosedFile() ); | |||
} | } | ||
</source> | </source> | ||
2019年4月29日 (月) 10:49時点における版
ファイルメニュー では「最近開いたファイルの履歴」が表示されますが、タブをたくさん並べているときには「現在開いているファイル」ばかりが表示されがちです。
このマクロ(組み込み関数)では、Mery.ini ファイルに記録されている「最近開いたファイルの履歴」ではなく、 Mery.his ファイルに記録されている履歴情報を読み込み、「現在開いているファイル」を除いて、後ろから順にファイルパスを取得します。
- Mery の「オプション」設定の「履歴」グループで「カーソル位置とブックマークを保存する」が無効の場合は、Mery.his ファイルを参照できないので "" を返します。
- 通常の操作でタブを閉じず、「すべて閉じる」マクロなどでタブを閉じた場合、Mery.his ファイルの並び順が「保存された順 または 閉じた順」にならないことがあるので、このマクロで取得できる履歴の順番の正確さについては保証できません。
- ロースペックの XP (32bit, CPU 1コア) でテストしたかぎりでは、処理時間はそれほどかからないようでした(0.03 ~ 0.05 秒ぐらい)。
組み込み関数 LatestClosedFile()
includeライブラリ を導入(#include "include/IO.js" #include "include/MryInfo.js")したマクロで利用する前提なら前半部分「Mery.his をさがす」「Mery.his を読み込む」のコードを圧縮することもできますが、あえて include なしで使えるようにしてあります(処理手続きはおなじなので、動作速度に差はないはず)。
// #title = "さいごに閉じたファイル" // #tooltip = "「さいごに閉じたファイル」のフルパスを返す" /** * 関数 LatestClosedFile( num ) * Mery.his を読み込んで「さいごに閉じたファイル」のフルパスを返す * * 引数 num: 「さいごに閉じたファイル」の件数を指定 * 1 を指定した場合または省略した場合は、1件のフルパスを文字列で返す * 2 以上の数値を指定した場合は、配列で返す * * ※ Mery の「オプション」設定で「カーソル位置とブックマークを保存する」 * が無効(Mery.his がない)なら "" を返す * ※ Mery.his を下から順にチェックするだけなので * マクロなどで閉じられたファイルは Mery.his の並び順に反映されていないことがあるかも */
function LatestClosedFile( num ) {
var start = new Date(); // 所要時間計測(開始)
var closedFile = "";
var closedFileArray = [];
var num = num ? num : 1;
// Mery.his をさがす
var Fso = new ActiveXObject( "Scripting.FileSystemObject" );
var meryhis = editor.FullName.replace( /\.exe$/i , ".his" );
if ( ! Fso.FileExists( meryhis ) ) {
meryhis = new ActiveXObject( "WScript.Shell" )
.ExpandEnvironmentStrings( "%APPDATA%" )
+ "\\Mery\\Mery.his";
}
if ( ! Fso.FileExists( meryhis ) ) {
return closedFile;
}
// Mery.his を読みこむ
var Adodb = new ActiveXObject( "ADODB.Stream" );
var adTypeText = 2, adReadAll = -1;
Adodb.Type = adTypeText, Adodb.Charset = "UTF-8";
Adodb.Open();
Adodb.LoadFromFile( meryhis );
var hisText = Adodb.ReadText( adReadAll ).replace( /\r\n?/g, "\n" );
Adodb.Close();
// Mery.his からファイルパスを抽出する
var hisArray = hisText.match( /^\[.+\]$/gm );
var hCount = hisArray.length;
if ( ! hCount ) {
return closedFile;
}
// 履歴のファイルパスをうしろから順にチェックして
// 現在開いているファイルにないものを「さいごに閉じたファイル」とする
hisArray.reverse();
var eCount = Editors.Count, dCount, cCount;
for ( var i = 0; i < hCount || cCount < num; i ++ ) {
closedFile = hisArray[i].replace( /^\[|\]$/g, "" );
for ( var ee = 0, hit; ee < eCount; ee ++ ) {
dCount = Editors.Item( ee ).Documents.Count;
for ( var dd = 0, hit = 0; dd < dCount; dd ++ ) {
file = Editors.Item( ee ).Documents.Item( dd ).FullName;
if ( closedFile == file ) {
hit ++;
}
}
cCount = closedFileArray.length;
if ( ! hit && cCount < num
&& ( ! cCount || closedFile != closedFileArray[ cCount-1 ] )
&& Fso.FileExists( closedFile ) ) {
closedFileArray.push( closedFile );
}
}
}
Status = " [ " + ( ( new Date() - start ) / 1000 ).toFixed( 3 ) + " 秒 ]";
return num == 1 ? closedFileArray[0] : closedFileArray;
}
使い方
例2 のポップアップメニューは「ファイルを読み直す・開きなおす」マクロにも搭載してあります。(2019/04/28)
- 例1. 「さいごに閉じたファイル」を3件 取得する
var _latestClosed3 = LatestClosedFile( 3 );
OutputBar.Writeln( "さいごに閉じたファイル: \n" + latestClosed3 );
Alert( "さいごに閉じたファイル: \n\n" + latestClosed3.join( "\n" ) );
- 例2. 「さいごに閉じたファイル」5件 をポップアップメニューに表示する
var _latestClosed5 = LatestClosedFile( 5 );
var menu = CreatePopupMenu();
menu.Add( "▼ さいごに閉じたファイル ▼", 0, meMenuGrayed );
for ( var i = 0; i < _latestClosed5.length; i ++ ) {
// 「親フォルダ名\ ファイル名」に切りつめる
menu.Add( "&" + ( i + 1 ) + ": " + _latestClosed5[i].replace( /(?:.+\\)*([^\\]+\\)([^\\]+)$/, "$1 $2" ), i + 1 )
}
// ※ LatestClosedFile() または LatestClosedFile( 1 ) であれば
// 戻り値は配列ではなくフルパスの文字列1件だけなので for() 文は無用
// menu.Add( "&1: " + LatestClosedFile().replace( /(?:.+\\)*([^\\]+\\)([^\\]+)$/, "$1 $2" ), 1 );
var r = menu.Track( mePosMouse );
if ( r > 0 ) {
editor.NewFile();
editor.OpenFile( _latestClosed5[ r - 1 ] );
// ※ LatestClosedFile() または LatestClosedFile( 1 ) であれば
// editor.OpenFile( LatestClosedFile() );
}
スポンサーリンク