summaryrefslogtreecommitdiffstats
path: root/win/rfb_win32/TCharArray.h
blob: dde63b788b4b5bff2ef70101950a1cd3b0ae4ce5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
/* Copyright (C) 2002-2005 RealVNC Ltd.  All Rights Reserved.
 * 
 * This is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 * 
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with this software; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,
 * USA.
 */

// -=- TCharArray.h

// This library contains the wide-character equivalent of CharArray, named
// WCharArray.  In addition to providing wide-character equivalents of
// the char* string manipulation functions (strDup, strFree, etc), special
// versions of those functions are provided which attempt to convert from
// one format to the other.
//    e.g. char* t = "hello world"; WCHAR* w = wstrDup(t);
//    Results in w containing the wide-character text "hello world".
// For convenience, the WStr and CStr classes are also provided.  These
// accept an existing (const) WCHAR* or char* null-terminated string and
// create a read-only copy of that in the desired format.  The new copy
// will actually be the original copy if the format has not changed, otherwise
// it will be a new buffer owned by the WStr/CStr.

// In addition to providing wide character functions, this header defines
// TCHAR* handling classes & functions.  TCHAR is defined at compile time to
// either char or WCHAR.  Programs can treat this as a third data type and
// call TStr() whenever a TCHAR* is required but a char* or WCHAR* is supplied,
// and TStr will do the right thing.

#ifndef __RFB_WIN32_TCHARARRAY_H__
#define __RFB_WIN32_TCHARARRAY_H__

#include <windows.h>
#include <tchar.h>
#include <rfb/util.h>
#include <rfb/Password.h>

namespace rfb {

  // -=- String duplication and cleanup functions.
  //     These routines also handle conversion between WCHAR* and char*

  char* strDup(const WCHAR* s);
  WCHAR* wstrDup(const WCHAR* s);
  WCHAR* wstrDup(const char* s);
  void wstrFree(WCHAR* s);

  bool wstrSplit(const WCHAR* src, const WCHAR limiter, WCHAR** out1, WCHAR** out2, bool fromEnd=false);
  bool wstrContains(const WCHAR* src, WCHAR c);

  // -=- Temporary format conversion classes
  //     CStr accepts WCHAR* or char* and behaves like a char*
  //     WStr accepts WCHAR* or char* and behaves like a WCHAR*

  struct WStr {
    WStr(const char* s) : buf(wstrDup(s)), free_(true) {}
    WStr(const WCHAR* s) : buf(s), free_(false) {}
    ~WStr() {if (free_) wstrFree((WCHAR*)buf);}
    operator const WCHAR*() {return buf;}
    const WCHAR* buf;
    bool free_;
  };

  struct CStr {
    CStr(const char* s) : buf(s), free_(false) {}
    CStr(const WCHAR* s) : buf(strDup(s)), free_(true) {}
    ~CStr() {if (free_) strFree((char*)buf);}
    operator const char*() {return buf;}
    const char* buf;
    bool free_;
  };

  // -=- Class to handle cleanup of arrays of native Win32 characters
  class WCharArray {
  public:
    WCharArray() : buf(0) {}
    WCharArray(char* str) : buf(wstrDup(str)) {strFree(str);} // note: assumes ownership
    WCharArray(WCHAR* str) : buf(str) {}                      // note: assumes ownership
    WCharArray(int len) {
      buf = new WCHAR[len];
    }
    ~WCharArray() {
      delete [] buf;
    }
    // Get the buffer pointer & clear it (i.e. caller takes ownership)
    WCHAR* takeBuf() {WCHAR* tmp = buf; buf = 0; return tmp;}
    void replaceBuf(WCHAR* str) {delete [] buf; buf = str;}
    WCHAR* buf;
  };

  // -=- Wide-character-based password-buffer handler.  Zeroes the password
  //     buffer when deleted or replaced.
  class WPlainPasswd : public WCharArray {
  public:
    WPlainPasswd() {}
    WPlainPasswd(WCHAR* str) : WCharArray(str) {}
    ~WPlainPasswd() {replaceBuf(0);}
    void replaceBuf(WCHAR* str) {
      if (buf)
        memset(buf, 0, sizeof(WCHAR)*wcslen(buf));
      WCharArray::replaceBuf(str);
    }
  };
    
#ifdef _UNICODE
#define tstrDup wstrDup
#define tstrFree wstrFree
#define tstrSplit wstrSplit
#define tstrContains wstrContains
  typedef WCharArray TCharArray;
  typedef WStr TStr;
  typedef WPlainPasswd TPlainPasswd;
#else
#define tstrDup strDup
#define tstrFree strFree
#define tstrSplit strSplit
#define tstrContains strContains
  typedef CharArray TCharArray;
  typedef CStr TStr;
  typedef PlainPasswd TPlainPasswd;
#endif

};

#endif