| 
									
										
										
										
											2015-04-02 20:32:22 +00:00
										 |  |  | /* TODO: it will be useful to parse the function str */ | 
					
						
							|  |  |  | var rc_to_a1 = (function(){ | 
					
						
							|  |  |  | 	var rcregex = /(^|[^A-Za-z])R(\[?)(-?\d+|)\]?C(\[?)(-?\d+|)\]?/g; | 
					
						
							|  |  |  | 	var rcbase; | 
					
						
							|  |  |  | 	function rcfunc($$,$1,$2,$3,$4,$5) { | 
					
						
							|  |  |  | 		var R = $3.length>0?parseInt($3,10)|0:0, C = $5.length>0?parseInt($5,10)|0:0; | 
					
						
							|  |  |  | 		if(C<0 && $4.length === 0) C=0; | 
					
						
							| 
									
										
										
										
											2017-02-19 20:36:32 +00:00
										 |  |  | 		var cRel = false, rRel = false; | 
					
						
							|  |  |  | 		if($4.length > 0 || $5.length == 0) cRel = true; if(cRel) C += rcbase.c; else --C; | 
					
						
							|  |  |  | 		if($2.length > 0 || $3.length == 0) rRel = true; if(rRel) R += rcbase.r; else --R; | 
					
						
							|  |  |  | 		return $1 + (cRel ? "" : "$") + encode_col(C) + (rRel ? "" : "$") + encode_row(R); | 
					
						
							| 
									
										
										
										
											2015-04-02 20:32:22 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return function rc_to_a1(fstr, base) { | 
					
						
							|  |  |  | 		rcbase = base; | 
					
						
							|  |  |  | 		return fstr.replace(rcregex, rcfunc); | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | })(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-13 06:46:37 +00:00
										 |  |  | var crefregex = /(^|[^._A-Z0-9])([$]?)([A-Z]{1,2}|[A-W][A-Z]{2}|X[A-E][A-Z]|XF[A-D])([$]?)([1-9]\d{0,5}|10[0-3]\d{4}|104[0-7]\d{3}|1048[0-4]\d{2}|10485[0-6]\d|104857[0-6])(?![_.\(A-Za-z0-9])/g; | 
					
						
							| 
									
										
										
										
											2017-03-14 08:19:51 +00:00
										 |  |  | var a1_to_rc =(function(){ | 
					
						
							|  |  |  | 	return function a1_to_rc(fstr, base) { | 
					
						
							|  |  |  | 		return fstr.replace(crefregex, function($0, $1, $2, $3, $4, $5, off, str) { | 
					
						
							|  |  |  | 			/* TODO: handle fixcol / fixrow */ | 
					
						
							|  |  |  | 			var c = decode_col($3) - base.c; | 
					
						
							|  |  |  | 			var r = decode_row($5) - base.r; | 
					
						
							|  |  |  | 			return $1 + "R" + (r == 0 ? "" : "[" + r + "]") + "C" + (c == 0 ? "" : "[" + c + "]"); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | })(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* no defined name can collide with a valid cell address A1:XFD1048576 ... except LOG10! */ | 
					
						
							| 
									
										
										
										
											2017-02-19 20:36:32 +00:00
										 |  |  | function shift_formula_str(f/*:string*/, delta/*:Cell*/)/*:string*/ { | 
					
						
							| 
									
										
										
										
											2017-03-13 06:46:37 +00:00
										 |  |  | 	return f.replace(crefregex, function($0, $1, $2, $3, $4, $5, off, str) { | 
					
						
							| 
									
										
										
										
											2017-02-19 20:36:32 +00:00
										 |  |  | 		return $1+($2=="$" ? $2+$3 : encode_col(decode_col($3)+delta.c))+($4=="$" ? $4+$5 : encode_row(decode_row($5) + delta.r)); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function shift_formula_xlsx(f/*:string*/, range/*:string*/, cell/*:string*/)/*:string*/ { | 
					
						
							|  |  |  | 	var r = decode_range(range), s = r.s, c = decode_cell(cell); | 
					
						
							|  |  |  | 	var delta = {r:c.r - s.r, c:c.c - s.c}; | 
					
						
							|  |  |  | 	return shift_formula_str(f, delta); | 
					
						
							|  |  |  | } |