locationalias is case insensitive now

This commit is contained in:
Ianos Gnatiuc 2005-10-12 01:34:44 +00:00
parent fc011f01b9
commit 73b0d1b7d3
4 changed files with 20 additions and 7 deletions

View File

@ -79,6 +79,7 @@ LocationAlias Cheboxary
LocationAlias Cherkassy —¥àª ááë LocationAlias Cherkassy —¥àª ááë
LocationAlias Chistopol —¨á⮯®« LocationAlias Chistopol —¨á⮯®«
LocationAlias Chornobyl —¥à­®¡ë«ì LocationAlias Chornobyl —¥à­®¡ë«ì
LocationAlias Dalmatovo „ «¬ â®¢®
LocationAlias Energodar <20>­¥à£®¤ à LocationAlias Energodar <20>­¥à£®¤ à
LocationAlias Essentuky …áᥭâ㪨 LocationAlias Essentuky …áᥭâ㪨
LocationAlias Karaganda Š à £ ­¤  LocationAlias Karaganda Š à £ ­¤ 
@ -100,7 +101,7 @@ LocationAlias Vasilyevo
LocationAlias Volgograd ‚®«£®£à ¤ LocationAlias Volgograd ‚®«£®£à ¤
LocationAlias Yaroslavl Ÿà®á« ¢«ì LocationAlias Yaroslavl Ÿà®á« ¢«ì
LocationAlias Zapolarny ‡ ¯®«ïà­ë© LocationAlias Zapolarny ‡ ¯®«ïà­ë©
LocationAlias zarechniy ‡ à¥ç­ë© LocationAlias Zarechniy ‡ à¥ç­ë©
LocationAlias Zhukovsky †ãª®¢áª¨© LocationAlias Zhukovsky †ãª®¢áª¨©
LocationAlias Alma-Ata €«¬ -€â  LocationAlias Alma-Ata €«¬ -€â 
LocationAlias Belgorod <20>¥«£®à®¤ LocationAlias Belgorod <20>¥«£®à®¤
@ -135,6 +136,7 @@ LocationAlias Volzhsky
LocationAlias Voronezh ‚®à®­¥¦ LocationAlias Voronezh ‚®à®­¥¦
LocationAlias Zauralie ‡ ãà «ì¥ LocationAlias Zauralie ‡ ãà «ì¥
LocationAlias Angarsk €­£ à᪠LocationAlias Angarsk €­£ àáª
LocationAlias Armavir €à¬ ¢¨à
LocationAlias Barnaul <20> à­ ã« LocationAlias Barnaul <20> à­ ã«
LocationAlias Bendery <20>¥­¤¥àë LocationAlias Bendery <20>¥­¤¥àë
LocationAlias Borisov <20>®à¨á®¢ LocationAlias Borisov <20>®à¨á®¢
@ -146,7 +148,6 @@ LocationAlias Ivanovo
LocationAlias Izhevsk ˆ¦¥¢áª LocationAlias Izhevsk ˆ¦¥¢áª
LocationAlias Kharkov • à쪮¢ LocationAlias Kharkov • à쪮¢
LocationAlias Kherson •¥àá®­ LocationAlias Kherson •¥àá®­
LocationAlias kherson •¥àá®­
LocationAlias Klichev Š«¨ç¥¢ LocationAlias Klichev Š«¨ç¥¢
LocationAlias Kolomna Š®«®¬­  LocationAlias Kolomna Š®«®¬­ 
LocationAlias Lipetsk ‹¨¯¥â᪠LocationAlias Lipetsk ‹¨¯¥âáª
@ -176,7 +177,6 @@ LocationAlias Grodno
LocationAlias Kaluga Š «ã£  LocationAlias Kaluga Š «ã£ 
LocationAlias Ketovo Š¥â®¢® LocationAlias Ketovo Š¥â®¢®
LocationAlias Kobrin Š®¡à¨­ LocationAlias Kobrin Š®¡à¨­
LocationAlias kurgan Šã࣠­
LocationAlias Kurgan Šã࣠­ LocationAlias Kurgan Šã࣠­
LocationAlias Moscow Œ®áª¢  LocationAlias Moscow Œ®áª¢ 
LocationAlias Odessa Ž¤¥áá  LocationAlias Odessa Ž¤¥áá 

View File

@ -10,6 +10,8 @@ ______________________________________________________________________
Notes for GoldED+ 1.1.5, /snapshot/ Notes for GoldED+ 1.1.5, /snapshot/
______________________________________________________________________ ______________________________________________________________________
+ LocationAlias is case insensitive now.
+ Macro '@widepid' contains platform ID again. + Macro '@widepid' contains platform ID again.
! Golded+ now may be compiled on 64bit platforms. ! Golded+ now may be compiled on 64bit platforms.

View File

@ -326,7 +326,7 @@ void CfgLocationalias()
getkeyval(&key, &val); getkeyval(&key, &val);
StripQuotes(key); StripQuotes(key);
StripQuotes(val); StripQuotes(val);
CFG->locationalias.Add(key, val); CFG->locationalias.Add(strupr(key), val);
} }
// ------------------------------------------------------------------ // ------------------------------------------------------------------

View File

@ -30,6 +30,10 @@
#include <gftnnlge.h> #include <gftnnlge.h>
#include <gftnnlv7.h> #include <gftnnlv7.h>
#if defined(__USE_ALLOCA__)
#include <malloc.h>
#endif
// ------------------------------------------------------------------ // ------------------------------------------------------------------
@ -1141,12 +1145,19 @@ void LookupNodeLocation(GMsg* msg, std::string &location, int what)
if (strbag.First()) if (strbag.First())
{ {
#if defined(__USE_ALLOCA__)
char *city_upr = (char*)alloca(city.length()+1);
#else
__extension__ char city_upr[city.length()+1];
#endif
strcpy(city_upr, city.c_str());
strupr(city_upr);
do do
{ {
const char* str = strbag.Current1(); const char* str = strbag.Current1();
size_t pos = city.find(str); const char* ptr = strstr(city_upr, str);
if (pos != city.npos) if (ptr) city.replace(ptr-city_upr, strlen(str), strbag.Current2());
city.replace(pos, strlen(str), strbag.Current2());
} }
while (strbag.Next()); while (strbag.Next());
} }