101 if (0 == strcmp(s,h->
name))
135 void *
atGet(
idhdl root,
const char * name,
int t,
void *defaultReturnValue)
138 if ((temp!=
NULL) && (temp->
atyp==t))
141 return defaultReturnValue;
150 if ((temp!=
NULL) && (temp->
atyp==t))
163 WerrorS(
"cannot set ring-dependend objects at this type");
176 WerrorS(
"cannot set attributes of this object");
180 WerrorS(
"cannot set ring-dependend objects at this type");
183 *a=(*a)->
set(name,data,typ);
198 attr temp =
this,temp1;
222 while (temp1->
next!=temp) temp1 = temp1->
next;
247 WerrorS(
"this object cannot have attributes");
256 PrintS(
"attr:isSB, type int\n");
257 haveNoAttribute=
FALSE;
261 PrintS(
"attr:qringNF, type int\n");
262 haveNoAttribute=
FALSE;
266 PrintS(
"attr:global, type int\n");
267 haveNoAttribute=
FALSE;
276 else if(haveNoAttribute)
PrintS(
"no attributes\n");
281 char *name=(
char *)b->
Data();
286 if (strcmp(name,
"isSB")==0)
292 else if ((strcmp(name,
"rank")==0)&&(v->
Typ()==
MODUL_CMD))
295 res->
data=(
void *)(((ideal)v->
Data())->rank);
297 else if ((strcmp(name,
"global")==0)
301 res->
data=(
void *)(((ring)v->
Data())->OrdSgn==1);
303 else if ((strcmp(name,
"ring_cf")==0)
309 else if (strcmp(name,
"qringNF")==0)
316 else if ((strcmp(name,
"isLPring")==0)
320 res->
data=(
void *)(
long)(((ring)v->
Data())->isLPring);
328 WerrorS(
"this object cannot have attributes");
358 char *name=(
char *)b->
Data();
359 if (strcmp(name,
"isSB")==0)
363 WerrorS(
"attribute isSB must be int");
366 if (((
long)c->
Data())!=0L)
377 else if (strcmp(name,
"qringNF")==0)
381 WerrorS(
"attribute qringNF must be int");
384 if (((
long)c->
Data())!=0L)
395 else if ((strcmp(name,
"rank")==0)&&(v->
Typ()==
MODUL_CMD))
399 WerrorS(
"attribute `rank` must be int");
402 ideal I=(ideal)v->
Data();
403 I->rank=
si_max((
int)I->rank,(
int)((
long)c->
Data()));
405 else if ((strcmp(name,
"global")==0)
408 WerrorS(
"can not set attribute `global`");
412 else if ((strcmp(name,
"isLPring")==0)
416 ((ring)v->
Data())->isLPring=(
int)(long)c->
Data();
419 WerrorS(
"attribute `isLPring` must be int");
454 WerrorS(
"object must have a name");
457 char *name=(
char *)b->
Data();
458 if (strcmp(name,
"isSB")==0)
463 else if (strcmp(name,
"global")==0)
465 WerrorS(
"can not set attribut `global`");
const CanonicalForm int s
#define omCheckAddrSize(addr, size)
void atSet(idhdl root, const char *name, void *data, int typ)
Class used for (list of) interpreter objects.
void killAll(const ring r)
attr set(const char *s, void *data, int t)
Compatiblity layer for legacy polynomial operations (over currRing)
void at_KillAll(idhdl root, const ring r)
void WerrorS(const char *s)
BOOLEAN atKILLATTR2(leftv, leftv a, leftv b)
BOOLEAN atKILLATTR1(leftv, leftv a)
BOOLEAN atATTRIB2(leftv res, leftv v, leftv b)
void at_Kill(idhdl root, const char *name, const ring r)
ring currRing
Widely used global variable which specifies the current polynomial ring for Singular interpreter and ...
const CanonicalForm CFMap CFMap & N
BOOLEAN atATTRIB3(leftv, leftv v, leftv b, leftv c)
void s_internalDelete(const int t, void *d, const ring r)
static int si_max(const int a, const int b)
void PrintS(const char *s)
BOOLEAN atATTRIB1(leftv res, leftv v)
#define omGetSpecBin(size)
const Variable & v
< [in] a sqrfree bivariate poly
void * atGet(idhdl root, const char *name, int t, void *defaultReturnValue)
static BOOLEAN rField_is_Ring(const ring r)
const char * Tok2Cmdname(int tok)
#define omCheckAddr(addr)
static void attr_free(attr h, const ring r=currRing)
#define omFreeBin(addr, bin)