#include #include #include #include #include #include #include #include #include #include static TStatus PolymarkerSizeDisplay( TSM_ELEM_DATA, Tint, cmn_key* ); static TStatus PolymarkerSizeAdd( TSM_ELEM_DATA, Tint, cmn_key* ); static TStatus PolymarkerSizeDelete( TSM_ELEM_DATA, Tint, cmn_key* ); static TStatus PolymarkerSizePrint( TSM_ELEM_DATA, Tint, cmn_key* ); static TStatus PolymarkerSizeInquire( TSM_ELEM_DATA, Tint, cmn_key* ); static TStatus (*MtdTbl[])( TSM_ELEM_DATA, Tint, cmn_key* ) = { 0, /* PickTraverse */ PolymarkerSizeDisplay, PolymarkerSizeAdd, PolymarkerSizeDelete, PolymarkerSizePrint, PolymarkerSizeInquire }; MtblPtr TelPolymarkerSizeInitClass( TelType *el ) { *el = TelPolymarkerSize; return MtdTbl; } static TStatus PolymarkerSizeAdd( TSM_ELEM_DATA d, Tint n, cmn_key *k ) { Tfloat *data = new Tfloat(); if( !data ) return TFailure; *data = k[0]->data.fdata; ((tsm_elem_data)(d.pdata))->pdata = data; return TSuccess; } static TStatus PolymarkerSizeDisplay( TSM_ELEM_DATA data, Tint n, cmn_key *k ) { CMN_KEY key; key.id = TelPolymarkerSize; key.data.fdata = *(Tfloat*)(data.pdata); TsmSetAttri( 1, &key ); return TSuccess; } static TStatus PolymarkerSizeDelete( TSM_ELEM_DATA data, Tint n, cmn_key *k ) { if (data.pdata) delete data.pdata; return TSuccess; } static TStatus PolymarkerSizePrint( TSM_ELEM_DATA data, Tint n, cmn_key *k ) { fprintf( stdout, "TelPolymarkerSize. Value = %g\n", *(Tfloat *)(data.pdata)); fprintf( stdout, "\n" ); return TSuccess; } static TStatus PolymarkerSizeInquire( TSM_ELEM_DATA data, Tint n, cmn_key *k ) { Tint i; Tfloat *f = (Tfloat *)data.pdata; for( i = 0; i < n; i++ ) { switch( k[i]->id ) { case INQ_GET_SIZE_ID: { k[i]->data.ldata = sizeof( Tint ); break; } case INQ_GET_CONTENT_ID: { TEL_INQ_CONTENT *c; Teldata *w; c = (tel_inq_content)k[i]->data.pdata; w = c->data; c->act_size = 0; w->fdata = *f; break; } } } return TSuccess; }