- if (is_a<varidx>(*ip)) {
- varidx mu((new symbol)->setflag(status_flags::dynallocated), ex_to<varidx>(*ip).get_dim(), ex_to<varidx>(*ip).is_covariant());
- old_indices.push_back(*ip);
- new_indices.push_back(mu);
+ ex newsym=(new symbol)->setflag(status_flags::dynallocated);
+ ex newidx;
+ if(is_exactly_a<spinidx>(*ip))
+ newidx = (new spinidx(newsym, ex_to<spinidx>(*ip).get_dim(),
+ ex_to<spinidx>(*ip).is_covariant(),
+ ex_to<spinidx>(*ip).is_dotted()))
+ -> setflag(status_flags::dynallocated);
+ else if (is_exactly_a<varidx>(*ip))
+ newidx = (new varidx(newsym, ex_to<varidx>(*ip).get_dim(),
+ ex_to<varidx>(*ip).is_covariant()))
+ -> setflag(status_flags::dynallocated);
+ else
+ newidx = (new idx(newsym, ex_to<idx>(*ip).get_dim()))
+ -> setflag(status_flags::dynallocated);
+ old_indices.push_back(*ip);
+ new_indices.push_back(newidx);
+ if(is_a<varidx>(*ip)) {