Rxstring.hpp
Go to the documentation of this file.
1 /*----------------------------------------------------------------------------*/
2 /* */
3 /* Copyright (c) 1995, 2004 IBM Corporation. All rights reserved. */
4 /* Copyright (c) 2005-2009 Rexx Language Association. All rights reserved. */
5 /* */
6 /* This program and the accompanying materials are made available under */
7 /* the terms of the Common Public License v1.0 which accompanies this */
8 /* distribution. A copy is also available at the following address: */
9 /* http://www.ibm.com/developerworks/oss/CPLv1.0.htm */
10 /* */
11 /* Redistribution and use in source and binary forms, with or */
12 /* without modification, are permitted provided that the following */
13 /* conditions are met: */
14 /* */
15 /* Redistributions of source code must retain the above copyright */
16 /* notice, this list of conditions and the following disclaimer. */
17 /* Redistributions in binary form must reproduce the above copyright */
18 /* notice, this list of conditions and the following disclaimer in */
19 /* the documentation and/or other materials provided with the distribution. */
20 /* */
21 /* Neither the name of Rexx Language Association nor the names */
22 /* of its contributors may be used to endorse or promote products */
23 /* derived from this software without specific prior written permission. */
24 /* */
25 /* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS */
26 /* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT */
27 /* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS */
28 /* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT */
29 /* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */
30 /* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */
31 /* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, */
32 /* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY */
33 /* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING */
34 /* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS */
35 /* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
36 /* */
37 /*----------------------------------------------------------------------------*/
38 
39 #ifndef RxString_HPP_INCLUDED
40 #define RxString_HPP_INCLUDED
41 
42 #include "rexx.h"
43 #include "ServiceException.hpp"
44 #include "SysAPIManager.hpp"
45 
46 class Rxstring
47 {
48 public:
49  size_t strlength; // length of the string
50  char * strptr; // the string data
51 };
52 
53 class ManagedRxstring : public Rxstring
54 {
55 public:
56  inline ManagedRxstring()
57  {
58  strlength = 0;
59  strptr = NULL;
60  }
61 
62  inline ManagedRxstring(size_t size)
63  {
64  setStringSize(size);
65  }
66 
68  {
69  if (strptr != NULL)
70  {
72  }
73  }
74 
75  void setStringSize(size_t size)
76  {
77  strlength = size;
78  allocateResult(size);
79  }
80 
81 
82  void ensureCapacity(size_t size)
83  {
84  if (strlength < size || strptr == NULL)
85  {
86  if (strptr != NULL)
87  {
89  strptr = NULL;
90  }
91  setStringSize(size);
92  }
93  }
94 
95  char *allocateResult(size_t size)
96  {
97  strptr = (char *)SysAPIManager::allocateMemory(size);
98  if (strptr == NULL)
99  {
100  throw new ServiceException(MEMORY_ERROR, "Error allocating result data");
101  }
102  return strptr;
103  }
104 };
105 
106 #endif
@ MEMORY_ERROR
void setStringSize(size_t size)
Definition: Rxstring.hpp:75
ManagedRxstring(size_t size)
Definition: Rxstring.hpp:62
char * allocateResult(size_t size)
Definition: Rxstring.hpp:95
void ensureCapacity(size_t size)
Definition: Rxstring.hpp:82
size_t strlength
Definition: Rxstring.hpp:49
char * strptr
Definition: Rxstring.hpp:50
static void * allocateMemory(size_t length)
static void releaseMemory(void *p)