「カッコをはずす」の版間の差分

提供: MeryWiki
ナビゲーションに移動 検索に移動
Sukemaru (トーク | 投稿記録)
編集の要約なし
Sukemaru (トーク | 投稿記録)
192行目: 192行目:


   // 選択範囲内の先頭と末尾が「対になるカッコ」のとき
   // 選択範囲内の先頭と末尾が「対になるカッコ」のとき
   if ( st.length > o.length + c.length && i % 2 == 0
   if ( st.length >= o.length + c.length && i % 2 == 0
       && st.slice( 0, o.length ) == o
       && st.slice( 0, o.length ) == o
       && st.slice( - c.length ) == c ) {
       && st.slice( - c.length ) == c ) {
225行目: 225行目:
}
}
</source>
</source>


= メモ =
= メモ =

2019年3月18日 (月) 19:47時点における版

カッコをはずす

選択範囲の "最初の1文字" と "最後の1文字" が「対になるカッコ」のとき、または選択範囲の外側 (前と後) の各1文字が「対になるカッコ」のときに、カッコ囲いをはずします。

  • カッコの種類はソースコード内で定義したもののみ
    (開き/閉じカッコはそれぞれ「1文字」ずつのペアで)。
  • カッコの種類
  • 各種のカッコ(半角/全角/縦書き)
 () 「」 <> [] {} ⦅⦆
() 「」 『』 <> [] {} 【】 〖〗 ⦅⦆ 〚〛 〔〕 〘〙 〈〉 《》
﹁﹂ ﹃﹄ ︵︶ ︿﹀ ︽︾ ︹︺ ︷︸ ︻︼ ︗︘
  • 各種の引用符(半角/全角)
" "  ' '  ” ”  ’ ’  〝 〞  〝 〟  ‘ ’  “ ”
  • ーダーシー、〜波ダーシ〜、~全角チルダ~
  • ␣半角空白␣も含んでいるので、選択単語の左右の半角空白も削除できます。


  • 1回の実行につき1組のカッコ囲いをはずします。
例. 以下の行で [ "hoge" ] を範囲選択して連続で実行した場合、次のように作用します。(※内側の両端が優先)
( [ "hoge" ] )	// 元の文字列

(  "hoge"  )	// 1回目 実行後: [  と  ] を削除しました。
( "hoge" )	// 2回目 実行後: ␣ と ␣ を削除しました。
( hoge )	// 3回目 実行後: "  と  " を削除しました。
(hoge)		// 4回目 実行後: ␣ と ␣ を削除しました。	※選択範囲の外側
hoge		// 5回目 実行後: (  と  ) を削除しました。	※選択範囲の外側
  • 選択範囲(複数行)の各行の行頭/行末からカッコを除去したい場合は、「カッコで囲う(ポップアップメニュー)」マクロや「テキスト整形」マクロの削除系コマンドをご利用ください。


ソースコード

#title="カッコをはずす"
#tooltip="対になるカッコを除去する"

/**
 * ------------------------------------------------------------
 * カッコをはずす (2019/03/14 - 2019/03/18, sukemaru) 
 * ------------------------------------------------------------
 * 選択範囲の最初の1文字と最後の1文字が「対になるカッコ」のとき、
 * または選択範囲の外側 (前と後) の各1文字が「対になるカッコ」のときに、
 * カッコ囲いをはずします。
 * ※「外側」オプションが有効な場合でも、
 *  選択範囲"内側"の先頭/末尾のカッコの削除が優先されます。
 */

// ▼「対になるカッコ」の種類 (始)+(終) を列挙する ▼ 
// ※ 開き/閉じカッコはそれぞれ「1文字」でないとダメ

var brackets = "()「」<>[]{}\"\"''()「」『』<>[]{}【】〖〗﹁﹂﹃﹄︵︶︿﹀︽︾︹︺︷︸︻︼︗︘⦅⦆⦅⦆〚〛〔〕〘〙〈〉《》””’’〝〞〝〟‘’“”――~~〜〜  ";

// 削除対象に ▼各種記号のペア▼ を追加する場合は、コメントアウトを解除する
// brackets += "++--**//##==%%::::@@@@※※○○●●□□■■◇◇◆◆▽▽▼▼△△▲▲☆☆★★††||←→→←↑↓↓↑←←→→↑↑↓↓……¿?¡!‚‘‚’„“„”“„‘‚‹››‹«»»«——‐‐--␣␣__";


// ■ 選択範囲の『外側』(前と後ろ) の各1文字がカッコのときも除去する? ■ 
// (※ 選択範囲の前後を1文字ずつ拡張してカッコを除去する)
var removeOuterBracketsEnable = true;	// true:する / false:しない


var d = document;
if ( d.ReadOnly ) {
  Status = " ドキュメントは書き換え禁止です。";
  Quit();
}

var s = document.selection;
var st = s.Text;	// 選択範囲の文字列
var act = s.GetActivePos();
var anc = s.GetAnchorPos();
var tp = ( anc < act ) ? anc : act;	// 選択範囲の先頭位置
var bp = ( anc < act ) ? act : anc;	// 選択範囲の末尾位置
var del = false;
var o, c;

// 選択範囲内の最初と最後の各1文字がカッコのとき
for ( var i = 0, len = brackets.length - 1; i < len; i ++ ) {
  o = brackets[ i ];			// 開きカッコ
  c = brackets[ i + 1 ]		// 閉じカッコ
  if ( st.length >= o.length + c.length && i % 2 == 0
      && st.slice( 0, o.length ) == o
      && st.slice( - c.length ) == c ) {
    s.Text = st.slice( o.length, - c.length );// 先頭と末尾の各1文字ずつを削除
    s.SetAnchorPos( tp );			// 選択範囲を復帰する
    del = true;
    break;
  }
}

// 選択範囲の外側 (前と後) の各1文字がカッコのとき
if ( removeOuterBracketsEnable && ! del ) {
  for ( var i = 0, len = brackets.length - 1; i < len; i ++ ) {
    o = brackets[ i ];		// 開きカッコ
    c = brackets[ i + 1 ]	// 閉じカッコ
    if ( i % 2 == 0
        && d.Text.slice( tp - o.length, tp ) == o
        && d.Text.slice( bp, bp + c.length ) == c ) {
      s.SetAnchorPos( tp - o.length );		// 選択範囲の先頭を1文字拡張
      s.SetActivePos( bp + c.length, true );	// 選択範囲の末尾を1文字拡張
      st = s.Text;
      s.Text = st.slice( o.length, - c.length );// 先頭と末尾の各1文字を削除
      s.SetAnchorPos( tp - o.length );		// 選択範囲を復帰する
      del = true;
      break;
    }
  }
}

// 終了ステータス
if ( del ) {
  Status = " " + ( o == " " ? "␣" : o ) + "  と  "
         + ( c == " " ? "␣" : c ) + "  を削除しました。";
}
else {
  Status = " カッコがありません。" 
}


カッコを削除/追加

選択範囲の先頭と末尾が「対になるカッコ」のときは、カッコ囲いをはずします。
選択範囲の先頭と末尾が「対になるカッコ」でなかったときは、「さいごに 追加/削除 したカッコ」と同種のカッコで選択範囲を囲います。

  • includeライブラリを利用して「さいごに 追加/削除 したカッコ」を外部ファイルに保存します。
あらかじめ includeライブラリ を Macros フォルダにインストールしてください。
外部ファイルの保存場所は Mery\Macros\MacroSettings\<カッコを削除/追加>.json
または %AppData%\Mery\MacroSettings\<カッコを削除/追加>.json です。
( <カッコを削除/追加> の部分はこのマクロのファイル名と同一になります )
  • 定義されたカッコのペアを削除したときに「さいごに 追加/削除 したカッコ」を更新します。
  • カッコの追加に使用する前に、一度「使いたいカッコ」の削除を実行して、設定ファイルの「さいごに 追加/削除 したカッコ」を更新する必要があります。
      e.g. "削除" → "追加" → "追加" …… (削除) → (追加) → (追加) ……
  • 両端が " " で囲われた文字列を範囲選択して、外側を ( ) などで囲うことはできません。
      ∵ " " のペアもカッコの定義にあるので「削除」が優先。
  • おなじ選択範囲のまま連続で実行すると、削除 ⇔ 追加 の繰り返しになります。


ソースコード

#title="カッコを削除/追加"
#tooltip="対になるカッコを削除/追加する"
#icon="code_slashed.ico"
#include "include/IO.js"

/**
 * ------------------------------------------------------------
 * カッコを削除/追加 (2019/03/18, sukemaru) 
 * ------------------------------------------------------------
 * 選択範囲の先頭と末尾が「対になるカッコ」のときは、カッコ囲いをはずします。
 * 選択範囲の先頭と末尾が「対になるカッコ」でなかったときは、
 * さいごに 追加/削除 したカッコと同種のカッコで囲います。
 */


// ▼「対になるカッコ」の種類 (始)+(終) を列挙する ▼ 
// ※ 開き/閉じカッコはそれぞれ「1文字」でないとダメ

var brackets = "()「」<>[]{}\"\"''()「」『』<>[]{}【】〖〗﹁﹂﹃﹄︵︶︿﹀︽︾︹︺︷︸︻︼︗︘⦅⦆⦅⦆〚〛〔〕〘〙〈〉《》””’’〝〞〝〟‘’“”――~~〜〜  ";

// 削除対象に ▼各種記号のペア▼ を追加する場合は、コメントアウトを解除する
// brackets += "++--**//##==%%::::@@@@※※○○●●□□■■◇◇◆◆▽▽▼▼△△▲▲☆☆★★††||←→→←↑↓↓↑←←→→↑↑↓↓……¿?¡!‚‘‚’„“„”“„‘‚‹››‹«»»«——‐‐--␣␣__";


var d = document;
if ( d.ReadOnly ) {
  Status = " ドキュメントは書き換え禁止です。";
  Quit();
}

var setting = {};

// JSON ファイルから「最後に使用したカッコ」を読み込む
setting = IO.Deserialize( setting );

var s = document.selection;
var st = s.Text;	// 選択範囲の文字列
var act = s.GetActivePos();
var anc = s.GetAnchorPos();
var tp = ( anc < act ) ? anc : act;	// 選択範囲の先頭位置
var bp = ( anc < act ) ? act : anc;	// 選択範囲の末尾位置
var o = setting.openBracket ? setting.openBracket : "(";
var c = setting.closeBracket ? setting.closeBracket : ")";
var del = false;

// ループ処理で「対になるカッコ」と一致するかチェック
for ( var i = 0, len = brackets.length - 1; i < len; i ++ ) {
  o = brackets[ i ];		// 開きカッコ
  c = brackets[ i + 1 ]		// 閉じカッコ

  // 選択範囲内の先頭と末尾が「対になるカッコ」のとき
  if ( st.length >= o.length + c.length && i % 2 == 0
      && st.slice( 0, o.length ) == o
      && st.slice( - c.length ) == c ) {
    s.Text = st.slice( o.length, - c.length );	// 先頭と末尾のカッコを削除
    s.SetAnchorPos( tp );			// 選択範囲を復帰する
    del = true;

    setting.openBracket = o;
    setting.closeBracket = c;
    IO.Serialize( setting );	// ヒットしたカッコを保存する
    break;
  }
}

// 選択範囲内の先頭と末尾が「対になるカッコ」ではなかったとき
if ( ! del ) {
  // 「最後に使用したカッコ」
  var o = setting.openBracket;
  var c = setting.closeBracket;
  s.Text = o + st + c;		// 先頭と末尾にカッコを追加
  s.SetAnchorPos( tp );		// 選択範囲を復帰する
}

// 終了ステータス
if ( del ) {
  Status = " " + o.replace( /[ ]+/g , "␣" ) + "  と  "
         + c.replace( /[ ]+/g , "␣" ) + "  を削除しました。";
}
else {
  Status = " " +  o.replace( /[ ]+/g , "␣" )  + " カッコ "
         + c.replace( /[ ]+/g , "␣" ) + "  で囲いました。";
}

メモ

  • 注釈では「開きカッコ/閉じカッコの指定は 各1文字 ずつ」としてありますが、削除ループのコードは「複数文字」の文字列を扱えるようにしてあります。
    変数 blackets の最初の代入値を配列形式にすれば、 (始)と(終) のペアは「任意の複数文字の文字列」も追加できます。
     e.g. var brackets = [ "(" , ")" , "<" , ">" , "<!-- " , " -->" , "<" , " />" ];
  • カッコの定義文字列に "\n" を含めることを想定していません(問題ないはずですが動作検証していません)。
スポンサーリンク