
var m0 = new Array(1)

m0[1] = new Array(51,35,11,27,50,34,12,20,57,42,6,21,58,30);
m0[1].base = new Array(1,2,3,4,5,6,7,0);
m0[1].root =0;
m0[1].move =0;
m0[2] = new Array(6,21);
m0[2].base = new Array(9,0);
m0[2].root =0;
m0[2].move =1;
m0[3] = new Array(49,41);
m0[3].base = new Array(13,0);
m0[3].root =0;
m0[3].move =4;
m0[4] = new Array(1,11,56,58,10,18,61,43,27,34,43,34);
m0[4].base = new Array(21,22,23,24,25,26,0);
m0[4].root =0;
m0[4].move =12;
m0[5] = new Array(30,21);
m0[5].base = new Array(28,0);
m0[5].root =0;
m0[5].move =13;
m0[6] = new Array(21,36,39,12,3,12,56,58);
m0[6].base = new Array(30,31,32,33,0);
m0[6].root =0;
m0[6].move =14;
m0[7] = new Array(61,52);
m0[7].base = new Array(35,0);
m0[7].root =0;
m0[7].move =15;
m0[8] = new Array(20,27,61,43);
m0[8].base = new Array(37,38,0);
m0[8].root =0;
m0[8].move =16;
m0[9] = new Array(39,46);
m0[9].base = new Array(40,0);
m0[9].root =0;
m0[9].move =17;
m0[10] = new Array(27,12);
m0[10].base = new Array(42,0);
m0[10].root =0;
m0[10].move =18;
m0[11] = new Array(61,43);
m0[11].base = new Array(44,0);
m0[11].root =0;
m0[11].move =19;
m0[12] = new Array(61,43);
m0[12].base = new Array(47,0);
m0[12].root =0;
m0[12].move =21;
m0[13] = new Array(12,33,59,51,33,51,60,51,10,18,45,28,2,9,49,33);
m0[13].base = new Array(49,50,51,52,53,54,55,56,0);
m0[13].root =0;
m0[13].move =22;
m0[14] = new Array(61,43,10,26,60,62,127,61);
m0[14].base = new Array(58,59,60,60,0);
m0[14].root =0;
m0[14].move =23;
m0[15] = new Array(1,11,58,10);
m0[15].base = new Array(62,63,0);
m0[15].root =0;
m0[15].move =24;
m0[17] = new Array(1,11,61,59);
m0[17].base = new Array(73,74,0);
m0[17].root =16;
m0[17].move =6;
m0[18] = new Array(40,42);
m0[18].base = new Array(76,0);
m0[18].root =16;
m0[18].move =7;
m0[16] = new Array(61,52,6,5,35,26,17,26,60,62,127,61,8,24,58,42,1,11,42,41);
m0[16].base = new Array(67,68,69,70,71,71,72,75,77,78,0);
m0[16].root =0;
m0[16].move =27;
m0[19] = new Array(12,5);
m0[19].base = new Array(80,0);
m0[19].root =0;
m0[19].move =28;
m0[20] = new Array(6,5);
m0[20].base = new Array(81,0);
m0[20].root =0;
m0[20].move =28;
m0[21] = new Array(8,24);
m0[21].base = new Array(82,0);
m0[21].root =0;
m0[21].move =28;
m0[22] = new Array(49,41);
m0[22].base = new Array(84,0);
m0[22].root =0;
m0[22].move =29;
m0[23] = new Array(16,25,40,0);
m0[23].base = new Array(86,87,0);
m0[23].root =0;
m0[23].move =30;
m0[24] = new Array(2,26,60,62,127,61);
m0[24].base = new Array(88,89,89,0);
m0[24].root =0;
m0[24].move =30;
m0[25] = new Array(25,52);
m0[25].base = new Array(91,0);
m0[25].root =0;
m0[25].move =32;
m0[26] = new Array(12,8,25,43);
m0[26].base = new Array(93,94,0);
m0[26].root =0;
m0[26].move =33;
m0[27] = new Array(25,43);
m0[27].base = new Array(96,0);
m0[27].root =0;
m0[27].move =34;
m0[28] = new Array(1,18,40,26);
m0[28].base = new Array(98,99,0);
m0[28].root =0;
m0[28].move =35;
m0[29] = new Array(61,59);
m0[29].base = new Array(101,0);
m0[29].root =0;
m0[29].move =36;
m0[31] = new Array(35,20);
m0[31].base = new Array(105,0);
m0[31].root =30;
m0[31].move =1;
m0[30] = new Array(11,21,35,41,26,34,40,12,8,12,41,35,12,9,58,50,16,24,61,58);
m0[30].base = new Array(103,104,106,107,108,109,110,111,112,113,0);
m0[30].root =0;
m0[30].move =37;
m0[32] = new Array(40,42);
m0[32].base = new Array(115,0);
m0[32].root =0;
m0[32].move =38;
m0[33] = new Array(5,12,20,37);
m0[33].base = new Array(117,118,0);
m0[33].root =0;
m0[33].move =39;
m0[34] = new Array(61,59);
m0[34].base = new Array(120,0);
m0[34].root =0;
m0[34].move =40;
m0[35] = new Array(27,36,40,47);
m0[35].base = new Array(122,123,0);
m0[35].root =0;
m0[35].move =41;
m0[36] = new Array(49,41);
m0[36].base = new Array(125,0);
m0[36].root =0;
m0[36].move =42;
m0[37] = new Array(2,18,52,34);
m0[37].base = new Array(127,128,0);
m0[37].root =0;
m0[37].move =43;
m0[38] = new Array(37,29,20,29);
m0[38].base = new Array(130,131,0);
m0[38].root =0;
m0[38].move =44;
m0[39] = new Array(11,17,37,29);
m0[39].base = new Array(133,134,0);
m0[39].root =0;
m0[39].move =45;
m0[40] = new Array(54,38);
m0[40].base = new Array(136,0);
m0[40].root =0;
m0[40].move =46;
m0[41] = new Array(8,9,49,41,9,17,37,29,11,28,34,20,6,7,58,26);
m0[41].base = new Array(138,139,140,141,142,143,144,145,0);
m0[41].root =0;
m0[41].move =47;
m0[42] = new Array(61,53);
m0[42].base = new Array(147,0);
m0[42].root =0;
m0[42].move =48;
m0[43] = new Array(1,49,34,20,11,5,20,34,12,9,37,29);
m0[43].base = new Array(149,150,151,152,153,154,0);
m0[43].root =0;
m0[43].move =49;
m0[44] = new Array(58,50);
m0[44].base = new Array(156,0);
m0[44].root =0;
m0[44].move =50;
m0[45] = new Array(8,11,47,38);
m0[45].base = new Array(158,159,0);
m0[45].root =0;
m0[45].move =51;
m0[46] = new Array(47,45,8,11,37,29);
m0[46].base = new Array(161,162,163,0);
m0[46].root =0;
m0[46].move =52;
m0[47] = new Array(8,10,29,21);
m0[47].base = new Array(165,166,0);
m0[47].root =0;
m0[47].move =53;
m0[48] = new Array(47,43);
m0[48].base = new Array(170,0);
m0[48].root =0;
m0[48].move =56;
m0[49] = new Array(48,32);
m0[49].base = new Array(173,0);
m0[49].root =0;
m0[49].move =58;
m0[50] = new Array(62,63);
m0[50].base = new Array(176,0);
m0[50].root =0;
m0[50].move =60;
m0[51] = new Array(24,32);
m0[51].base = new Array(178,0);
m0[51].root =0;
m0[51].move =61;
m0[52] = new Array(62,63);
m0[52].base = new Array(180,0);
m0[52].root =0;
m0[52].move =62;
m0[53] = new Array(9,8);
m0[53].base = new Array(182,0);
m0[53].root =0;
m0[53].move =63;
m0[54] = new Array(29,27);
m0[54].base = new Array(184,0);
m0[54].root =0;
m0[54].move =64;
m0[55] = new Array(54,38);
m0[55].base = new Array(187,0);
m0[55].root =0;
m0[55].move =66;
m0[56] = new Array(29,13);
m0[56].base = new Array(194,0);
m0[56].root =0;
m0[56].move =72;
m0[57] = new Array(3,6);
m0[57].base = new Array(196,0);
m0[57].root =0;
m0[57].move =73;
m0[58] = new Array(29,13);
m0[58].base = new Array(198,0);
m0[58].root =0;
m0[58].move =74;
m0[59] = new Array(10,8,29,5,15,5,45,5,4,5,36,15);
m0[59].base = new Array(200,201,202,203,204,205,0);
m0[59].root =0;
m0[59].move =75;
m0[60] = new Array(36,37);
m0[60].base = new Array(207,0);
m0[60].root =0;
m0[60].move =76;
m0[61] = new Array(36,37);
m0[61].base = new Array(212,0);
m0[61].root =0;
m0[61].move =80;
m0[62] = new Array(36,28,7,15,34,25);
m0[62].base = new Array(215,216,217,0);
m0[62].root =0;
m0[62].move =82;
m0[64] = new Array(35,43,21,22,12,14,20,12);
m0[64].base = new Array(222,223,224,225,0);
m0[64].root =63;
m0[64].move =3;
m0[63] = new Array(36,37,7,6,37,23,12,14,20,12,4,13,524,4);
m0[63].base = new Array(218,219,220,221,226,227,228,0);
m0[63].root =0;
m0[63].move =82;
m0[0] = new Array(50,34,12,20,62,45,11,27,51,35,6,21,57,42,5,12,58,30,4,6,71,5,52,44,15,23,30,39,9,17,34,27,21,27,39,12,3,12,42,27,20,27,56,58,2,20,59,32,10,26,32,40,5,2,61,25,8,16,35,26,17,26,60,62,127,61,0,8,25,52,1,11,45,35,12,5,35,20,13,20,44,36,27,35,53,37,5,12,36,28,2,1,52,34,6,7,40,47,11,5,49,41,16,24,37,29,20,29,61,29,5,15,58,61,12,3,47,46,8,12,55,39,1,9,28,20,9,10,46,28,3,4,48,32,4,3,61,53,3,4,53,45,4,3,34,43,3,4,28,36,15,21,29,21,14,21,45,21,7,6,43,34,6,7,36,37);
m0[0].base = new Array(0,8,10,11,12,14,15,16,17,18,18,19,20,27,29,34,36,39,41,43,45,46,48,57,61,64,65,66,79,83,85,90,90,92,95,97,100,102,114,116,119,121,124,126,129,132,135,137,146,148,155,157,160,164,167,168,169,171,172,174,175,177,179,181,183,185,186,188,189,190,191,192,193,195,197,199,206,208,209,210,211,213,214,0);
m0[0].root =0;
m0[0].move =0;
var n0 = new Array();
var b0 = -1;
var pieces = "KQNBR ";
var pos_after = "Position after ";
var start_pos = "Startposition ";
function g0(a,b)
{	gm(m0,n0,0,b0,'fischerspassky_rp1g0.htm',a,b);}
function MB_50()
{b0=MB_5(m0,n0,0,b0,'fischerspassky_rp1g0.htm'); GMS(m0,n0,0,b0,'fischerspassky_rp1g0.htm');}
function MB0()
{b0=MB(m0,n0,0,b0,'fischerspassky_rp1g0.htm'); GMS(m0,n0,0,b0,'fischerspassky_rp1g0.htm');}
function MF_50()
{b0=MF_5(m0,n0,0,b0,'fischerspassky_rp1g0.htm'); GMS(m0,n0,0,b0,'fischerspassky_rp1g0.htm');}
function MF0(bVarWin)
{b0=MF(m0,n0,0,b0,'fischerspassky_rp1g0.htm',bVarWin); GMS(m0,n0,0,b0,'fischerspassky_rp1g0.htm');}
var nMoves = new Array(0,0);
var nLevels = new Array(0,0);
var nNameCount = new Array(0,0);
var nOld = new Array(-1,-1);
baseName = 'fischerspassky_rp1';
var EmptyWhitePath = "gif/w.gif";
var EmptyBlackPath = "gif/b.gif";
var gifPath  = 'gif/';
var BackColor = "#F0F4C8";
var leftWindow		= this;
var rightWindow		= this;
var bFrames = 0;
var leftDocument		= leftWindow.document;
var rightDocument	= rightWindow.document;
// Copyright 98,99,00,01 by ChessBase GmbH, Germany
function Init( path )
{ gifs = new Array(6);
	for ( var i=0; i< 26; i++)
		gifs[i]= new Image();
	gifs[0].src = path + "b.gif";
	gifs[1].src = path + "bbb.gif";
	gifs[2].src = path + "bbw.gif";
	gifs[3].src = path + "bkb.gif";
	gifs[4].src = path + "bkw.gif";
	gifs[5].src = path + "bqb.gif";
	gifs[6].src = path + "bqw.gif";
	gifs[7].src = path + "brb.gif";
	gifs[8].src = path + "brw.gif";
	gifs[9].src = path + "bnb.gif";
	gifs[10].src = path + "bnw.gif";
	gifs[11].src = path + "wbb.gif";
	gifs[12].src = path + "wbw.gif";
	gifs[13].src = path + "wrb.gif";
	gifs[14].src = path + "wrw.gif";
	gifs[15].src = path + "wqb.gif";
	gifs[16].src = path + "wqw.gif";
	gifs[17].src = path + "wkb.gif";
	gifs[18].src = path + "wkw.gif";
	gifs[19].src = path + "wnb.gif";
	gifs[20].src = path + "wnw.gif";
	gifs[21].src = path + "wpb.gif";
	gifs[22].src = path + "wpw.gif";
	gifs[23].src = path + "bpb.gif";
	gifs[24].src = path + "wpb.gif";
	gifs[25].src = path + "b.gif";
}
function SyncPicture( base, basename )
{	if ( base > -1 ) return base;
	for ( i=0; i < leftDocument.images.length; i++ )
	{	if ( leftDocument.images[i].name != "" )
			if ( leftDocument.images[i].name == basename )
				return i;
			else if ( leftDocument.images[i].name.substring(0,3) == basename.substring(0,3) )
				i+= 63;
	}
	return -1;
}
function MF_5( moves, names, nm, base, basename )
{	base = SyncPicture( base, basename );
	for ( i=0; nMoves[nm] < moves[nLevels[nm]].length / 2 && i < 10; i++ )
		MF( moves, names, nm, base, false );
	return base;
}
function MB_5( moves, names, nm, base, basename )
{	base = SyncPicture( base, basename );
	for ( i=0; ( nMoves[nm] > 0 || nLevels[nm] > 0 ) && i < 10; i++ )
		MB( moves, names, nm, base );
	return base;
}
function GoStart( moves, names, nm, base, basename )
{	base = SyncPicture( base, basename );
	while ( nMoves[nm] > 0 || nLevels[nm] > 0 )
		MB( moves, names, nm, base );
	return base;
}
function GoEnd( moves, names, nm, base, basename )
{	base = SyncPicture( base, basename );
	while ( nMoves[nm] < moves[nLevels[nm]].length / 2 )
		MF( moves, names, nm, base, false );
	return base;
}
function MF( moves, names, nm, base, basename, bCheckV )
{	base = SyncPicture( base, basename );
	if ( bCheckV )
	{	var b = false;
		for ( i=0; i < moves.length; i++ )
			if ( i != nLevels[nm] && moves[i].root == nLevels[nm] && moves[i].move == nMoves[nm] )
				b = true;
		if ( b )
		{	GenerateVarWindow(moves, names, nm, base, basename);
			return base;
		}
	}
	if ( nMoves[nm] < moves[nLevels[nm]].length / 2 )
	{	var n = nMoves[nm]*2;
		var from = moves[nLevels[nm]][ n ] & 0x3f;
		var to = moves[nLevels[nm]][ n+1 ] & 0x3f;
		names[ nNameCount[nm]   ] = leftDocument.images[ base + from ].src;
		names[ nNameCount[nm]+1 ] = leftDocument.images[ base + to ].src;
		var len = names[nNameCount[nm]].length;
		var nn = (Math.floor(( to / 8 )) + ( to % 8 ));
		var dest = ( nn % 2 ) == 1 ? "b" : "w";
		var piece = names[nNameCount[nm]].substring(len-6,len-5);
		if (( moves[nLevels[nm]][ n ] & 0x380 ) == 0x80 )
			piece = "q";
		else if (( moves[nLevels[nm]][ n ] & 0x380 ) == 0x100 )
			piece = "n";
		else if (( moves[nLevels[nm]][ n ] & 0x380 ) == 0x180 )
			piece = "b";
		else if (( moves[nLevels[nm]][ n ] & 0x380 ) == 0x200 )
			piece = "r";
		leftDocument.images[ base + to ].src = names[nNameCount[nm]].substring(0,len-6) + piece + dest + names[nNameCount[nm]].substring(len-4,len);
		nn = (Math.floor(( from / 8 )) + ( from % 8 ));
		if (( nn % 2 ) == 1 )
			leftDocument.images[ base + from ].src = EmptyBlackPath;
		else
			leftDocument.images[ base + from ].src = EmptyWhitePath;
		nMoves[nm]++;
		nNameCount[nm] = nNameCount[nm] + 2;
		if ( nMoves[nm] < moves[nLevels[nm]].length / 2 && ( moves[nLevels[nm]][ nMoves[nm]*2 ] & 0x40 ) == 0x40 )
			MF( moves, names, nm, base, bCheckV );
	}
	return base
}
function MB( moves, names, nm, base, basename )
{	base = SyncPicture( base, basename );
	if ( nMoves[nm] > 0 )
	{	nMoves[nm]--;
		nNameCount[nm] -= 2;
		var from = moves[nLevels[nm]][ nMoves[nm]*2 ] & 0x3f;
		var to = moves[nLevels[nm]][ nMoves[nm]*2+1 ] & 0x3f;
		leftDocument.images[ base + from ].src = names[ nNameCount[nm] ];
		leftDocument.images[ base + to ].src = names[ nNameCount[nm]+1 ];
		if (( moves[nLevels[nm]][ nMoves[nm]*2 ] & 0x40 ) == 0x40 )
			MB( moves, names, nm, base );
	}
	if ( nMoves[nm] == 0 )
		if ( nLevels[nm] > 0 )
		{	nMoves[nm] = moves[nLevels[nm]].move;
			nLevels[nm] = moves[nLevels[nm]].root;
			if (( moves[nLevels[nm]][nMoves[nm]*2] & 0x40 ) == 0x40 )
				nMoves[nm]--;
		}
	return base;
}
function GMS2(  moves, names, nm, base, nMoveNumber, nLevel, basename )
{	if ( nMoveNumber > 0 )
	{	var n = (nMoveNumber-1)*2;
		var off=1;
		for ( i=0; i <= n; i += 2 )
			if (( moves[nLevel][i] & 0x40 ) == 0x40 )
				off = off+1;
		var from = moves[nLevel][ n ] & 0x3f;
		var to = moves[nLevel][ n+1 ] & 0x3f;
		var len = leftDocument.images[ base + to ].src.length;
		var piece = leftDocument.images[ base + to ].src.substring(len-6,len-5);
		if ( piece == "q" )
			piece = pieces.substring(1,2);
		else if ( piece == "r" )
			piece = pieces.substring(4,5);
		else if ( piece == "b" )
			piece = pieces.substring(3,4);
		else if ( piece == "n" )
			piece = pieces.substring(2,3);
		else if ( piece ==  "k" )
			piece = pieces.substring(0,1);
		else piece = pieces.substring(5,6);
		var piece2 = "";
		if (( moves[nLevel][ n ] & 0x380 ) == 0x80 )
			piece2 = pieces.substring(1,2);
		else if (( moves[nLevel][ n ] & 0x380 ) == 0x100 )
			piece2 = pieces.substring(2,3);
		else if (( moves[nLevel][ n ] & 0x380 ) == 0x180 )
			piece2 = pieces.substring(3,4);
		else if (( moves[nLevel][ n ] & 0x380 ) == 0x200 )
			piece2 = pieces.substring(4,5);
		var lines = "abcdefgh";
		var rows = "87654321";
		var fromLine = from%8;
		var fromRow = Math.floor(from/8);
		var toLine = to%8;
		var toRow = Math.floor(to/8);
		var moveNumber = gmn( moves, nLevel ) + nMoveNumber-off;
		var result = (Math.floor((moveNumber)/2)+1).toString() + ". ";
		if ( leftDocument.images[ base + to ].src.substring(len-7,len-6) == "b" )
			result = result + "... ";
		if ( n >= 2 && (( moves[nLevel][n] & 0x40 ) == 0x40 ))
		{	if (( moves[nLevel][n-1] == 62 ) || ( moves[nLevel][n-1] == 6 ))
				result = result + "0-0"
			else if (( moves[nLevel][n-1] == 2 + 7 * 8 ) || ( moves[nLevel][n-1] == 2 + 0 * 8 ))
				result = result + "0-0-0"
			else
			{	var sep = "x";
				from = moves[nLevel][ n-2 ] & 0x3f;
				to = moves[nLevel][ n-1 ] & 0x3f;
				fromLine = from%8;
				fromRow = Math.floor(from/8);
				toLine = to%8;
				toRow = Math.floor(to/8);
				result = result	+ lines.substring( fromLine, fromLine+1 ) + rows.substring( fromRow, fromRow+1 )
										+ sep
										+ lines.substring( toLine, toLine+1 ) + rows.substring( toRow, toRow+1 )
										+ piece2 + " ep";
			}
		}
		else
		{	var len = names[ nNameCount[nm]-1 ].length;
			var substr = names[ nNameCount[nm]-1 ].substring( len-6, len );
			var sep = (( substr == "/w.gif" ) || ( substr == "\\w.gif" ) ||
						  ( substr == "/b.gif" ) || ( substr == "\\b.gif" )) ? "-" : "x";
			if ( piece2 != "" ) piece = "";
			result = result + piece.toUpperCase() + lines.substring( fromLine, fromLine+1 ) + rows.substring( fromRow, fromRow+1 )
				+ sep
				+ lines.substring( toLine, toLine+1 ) + rows.substring( toRow, toRow+1 )
				+ piece2;
		}
	}
	else
		result='';
	if (leftDocument.all)
	{	if ( bFrames )	name = 'i' + baseName + '0';
		else name = 'i' + baseName + nm;
		if ( result == '' )
			leftDocument.all.tags( "DIV" )[name].innerHTML = start_pos;
		else
			leftDocument.all.tags( "DIV" )[name].innerHTML = pos_after + result;
	}
	else if ( leftDocument.layers )
	{	var inx = nm;
		if ( bFrames ) inx = 0;
		leftDocument.layers[inx].document.layers[0].document.clear();
		if ( result == '' )
			var gesamt = "<center>" + start_pos + "</center>";
		else
			var gesamt = "<center>" + pos_after + " " + result + "</center>";
		leftDocument.layers[inx].document.layers[0].document.write(gesamt);
		leftDocument.layers[inx].document.layers[0].document.close();
	}
	return result;
}
function GMS( moves, names, nm, base, basename )
{	base = SyncPicture( base, basename );
	var nLevel = nLevels[nm];
	var nMoveNumber = nMoves[nm];
	if ( nMoveNumber >= 0 && nMoveNumber <= moves[nLevel].length / 2 )
	{	if ( leftDocument.all )
		{	if ( nOld[nm] != -1 )
				rightDocument.anchors[nOld[nm]].style.background=BackColor;
			if ( nMoveNumber > 0 )
			{	nOld[nm] = moves[nLevel].base[nMoveNumber-1];
				rightDocument.anchors[nOld[nm]].style.background="gray";
				with ( rightDocument )
					with ( all.tags("a")[nOld[nm]] )
					{	if ( parent.frames[1] && ( offsetTop > body.scrollTop + offsetParent.offsetHeight - offsetHeight || offsetTop < body.scrollTop ))
							rightWindow.scrollTo( 0, offsetTop - ( offsetParent.offsetHeight / 2 ) );
					}
			}
			else
				nOld[nm] = -1;
		}
		return GMS2( moves, names, nm, base, nMoveNumber, nLevel, basename );
	}
	else
		return "??";
}
function gm( moves, names, nm, base, basename, n, m )
{	base = SyncPicture( base, basename );
	GoStart(moves,names,nm,base,basename );
	gm_sub( moves,names,nm,base,basename,n,m);
	GMS( moves, names, nm, base, basename );
}
function gmn( moves, m )
{	if ( m > 0 )
	{	var off=0;
		var n2 = moves[m].move;
		var m2 = moves[m].root;
		for ( i=0; i <= n2*2; i += 2 )
			if (( moves[m2][i] & 0x40 ) == 0x40 )
				off = off+1;
		return gmn( moves, m2 ) + ( n2 - off );
	}
	return 0;
}
function gm_sub( moves, names, nm, base, basename, n, m )
{	if ( m > 0 )
	{	var off=0;
		var n2 = moves[m].move;
		var m2 = moves[m].root;
		for ( i=0; i <= n2*2; i += 2 )
			if (( moves[m2][i] & 0x40 ) == 0x40 )
				off = off+1;
		gm_sub( moves,names,nm,base, basename, n2-off, m2  );
	}
	nLevels[nm]=m;
	nMoves[nm]=0;
	for ( i=0; i < n; i++ )
		MF(moves,names,nm,base,basename, false);
}
