【MATLAB/Simulink】コメントアウトを探して削除するスクリプトを作ってみた
あらすじ
Simulinkモデルを書き進めていくと、テキスト言語と同様にコメントアウトがどんどん溜まっていきます。幸い、Simulink(というかMATLAB)でコメントアウトを探すことができ、それらの一斉削除も容易です。しかしその中には当然他人が残したものもあり、それらを削除していいかどうかは自分では判断できません。
そこで、モデルに残されたコメントアウトをひとつずつ検索していき、削除もしくは削除しない、の判断が可能なツールを作成します。
環境
・MATLAB 2015b
・Simulink 8.6
実際に使ってみる
作成したスクリプトを、下記Simulinkモデル「test_co.slx」に対して使用してみます。
このモデルは、各階層にブロックやサブシステムのコメントアウトが散りばめられています。
まず、スクリプトを実行します。モデル中の全コメントアウトがリストに記載されます。
次にリストに追加されたコメントアウトをクリックすると、その場所にジャンプしてクリック対象が青く強調表示されます。GUIの方には「削除して次を検索」ボタンと「削除せずに次を検索」ボタンが新たに表示されます。
「削除して次を検索」を押すと、Simulink上で対象のコメントアウトが削除され、リストからも消えます。
「削除せずに次を検索」を押すと、単に強調の対象が次のブロックに移ります。
どんどん削除していくと、最後には以下のように表示されます。
(最初からコメントアウトが存在しない場合も、同様の表示がなされます)
ソース
delete_comment_out.m
function delete_comment_out
% リスト上のブロック/サブシステムをクリック時、そのブロック/サブシステムを強調する
function go_to_commented_out(source, command)
if ~strcmp(source.String, nocomsg) % コメントアウトが存在する場合
if prvco ~= 0 && ~strcmp(command, 'delete')
% 前回強調したブロックを、元の状態に戻す
hilite_system(source.String(prvco), 'default');
else
% 特定のブロック/サブシステムが強調状態になって初めて、削除ボタンなどを表示する
dlt_next.Visible = 'on';
just_next.Visible = 'on';
end
% ブロックを強調
hilite_system(source.String(source.Value), 'user1');
prvco = source.Value; % 今回強調したブロックを、前回値として保存
end
end
% 現在強調しているコメントアウトを削除して次のコメントアウトを強調
function delete_block_and_next_block(~, ~)
% リストの一番下以外のコメントアウトを強調している時
if tgtbox.Value < size(tgtbox.String, 1)
curco = tgtbox.Value; % リスト上で強調中のブロック/サブシステム番号を保存
else % 一番下を強調している時
curco = 1;
tgtbox.Value = curco; % リストの最初に戻る
end
delete_block(tgtbox.String(tgtbox.Value));
% コメントアウトされたブロック/サブシステムを再取得(削除したコメントアウトをリストから除くため)
list = find_system('test_co', 'IncludeCommented', 'on', 'Commented', 'on');
if isempty(list) % コメントアウトが1つもない場合
list = nocomsg;
end
tgtbox.String = list;
tgtbox.Value = curco;
go_to_commented_out(tgtbox, 'delete'); % 次のブロック/サブシステムを強調
end
% 現在強調しているコメントアウトを削除しないで次のコメントアウトを強調
function go_next_block(~, ~)
% リストの一番下以外のコメントアウトを強調している時
if tgtbox.Value < size(tgtbox.String, 1)
tgtbox.Value = tgtbox.Value + 1; % リスト上の次のブロック/サブシステムを強調
else % 一番下を強調している時
tgtbox.Value = 1; % リストの最初に戻る
end
go_to_commented_out(tgtbox, 'go_next'); % 次のブロック/サブシステムを強調
end
% Simulinkモデルを読み込み
load_system('test_co');
% コメントアウトされたブロック/サブシステムを取得
list = find_system('test_co', 'IncludeCommented', 'on', 'Commented', 'on');
figure('Name', 'コメントアウト削除ツール', 'Position', [300, 150, 600, 370]);
prvco = 0; % 前回強調していたブロック/サブシステムの番号
nocomsg = '** コメントアウトされているブロック/サブシステムはありません。 **';
if isempty(list) % コメントアウトが1つもない場合
list = nocomsg;
end
% ブロックの強調/強調解除の設定
set_param(0, 'HiliteAncestorsData',...
struct('HiliteType', 'user1', ...
'ForegroundColor', 'darkGreen', ...
'BackgroundColor', 'lightBlue'));
set_param(0, 'HiliteAncestorsData', ...
struct('HiliteType', 'default', ...
'ForegroundColor', 'black', ...
'BackgroundColor', 'white'));
uicontrol('Style', 'text', 'String', 'コメントアウトされたブロック/サブシステムを以下に表示', 'Position', [35, 335, 250, 20]);
tgtbox = uicontrol('Style', 'listbox', 'String', list, 'Position', [35, 45, 525, 250], 'Callback', @go_to_commented_out);
dlt_next = uicontrol('Visible', 'off', 'Style', 'pushbutton', 'String', '削除して次を検索', 'Position', [35, 305, 110, 25], 'Callback', @delete_block_and_next_block);
just_next = uicontrol('Visible', 'off', 'Style', 'pushbutton', 'String', '削除せずに次を検索', 'Position', [170, 305, 110, 25], 'Callback', @go_next_block);
end
参考にさせていただいた情報
function delete_comment_out
% リスト上のブロック/サブシステムをクリック時、そのブロック/サブシステムを強調する
function go_to_commented_out(source, command)
if ~strcmp(source.String, nocomsg) % コメントアウトが存在する場合
if prvco ~= 0 && ~strcmp(command, 'delete')
% 前回強調したブロックを、元の状態に戻す
hilite_system(source.String(prvco), 'default');
else
% 特定のブロック/サブシステムが強調状態になって初めて、削除ボタンなどを表示する
dlt_next.Visible = 'on';
just_next.Visible = 'on';
end
% ブロックを強調
hilite_system(source.String(source.Value), 'user1');
prvco = source.Value; % 今回強調したブロックを、前回値として保存
end
end
% 現在強調しているコメントアウトを削除して次のコメントアウトを強調
function delete_block_and_next_block(~, ~)
% リストの一番下以外のコメントアウトを強調している時
if tgtbox.Value < size(tgtbox.String, 1)
curco = tgtbox.Value; % リスト上で強調中のブロック/サブシステム番号を保存
else % 一番下を強調している時
curco = 1;
tgtbox.Value = curco; % リストの最初に戻る
end
delete_block(tgtbox.String(tgtbox.Value));
% コメントアウトされたブロック/サブシステムを再取得(削除したコメントアウトをリストから除くため)
list = find_system('test_co', 'IncludeCommented', 'on', 'Commented', 'on');
if isempty(list) % コメントアウトが1つもない場合
list = nocomsg;
end
tgtbox.String = list;
tgtbox.Value = curco;
go_to_commented_out(tgtbox, 'delete'); % 次のブロック/サブシステムを強調
end
% 現在強調しているコメントアウトを削除しないで次のコメントアウトを強調
function go_next_block(~, ~)
% リストの一番下以外のコメントアウトを強調している時
if tgtbox.Value < size(tgtbox.String, 1)
tgtbox.Value = tgtbox.Value + 1; % リスト上の次のブロック/サブシステムを強調
else % 一番下を強調している時
tgtbox.Value = 1; % リストの最初に戻る
end
go_to_commented_out(tgtbox, 'go_next'); % 次のブロック/サブシステムを強調
end
% Simulinkモデルを読み込み
load_system('test_co');
% コメントアウトされたブロック/サブシステムを取得
list = find_system('test_co', 'IncludeCommented', 'on', 'Commented', 'on');
figure('Name', 'コメントアウト削除ツール', 'Position', [300, 150, 600, 370]);
prvco = 0; % 前回強調していたブロック/サブシステムの番号
nocomsg = '** コメントアウトされているブロック/サブシステムはありません。 **';
if isempty(list) % コメントアウトが1つもない場合
list = nocomsg;
end
% ブロックの強調/強調解除の設定
set_param(0, 'HiliteAncestorsData',...
struct('HiliteType', 'user1', ...
'ForegroundColor', 'darkGreen', ...
'BackgroundColor', 'lightBlue'));
set_param(0, 'HiliteAncestorsData', ...
struct('HiliteType', 'default', ...
'ForegroundColor', 'black', ...
'BackgroundColor', 'white'));
uicontrol('Style', 'text', 'String', 'コメントアウトされたブロック/サブシステムを以下に表示', 'Position', [35, 335, 250, 20]);
tgtbox = uicontrol('Style', 'listbox', 'String', list, 'Position', [35, 45, 525, 250], 'Callback', @go_to_commented_out);
dlt_next = uicontrol('Visible', 'off', 'Style', 'pushbutton', 'String', '削除して次を検索', 'Position', [35, 305, 110, 25], 'Callback', @delete_block_and_next_block);
just_next = uicontrol('Visible', 'off', 'Style', 'pushbutton', 'String', '削除せずに次を検索', 'Position', [170, 305, 110, 25], 'Callback', @go_next_block);
end
本記事執筆のために、下記サイト様の情報を参考にさせていただきました。
内容 | リンク先 |
---|---|
MATLABによるSimulink中の全コメントアウト削除 | http://blog.smooth-works.net/archives/3343 |
最後
ご指摘・改善案・間違い指摘、大歓迎です。どしどしいただければ喜びに舞い、技術の海に溺れます。
Author And Source
この問題について(【MATLAB/Simulink】コメントアウトを探して削除するスクリプトを作ってみた), 我々は、より多くの情報をここで見つけました https://qiita.com/Fuminori_Souma/items/34c0007498243df178cb著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .