Looks like one file was lost.

--HG--
branch : feature
This commit is contained in:
Roman Telezhynskyi 2017-06-21 16:32:19 +03:00
parent af51cc0edf
commit 98dc6893a9

View file

@ -38,66 +38,84 @@ void DRW_Header::parseCode(int code, dxfReader *reader){
vars[name]=curr; vars[name]=curr;
break; break;
case 1: case 1:
curr->addString(code, reader->getUtf8String()); curr->addString(reader->getUtf8String());
if (name =="$ACADVER") { if (name =="$ACADVER") {
reader->setVersion(curr->content.s, true); reader->setVersion(curr->content.s, true);
version = reader->getVersion(); version = reader->getVersion();
} }
curr->code = code;
break; break;
case 2: case 2:
curr->addString(code, reader->getUtf8String()); curr->addString(reader->getUtf8String());
curr->code = code;
break; break;
case 3: case 3:
curr->addString(code, reader->getUtf8String()); curr->addString(reader->getUtf8String());
if (name =="$DWGCODEPAGE") { if (name =="$DWGCODEPAGE") {
reader->setCodePage(curr->content.s); reader->setCodePage(curr->content.s);
curr->addString(code, reader->getCodePage()); curr->addString(reader->getCodePage());
} }
curr->code = code;
break; break;
case 6: case 6:
curr->addString(code, reader->getUtf8String()); curr->addString(reader->getUtf8String());
curr->code = code;
break; break;
case 7: case 7:
curr->addString(code, reader->getUtf8String()); curr->addString(reader->getUtf8String());
curr->code = code;
break; break;
case 8: case 8:
curr->addString(code, reader->getUtf8String()); curr->addString(reader->getUtf8String());
curr->code = code;
break; break;
case 10: case 10:
curr->addCoord(code, DRW_Coord(reader->getDouble(), 0.0, 0.0)); curr->addCoord();
curr->setCoordX(reader->getDouble());
curr->code = code;
break; break;
case 20: case 20:
curr->setCoordY(reader->getDouble()); curr->setCoordY(reader->getDouble());
break; break;
case 30: case 30:
curr->setCoordZ(reader->getDouble()); curr->setCoordZ(reader->getDouble());
curr->code = code;
break; break;
case 40: case 40:
curr->addDouble(code, reader->getDouble()); curr->addDouble(reader->getDouble());
curr->code = code;
break; break;
case 50: case 50:
curr->addDouble(code, reader->getDouble()); curr->addDouble(reader->getDouble());
curr->code = code;
break; break;
case 62: case 62:
curr->addInt(code, reader->getInt32()); curr->addInt(reader->getInt32());
curr->code = code;
break; break;
case 70: case 70:
curr->addInt(code, reader->getInt32()); curr->addInt(reader->getInt32());
curr->code = code;
break; break;
case 280: case 280:
curr->addInt(code, reader->getInt32()); curr->addInt(reader->getInt32());
curr->code = code;
break; break;
case 290: case 290:
curr->addInt(code, reader->getInt32()); curr->addInt(reader->getInt32());
curr->code = code;
break; break;
case 370: case 370:
curr->addInt(code, reader->getInt32()); curr->addInt(reader->getInt32());
curr->code = code;
break; break;
case 380: case 380:
curr->addInt(code, reader->getInt32()); curr->addInt(reader->getInt32());
curr->code = code;
break; break;
case 390: case 390:
curr->addString(code, reader->getUtf8String()); curr->addString(reader->getUtf8String());
curr->code = code;
break; break;
default: default:
break; break;
@ -303,7 +321,7 @@ void DRW_Header::write(dxfWriter *writer, DRW::Version ver){
if (getDouble("$DIMSCALE", &varDouble)) if (getDouble("$DIMSCALE", &varDouble))
writer->writeDouble(40, varDouble); writer->writeDouble(40, varDouble);
else else
writer->writeDouble(40, 2.5); writer->writeDouble(40, 1.0);
writer->writeString(9, "$DIMASZ"); writer->writeString(9, "$DIMASZ");
if (getDouble("$DIMASZ", &varDouble)) if (getDouble("$DIMASZ", &varDouble))
writer->writeDouble(40, varDouble); writer->writeDouble(40, varDouble);
@ -472,14 +490,12 @@ void DRW_Header::write(dxfWriter *writer, DRW::Version ver){
if (getInt("$DIMSOXD", &varInt)) if (getInt("$DIMSOXD", &varInt))
writer->writeInt16(70, varInt); writer->writeInt16(70, varInt);
else else
{
writer->writeInt16(70, 0); writer->writeInt16(70, 0);
writer->writeString(9, "$DIMSAH"); writer->writeString(9, "$DIMSAH");
if (getInt("$DIMSAH", &varInt)) if (getInt("$DIMSAH", &varInt))
writer->writeInt16(70, varInt); writer->writeInt16(70, varInt);
else else
writer->writeInt16(70, 0); writer->writeInt16(70, 0);
}
writer->writeString(9, "$DIMBLK1"); writer->writeString(9, "$DIMBLK1");
if (getStr("$DIMBLK1", &varStr)) if (getStr("$DIMBLK1", &varStr))
if (ver == DRW::AC1009) if (ver == DRW::AC1009)
@ -1671,22 +1687,30 @@ void DRW_Header::write(dxfWriter *writer, DRW::Version ver){
} }
void DRW_Header::addDouble(std::string key, double value, int code){ void DRW_Header::addDouble(std::string key, double value, int code){
curr = new DRW_Variant(code, value); curr = new DRW_Variant();
curr->addDouble( value );
curr->code = code;
vars[key] =curr; vars[key] =curr;
} }
void DRW_Header::addInt(std::string key, int value, int code){ void DRW_Header::addInt(std::string key, int value, int code){
curr = new DRW_Variant(code, value); curr = new DRW_Variant();
curr->addInt( value );
curr->code = code;
vars[key] =curr; vars[key] =curr;
} }
void DRW_Header::addStr(std::string key, std::string value, int code){ void DRW_Header::addStr(std::string key, std::string value, int code){
curr = new DRW_Variant(code, value); curr = new DRW_Variant();
curr->addString( value );
curr->code = code;
vars[key] =curr; vars[key] =curr;
} }
void DRW_Header::addCoord(std::string key, DRW_Coord value, int code){ void DRW_Header::addCoord(std::string key, DRW_Coord value, int code){
curr = new DRW_Variant(code, value); curr = new DRW_Variant();
curr->addCoord( value );
curr->code = code;
vars[key] =curr; vars[key] =curr;
} }
@ -1696,7 +1720,7 @@ bool DRW_Header::getDouble(std::string key, double *varDouble){
it=vars.find( key); it=vars.find( key);
if (it != vars.end()) { if (it != vars.end()) {
DRW_Variant *var = (*it).second; DRW_Variant *var = (*it).second;
if (var->type() == DRW_Variant::DOUBLE) { if (var->type == DRW_Variant::DOUBLE) {
*varDouble = var->content.d; *varDouble = var->content.d;
result = true; result = true;
} }
@ -1712,7 +1736,7 @@ bool DRW_Header::getInt(std::string key, int *varInt){
it=vars.find( key); it=vars.find( key);
if (it != vars.end()) { if (it != vars.end()) {
DRW_Variant *var = (*it).second; DRW_Variant *var = (*it).second;
if (var->type() == DRW_Variant::INTEGER) { if (var->type == DRW_Variant::INTEGER) {
*varInt = var->content.i; *varInt = var->content.i;
result = true; result = true;
} }
@ -1728,7 +1752,7 @@ bool DRW_Header::getStr(std::string key, std::string *varStr){
it=vars.find( key); it=vars.find( key);
if (it != vars.end()) { if (it != vars.end()) {
DRW_Variant *var = (*it).second; DRW_Variant *var = (*it).second;
if (var->type() == DRW_Variant::STRING) { if (var->type == DRW_Variant::STRING) {
*varStr = *var->content.s; *varStr = *var->content.s;
result = true; result = true;
} }
@ -1744,7 +1768,7 @@ bool DRW_Header::getCoord(std::string key, DRW_Coord *varCoord){
it=vars.find( key); it=vars.find( key);
if (it != vars.end()) { if (it != vars.end()) {
DRW_Variant *var = (*it).second; DRW_Variant *var = (*it).second;
if (var->type() == DRW_Variant::COORD) { if (var->type == DRW_Variant::COORD) {
*varCoord = *var->content.v; *varCoord = *var->content.v;
result = true; result = true;
} }
@ -2367,7 +2391,7 @@ bool DRW_Header::parseDwg(DRW::Version version, dwgBuffer *buf, dwgBuffer *hBbuf
if (DRW_DBGGL == DRW_dbg::DEBUG){ if (DRW_DBGGL == DRW_dbg::DEBUG){
for (std::map<std::string,DRW_Variant*>::iterator it=vars.begin(); it!=vars.end(); ++it){ for (std::map<std::string,DRW_Variant*>::iterator it=vars.begin(); it!=vars.end(); ++it){
DRW_DBG("\n"); DRW_DBG(it->first); DRW_DBG(": "); DRW_DBG("\n"); DRW_DBG(it->first); DRW_DBG(": ");
switch (it->second->type()){ switch (it->second->type){
case DRW_Variant::INTEGER: case DRW_Variant::INTEGER:
DRW_DBG(it->second->content.i); DRW_DBG(it->second->content.i);
break; break;
@ -2385,7 +2409,7 @@ bool DRW_Header::parseDwg(DRW::Version version, dwgBuffer *buf, dwgBuffer *hBbuf
default: default:
break; break;
} }
DRW_DBG(" code: ");DRW_DBG(it->second->code()); DRW_DBG(" code: ");DRW_DBG(it->second->code);
} }
} }
@ -2450,4 +2474,3 @@ bool DRW_Header::parseDwg(DRW::Version version, dwgBuffer *buf, dwgBuffer *hBbuf
return result; return result;
} }