Commit d561b152 authored by Ilya.Kirillov's avatar Ilya.Kirillov Committed by Alexander.Trofimov

Исправлены баги, связанные, с неправильной записью и чтением юникодов в формулах.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@59408 954022d7-b5bf-4e40-9824-e11837661b57
parent e4150772
......@@ -37,6 +37,44 @@ function encodeSurrogateChar(nUnicode) {
}
}
function convertUnicodeToUTF16(sUnicode)
{
var sUTF16 = "";
var nLength = sUnicode.length;
for (var nPos = 0; nPos < nLength; nPos++)
{
sUTF16 += encodeSurrogateChar(sUnicode[nPos]);
}
return sUTF16;
}
function convertUTF16toUnicode(sUTF16)
{
var sUnicode = [];
var nLength = sUTF16.length;
for (var nPos = 0; nPos < nLength; nPos++)
{
var nUnicode = null;
var nCharCode = sUTF16.charCodeAt(nPos);
if (isLeadingSurrogateChar(nCharCode))
{
if (nPos + 1 < nLength)
{
nPos++;
var nTrailingChar = sUTF16.charCodeAt(nPos);
nUnicode = decodeSurrogateChar(nCharCode, nTrailingChar);
}
}
else
nUnicode = nCharCode;
if (null !== nUnicode)
sUnicode.push(nUnicode);
}
return sUnicode;
}
/**
* @constructor
*/
......
......@@ -1879,7 +1879,7 @@ function Binary_oMathWriter(memory, oMathPara)
break;
}
case para_Math_Text:
this.bs.WriteItem(c_oSer_OMathContentType.MText, function(){ oThis.memory.WriteString2(String.fromCharCode(item.value));}); //m:t
this.bs.WriteItem(c_oSer_OMathContentType.MText, function(){ oThis.memory.WriteString2(convertUnicodeToUTF16([item.value]));}); //m:t
break;
case para_Math_Run:
this.bs.WriteItem(c_oSer_OMathContentType.MRun, function(){oThis.WriteMRun(item);});
......@@ -1916,7 +1916,7 @@ function Binary_oMathWriter(memory, oMathPara)
switch ( Item.Type )
{
case para_Math_Ampersand : oText += "&"; break;
case para_Math_Text : oText += String.fromCharCode(Item.value); break;
case para_Math_Text : oText += convertUnicodeToUTF16([Item.value]); break;
case para_Space:
case para_Tab : oText += " "; break;
}
......@@ -1996,13 +1996,6 @@ function Binary_oMathWriter(memory, oMathPara)
}
this.memory.WriteByte(val);
}
this.WriteBegChr = function(BegChr)
{
var str = String.fromCharCode(BegChr);
this.memory.WriteByte(c_oSer_OMathBottomNodesValType.Val);
this.memory.WriteByte(c_oSerPropLenType.Variable);
this.memory.WriteString2(str);
}
this.WriteBorderBox = function(oBorderBox)
{
var oThis = this;
......@@ -2088,10 +2081,9 @@ function Binary_oMathWriter(memory, oMathPara)
}
this.WriteChr = function(Chr)
{
var str = String.fromCharCode(Chr);
this.memory.WriteByte(c_oSer_OMathBottomNodesValType.Val);
this.memory.WriteByte(c_oSerPropLenType.Variable);
this.memory.WriteString2(str);
this.memory.WriteString2(convertUnicodeToUTF16([Chr]));
}
this.WriteCount = function(Count)
{
......@@ -2143,25 +2135,18 @@ function Binary_oMathWriter(memory, oMathPara)
if (null != props.column)
this.bs.WriteItem(c_oSer_OMathBottomNodesType.Column, function(){oThis.WriteCount(props.column);});
if (null != props.begChr)
this.bs.WriteItem(c_oSer_OMathBottomNodesType.BegChr, function(){oThis.WriteBegChr(props.begChr);});
this.bs.WriteItem(c_oSer_OMathBottomNodesType.BegChr, function(){oThis.WriteChr(props.begChr);});
if (null != props.endChr)
this.bs.WriteItem(c_oSer_OMathBottomNodesType.EndChr, function(){oThis.WriteEndChr(props.endChr);});
this.bs.WriteItem(c_oSer_OMathBottomNodesType.EndChr, function(){oThis.WriteChr(props.endChr);});
if (null != props.grow)
this.bs.WriteItem(c_oSer_OMathBottomNodesType.Grow, function(){oThis.WriteGrow(props.grow);});
if (null != props.sepChr)
this.bs.WriteItem(c_oSer_OMathBottomNodesType.SepChr, function(){oThis.WriteSepChr(props.sepChr);});
this.bs.WriteItem(c_oSer_OMathBottomNodesType.SepChr, function(){oThis.WriteChr(props.sepChr);});
if (null != props.shp)
this.bs.WriteItem(c_oSer_OMathBottomNodesType.Shp, function(){oThis.WriteShp(props.shp);});
if (null != oDelimiter.CtrPrp)
this.bs.WriteItem(c_oSer_OMathBottomNodesType.CtrlPr, function(){oThis.WriteCtrlPr(oDelimiter);});
}
this.WriteEndChr = function(EndChr)
{
var str = String.fromCharCode(EndChr);
this.memory.WriteByte(c_oSer_OMathBottomNodesValType.Val);
this.memory.WriteByte(c_oSerPropLenType.Variable);
this.memory.WriteString2(str);
}
this.WriteEqArr = function(oEqArr)
{
var oThis = this;
......@@ -2635,13 +2620,6 @@ function Binary_oMathWriter(memory, oMathPara)
}
this.memory.WriteByte(val);
}
this.WriteSepChr = function(SepChr)
{
var str = String.fromCharCode(SepChr);
this.memory.WriteByte(c_oSer_OMathBottomNodesValType.Val);
this.memory.WriteByte(c_oSerPropLenType.Variable);
this.memory.WriteString2(str);
}
this.WriteShow = function(Show)
{
this.memory.WriteByte(c_oSer_OMathBottomNodesValType.Val);
......@@ -7584,6 +7562,7 @@ function Binary_DocumentTableReader(doc, oReadResult, openParams, stream, bAllow
for(var i in this.oCurComments)
this.oCurComments[i] += text;
}
for (var i = 0; i < text.length; ++i)
{
var nUnicode = null;
......@@ -8643,22 +8622,6 @@ function Binary_oMathReader(stream)
else
res = c_oSerConstants.ReadUnknown;
return res;
};
this.ReadMathBegChr = function(type, length, props)
{
var res = c_oSerConstants.ReadOk;
var oThis = this;
if (c_oSer_OMathBottomNodesValType.Val === type)
{
var text = this.stream.GetString2LE(length);
if (text == "")
props.begChr = OPERATOR_EMPTY;
else
props.begChr = text.charCodeAt(0);
}
else
res = c_oSerConstants.ReadUnknown;
return res;
};
this.ReadMathBar = function(type, length,props, oParent, oContent)
{
......@@ -8949,10 +8912,12 @@ function Binary_oMathReader(stream)
if (c_oSer_OMathBottomNodesValType.Val === type)
{
var text = this.stream.GetString2LE(length);
if (text == "")
var aUnicode = convertUTF16toUnicode(text);
if (aUnicode.length <= 0)
props.chr = OPERATOR_EMPTY;
else
props.chr = text.charCodeAt(0);
props.chr = aUnicode[0];
}
else
res = c_oSerConstants.ReadUnknown;
......@@ -9013,7 +8978,7 @@ function Binary_oMathReader(stream)
else if (c_oSer_OMathBottomNodesType.BegChr === type)
{
res = this.bcr.Read2(length, function(t, l){
return oThis.ReadMathBegChr(t,l,props);
return oThis.ReadMathChr(t,l,props);
});
}
else if (c_oSer_OMathBottomNodesType.CtrlPr === type)
......@@ -9025,7 +8990,7 @@ function Binary_oMathReader(stream)
else if (c_oSer_OMathBottomNodesType.EndChr === type)
{
res = this.bcr.Read2(length, function(t, l){
return oThis.ReadMathEndChr(t,l,props);
return oThis.ReadMathChr(t,l,props);
});
}
else if (c_oSer_OMathBottomNodesType.Grow === type)
......@@ -9037,7 +9002,7 @@ function Binary_oMathReader(stream)
else if (c_oSer_OMathBottomNodesType.SepChr === type)
{
res = this.bcr.Read2(length, function(t, l){
return oThis.ReadMathSepChr(t,l,props);
return oThis.ReadMathChr(t,l,props);
});
}
else if (c_oSer_OMathBottomNodesType.Shp === type)
......@@ -9154,22 +9119,6 @@ function Binary_oMathReader(stream)
else
res = c_oSerConstants.ReadUnknown;
return res;
};
this.ReadMathEndChr = function(type, length, props)
{
var res = c_oSerConstants.ReadOk;
var oThis = this;
if (c_oSer_OMathBottomNodesValType.Val === type)
{
var text = this.stream.GetString2LE(length);
if (text == "")
props.endChr = OPERATOR_EMPTY;
else
props.endChr = text.charCodeAt(0);
}
else
res = c_oSerConstants.ReadUnknown;
return res;
};
this.ReadMathFraction = function(type, length, props, oParent, oElemDen, oElemNum)
{
......@@ -9745,25 +9694,24 @@ function Binary_oMathReader(stream)
if (c_oSer_OMathContentType.MText === type)
{
var text = "";
var aUnicodes = [];
if (length > 0)
text = this.stream.GetString2();
for (var i = 0; i < text.length; ++i)
aUnicodes = convertUTF16toUnicode(this.stream.GetString2());
for (var nPos = 0, nCount = aUnicodes.length; nPos < nCount; ++nPos)
{
var nUnicode = aUnicodes[nPos];
var oText = null;
if ( 0x0026 == text[i].charCodeAt(0))
if (0x0026 == nUnicode)
oText = new CMathAmp();
else if (0x001F < text[i].charCodeAt(0)) //управляющие символы
else if (0x001F < nUnicode) //управляющие символы
{
oText = new CMathText(false);
oText.addTxt(text[i]);
oText.add(nUnicode);
}
/*в будущем переделка под para_space
else if (text[i] == ' ')
oText = new ParaSpace(1)
*/
if (oText)
oMRun.Add_ToContent(i, oText, false, true);
oMRun.Add_ToContent(nPos, oText, false, true);
}
}
else if (c_oSer_OMathContentType.MRPr === type)
......@@ -10223,22 +10171,6 @@ function Binary_oMathReader(stream)
else
res = c_oSerConstants.ReadUnknown;
return res;
};
this.ReadMathSepChr = function(type, length, props)
{
var res = c_oSerConstants.ReadOk;
var oThis = this;
if (c_oSer_OMathBottomNodesValType.Val === type)
{
var text = this.stream.GetString2LE(length);
if (text == "")
props.sepChr = OPERATOR_EMPTY;
else
props.sepChr = text.charCodeAt(0);
}
else
res = c_oSerConstants.ReadUnknown;
return res;
};
this.ReadMathShow = function(type, length, props)
{
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment