Fixed g++ std::string incompatibility
This commit is contained in:
parent
f2c63a70a9
commit
5fb7f95cb8
@ -33,6 +33,14 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------
|
||||||
|
|
||||||
|
inline const char *it2str(std::string &str, std::string::iterator it)
|
||||||
|
{
|
||||||
|
return &(str.c_str()[it-str.begin()]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
|
|
||||||
static bool tokenxchg(std::string &input, std::string::iterator &pos,
|
static bool tokenxchg(std::string &input, std::string::iterator &pos,
|
||||||
@ -41,7 +49,7 @@ static bool tokenxchg(std::string &input, std::string::iterator &pos,
|
|||||||
{
|
{
|
||||||
size_t toklen = strlen(tok);
|
size_t toklen = strlen(tok);
|
||||||
|
|
||||||
if (strnieql(pos, tok, toklen))
|
if (strnieql(it2str(input, pos), tok, toklen))
|
||||||
{
|
{
|
||||||
std::string str = src;
|
std::string str = src;
|
||||||
std::string::iterator tokend = pos+toklen;
|
std::string::iterator tokend = pos+toklen;
|
||||||
@ -101,17 +109,21 @@ static void translate(std::string &text)
|
|||||||
{
|
{
|
||||||
const char* str1 = strbag.Current1();
|
const char* str1 = strbag.Current1();
|
||||||
size_t s1len = strlen(str1);
|
size_t s1len = strlen(str1);
|
||||||
|
size_t length = text.length();
|
||||||
std::string::iterator pos;
|
|
||||||
for (pos = text.begin(); (*pos != '}') && (pos != text.end()); pos++)
|
for (size_t pos = 0; (pos < length) && (text[pos] != '}'); )
|
||||||
{
|
{
|
||||||
if (strnieql(pos, str1, s1len))
|
if (strnieql(&(text.c_str()[pos]), str1, s1len))
|
||||||
{
|
{
|
||||||
const char* str2 = strbag.Current2();
|
const char* str2 = strbag.Current2();
|
||||||
size_t idx = pos - text.begin();
|
size_t s2len = strlen(str2);
|
||||||
text.replace(pos, pos+s1len, str2, strlen(str2));
|
|
||||||
pos = text.begin() + idx;
|
text.replace(pos, s1len, str2, s2len);
|
||||||
|
pos += s2len;
|
||||||
|
length = text.length();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
pos++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while (strbag.Next());
|
while (strbag.Next());
|
||||||
@ -121,9 +133,9 @@ static void translate(std::string &text)
|
|||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
|
|
||||||
inline bool domain_requested(std::string::iterator str, size_t pos)
|
inline bool domain_requested(const char *str, size_t pos)
|
||||||
{
|
{
|
||||||
if (*(str+1) == '_') pos++;
|
if (str[1] == '_') pos++;
|
||||||
return strnieql(str+pos, "{domain}", 8);
|
return strnieql(str+pos, "{domain}", 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -270,30 +282,30 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((not origareaisinet or not currareaisinet) and (strlen(dst) >= 6))
|
if ((not origareaisinet or not currareaisinet) and (strlen(it2str(input, dst)) >= 6))
|
||||||
{
|
{
|
||||||
bool dr = domain_requested(dst, 6);
|
bool dr = domain_requested(it2str(input, dst), 6);
|
||||||
if (not origareaisinet)
|
if (not origareaisinet)
|
||||||
{
|
{
|
||||||
if (tokenxchg(input, dst, "@oaddr", oldmsg->orig.make_string(buf, dr ? oldmsg->odom : NULL), 19, 1, 0))
|
if (tokenxchg(input, dst, "@oaddr", oldmsg->orig.make_string(buf, dr ? oldmsg->odom : NULL), 19, 1, 0))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strnieql(dst, "@o3daddr", 8))
|
if (strnieql(it2str(input, dst), "@o3daddr", 8))
|
||||||
{
|
{
|
||||||
ftn_addr boss = oldmsg->orig;
|
ftn_addr boss = oldmsg->orig;
|
||||||
boss.point = 0;
|
boss.point = 0;
|
||||||
tokenxchg(input, dst, "@o3daddr", boss.make_string(buf, domain_requested(dst, 8) ? oldmsg->odom : NULL), 19, 1, 0);
|
tokenxchg(input, dst, "@o3daddr", boss.make_string(buf, domain_requested(it2str(input, dst), 8) ? oldmsg->odom : NULL), 19, 1, 0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tokenxchg(input, dst, "@daddr", oldmsg->dest.make_string(buf, dr ? oldmsg->ddom : NULL), 19, 1, 0))
|
if (tokenxchg(input, dst, "@daddr", oldmsg->dest.make_string(buf, dr ? oldmsg->ddom : NULL), 19, 1, 0))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strnieql(dst, "@d3daddr", 8))
|
if (strnieql(it2str(input, dst), "@d3daddr", 8))
|
||||||
{
|
{
|
||||||
ftn_addr boss = oldmsg->dest;
|
ftn_addr boss = oldmsg->dest;
|
||||||
boss.point = 0;
|
boss.point = 0;
|
||||||
tokenxchg(input, dst, "@d3daddr", boss.make_string(buf, domain_requested(dst, 8) ? oldmsg->ddom : NULL), 19, 1, 0);
|
tokenxchg(input, dst, "@d3daddr", boss.make_string(buf, domain_requested(it2str(input, dst), 8) ? oldmsg->ddom : NULL), 19, 1, 0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -304,33 +316,33 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
if (tokenxchg(input, dst, "@caddr", caka.addr.make_string(buf, dr ? caka.domain : NULL), 19, 1, 0))
|
if (tokenxchg(input, dst, "@caddr", caka.addr.make_string(buf, dr ? caka.domain : NULL), 19, 1, 0))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strnieql(dst, "@c3daddr", 8))
|
if (strnieql(it2str(input, dst), "@c3daddr", 8))
|
||||||
{
|
{
|
||||||
ftn_addr boss = caka.addr;
|
ftn_addr boss = caka.addr;
|
||||||
boss.point = 0;
|
boss.point = 0;
|
||||||
tokenxchg(input, dst, "@c3daddr", boss.make_string(buf, domain_requested(dst, 8) ? caka.domain : NULL), 19, 1, 0);
|
tokenxchg(input, dst, "@c3daddr", boss.make_string(buf, domain_requested(it2str(input, dst), 8) ? caka.domain : NULL), 19, 1, 0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tokenxchg(input, dst, "@taddr", msg->dest.make_string(buf, dr ? msg->ddom : NULL), 19, 1, 0))
|
if (tokenxchg(input, dst, "@taddr", msg->dest.make_string(buf, dr ? msg->ddom : NULL), 19, 1, 0))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strnieql(dst, "@t3daddr", 8))
|
if (strnieql(it2str(input, dst), "@t3daddr", 8))
|
||||||
{
|
{
|
||||||
ftn_addr boss = msg->dest;
|
ftn_addr boss = msg->dest;
|
||||||
boss.point = 0;
|
boss.point = 0;
|
||||||
tokenxchg(input, dst, "@t3daddr", boss.make_string(buf, domain_requested(dst, 8) ? msg->ddom : NULL), 19, 1, 0);
|
tokenxchg(input, dst, "@t3daddr", boss.make_string(buf, domain_requested(it2str(input, dst), 8) ? msg->ddom : NULL), 19, 1, 0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tokenxchg(input, dst, "@faddr", msg->orig.make_string(buf, dr ? msg->odom : NULL), 19, 1, 0))
|
if (tokenxchg(input, dst, "@faddr", msg->orig.make_string(buf, dr ? msg->odom : NULL), 19, 1, 0))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strnieql(dst, "@f3daddr", 8))
|
if (strnieql(it2str(input, dst), "@f3daddr", 8))
|
||||||
{
|
{
|
||||||
ftn_addr boss = msg->orig;
|
ftn_addr boss = msg->orig;
|
||||||
boss.point = 0;
|
boss.point = 0;
|
||||||
tokenxchg(input, dst, "@f3daddr", boss.make_string(buf, domain_requested(dst, 8) ? msg->odom : NULL), 19, 1, 0);
|
tokenxchg(input, dst, "@f3daddr", boss.make_string(buf, domain_requested(it2str(input, dst), 8) ? msg->odom : NULL), 19, 1, 0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -387,7 +399,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
if (tokenxchg(input, dst, "@flname", strrword(msg->By())))
|
if (tokenxchg(input, dst, "@flname", strrword(msg->By())))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strnieql(dst, "@dpseudo", 8))
|
if (strnieql(it2str(input, dst), "@dpseudo", 8))
|
||||||
{
|
{
|
||||||
if (*(oldmsg->pseudoto) == NUL)
|
if (*(oldmsg->pseudoto) == NUL)
|
||||||
build_pseudo(oldmsg);
|
build_pseudo(oldmsg);
|
||||||
@ -395,7 +407,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strnieql(dst, "@opseudo", 8))
|
if (strnieql(it2str(input, dst), "@opseudo", 8))
|
||||||
{
|
{
|
||||||
if (*(oldmsg->pseudofrom) == NUL)
|
if (*(oldmsg->pseudofrom) == NUL)
|
||||||
build_pseudo(oldmsg, false);
|
build_pseudo(oldmsg, false);
|
||||||
@ -403,7 +415,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strnieql(dst, "@tpseudo", 8))
|
if (strnieql(it2str(input, dst), "@tpseudo", 8))
|
||||||
{
|
{
|
||||||
if (*(msg->pseudoto) == NUL)
|
if (*(msg->pseudoto) == NUL)
|
||||||
build_pseudo(msg);
|
build_pseudo(msg);
|
||||||
@ -412,7 +424,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Same as above (just for backward compatibility)
|
// Same as above (just for backward compatibility)
|
||||||
if (strnieql(dst, "@pseudo", 7))
|
if (strnieql(it2str(input, dst), "@pseudo", 7))
|
||||||
{
|
{
|
||||||
if (*(msg->pseudoto) == NUL)
|
if (*(msg->pseudoto) == NUL)
|
||||||
build_pseudo(msg);
|
build_pseudo(msg);
|
||||||
@ -420,7 +432,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strnieql(dst, "@fpseudo", 8))
|
if (strnieql(it2str(input, dst), "@fpseudo", 8))
|
||||||
{
|
{
|
||||||
if (*(msg->pseudofrom) == NUL)
|
if (*(msg->pseudofrom) == NUL)
|
||||||
build_pseudo(msg, false);
|
build_pseudo(msg, false);
|
||||||
@ -479,7 +491,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
HandleRandomLine(strxcpy(buf, AA->Origin(), sizeof(buf)), sizeof(buf))))
|
HandleRandomLine(strxcpy(buf, AA->Origin(), sizeof(buf)), sizeof(buf))))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (strnieql(dst, "@area", 5))
|
if (strnieql(it2str(input, dst), "@area", 5))
|
||||||
{
|
{
|
||||||
if (tokenxchg(input, dst, "@areatype", AA->basetype()))
|
if (tokenxchg(input, dst, "@areatype", AA->basetype()))
|
||||||
continue;
|
continue;
|
||||||
@ -514,7 +526,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strnieql(dst, "@align{", 7))
|
if (strnieql(it2str(input, dst), "@align{", 7))
|
||||||
{
|
{
|
||||||
std::string::iterator ptr = dst+7;
|
std::string::iterator ptr = dst+7;
|
||||||
while ((*ptr != '}') && (ptr != input.end())) ptr++;
|
while ((*ptr != '}') && (ptr != input.end())) ptr++;
|
||||||
@ -523,7 +535,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
tokenxchg(input, dst, "@align", "");
|
tokenxchg(input, dst, "@align", "");
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int size = atoi(dst+7) - (dst-input.begin());
|
int size = atoi(it2str(input, dst)+7) - (dst-input.begin());
|
||||||
if (size < 0) size = 0;
|
if (size < 0) size = 0;
|
||||||
|
|
||||||
char filler = ' ';
|
char filler = ' ';
|
||||||
@ -541,7 +553,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strnieql(dst, "@pipe{", 6))
|
if (strnieql(it2str(input, dst), "@pipe{", 6))
|
||||||
{
|
{
|
||||||
std::string::iterator pbeg = dst+6;
|
std::string::iterator pbeg = dst+6;
|
||||||
std::string::iterator pend = pbeg;
|
std::string::iterator pend = pbeg;
|
||||||
@ -580,7 +592,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strnieql(dst, "@pad{", 5))
|
if (strnieql(it2str(input, dst), "@pad{", 5))
|
||||||
{
|
{
|
||||||
std::string::iterator pbeg = dst+5;
|
std::string::iterator pbeg = dst+5;
|
||||||
std::string::iterator pend = pbeg;
|
std::string::iterator pend = pbeg;
|
||||||
@ -595,7 +607,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
|
|
||||||
char fill = *pbeg;
|
char fill = *pbeg;
|
||||||
char align = toupper(*(pbeg+1));
|
char align = toupper(*(pbeg+1));
|
||||||
int padsize = atoi(pbeg+2);
|
int padsize = atoi(it2str(input, pbeg)+2);
|
||||||
|
|
||||||
if (padsize < 0) padsize = 0;
|
if (padsize < 0) padsize = 0;
|
||||||
|
|
||||||
@ -655,7 +667,7 @@ void TokenXlat(int mode, std::string &input, GMsg* msg, GMsg* oldmsg, int __orig
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strnieql(dst, "@tr{", 4))
|
if (strnieql(it2str(input, dst), "@tr{", 4))
|
||||||
{
|
{
|
||||||
std::string buff = input.substr(dst+3-input.begin());
|
std::string buff = input.substr(dst+3-input.begin());
|
||||||
TokenXlat(mode, buff, msg, oldmsg, __origarea);
|
TokenXlat(mode, buff, msg, oldmsg, __origarea);
|
||||||
|
@ -545,7 +545,7 @@ int ExternUtil(GMsg *msg, ExtUtil *extutil) {
|
|||||||
strcpy(buf, editorfile);
|
strcpy(buf, editorfile);
|
||||||
strchg(buf, GOLD_WRONG_SLASH_CHR, GOLD_SLASH_CHR);
|
strchg(buf, GOLD_WRONG_SLASH_CHR, GOLD_SLASH_CHR);
|
||||||
strischg(cmdline, "@file", buf);
|
strischg(cmdline, "@file", buf);
|
||||||
if(striinc("@tmpfile", cmdline) != cmdline.end())
|
if(striinc("@tmpfile", cmdline.c_str()))
|
||||||
{
|
{
|
||||||
mktemp(strcpy(tmpfile, AddPath(CFG->temppath, "GDXXXXXX")));
|
mktemp(strcpy(tmpfile, AddPath(CFG->temppath, "GDXXXXXX")));
|
||||||
SaveLines(mode, tmpfile, msg, 79);
|
SaveLines(mode, tmpfile, msg, 79);
|
||||||
|
@ -62,7 +62,6 @@ int strchg(char* str, char oldch, char newch);
|
|||||||
char* stridela(const char* substr, char* str);
|
char* stridela(const char* substr, char* str);
|
||||||
int strnicmpw(const char* str1, const char* str2, int len);
|
int strnicmpw(const char* str1, const char* str2, int len);
|
||||||
const char* striinc(const char* str1, const char* str2);
|
const char* striinc(const char* str1, const char* str2);
|
||||||
std::string::iterator striinc(const char* str1, std::string &str2);
|
|
||||||
char* strins(const char* instr, char* str, int st_pos);
|
char* strins(const char* instr, char* str, int st_pos);
|
||||||
char* strisrep(char* str, const char* search, const char* replace);
|
char* strisrep(char* str, const char* search, const char* replace);
|
||||||
char* strischg(char* str, const char* find, const char* replace);
|
char* strischg(char* str, const char* find, const char* replace);
|
||||||
|
@ -150,22 +150,6 @@ const char* striinc(const char* str1, const char* str2) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
|
||||||
// Determines if string1 is included in string2
|
|
||||||
|
|
||||||
std::string::iterator striinc(const char* str1, std::string &str2)
|
|
||||||
{
|
|
||||||
int max = strlen(str1);
|
|
||||||
|
|
||||||
std::string::iterator it;
|
|
||||||
for (it = str2.begin(); it != str2.end(); it++)
|
|
||||||
if (!strnicmp(str1, it, max))
|
|
||||||
return it;
|
|
||||||
|
|
||||||
return str2.end(); // string1 not found in string2
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------
|
// ------------------------------------------------------------------
|
||||||
// Inserts one string into another
|
// Inserts one string into another
|
||||||
|
|
||||||
@ -232,18 +216,20 @@ char* strischg(char* str, const char* find, const char* replace) {
|
|||||||
|
|
||||||
void strischg(std::string &str, const char* find, const char* replace)
|
void strischg(std::string &str, const char* find, const char* replace)
|
||||||
{
|
{
|
||||||
int lenf = strlen(find);
|
size_t lenf = strlen(find);
|
||||||
int lenr = strlen(replace);
|
size_t lenr = strlen(replace);
|
||||||
|
size_t length = str.length();
|
||||||
|
|
||||||
std::string::iterator it;
|
for (size_t pos = 0; pos < length; )
|
||||||
for (it = str.begin(); it != str.end(); it++)
|
|
||||||
{
|
{
|
||||||
if (strnieql(find, it, lenf))
|
if (strnieql(&(str.c_str()[pos]), find, lenf))
|
||||||
{
|
{
|
||||||
size_t idx = it - str.begin();
|
str.replace(pos, lenf, replace, lenr);
|
||||||
str.replace(it, it+lenf, replace, lenr);
|
pos += lenr;
|
||||||
it = str.begin() + idx + lenr - 1;
|
length = str.length();
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
pos++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user