LoginSignup
5
0

More than 3 years have passed since last update.

【MATLAB/Simulink】コメントアウトを探して削除するスクリプトを作ってみた

Last updated at Posted at 2020-09-13

あらすじ

Simulinkモデルを書き進めていくと、テキスト言語と同様にコメントアウトがどんどん溜まっていきます。幸い、Simulink(というかMATLAB)でコメントアウトを探すことができ、それらの一斉削除も容易です。しかしその中には当然他人が残したものもあり、それらを削除していいかどうかは自分では判断できません。

そこで、モデルに残されたコメントアウトをひとつずつ検索していき、削除もしくは削除しない、の判断が可能なツールを作成します。

環境

・MATLAB 2015b
・Simulink 8.6

実際に使ってみる

作成したスクリプトを、下記Simulinkモデル「test_co.slx」に対して使用してみます。
このモデルは、各階層にブロックやサブシステムのコメントアウトが散りばめられています。

図1.png

まず、スクリプトを実行します。モデル中の全コメントアウトがリストに記載されます。
image.png

次にリストに追加されたコメントアウトをクリックすると、その場所にジャンプしてクリック対象が青く強調表示されます。GUIの方には「削除して次を検索」ボタンと「削除せずに次を検索」ボタンが新たに表示されます。
image.png
image.png

「削除して次を検索」を押すと、Simulink上で対象のコメントアウトが削除され、リストからも消えます。
image.png
image.png

「削除せずに次を検索」を押すと、単に強調の対象が次のブロックに移ります。
image.png
image.png

どんどん削除していくと、最後には以下のように表示されます。
(最初からコメントアウトが存在しない場合も、同様の表示がなされます)
image.png

ソース

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

参考にさせていただいた情報

本記事執筆のために、下記サイト様の情報を参考にさせていただきました。

内容 リンク先
MATLABによるSimulink中の全コメントアウト削除 http://blog.smooth-works.net/archives/3343

最後

ご指摘・改善案・間違い指摘、大歓迎です。どしどしいただければ喜びに舞い、技術の海に溺れます。

5
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
0