[BACK]Return to strobj.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / builtin

Diff for /OpenXM_contrib2/asir2000/builtin/strobj.c between version 1.35 and 1.37

version 1.35, 2004/03/10 05:27:03 version 1.37, 2004/03/10 06:12:25
Line 45 
Line 45 
  * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,   * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
  * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.   * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
  *   *
  * $OpenXM: OpenXM_contrib2/asir2000/builtin/strobj.c,v 1.34 2004/03/09 09:40:46 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/strobj.c,v 1.36 2004/03/10 05:37:24 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
Line 184  char *conv_subscript(char *name)
Line 184  char *conv_subscript(char *name)
         char **subs;          char **subs;
   
         len = strlen(name);          len = strlen(name);
           if ( !len ) return 0;
         subs = (char **)ALLOCA(len*sizeof(char* ));          subs = (char **)ALLOCA(len*sizeof(char* ));
         for ( i = 0, j = 0, start = i; ; j++ ) {          for ( i = 0, j = 0, start = i; ; j++ ) {
                 while ( (i < len) &&                  while ( (i < len) &&
Line 196  char *conv_subscript(char *name)
Line 197  char *conv_subscript(char *name)
                                 else if ( name[i] == '}' ) level--;                                  else if ( name[i] == '}' ) level--;
                         }                          }
                         slen = i-start;                          slen = i-start;
                         brace = (char *)ALLOCA((slen+1)*sizeof(char));                          if ( slen >= 3 ) {
                         strncpy(brace,name+start+1,slen-2);                                  brace = (char *)ALLOCA((slen+1)*sizeof(char));
                         brace[slen-2] = 0;                                  strncpy(brace,name+start+1,slen-2);
                         buf = conv_subscript(brace);                                  brace[slen-2] = 0;
                         subs[j] = (char *)ALLOCA((strlen(buf)+3)*sizeof(char));                                  buf = conv_subscript(brace);
                         sprintf(subs[j],"{%s}",buf);                                  subs[j] = (char *)ALLOCA((strlen(buf)+3)*sizeof(char));
                                   sprintf(subs[j],"{%s}",buf);
                           } else
                                   subs[j] = "{}";
                 } else {                  } else {
                         if ( isdigit(name[i]) )                          if ( isdigit(name[i]) )
                                 while ( i < len && isdigit(name[i]) ) i++;                                  while ( i < len && isdigit(name[i]) ) i++;
Line 1130  int top_is_minus(FNODE f)
Line 1134  int top_is_minus(FNODE f)
                         return top_is_minus((FNODE)FA0(f));                          return top_is_minus((FNODE)FA0(f));
                 case I_FORMULA:                  case I_FORMULA:
                         obj = (Obj)FA0(f);                          obj = (Obj)FA0(f);
                         if ( obj && OID(obj) == O_P ) {                          if ( !obj )
                                 opname = conv_rule(VR((P)obj)->name);                                  return 0;
                         } else {                          else {
                                 len = estimate_length(CO,obj);                                  switch ( OID(obj) ) {
                                 opname = (char *)MALLOC_ATOMIC(len+1);                                          case O_N:
                                 soutput_init(opname);                                                  return mmono((P)obj);
                                 sprintexpr(CO,obj);                                          case O_P:
                                                   /* must be a variable */
                                                   opname = conv_rule(VR((P)obj)->name);
                                                   return opname[0]=='-';
                                           default:
                                                   /* ??? */
                                                   len = estimate_length(CO,obj);
                                                   opname = (char *)MALLOC_ATOMIC(len+1);
                                                   soutput_init(opname);
                                                   sprintexpr(CO,obj);
                                                   return opname[0]=='-';
                                   }
                         }                          }
                         return opname[0]=='-';  
                 default:                  default:
                         return 0;                          return 0;
         }          }

Legend:
Removed from v.1.35  
changed lines
  Added in v.1.37

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