Sds link
- 構文
- int sds_link (int lispmsg);
- 機能
- LISPにSDSアプリケーションの準備ができているか知らせる。
- エラーがあった場合、コマンドラインに "Error: SDS error in evaluation" を表示する。
- 引数
- 
- lispmsg : LISPへのメッセージ。
 
- 戻り値
- 準備ができていれば RSRSLT、そうでなければ RSERR
- サンプル
/* Prototype for an sds application */
#include <stdio.h>
#include "sdslib.h"
/* MAIN -- the main routine */
void
main(argc, argv)
	int argc;
	char *argv[];
{
	int stat;
	short scode = RSRSLT; /* Default result code */
	sds_init(argc, argv); /* Initialize the interface */
	for ( ;; ) { /* Infinite loop */
		if ((stat = sds_link(scode)) < 0) {
			printf("TEMPLATE: bad status from sds_link() = %d\n", stat);
			/* Can't use sds_printf() to display this message, because the link failed */
			fflush(stdout);
			exit(1); /* exit() only req'd for abnormal termination */
		}
		scode = RSRSLT; /* Default return value */
		/* The cases in this switch check for AutoLISP request codes */
		switch (stat) {
			case RQXLOAD:
					scode = loadfuncs() == GOOD ? RSRSLT :
					RSERR;
					break;
			case RQSUBR: /* Usually implemented to call an external function */
					break;
			case RQXUNLD: /* Usually implemented just to return RSRSLT, */
			case RQSAVE: /* not often needed */
			case RQEND:
			case RQQUIT:
			default: /* Return RSRSLT */
					break;
		}
	}
}
/* LOADFUNCS -- Define external functions by calling sds_defun */
static int loadfuncs()
{
	return GOOD;
}
