added size adjustment to dynamic strings
--HG-- extra : convert_revision : svn%3A39bc706e-5318-0410-9160-8a85361fbb7c/trunk%40205
This commit is contained in:
		
							parent
							
								
									7b2455db2e
								
							
						
					
					
						commit
						34c711fffd
					
				| @ -626,6 +626,7 @@ SC_FUNC void char2addr(void); | ||||
| SC_FUNC void charalign(void); | ||||
| SC_FUNC void addconst(cell value); | ||||
| SC_FUNC void setheap_save(cell value); | ||||
| SC_FUNC void stradjust(regid reg); | ||||
| 
 | ||||
| /*  Code generation functions for arithmetic operators.
 | ||||
|  * | ||||
|  | ||||
| @ -2241,7 +2241,10 @@ static int declloc(int fstatic) | ||||
|         if (numdim == sDIMEN_MAX) { | ||||
|           error(53);                      /* exceeding maximum number of dimensions */ | ||||
|           return (all_constant ? iARRAY : iREFARRAY); | ||||
|         } /* if */ | ||||
|         } else if (numdim) { /* if */ | ||||
|           /* If we have a dimension on the stack, push it */ | ||||
|           pushreg(sPRI); | ||||
|         } | ||||
|         if (matchtoken(']')) { | ||||
|           dim[numdim++] = 0; | ||||
|           continue; | ||||
| @ -2249,9 +2252,7 @@ static int declloc(int fstatic) | ||||
|         dim_ident = doexpr2(TRUE,FALSE,FALSE,FALSE,&idxtag[numdim],&dim_sym,0,&dim_val); | ||||
|         if (dim_ident == iVARIABLE || dim_ident == iEXPRESSION || dim_ident == iARRAYCELL) { | ||||
|           all_constant = 0; | ||||
|           pushreg(sPRI); | ||||
|         } else if (dim_ident == iCONSTEXPR) { | ||||
|           pushreg(sPRI); | ||||
|           dim[numdim] = dim_val.constval; | ||||
| 		  /* :TODO: :URGENT: Make sure this still works */ | ||||
|           if (dim_sym && dim_sym->usage & uENUMROOT) | ||||
| @ -2275,6 +2276,10 @@ static int declloc(int fstatic) | ||||
|         ident = iARRAY; | ||||
|         stgdel(_index, _code); | ||||
|       } else { | ||||
|         if (tag == pc_tag_string && numdim && dim[numdim-1]) { | ||||
|           stradjust(sPRI); | ||||
|         } | ||||
|         pushreg(sPRI); | ||||
|         memset(dim, 0, sizeof(int)*sDIMEN_MAX); | ||||
|         ident = iREFARRAY; | ||||
|         genarray(numdim, autozero); | ||||
|  | ||||
| @ -593,6 +593,13 @@ SC_FUNC void fillarray(symbol *sym,cell size,cell value) | ||||
|   code_idx+=opcodes(2)+opargs(2); | ||||
| } | ||||
| 
 | ||||
| SC_FUNC void stradjust(regid reg) | ||||
| { | ||||
|   assert(reg==sPRI); | ||||
|   stgwrite("\tstradjust.pri\n"); | ||||
|   code_idx+=opcodes(1); | ||||
| } | ||||
| 
 | ||||
| /* Instruction to get an immediate value into the primary or the alternate
 | ||||
|  * register | ||||
|  */ | ||||
|  | ||||
| @ -602,6 +602,7 @@ static OPCODEC opcodelist[] = { | ||||
|   { 15, "stor.pri",   sIN_CSEG, parm1 }, | ||||
|   { 18, "stor.s.alt", sIN_CSEG, parm1 }, | ||||
|   { 17, "stor.s.pri", sIN_CSEG, parm1 }, | ||||
|   {164, "stradjust.pri", sIN_CSEG, parm0 }, | ||||
|   { 24, "strb.i",     sIN_CSEG, parm1 }, | ||||
|   { 79, "sub",        sIN_CSEG, parm0 }, | ||||
|   { 80, "sub.alt",    sIN_CSEG, parm0 }, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user