123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449 |
- /*##############################################################################
- HPCC SYSTEMS software Copyright (C) 2012 HPCC Systems®.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- ############################################################################## */
- #include "platform.h"
- #include "hidl_utils.hpp"
- // borrow from jlib
- bool checkDirExists(const char * filename)
- {
- #ifdef _WIN32
- DWORD attr = GetFileAttributes(filename);
- return (attr != (DWORD)-1)&&(attr & FILE_ATTRIBUTE_DIRECTORY);
- #else
- struct stat info;
- if (stat(filename, &info) != 0)
- return false;
- return S_ISDIR(info.st_mode);
- #endif
- }
- void createDirectory(const char* dir)
- {
- if (dir && *dir)
- {
- if (!checkDirExists(dir)) {
- #ifdef WIN32
- if (mkdir(dir)!=0)
- #else
- if (mkdir(dir,0755)!=0)
- #endif
- {
- if (!checkDirExists(dir))
- {
- fprintf(stderr,"Create directory %s failed", dir);
- exit(1);
- }
- }
- }
- }
- }
- int createFile(const char* src, const char* ext)
- {
- char * path = changeext(src,ext);
- //printf("Target: %s\n", path);
- int h = open(path,_O_WRONLY | _O_CREAT | _O_TRUNC | _O_TEXT , _S_IREAD|_S_IWRITE);
- if (h==-1)
- {
- printf("Could not open file for write: %s (current dir: %s)\n",path,getcwd(NULL,0));
- }
- free(path);
- return h;
- }
- char * gettail(const char *fn)
- {
- const char *e=NULL;
- const char *e1=fn;
- while((e1=strchr(e1,'.'))!=NULL)
- e = e1++;
- const char *s=fn;
- const char *s1;
- #ifdef _WIN32
- if (*s&&s[1]==':')
- s+=2;
- #endif
- for (s1 = s;*s1&&(s1!=e);s1++)
- {
- if (*s1=='\\' || *s1=='/')
- s = s1+1;
- }
- size_t l = s1-s;
- char *ret = (char *)malloc(l+1);
- memcpy(ret,s,l);
- ret[l] = 0;
- return ret;
- }
- char * changeext(const char *fn,const char *ext)
- {
- int preext, l;
- preext = l = (int)strlen(fn);
- char *p;
- for (p=(char*)(fn+preext-1); p>=fn; p--)
- {
- if (*p == '.')
- {
- preext = (int)(p-fn);
- break;
- }
- }
-
- // char *ret=gettail(fn);
- // size_t l = strlen(ret);
- // ret = (char *)realloc(ret,l+strlen(ext)+2);
-
- char *ret = (char *)malloc(preext+strlen(ext)+2);
- memcpy(ret, fn, preext);
-
- ret[preext] = '.';
- strcpy(ret+preext+1,ext);
- return ret;
- }
- char * changetail(const char *fn,const char *tail, const char *ext)
- {
- int preext, l;
- preext = l = (int)strlen(fn);
- char *p;
- for (p=(char*)(fn+preext-1); p>=fn; p--)
- {
- if (*p == '.')
- {
- preext = (int)(p-fn);
- break;
- }
- }
-
- char *ret = (char *)malloc(preext+strlen(tail)+strlen(ext)+2);
- memcpy(ret, fn, preext);
-
- ret[preext] = 0;
- strcat(ret,tail);
- strcat(ret,".");
- strcat(ret,ext);
- return ret;
- }
- bool hasext(const char *fn,const char *ext)
- { // assumes 3 char ext
- const char *s = strstr(fn,ext);
- if (!s)
- return false;
- return (s!=fn)&&(*(s-1)=='.')&&(s[4]==0);
- }
- int createFile(const char* src, const char* tail, const char* ext)
- {
- char * path=changetail(src,tail,ext);
- int h = open(path,_O_WRONLY | _O_CREAT | _O_TRUNC | _O_TEXT , _S_IREAD|_S_IWRITE);
- if (h==-1)
- {
- printf("Could not open file for write: %s (current dir: %s)\n",path,getcwd(NULL,0));
- }
- free(path);
- return h;
- }
- //==============================================================
- // class StrBuffer
- #include <stdarg.h>
- static const char * TheNullStr = "";
- #define FIRST_CHUNK_SIZE 8
- #define DOUBLE_LIMIT 0x100000 // must be a power of 2
- //#define DETACH_GRANULARITY 16
- StrBuffer::StrBuffer()
- {
- init();
- }
- StrBuffer::StrBuffer(const char *value)
- {
- init();
- append(value);
- }
- StrBuffer::StrBuffer(unsigned len, const char *value)
- {
- init();
- append(len, value);
- }
- void StrBuffer::_realloc(size32_t newLen)
- {
- if (newLen >= maxLen)
- {
- size32_t newMax = maxLen;
- if (newMax == 0)
- newMax = FIRST_CHUNK_SIZE;
- if (newLen > DOUBLE_LIMIT)
- {
- newMax = (newLen + DOUBLE_LIMIT) & ~(DOUBLE_LIMIT-1);
- if (newLen >= newMax)
- throw "StrBuffer::_realloc: Request for memory is too big";
- }
- else
- {
- while (newLen >= newMax)
- newMax += newMax;
- }
- char * newStr;
- if(!newMax || !(newStr=(char *)realloc(buffer, newMax)))
- throw "StrBuffer::_realloc: Failed to realloc memory";
-
- buffer = newStr;
- maxLen = newMax;
- }
- }
- StrBuffer & StrBuffer::append(int value)
- {
- char temp[12];
-
- unsigned written = sprintf(temp, "%d", value);
- return append(written, temp);
- }
- StrBuffer & StrBuffer::append(unsigned int value)
- {
- char temp[12];
-
- unsigned written = sprintf(temp, "%u", value);
- return append(written, temp);
- }
- StrBuffer & StrBuffer::append(char c)
- {
- appendf("%c",c);
- return *this;
- }
- StrBuffer & StrBuffer::append(double value)
- {
- char temp[317];
- unsigned written = sprintf(temp, "%g", value);
- return append(written, temp);
- }
- StrBuffer & StrBuffer::append(const char * value)
- {
- if (value)
- {
- size32_t SourceLen = (size32_t)::strlen(value);
-
- ensureCapacity(SourceLen);
- memcpy(buffer + curLen, value, SourceLen);
- curLen += SourceLen;
- }
- return *this;
- }
- StrBuffer & StrBuffer::append(unsigned len, const char * value)
- {
- if (len)
- {
- ensureCapacity(len);
- memcpy(buffer + curLen, value, len);
- curLen += len;
- }
- return *this;
- }
- StrBuffer & StrBuffer::appendf(const char *format, ...)
- {
- va_list args;
- va_start(args, format);
- va_append(format, args);
- va_end(args);
- return *this;
- }
- StrBuffer & StrBuffer::setf(const char *format, ...)
- {
- clear();
- va_list args;
- va_start(args, format);
- va_append(format, args);
- va_end(args);
- return *this;
- }
- StrBuffer & StrBuffer::va_append(const char *format, va_list args)
- {
- const int BUF_SIZE = 1024;
- char buf[BUF_SIZE];
-
- int len = _vsnprintf(buf,sizeof(buf),format,args);
- if (len >= 0)
- {
- if (len < BUF_SIZE)
- append(len, buf);
- else
- {
- ensureCapacity(len);
- // no need for _vsnprintf since the buffer is already made big enough
- vsprintf(buffer+curLen,format,args);
- curLen += len;
- }
- }
- else
- {
- size32_t size = BUF_SIZE * 2;
- char* pbuf = (char *)malloc(size);
- while ((len = _vsnprintf(pbuf,size,format,args)) < 0)
- {
- size <<= 1;
- pbuf = (char*)realloc(pbuf,size);
- }
- append(len, pbuf);
- free(pbuf);
- }
-
- return *this;
- }
- const char * StrBuffer::str() const
- {
- if (buffer)
- {
- buffer[curLen] = '\0'; // There is always room for this null
- return buffer;
- }
- return TheNullStr;
- }
- void StrBuffer::setLength(unsigned len)
- {
- if (len > curLen)
- {
- ensureCapacity(len-curLen);
- }
- curLen = len;
- }
- VStrBuffer::VStrBuffer(const char* format, ...)
- {
- va_list args;
- va_start(args,format);
- va_append(format,args);
- va_end(args);
- }
- StrBuffer& printfEncode(const char* src, StrBuffer& encoded)
- {
- for (const char* p = src; *p!=0; p++)
- {
- switch(*p)
- {
- case '%': encoded.append("%%%%"); break;
- case '\\': encoded.append("\\\\"); break;
- case '"': encoded.append("\\\""); break;
- default: encoded.appendf("%c",*p); break;
- }
- }
- return encoded;
- }
- // steal from jlib with some simplification
- StrBuffer& encodeXML(const char *x, StrBuffer &ret)
- {
- while (true)
- {
- switch(*x)
- {
- case '&':
- ret.append("&");
- break;
- case '<':
- ret.append("<");
- break;
- case '>':
- ret.append(">");
- break;
- case '\"':
- ret.append(""");
- break;
- case '\'':
- ret.append("'");
- break;
- case ' ':
- //ret.append(" ");
- ret.append(" ");
- break;
- case '\n':
- ret.append(" ");
- break;
- case '\r':
- ret.append(" ");
- break;
- case '\t':
- ret.append("	");
- break;
- case '\0':
- return ret;
- default:
- if (*x >= ' ' && ((byte)*x) < 128)
- ret.append(*x);
- else if (*x < ' ' && *x > 0)
- ret.append("à").append((unsigned int)*(unsigned char *) x).append(';'); // HACK
- else
- ret.append("&#").append((unsigned int)*(unsigned char *) x).append(';');
- break;
- }
- ++x;
- }
- return ret;
- }
- // borrow from hqltest
- void initLeakCheck(bool fullMemoryCheck)
- {
- #if defined(_WIN32) && defined(_DEBUG)
- _CrtSetReportMode( _CRT_WARN, _CRTDBG_MODE_FILE|_CRTDBG_MODE_DEBUG );
- _CrtSetReportFile( _CRT_WARN, _CRTDBG_FILE_STDOUT );
- _CrtSetReportMode( _CRT_ERROR, _CRTDBG_MODE_FILE|_CRTDBG_MODE_DEBUG );
- _CrtSetReportFile( _CRT_ERROR, _CRTDBG_FILE_STDOUT );
- _CrtSetReportMode( _CRT_ASSERT, _CRTDBG_MODE_FILE|_CRTDBG_MODE_DEBUG );
- _CrtSetReportFile( _CRT_ASSERT, _CRTDBG_FILE_STDOUT );
- //
- // set the states we want to monitor
- //
- int LeakTmpFlag = _CrtSetDbgFlag( _CRTDBG_REPORT_FLAG );
- LeakTmpFlag &= ~_CRTDBG_CHECK_CRT_DF;
- LeakTmpFlag |= _CRTDBG_LEAK_CHECK_DF;
- if (fullMemoryCheck)
- {
- LeakTmpFlag |= _CRTDBG_CHECK_ALWAYS_DF;
- LeakTmpFlag |= _CRTDBG_DELAY_FREE_MEM_DF;
- /* This check is not needed since CRT block only exists in debug version */
- // LeakTmpFlag |= _CRTDBG_CHECK_CRT_DF;
- }
- _CrtSetDbgFlag(LeakTmpFlag);
- #endif
- }
|