-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgz_msgbox.lsp
489 lines (460 loc) · 19.1 KB
/
gz_msgbox.lsp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
;;; gz_msgbox 各種のメッセージボックス関数
;;; 関連ファイル:gz_msgbox.dcl
; バージョン
(defun gz_msgbox_ver () (princ "\nGZ_MsgBox --- ver1.6 (MIT License)"))
;;; ------------------------------------------------------------------
;;; ダイアログの種類 --- 対応する関数
;;; ------------------------------------------------------------------
;;; [OK]-[Cancel] --- gz:lspOkCancel
;;; [Yes]-[No] --- gz:lspYesNo
;;; [OK] --- gz:lspOkOnly
;;; [Yes]-[No]-[Cancel] --- gz:lspYesNoCancel
;;; [OK]-[Cancel] --- gz:lspRetryCancel
;;;
;;; 戻り値 OK=T、キャンセル=nil、No="F"
;;;
;;; ------------------------------------------------------------------
;;; ダイアログの種類 --- 対応する関数
;;; ------------------------------------------------------------------
;;; [パスワード入力] --- gz:lspGetPass
;;; [Inputbox] --- gz:lspInputBox (ボタンが横にあるタイプ)
;;; --- gz:lspInputBox2 (ボタンが下にあるタイプ)
;;; --- gz:lspInputBox3 (ボタンが下+チェック欄が一つあるタイプ)
;;; [Combobox] --- gz:lspComboBox
;;; [Listbox] --- gz:lspListBox
;;; [Listbox] --- gz:lspListBoxMlti (複数選択可)
;;;
;;; 戻り値 OK=文字列、キャンセル=nil
;;;
;;; ------------------------------------------------------------------
;;; ダイアログの種類 --- 対応する関数
;;; ------------------------------------------------------------------
;;; [フォルダ選択] --- gz:lspbrowsefolder
;;;
;;; 戻り値 フォルダ名の文字列
;;; ------------------------------------------------------------------
;;; [popup] WSH の popup メソッドを使ったMSGボックス --- gz:popup
;;;
;;; 戻り値 OK=1,キャンセル=2, 中止=3, 再試行=4, 無視=5,
;;; はい=6, いいえ=7, 再実行=10, 続行=11
;;;
;;; ------------------------------------------------------------------
; ライセンス(MIT License)
; Copyright (c) 2021 - Hiroki Sugihara
;
; 以下に定める条件に従い、本ソフトウェアおよび関連文書のファイル
; (以下「ソフトウェア」)の複製を取得するすべての人に対し、ソフトウェアを
; 無制限に扱うことを無償で許可します。これには、ソフトウェアの複製を使用、複写、
; 変更、結合、掲載、頒布、サブライセンス、および/または販売する権利、および
; ソフトウェアを提供する相手に同じことを許可する権利も無制限に含まれます。
; 上記の著作権表示および本許諾表示を、ソフトウェアのすべての複製または重要な
; 部分に記載するものとします。
; ソフトウェアは「現状のまま」で、明示であるか暗黙であるかを問わず、何らの
; 保証もなく提供されます。ここでいう保証とは、商品性、特定の目的への適合性、
; および権利非侵害についての保証も含みますが、それに限定されるものではありません。
; 作者または著作権者は、契約行為、不法行為、またはそれ以外であろうと、
; ソフトウェアに起因または関連し、あるいはソフトウェアの使用またはその他の
; 扱いによって生じる一切の請求、損害、その他の義務について何らの責任も負わない
; ものとします。
;;; ------------------------------------------------------------------
(defun msgchk (m /)
; メッセージの文字列チェックとリスト化。
; 単純な文字列だったらリスト化する。
; 文字列リストは、5個まで空文字追加。
(if (and (/= 'STR (type m)) (/= 'LIST (type m)))
(setq m '("not strings")))
(if (= 'STR (type m)) (setq m (list m)))
(while (<= (length m) 4) (setq m (append m '(""))))
m)
(defun gz:LispEd (txt / dcl_id dcl state)
; シンプルな1行の文字列編集ダイアログコマンド(autocad の lisped 関数対処用)
; 入力された文字列を返す
; メッセージラベル付きがいいなら gz:lspInputBox を使いましょう。
; ex. (gz:LispEd "txt")
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "LspEd" dcl_id)) (exit))
(set_tile "contents" txt)
(mode_tile "contents" 2)
(action_tile "contents" "(setq txt $value)")
(action_tile "accept" "(done_dialog 1)")
(setq state (start_dialog))
(unload_dialog dcl_id)
(cond
((= state 1) txt)
((= state 2) -1)
(t 0)
)
)
(defun gz:lspOkCancel (title msg1 / result dcl_id)
; title = ダイアログのタイトル文字列
; msg1 = メッセージ文字列または文字列のリスト ("メッセージ1" "メッセージ2" "メッセージ3")
; 3つ目以降は無視される
; 戻り値 : T or nil
; ex. (gz:lspOkCancel "文字列1" "OK-Cancel メッセージボックス")
(setq msg1 (msgchk msg1))
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspOkCancel" dcl_id)) (exit))
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "main" title)
(action_tile "cancel" "(done_dialog) (setq result nil)")
(action_tile "accept" "(done_dialog) (setq result T)")
(start_dialog)
(unload_dialog dcl_id)
result)
(defun gz:lspYesNo (main msg1 / result dcl_id)
; (gz:lspYesNo "文字列1" "Yes-No メッセージボックス")
; 戻り値 : T or "F"
(setq msg1 (msgchk msg1))
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspYesNo" dcl_id)) (exit))
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "main" main)
(action_tile "no" "(done_dialog) (setq result \"F\")")
(action_tile "yes" "(done_dialog) (setq result T)" )
(start_dialog)
(unload_dialog dcl_id)
result)
(defun gz:lspOkOnly (main msg1 / dcl_id)
; (lspOkOnly "文字列1" "OK のみメッセージボックス")
; 戻り値 : T のみ
(setq msg1 (msgchk msg1))
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspOkOnly" dcl_id)) (exit) )
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "main" main)
(action_tile "yes" "(done_dialog)")
(start_dialog)
(unload_dialog dcl_id)
T)
(defun gz:lspYesNoCancel (main msg1 / result dcl_id)
;(gz:lspYesNoCancel "文字列1" "Yes-No-Cancel メッセージボックス")
; 戻り値 : T or nil or "F"
(setq msg1 (msgchk msg1))
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspYesNoCancel" dcl_id)) (exit) )
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "main" main)
(action_tile "no" "(done_dialog) (setq result \"F\")")
(action_tile "yes" "(done_dialog) (setq result T)" )
(action_tile "cancel" "(done_dialog) (setq result nil)")
(start_dialog)
(unload_dialog dcl_id)
result)
(defun gz:lspRetryCancel (main msg1 / result dcl_id)
; (gz:lspRetryCancel "lspRetryCancel" "lspRetryCancelボックス")
; 戻り値 : T or nil
(setq msg1 (msgchk msg1))
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspRetryCancel" dcl_id)) (exit) )
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "main" main)
(action_tile "cancel" "(done_dialog) (setq result nil)")
(action_tile "retry" "(done_dialog) (setq result T)")
(start_dialog)
(unload_dialog dcl_id)
result)
(defun gz:lspGetPass (main msg1 / result dcl_id)
; (gz:lspGetPass "メッセージ1" "lspGetPass ボックス")
; 戻り値 : パスワードの文字列 or nil
(setq msg1 (msgchk msg1))
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspGetPass" dcl_id)) (exit) )
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "main" main)
(action_tile "password" "(setq result $value)")
(action_tile "cancel" "(done_dialog) (setq result nil)")
(action_tile "accept" "(done_dialog)")
(start_dialog)
(unload_dialog dcl_id)
result)
(defun gz:lspInputBox (main msg1 / result dcl_id)
; ex. (gz:lspInputBox "なんか入力して" "インプットボックス")
; 戻り値 : テキストボックスの文字列 or nil
(setq msg1 (msgchk msg1)
result "")
(while (= "" result)
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspInputBox" dcl_id)) (exit) )
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "message4" (nth 3 msg1))
(set_tile "main" main)
(action_tile "textbox" "(setq result $value)")
(action_tile "cancel" "(done_dialog) (setq result nil)")
(action_tile "accept" "(done_dialog)")
(start_dialog)
(unload_dialog dcl_id)
)
result)
(defun gz:lspInputBox2 (main msg1 def / result dcl_id)
; ex. (gz:lspInputBox2 "なんか入力して" "インプットボックス" "初期値")
; 戻り値 : テキストボックスの文字列 or nil
(setq msg1 (msgchk msg1)
result "")
(while (= "" result)
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspInputBox2" dcl_id)) (exit) )
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "message4" (nth 3 msg1))
(set_tile "textbox" def)
(set_tile "main" main)
(action_tile "textbox" "(setq result $value)")
(action_tile "cancel" "(done_dialog) (setq result nil)")
(action_tile "accept" "(done_dialog)")
(start_dialog)
(unload_dialog dcl_id)
)
result)
(defun gz:lspInputBox3 (main msg1 def chk / dcl_id result ret_chk)
; 引数 chk
; ex. (gz:lspInputBox3 "なんか入力して" "インプットボックス" "初期値" "1")
; 戻り値 : テキストボックスの文字列とチェック項目のON/OFF のリスト or nil
; -> ("テキストボックスの文字列" "1")
(setq msg1 (msgchk msg1)
result ""
ret_chk "")
(if (or (= "1" chk) (= 1 chk)) ; チェックボックスの引数チェック
(setq ret_chk "1")
(setq ret_chk "0")
)
(while (= "" result)
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspInputBox3" dcl_id)) (exit) )
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(set_tile "message4" (nth 3 msg1))
(set_tile "chk1" ret_chk)
(set_tile "textbox" def)
(set_tile "main" main)
(action_tile "chk1" "(setq ret_chk $value)")
(action_tile "textbox" "(setq result $value)")
(action_tile "cancel" "(done_dialog) (setq result nil)")
(action_tile "accept" "(done_dialog)")
(start_dialog)
(unload_dialog dcl_id)
)
; 返り値
(if result
(list result ret_chk)
nil)
)
(defun gz:lspComboBox (main msg1 lst / result dcl_id)
; ex. (gz:lspComboBox "xxxxなんで選んで" "コンボボックス" '("aaa" "AA" "あああ" "ぁぁぁ" "1234567890"))
; 戻り値 : ポップアップリストの値 or nil
(setq msg1 (msgchk msg1)
result "")
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog "lspCombobox" dcl_id)) (exit) )
(set_tile "main" main)
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(start_list "poplist") ; ポップアップリストの追加
(mapcar 'add_list lst)
(end_list)
(set_tile "poplist" "0")
(action_tile "poplist" "(setq result $value)")
(action_tile "cancel" "(setq result nil) (done_dialog)")
(action_tile "accept" "(setq result (get_tile \"poplist\")) (done_dialog) ")
(start_dialog)
(unload_dialog dcl_id)
result)
(defun gz:lspListBox (main msg1 lst / result dcl_id)
; ex. (gz:lspListBox "xxxxなんか選んで" "リスト" '("aaa" "AA" "あああ" "ぁぁぁ" "1234567890"))
; 戻り値 : 選択したリストボックスインデックス値の文字列 or nil ex. "2"
; 引数 msg1 が "lspListbox0 の場合 "メッセージ無しタイプ" で表示
(setq dcltype (if msg1 "lspListbox" "lspListbox0"))
(setq msg1 (msgchk msg1)
result "")
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog dcltype dcl_id)) (exit))
(set_tile "main" main)
(set_tile "message1" (car msg1))
(set_tile "message2" (cadr msg1))
(set_tile "message3" (caddr msg1))
(start_list "listbox") ; リストの追加
(mapcar 'add_list lst)
(end_list)
(set_tile "listbox" "0")
(action_tile "listbox" "(setq result $value)")
(action_tile "cancel" "(setq result nil) (done_dialog)")
(action_tile "accept" "(setq result (get_tile \"listbox\")) (done_dialog) ")
(start_dialog)
(unload_dialog dcl_id)
result)
(defun gz:lspListBoxMulti (main msg1 lst / dcltype msg2 result dcl_id)
; msg1 = nil なら メッセージ無しタイプのダイアログを読み込み
; ex. (gz:lspListBoxMulti "何個か選んでぇ" "リスト" '("aaa" "AA" "あああ" "ぁぁぁ" "1234567890"))
; ex. (gz:lspListBoxMulti "何個か選んでぇ" nil '("aaa" "AA" "あああ" "ぁぁぁ" "1234567890"))
; 戻り値 : 選択したリストボックスインデックス値の文字列(スペース区切り) or nil
; ex. "2 3 6"
;"lspListboxMulti0 = メッセージ無しタイプ"
(setq dcltype (if msg1 "lspListboxMulti" "lspListboxMulti0"))
(setq msg2 (msgchk msg1)
result "")
(setq dcl_id (load_dialog "gz_msgbox.dcl"))
(if (not (new_dialog dcltype dcl_id)) (exit))
(set_tile "main" main)
(if msg1 (progn
(set_tile "message1" (car msg2))
(set_tile "message2" (cadr msg2))
(set_tile "message3" (caddr msg2))
))
(start_list "listbox") ; リストの追加
(mapcar 'add_list lst)
(end_list)
(action_tile "listbox" "(setq result $value)")
(action_tile "cancel" "(setq result nil) (done_dialog)")
(action_tile "accept" "(setq result (get_tile \"listbox\")) (done_dialog) ")
(start_dialog)
(unload_dialog dcl_id)
; スペース区切りの文字列が返ってくるが、以下の形でリスト化できる
(setq ret_list (read (strcat "(" result ")" )))
; 選択された項目だけのリストを返す
(mapcar '(lambda (x) (nth x lst)) ret_list)
)
;;; ------------------------------------------------------------------
(defun gz:lspbrowsefolder (title folder / shlobj fldobj)
; フォルダ選択ダイアログの関数
; 戻り値:選択したフォルダのパス
; ex. (gz:lspbrowsefolder "○○のフォルダを選択" nil)
;
(vl-load-com)
(setq shlobj (vla-getinterfaceobject
(vlax-get-acad-object) "Shell.Application")
folder (vlax-invoke-method
shlobj
'browseforfolder
0
title
(+ 4 16 64 256 32768) ; フォルダ参照の動作オプション
folder)
)
(vlax-release-object shlobj)
(if folder
(progn
(setq fldobj (vlax-get-property folder 'self)
folderName (vlax-get-property fldobj 'path) )
(vlax-release-object folder)
(vlax-release-object fldobj)
folderName
)))
;;; ------------------------------------------------------------------
(defun GZ:popup ( title msg bit / wsh rtn )
; WSH のポップアップメソッドにあるメッセージボックスのラッパー。
;; title … タイトルの文字列
;; msg … メッセージボックスの文字列
;; bit … [INT] ビット符号化されたアイコン・ボタンの外観を示す整数
;; 戻り値:[INT] 押されたボタンを示す整数
; ex. (GZ:popup "タイトル文字列" "メッセージ文字列。" (+ 2 48 4096))
; -> 1
;;; 'bit' のリファレンス
;;; ボタン
;;; 値 内容
;;; 0 OK ボタン表示
;;; 1 OK、Cancel ボタン表示
;;; 2 Abort、Retry、Ignore ボタン表示
;;; 3 Yes,、No、 Cancel ボタン表示
;;; 4 Yes、No ボタン表示
;;; 5 Retry、Cancel ボタン表示
;;; 6 Cancel、Try Again、Continue ボタン表示
;;;
;;; アイコン
;;; 値 内容
;;; 16 Stop アイコン表示
;;; 32 Question アイコン表示
;;; 48 Exclamation アイコン表示
;;; 64 Information アイコン表示
;;;
;;; その他
;;; 値 内容
;;; 256 第2ボタンをデフォルトに。
;;; 512 第3ボタンをデフォルトに。
;;; 4096 メッセージボックスは、システムモーダルメッセージボックスであり、一番上のウィンドウに表示されます。
;;; 524288 テキストを右寄せで表示
;;; 1048576 テキストが右流れで表示
;;;
;;; 戻り値
;;; 関連するボタンを押してメッセージボックスを閉じるときに整数値が返される。
;;; 値 内容Description
;;; 1 OK ボタンがクリックされた。
;;; 2 Cancel(キャンセル) ボタンがクリックされた。
;;; 3 Abort(中止) ボタンがクリックされた。
;;; 4 Retry(再試行) ボタンがクリックされた。
;;; 5 Ignore(無視) ボタンがクリックされた。
;;; 6 Yes ボタンがクリックされた。
;;; 7 No ボタンがクリックされた。
;;; 10 Try Again(再実行) ボタンがクリックされた。
;;; 11 Continue(続行) ボタンがクリックされた。
;;;
;;; メモ : IJCAD だと呼び出しが正常ではないのかアイコンなし OKボタンのみの動作になる。2013~2020
(if (setq wsh (vlax-create-object "wscript.shell"))
(progn
(setq rtn (vl-catch-all-apply 'vlax-invoke-method (list wsh 'popup msg 0 title bit)))
(vlax-release-object wsh)
(if (not (vl-catch-all-error-p rtn)) rtn)
)))
;;; ------------------------------------------------------------------
(defun gz_msgbox_test (/ result)
; gz_msgbox 関連関数のテスト 実行→結果表示を一通り行う
(setq msg1 '("メッセージ1" "メッセージ2" "メッセージ3")
lst1 '("aaa" "AA" "あああ" "ぁぁぁ" "1234567890"))
(setq result (gz:lspOkCancel "OK-Cancel メッセージボックス" msg1))
(alert (if (= T result) "OK" "キャンセル"))
(setq result (gz:lspYesNo "Yes-No メッセージボックス" msg1 ))
(alert (if (= T result) "Yes" "No"))
(setq result (gz:lspokonly "OK Only メッセージボックス" msg1 ))
(alert (if (= T result) "OK" "エラー"))
(setq result (gz:lspRetryCancel "Retry-Cancel メッセージボックス" msg1 ))
(alert (if (= T result) "リトライ" "キャンセル"))
(setq result (gz:lspGetPass "GetPass メッセージボックス" msg1 ))
(alert (strcat "パスワードは" result))
(setq result (gz:lisped "シンプル文字入力" ))
(alert (if (= nil result) "キャンセル" result))
(setq result (gz:lspInputBox "インプットボックス" msg1 ))
(alert (if (= nil result) "キャンセル" result))
(setq result (gz:lspInputBox2 "インプットボックス" msg1 "初期値"))
(alert (if (= nil result) "キャンセル" result))
(setq result (gz:lspComboBox "コンボボックス" msg1 lst1))
(alert (if (= nil result) '("キャンセル") result))
(setq result (gz:lspListBox "リストボックス" msg1 lst1))
(alert (if (= nil result) "キャンセル" result))
(setq result (gz:lspListBoxMulti "複数選択リストボックス" msg1 lst1))
(if (= nil result) (prompt "\nキャンセル") (progn (apply 'strcat result)))
(setq result (gz:lspListBoxMulti "複数選択リストボックス" nil lst1))
(if (= nil result) (prompt "\nキャンセル") (progn (apply 'strcat result)))
(setq result (gz:lspbrowsefolder "○○のフォルダを選択" nil))
(alert (if (= nil result) "キャンセル" result))
(setq result (GZ:popup "ポップアップメッセージ" "OK ボタン" (+ 0 16 4096)))
(alert (if (= nil result) "キャンセル" (itoa result)))
(setq result (GZ:popup "ポップアップメッセージ" "OK、キャセル ボタン" (+ 1 32 4096)))
(alert (if (= nil result) "キャンセル" (itoa result)))
(setq result (GZ:popup "ポップアップメッセージ" "中止、再実行、無視 ボタン" (+ 2 48 4096)))
(alert (if (= nil result) "キャンセル" (itoa result)))
(setq result (GZ:popup "ポップアップメッセージ" "はい、いいえ、キャンセル ボタン" (+ 3 64 4096)))
(alert (if (= nil result) "キャンセル" (itoa result)))
(setq result (GZ:popup "ポップアップメッセージ" "はい、いいえ ボタン" (+ 4 48 4096)))
(alert (if (= nil result) "キャンセル" (itoa result)))
(setq result (GZ:popup "ポップアップメッセージ" "再試行 キャンセル ボタン" (+ 5 48 4096)))
(alert (if (= nil result) "キャンセル" (itoa result)))
(setq result (GZ:popup "ポップアップメッセージ" "キャンセル、再実行 続行 ボタン" (+ 6 48 4096)))
(alert (if (= nil result) "キャンセル" (itoa result)))
(princ)
)
(gz_msgbox_ver) (princ)