aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llinventory
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llinventory')
-rw-r--r--linden/indra/llinventory/llinventory.cpp30
-rw-r--r--linden/indra/llinventory/lllandmark.cpp4
-rw-r--r--linden/indra/llinventory/llpermissions.cpp24
-rw-r--r--linden/indra/llinventory/llsaleinfo.cpp8
4 files changed, 43 insertions, 23 deletions
diff --git a/linden/indra/llinventory/llinventory.cpp b/linden/indra/llinventory/llinventory.cpp
index 1f7efb3..3235748 100644
--- a/linden/indra/llinventory/llinventory.cpp
+++ b/linden/indra/llinventory/llinventory.cpp
@@ -320,6 +320,8 @@ void LLInventoryObject::setType(LLAssetType::EType type)
320// virtual 320// virtual
321BOOL LLInventoryObject::importLegacyStream(std::istream& input_stream) 321BOOL LLInventoryObject::importLegacyStream(std::istream& input_stream)
322{ 322{
323 // *NOTE: Changing the buffer size will require changing the scanf
324 // calls below.
323 char buffer[MAX_STRING]; 325 char buffer[MAX_STRING];
324 char keyword[MAX_STRING]; 326 char keyword[MAX_STRING];
325 char valuestr[MAX_STRING]; 327 char valuestr[MAX_STRING];
@@ -358,7 +360,7 @@ BOOL LLInventoryObject::importLegacyStream(std::istream& input_stream)
358 { 360 {
359 //strcpy(valuestr, buffer + strlen(keyword) + 3); 361 //strcpy(valuestr, buffer + strlen(keyword) + 3);
360 // *NOTE: Not ANSI C, but widely supported. 362 // *NOTE: Not ANSI C, but widely supported.
361 sscanf(buffer, " %254s %[^|]", keyword, valuestr); 363 sscanf(buffer, " %254s %254[^|]", keyword, valuestr);
362 mName.assign(valuestr); 364 mName.assign(valuestr);
363 LLString::replaceNonstandardASCII(mName, ' '); 365 LLString::replaceNonstandardASCII(mName, ' ');
364 LLString::replaceChar(mName, '|', ' '); 366 LLString::replaceChar(mName, '|', ' ');
@@ -681,6 +683,8 @@ BOOL LLInventoryItem::unpackMessage(LLMessageSystem* msg, const char* block, S32
681// virtual 683// virtual
682BOOL LLInventoryItem::importFile(FILE* fp) 684BOOL LLInventoryItem::importFile(FILE* fp)
683{ 685{
686 // *NOTE: Changing the buffer size will require changing the scanf
687 // calls below.
684 char buffer[MAX_STRING]; 688 char buffer[MAX_STRING];
685 char keyword[MAX_STRING]; 689 char keyword[MAX_STRING];
686 char valuestr[MAX_STRING]; 690 char valuestr[MAX_STRING];
@@ -769,7 +773,7 @@ BOOL LLInventoryItem::importFile(FILE* fp)
769 { 773 {
770 //strcpy(valuestr, buffer + strlen(keyword) + 3); 774 //strcpy(valuestr, buffer + strlen(keyword) + 3);
771 // *NOTE: Not ANSI C, but widely supported. 775 // *NOTE: Not ANSI C, but widely supported.
772 sscanf(buffer, " %254s%[\t]%[^|]", keyword, junk, valuestr); 776 sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr);
773 777
774 // IW: sscanf chokes and puts | in valuestr if there's no name 778 // IW: sscanf chokes and puts | in valuestr if there's no name
775 if (valuestr[0] == '|') 779 if (valuestr[0] == '|')
@@ -785,7 +789,7 @@ BOOL LLInventoryItem::importFile(FILE* fp)
785 { 789 {
786 //strcpy(valuestr, buffer + strlen(keyword) + 3); 790 //strcpy(valuestr, buffer + strlen(keyword) + 3);
787 // *NOTE: Not ANSI C, but widely supported. 791 // *NOTE: Not ANSI C, but widely supported.
788 sscanf(buffer, " %s%[\t]%[^|]", keyword, junk, valuestr); 792 sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr);
789 793
790 if (valuestr[0] == '|') 794 if (valuestr[0] == '|')
791 { 795 {
@@ -875,6 +879,8 @@ BOOL LLInventoryItem::exportFile(FILE* fp, BOOL include_asset_key) const
875// virtual 879// virtual
876BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream) 880BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream)
877{ 881{
882 // *NOTE: Changing the buffer size will require changing the scanf
883 // calls below.
878 char buffer[MAX_STRING]; 884 char buffer[MAX_STRING];
879 char keyword[MAX_STRING]; 885 char keyword[MAX_STRING];
880 char valuestr[MAX_STRING]; 886 char valuestr[MAX_STRING];
@@ -889,7 +895,7 @@ BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream)
889 while(success && input_stream.good()) 895 while(success && input_stream.good())
890 { 896 {
891 input_stream.getline(buffer, MAX_STRING); 897 input_stream.getline(buffer, MAX_STRING);
892 sscanf(buffer, " %s %s", keyword, valuestr); 898 sscanf(buffer, " %254s %254s", keyword, valuestr);
893 if(!keyword) 899 if(!keyword)
894 { 900 {
895 continue; 901 continue;
@@ -963,7 +969,7 @@ BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream)
963 { 969 {
964 //strcpy(valuestr, buffer + strlen(keyword) + 3); 970 //strcpy(valuestr, buffer + strlen(keyword) + 3);
965 // *NOTE: Not ANSI C, but widely supported. 971 // *NOTE: Not ANSI C, but widely supported.
966 sscanf(buffer, " %s%[\t]%[^|]", keyword, junk, valuestr); 972 sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr);
967 973
968 // IW: sscanf chokes and puts | in valuestr if there's no name 974 // IW: sscanf chokes and puts | in valuestr if there's no name
969 if (valuestr[0] == '|') 975 if (valuestr[0] == '|')
@@ -979,7 +985,7 @@ BOOL LLInventoryItem::importLegacyStream(std::istream& input_stream)
979 { 985 {
980 //strcpy(valuestr, buffer + strlen(keyword) + 3); 986 //strcpy(valuestr, buffer + strlen(keyword) + 3);
981 // *NOTE: Not ANSI C, but widely supported. 987 // *NOTE: Not ANSI C, but widely supported.
982 sscanf(buffer, " %s%[\t]%[^|]", keyword, junk, valuestr); 988 sscanf(buffer, " %254s%254[\t]%254[^|]", keyword, junk, valuestr);
983 989
984 if (valuestr[0] == '|') 990 if (valuestr[0] == '|')
985 { 991 {
@@ -1522,6 +1528,8 @@ void LLInventoryCategory::unpackMessage(LLMessageSystem* msg,
1522// virtual 1528// virtual
1523BOOL LLInventoryCategory::importFile(FILE* fp) 1529BOOL LLInventoryCategory::importFile(FILE* fp)
1524{ 1530{
1531 // *NOTE: Changing the buffer size will require changing the scanf
1532 // calls below.
1525 char buffer[MAX_STRING]; 1533 char buffer[MAX_STRING];
1526 char keyword[MAX_STRING]; 1534 char keyword[MAX_STRING];
1527 char valuestr[MAX_STRING]; 1535 char valuestr[MAX_STRING];
@@ -1531,7 +1539,7 @@ BOOL LLInventoryCategory::importFile(FILE* fp)
1531 while(!feof(fp)) 1539 while(!feof(fp))
1532 { 1540 {
1533 fgets(buffer, MAX_STRING, fp); 1541 fgets(buffer, MAX_STRING, fp);
1534 sscanf(buffer, " %s %s", keyword, valuestr); 1542 sscanf(buffer, " %254s %254s", keyword, valuestr);
1535 if(!keyword) 1543 if(!keyword)
1536 { 1544 {
1537 continue; 1545 continue;
@@ -1564,7 +1572,7 @@ BOOL LLInventoryCategory::importFile(FILE* fp)
1564 { 1572 {
1565 //strcpy(valuestr, buffer + strlen(keyword) + 3); 1573 //strcpy(valuestr, buffer + strlen(keyword) + 3);
1566 // *NOTE: Not ANSI C, but widely supported. 1574 // *NOTE: Not ANSI C, but widely supported.
1567 sscanf(buffer, " %s %[^|]", keyword, valuestr); 1575 sscanf(buffer, " %254s %254[^|]", keyword, valuestr);
1568 mName.assign(valuestr); 1576 mName.assign(valuestr);
1569 LLString::replaceNonstandardASCII(mName, ' '); 1577 LLString::replaceNonstandardASCII(mName, ' ');
1570 LLString::replaceChar(mName, '|', ' '); 1578 LLString::replaceChar(mName, '|', ' ');
@@ -1597,6 +1605,8 @@ BOOL LLInventoryCategory::exportFile(FILE* fp, BOOL) const
1597// virtual 1605// virtual
1598BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream) 1606BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream)
1599{ 1607{
1608 // *NOTE: Changing the buffer size will require changing the scanf
1609 // calls below.
1600 char buffer[MAX_STRING]; 1610 char buffer[MAX_STRING];
1601 char keyword[MAX_STRING]; 1611 char keyword[MAX_STRING];
1602 char valuestr[MAX_STRING]; 1612 char valuestr[MAX_STRING];
@@ -1606,7 +1616,7 @@ BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream)
1606 while(input_stream.good()) 1616 while(input_stream.good())
1607 { 1617 {
1608 input_stream.getline(buffer, MAX_STRING); 1618 input_stream.getline(buffer, MAX_STRING);
1609 sscanf(buffer, " %s %s", keyword, valuestr); 1619 sscanf(buffer, " %254s %254s", keyword, valuestr);
1610 if(!keyword) 1620 if(!keyword)
1611 { 1621 {
1612 continue; 1622 continue;
@@ -1639,7 +1649,7 @@ BOOL LLInventoryCategory::importLegacyStream(std::istream& input_stream)
1639 { 1649 {
1640 //strcpy(valuestr, buffer + strlen(keyword) + 3); 1650 //strcpy(valuestr, buffer + strlen(keyword) + 3);
1641 // *NOTE: Not ANSI C, but widely supported. 1651 // *NOTE: Not ANSI C, but widely supported.
1642 sscanf(buffer, " %s %[^|]", keyword, valuestr); 1652 sscanf(buffer, " %254s %254[^|]", keyword, valuestr);
1643 mName.assign(valuestr); 1653 mName.assign(valuestr);
1644 LLString::replaceNonstandardASCII(mName, ' '); 1654 LLString::replaceNonstandardASCII(mName, ' ');
1645 LLString::replaceChar(mName, '|', ' '); 1655 LLString::replaceChar(mName, '|', ' ');
diff --git a/linden/indra/llinventory/lllandmark.cpp b/linden/indra/llinventory/lllandmark.cpp
index bca64d1..d7dca20 100644
--- a/linden/indra/llinventory/lllandmark.cpp
+++ b/linden/indra/llinventory/lllandmark.cpp
@@ -138,10 +138,12 @@ LLLandmark* LLLandmark::constructFromString(const char *buffer)
138 } 138 }
139 else if(version == 2) 139 else if(version == 2)
140 { 140 {
141 // *NOTE: Changing the buffer size will require changing the
142 // scanf call below.
141 char region_id_str[MAX_STRING]; 143 char region_id_str[MAX_STRING];
142 LLVector3 pos; 144 LLVector3 pos;
143 cur += chars_read; 145 cur += chars_read;
144 count = sscanf(cur, "region_id %s\n%n", region_id_str, &chars_read); 146 count = sscanf(cur, "region_id %254s\n%n", region_id_str, &chars_read);
145 if(count != 1) goto error; 147 if(count != 1) goto error;
146 cur += chars_read; 148 cur += chars_read;
147 count = sscanf(cur, "local_pos %f %f %f\n%n", pos.mV+VX, pos.mV+VY, pos.mV+VZ, &chars_read); 149 count = sscanf(cur, "local_pos %f %f %f\n%n", pos.mV+VX, pos.mV+VY, pos.mV+VZ, &chars_read);
diff --git a/linden/indra/llinventory/llpermissions.cpp b/linden/indra/llinventory/llpermissions.cpp
index 39e7a72..35dbc3e 100644
--- a/linden/indra/llinventory/llpermissions.cpp
+++ b/linden/indra/llinventory/llpermissions.cpp
@@ -511,6 +511,8 @@ BOOL LLPermissions::importFile(FILE *fp)
511 init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null); 511 init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null);
512 const S32 BUFSIZE = 16384; 512 const S32 BUFSIZE = 16384;
513 513
514 // *NOTE: Changing the buffer size will require changing the scanf
515 // calls below.
514 char buffer[BUFSIZE]; 516 char buffer[BUFSIZE];
515 char keyword[256]; 517 char keyword[256];
516 char valuestr[256]; 518 char valuestr[256];
@@ -523,7 +525,7 @@ BOOL LLPermissions::importFile(FILE *fp)
523 while (!feof(fp)) 525 while (!feof(fp))
524 { 526 {
525 fgets(buffer, BUFSIZE, fp); 527 fgets(buffer, BUFSIZE, fp);
526 sscanf(buffer, " %s %s", keyword, valuestr); 528 sscanf(buffer, " %255s %255s", keyword, valuestr);
527 if (!keyword) 529 if (!keyword)
528 { 530 {
529 continue; 531 continue;
@@ -571,22 +573,22 @@ BOOL LLPermissions::importFile(FILE *fp)
571 } 573 }
572 else if (!strcmp("creator_id", keyword)) 574 else if (!strcmp("creator_id", keyword))
573 { 575 {
574 sscanf(valuestr, "%s", uuid_str); 576 sscanf(valuestr, "%255s", uuid_str);
575 mCreator.set(uuid_str); 577 mCreator.set(uuid_str);
576 } 578 }
577 else if (!strcmp("owner_id", keyword)) 579 else if (!strcmp("owner_id", keyword))
578 { 580 {
579 sscanf(valuestr, "%s", uuid_str); 581 sscanf(valuestr, "%255s", uuid_str);
580 mOwner.set(uuid_str); 582 mOwner.set(uuid_str);
581 } 583 }
582 else if (!strcmp("last_owner_id", keyword)) 584 else if (!strcmp("last_owner_id", keyword))
583 { 585 {
584 sscanf(valuestr, "%s", uuid_str); 586 sscanf(valuestr, "%255s", uuid_str);
585 mLastOwner.set(uuid_str); 587 mLastOwner.set(uuid_str);
586 } 588 }
587 else if (!strcmp("group_id", keyword)) 589 else if (!strcmp("group_id", keyword))
588 { 590 {
589 sscanf(valuestr, "%s", uuid_str); 591 sscanf(valuestr, "%255s", uuid_str);
590 mGroup.set(uuid_str); 592 mGroup.set(uuid_str);
591 } 593 }
592 else if (!strcmp("group_owned", keyword)) 594 else if (!strcmp("group_owned", keyword))
@@ -644,6 +646,8 @@ BOOL LLPermissions::importLegacyStream(std::istream& input_stream)
644 init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null); 646 init(LLUUID::null, LLUUID::null, LLUUID::null, LLUUID::null);
645 const S32 BUFSIZE = 16384; 647 const S32 BUFSIZE = 16384;
646 648
649 // *NOTE: Changing the buffer size will require changing the scanf
650 // calls below.
647 char buffer[BUFSIZE]; 651 char buffer[BUFSIZE];
648 char keyword[256]; 652 char keyword[256];
649 char valuestr[256]; 653 char valuestr[256];
@@ -656,7 +660,7 @@ BOOL LLPermissions::importLegacyStream(std::istream& input_stream)
656 while (input_stream.good()) 660 while (input_stream.good())
657 { 661 {
658 input_stream.getline(buffer, BUFSIZE); 662 input_stream.getline(buffer, BUFSIZE);
659 sscanf(buffer, " %s %s", keyword, valuestr); 663 sscanf(buffer, " %255s %255s", keyword, valuestr);
660 if (!keyword) 664 if (!keyword)
661 { 665 {
662 continue; 666 continue;
@@ -704,22 +708,22 @@ BOOL LLPermissions::importLegacyStream(std::istream& input_stream)
704 } 708 }
705 else if (!strcmp("creator_id", keyword)) 709 else if (!strcmp("creator_id", keyword))
706 { 710 {
707 sscanf(valuestr, "%s", uuid_str); 711 sscanf(valuestr, "%255s", uuid_str);
708 mCreator.set(uuid_str); 712 mCreator.set(uuid_str);
709 } 713 }
710 else if (!strcmp("owner_id", keyword)) 714 else if (!strcmp("owner_id", keyword))
711 { 715 {
712 sscanf(valuestr, "%s", uuid_str); 716 sscanf(valuestr, "%255s", uuid_str);
713 mOwner.set(uuid_str); 717 mOwner.set(uuid_str);
714 } 718 }
715 else if (!strcmp("last_owner_id", keyword)) 719 else if (!strcmp("last_owner_id", keyword))
716 { 720 {
717 sscanf(valuestr, "%s", uuid_str); 721 sscanf(valuestr, "%255s", uuid_str);
718 mLastOwner.set(uuid_str); 722 mLastOwner.set(uuid_str);
719 } 723 }
720 else if (!strcmp("group_id", keyword)) 724 else if (!strcmp("group_id", keyword))
721 { 725 {
722 sscanf(valuestr, "%s", uuid_str); 726 sscanf(valuestr, "%255s", uuid_str);
723 mGroup.set(uuid_str); 727 mGroup.set(uuid_str);
724 } 728 }
725 else if (!strcmp("group_owned", keyword)) 729 else if (!strcmp("group_owned", keyword))
diff --git a/linden/indra/llinventory/llsaleinfo.cpp b/linden/indra/llinventory/llsaleinfo.cpp
index b82bd18..98043d1 100644
--- a/linden/indra/llinventory/llsaleinfo.cpp
+++ b/linden/indra/llinventory/llsaleinfo.cpp
@@ -158,6 +158,8 @@ BOOL LLSaleInfo::importFile(FILE* fp, BOOL& has_perm_mask, U32& perm_mask)
158{ 158{
159 has_perm_mask = FALSE; 159 has_perm_mask = FALSE;
160 160
161 // *NOTE: Changing the buffer size will require changing the scanf
162 // calls below.
161 char buffer[MAX_STRING]; 163 char buffer[MAX_STRING];
162 char keyword[MAX_STRING]; 164 char keyword[MAX_STRING];
163 char valuestr[MAX_STRING]; 165 char valuestr[MAX_STRING];
@@ -168,7 +170,7 @@ BOOL LLSaleInfo::importFile(FILE* fp, BOOL& has_perm_mask, U32& perm_mask)
168 while(success && (!feof(fp))) 170 while(success && (!feof(fp)))
169 { 171 {
170 fgets(buffer, MAX_STRING, fp); 172 fgets(buffer, MAX_STRING, fp);
171 sscanf(buffer, " %s %s", keyword, valuestr); 173 sscanf(buffer, " %254s %254s", keyword, valuestr);
172 if(!keyword) 174 if(!keyword)
173 { 175 {
174 continue; 176 continue;
@@ -209,6 +211,8 @@ BOOL LLSaleInfo::importLegacyStream(std::istream& input_stream, BOOL& has_perm_m
209{ 211{
210 has_perm_mask = FALSE; 212 has_perm_mask = FALSE;
211 213
214 // *NOTE: Changing the buffer size will require changing the scanf
215 // calls below.
212 char buffer[MAX_STRING]; 216 char buffer[MAX_STRING];
213 char keyword[MAX_STRING]; 217 char keyword[MAX_STRING];
214 char valuestr[MAX_STRING]; 218 char valuestr[MAX_STRING];
@@ -219,7 +223,7 @@ BOOL LLSaleInfo::importLegacyStream(std::istream& input_stream, BOOL& has_perm_m
219 while(success && input_stream.good()) 223 while(success && input_stream.good())
220 { 224 {
221 input_stream.getline(buffer, MAX_STRING); 225 input_stream.getline(buffer, MAX_STRING);
222 sscanf(buffer, " %s %s", keyword, valuestr); 226 sscanf(buffer, " %254s %254s", keyword, valuestr);
223 if(!keyword) 227 if(!keyword)
224 { 228 {
225 continue; 229 continue;