diff options
author | kwolekr <mirrorisim@gmail.com> | 2013-02-05 15:01:33 -0500 |
---|---|---|
committer | kwolekr <mirrorisim@gmail.com> | 2013-02-06 16:52:48 -0500 |
commit | 97260d09a8e658b6ded7d9100b0aa1040fcfe50f (patch) | |
tree | 4ca603bb61d133b21ffe17d44d3a33589be28766 /src/util | |
parent | f148ae58c3c0e2b6d6c22c913492193021cbc4c3 (diff) | |
download | minetest-97260d09a8e658b6ded7d9100b0aa1040fcfe50f.tar.gz minetest-97260d09a8e658b6ded7d9100b0aa1040fcfe50f.tar.bz2 minetest-97260d09a8e658b6ded7d9100b0aa1040fcfe50f.zip |
Add flag string settings, flat map option
Diffstat (limited to 'src/util')
-rw-r--r-- | src/util/string.cpp | 40 | ||||
-rw-r--r-- | src/util/string.h | 7 |
2 files changed, 47 insertions, 0 deletions
diff --git a/src/util/string.cpp b/src/util/string.cpp index c10755ae1..61b307c60 100644 --- a/src/util/string.cpp +++ b/src/util/string.cpp @@ -21,6 +21,7 @@ with this program; if not, write to the Free Software Foundation, Inc., #include "../sha1.h" #include "../base64.h" +#include "../porting.h" // Get an sha-1 hash of the player's name combined with // the password entered. That's what the server uses as @@ -48,6 +49,45 @@ size_t curl_write_data(char *ptr, size_t size, size_t nmemb, void *userdata) { return count; } +u32 readFlagString(std::string str, FlagDesc *flagdesc) { + u32 result = 0; + char *s = &str[0]; + char *flagstr, *strpos = NULL; + + while ((flagstr = strtok_r(s, ",", &strpos))) { + s = NULL; + + while (*flagstr == ' ' || *flagstr == '\t') + flagstr++; + + for (int i = 0; flagdesc[i].name; i++) { + if (!strcasecmp(flagstr, flagdesc[i].name)) { + result |= flagdesc[i].flag; + break; + } + } + } + + return result; +} + +std::string writeFlagString(u32 flags, FlagDesc *flagdesc) { + std::string result; + + for (int i = 0; flagdesc[i].name; i++) { + if (flags & flagdesc[i].flag) { + result += flagdesc[i].name; + result += ", "; + } + } + + size_t len = result.length(); + if (len >= 2) + result.erase(len - 2, 2); + + return result; +} + char *mystrtok_r(char *s, const char *sep, char **lasts) { char *t; diff --git a/src/util/string.h b/src/util/string.h index d081b365b..a469a074a 100644 --- a/src/util/string.h +++ b/src/util/string.h @@ -28,6 +28,11 @@ with this program; if not, write to the Free Software Foundation, Inc., #include <vector> #include <sstream> +struct FlagDesc { + const char *name; + u32 flag; +}; + static inline std::string padStringRight(std::string s, size_t len) { if(len > s.size()) @@ -283,6 +288,8 @@ inline std::string wrap_rows(const std::string &from, u32 rowlen) std::string translatePassword(std::string playername, std::wstring password); size_t curl_write_data(char *ptr, size_t size, size_t nmemb, void *userdata); +u32 readFlagString(std::string str, FlagDesc *flagdesc); +std::string writeFlagString(u32 flags, FlagDesc *flagdesc); char *mystrtok_r(char *s, const char *sep, char **lasts); #endif |