月別アーカイブ: 2025年4月

VectorScriptのデバッグ2(debug2)ログファイルへ出力

プログラムを記述して、コンパイルエラーがなければ実行する。しかし思ったような結果にならないことはよくある。そんなときに有効なデバッグテクニックを紹介する。

ログファイルを使う方法

実行中のコードにログファイルに文字列を出力するコマンドを挿入しておいて、実行時に注目している変数がどのような値になっているかを調べる。アラートダイアログの方法と違ってプログラムが止まらないという長所がある。

次のコードをスクリプトパレットに登録し、図形を選択してから実行する。

procedure debug_test;
var
	h: handle;
	myType: integer;
	gAryLog: DYNARRAY [] OF STRING; { Jiro_LogAdd }
	gCntOfAryLog: LONGINT; { Jiro_LogAdd }
	
	(* -------------------------------
     関数:Jiro_LogAdd                                  
     機能:ログ出力バッファに1行メッセージを追加する 
	------------------------------ *)
    PROCEDURE Jiro_LogAdd( msg: STRING );
	BEGIN
		gCntOfAryLog:= gCntOfAryLog +1;
		ALLOCATE gAryLog[ 1.. gCntOfAryLog];
		gAryLog[gCntOfAryLog]:=msg;

	END;
	(* -------------------------------
	関数: Jiro_Logout
	機能: ログ出力: メッセージをテキストファイルに書き出す
	------------------------------ *)
	procedure Jiro_Logout;
	CONST
		kFileName='/Users/wat/Desktop/my_log.txt'; { デスクトップのファイル名 }
	var
		i: LONGINT;

	begin
		ReWrite( kFileName ); {保存ダイアログなし}
			FOR i:=1 TO gCntOfAryLog DO BEGIN
				WriteLn( gAryLog[i] );

			END;	
		Close(kFileName);
	end;

begin
	h:=FSActLayer;
	while h<>NIL do begin
		myType:=GetTypeN( h );
	
		Jiro_LogAdd( concat( 'debug_test: type=', Num2StrF(myType)));
		
		h:=NextSObj(h);
	end; {while}
	
	{ ログ出力 }
	Jiro_LogAdd( concat( Date(2,1), 'END of PGM' ) );
	Jiro_Logout;

end;
RUN ( debug_test );

グローバルな配列変数gAryLogに出力するログをためていって、プログラムの最後でファイルに出力する、というコードだ。

2つの図形を選択して実行する。

実行すると、デスクトップに「my_log.txt」というテキストファイルが作成される。ファイルの中身は次のとおり。

コーディングは少し面倒ではあるが、うまく使えばプログラムの動きがよくわかる。

VectorScriptのデバッグ1(debug1)アラートダイアログ

プログラムを記述して、コンパイルエラーがなければ実行する。しかし思ったような結果にならないことはよくある。そんなときに有効なデバッグテクニックを紹介する。

アラートダイアログを使う方法

実行中のコードにアラートダイアログを表示するコマンドを挿入しておいて、実行時に注目している変数がどのような値になっているかを調べる。

次のコードをスクリプトパレットに登録し、図形を選択してから実行する。

procedure debug_test;
var
	h: handle;
	myType: integer;
	
begin
	h:=FSActLayer;
	myType:=GetTypeN( h );
	
	alrtDialog( concat( 'debug_test: type=', Num2StrF(myType)));

end;
RUN ( debug_test );

文字列図形を選択して実行してみた結果は次の図

アラートダイアログによって変数の中身をみるためには、次のようなコマンドを知っていると便利。

  • AlrtDialog ダイアログ表示
  • concat 文字列連結。一度に2つの文字列を連結、3つ連結したかったら、2行にわけて記述。
  • Num2StrF 数値を文字に変換する
  • ” シングルクオーツ:Pascal言語では文字列はシングルクオーツで囲む

アラートダイアログによるデバッグはコード挿入が簡単だが、プログラムがいちいち止まってしまうという欠点がある。ループの中で使うと[OK]ボタンをクリックして繰り返しダイアログを閉じていかなくてはならない。抜けるにはoption+command+escキーでVectorWroksを強制終了する。

続いて、デバッグ2(debug2)ログファイルへの出力を紹介する。