[BACK]Return to sample.c CVS log [TXT][DIR] Up to [local] / OpenXM / src / kan96xx / plugin

Annotation of OpenXM/src/kan96xx/plugin/sample.c, Revision 1.1

1.1     ! maekawa     1: #include <stdio.h>
        !             2: #include "../Kan/datatype.h"
        !             3: #include "../Kan/stackm.h"
        !             4: #include "../Kan/kclass.h"
        !             5:
        !             6: #include "sample.h"
        !             7:
        !             8: /*
        !             9:   options for Kan/Makefile
        !            10: PLUGIN = ../plugin
        !            11: PLUGIN_PROTOTYPE  = $(PLUGIN)/sample.h
        !            12: PLUGIN_LIB  = $(PLUGIN)/sample.a
        !            13: PLUGIN_EXT = $(PLUGIN)/sample.hh
        !            14: PLUGIN_SM1 =$(PLUGIN)/sample.sm1
        !            15: PLUGIN_LINKFLAG =
        !            16: */
        !            17:
        !            18: static struct operandStack *SharedStack = NULL;
        !            19: static struct object Kplugin_NullObject;
        !            20:
        !            21: /*  Sample is a very simple stack machine.
        !            22:     There are only one operation "add" on the shared stack.
        !            23:     Kplugin_sample(KPLUGIN_SAMPLE_INIT,
        !            24:                    [ new-operand-stack-for-the-shared-stack ]);
        !            25:     Pplugin_sample(KPLUGIN_SAMPLE_ADD, [ ] ); push the result on the shared
        !            26:                                               stack.
        !            27: */
        !            28:
        !            29: int Kplugin_sample(int opcode, struct object obj) {
        !            30:   /* obj is assumed to be an array. */
        !            31:   struct object ob1,ob2,ob3;
        !            32:   static initialized = 0;
        !            33:   if (opcode != KPLUGIN_SAMPLE_INIT && !initialized) {
        !            34:     errorSample("This component is not initialized.");
        !            35:     return(-1);
        !            36:   }
        !            37:   switch(opcode) {
        !            38:   case KPLUGIN_SAMPLE_INIT:
        !            39:     if (getoaSize(obj) < 1) {
        !            40:       errorSample("No argument for opcode=0 (initialization).");
        !            41:       return(-1);
        !            42:     }
        !            43:     ob1 = getoa(obj,0);
        !            44:     if (ectag(ob1) != CLASSNAME_OPERANDSTACK) {
        !            45:       errorSample("Argument must be an operand stack.");
        !            46:       return(-1);
        !            47:     }
        !            48:     SharedStack = (struct operandStack *) ecbody(ob1);
        !            49:     fprintf(stderr,"Initializing plugin_sample\n");
        !            50:     initialized = 1;
        !            51:     Kplugin_NullObject.tag = Snull;
        !            52:     break;
        !            53:   case KPLUGIN_SAMPLE_SELECT:
        !            54:     return(1); /* finished. */
        !            55:     break;
        !            56:   case KPLUGIN_SAMPLE_WAIT:
        !            57:     return(0);
        !            58:     break;
        !            59:   case KPLUGIN_SAMPLE_ADD:
        !            60:     ob2 = Kplugin_pop(SharedStack);  printf("%d\n",ob2.lc.ival);
        !            61:     ob1 = Kplugin_pop(SharedStack);  printf("%d\n",ob1.lc.ival);
        !            62:     ob1.lc.ival += ob2.lc.ival;
        !            63:     Kplugin_push(ob1,SharedStack);
        !            64:     break;
        !            65:   default:
        !            66:     errorSample("plugin_sample: unknown op-code.");
        !            67:     return(-1);
        !            68:     break;
        !            69:   }
        !            70:   return(0);
        !            71: }
        !            72:
        !            73: /* Should we use functions to handle operand stacks defined in
        !            74:    ../Kan/  or we should have our own functions to handle operand stack?
        !            75:   We should copy functions to handle stacks from ../Kan.
        !            76: */
        !            77: int Kplugin_push(struct object ob,struct operandStack *operandstack)
        !            78: {
        !            79:   (operandstack->ostack)[(operandstack->sp)++] = ob;
        !            80:   if ((operandstack->sp) >= (operandstack->size)) {
        !            81:     errorSample("Operand stack overflow.");
        !            82:     (operandstack->sp)--;
        !            83:     return(-1);
        !            84:   }
        !            85:   return(0);
        !            86: }
        !            87:
        !            88: struct object Kplugin_pop(struct operandStack *operandstack)
        !            89: {
        !            90:   if ((operandstack->sp) <= 0) {
        !            91:     return( Kplugin_NullObject );
        !            92:   }else{
        !            93:     return( (operandstack->ostack)[--(operandstack->sp)]);
        !            94:   }
        !            95: }
        !            96:
        !            97: struct object Kplugin_peek(int k,struct operandStack *operandstack)
        !            98: {
        !            99:   if (((operandstack->ostack)-k-1) < 0) {
        !           100:     return( Kplugin_NullObject );
        !           101:   }else{
        !           102:     return( (operandstack->ostack)[(operandstack->sp)-k-1]);
        !           103:   }
        !           104: }
        !           105:
        !           106:
        !           107: static void errorSample(char *s) {
        !           108:   fprintf(stderr,"Error in plugin/sample: %s\n");
        !           109:   /* or push error message in the sharedStack. */
        !           110: }
        !           111:
        !           112:

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>