Bugfix : Zooming works correct, no more errors on screen.
[xara-cairo.git] / wxOil / fixstr64.cpp
blob04bd5b6e5997c124577f52ae0c02dd9c11bc8fe4
1 // $Id: fixstr64.cpp 1283 2006-06-09 10:45:34Z alex $
2 /* @@tag:xara-cn@@ DO NOT MODIFY THIS LINE
3 ================================XARAHEADERSTART===========================
5 Xara LX, a vector drawing and manipulation program.
6 Copyright (C) 1993-2006 Xara Group Ltd.
7 Copyright on certain contributions may be held in joint with their
8 respective authors. See AUTHORS file for details.
10 LICENSE TO USE AND MODIFY SOFTWARE
11 ----------------------------------
13 This file is part of Xara LX.
15 Xara LX is free software; you can redistribute it and/or modify it
16 under the terms of the GNU General Public License version 2 as published
17 by the Free Software Foundation.
19 Xara LX and its component source files are distributed in the hope
20 that it will be useful, but WITHOUT ANY WARRANTY; without even the
21 implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
22 See the GNU General Public License for more details.
24 You should have received a copy of the GNU General Public License along
25 with Xara LX (see the file GPL in the root directory of the
26 distribution); if not, write to the Free Software Foundation, Inc., 51
27 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
30 ADDITIONAL RIGHTS
31 -----------------
33 Conditional upon your continuing compliance with the GNU General Public
34 License described above, Xara Group Ltd grants to you certain additional
35 rights.
37 The additional rights are to use, modify, and distribute the software
38 together with the wxWidgets library, the wxXtra library, and the "CDraw"
39 library and any other such library that any version of Xara LX relased
40 by Xara Group Ltd requires in order to compile and execute, including
41 the static linking of that library to XaraLX. In the case of the
42 "CDraw" library, you may satisfy obligation under the GNU General Public
43 License to provide source code by providing a binary copy of the library
44 concerned and a copy of the license accompanying it.
46 Nothing in this section restricts any of the rights you have under
47 the GNU General Public License.
50 SCOPE OF LICENSE
51 ----------------
53 This license applies to this program (XaraLX) and its constituent source
54 files only, and does not necessarily apply to other Xara products which may
55 in part share the same code base, and are subject to their own licensing
56 terms.
58 This license does not apply to files in the wxXtra directory, which
59 are built into a separate library, and are subject to the wxWindows
60 license contained within that directory in the file "WXXTRA-LICENSE".
62 This license does not apply to the binary libraries (if any) within
63 the "libs" directory, which are subject to a separate license contained
64 within that directory in the file "LIBS-LICENSE".
67 ARRANGEMENTS FOR CONTRIBUTION OF MODIFICATIONS
68 ----------------------------------------------
70 Subject to the terms of the GNU Public License (see above), you are
71 free to do whatever you like with your modifications. However, you may
72 (at your option) wish contribute them to Xara's source tree. You can
73 find details of how to do this at:
74 http://www.xaraxtreme.org/developers/
76 Prior to contributing your modifications, you will need to complete our
77 contributor agreement. This can be found at:
78 http://www.xaraxtreme.org/developers/contribute/
80 Please note that Xara will not accept modifications which modify any of
81 the text between the start and end of this header (marked
82 XARAHEADERSTART and XARAHEADEREND).
85 MARKS
86 -----
88 Xara, Xara LX, Xara X, Xara X/Xtreme, Xara Xtreme, the Xtreme and Xara
89 designs are registered or unregistered trademarks, design-marks, and/or
90 service marks of Xara Group Ltd. All rights in these marks are reserved.
93 Xara Group Ltd, Gaddesden Place, Hemel Hempstead, HP2 6EX, UK.
94 http://www.xara.com/
96 =================================XARAHEADEREND============================
99 #include "camtypes.h"
100 //#include "fixstr64.h" - in camtypes.h [AUTOMATICALLY REMOVED]
102 DEFINE_BUFSIZE(64);
104 /**************************************************************************************
105 > String_64::String_64(const TCHAR* psz = 0)
107 Author: Justin_Flude (Xara Group Ltd) <camelotdev@xara.com>
108 Created: 12th August 1993
109 Inputs: An optional pointer to a (constant) Unicode character array - if
110 omitted then the String becomes empty (NOT the null pointer).
111 Purpose: Constructs a string of the appropriate maximum length.
112 Errors: ASSERTion failure if the passed character array is too long for
113 this length of string, or if psz is NULL.
114 Scope: Public
115 ***************************************************************************************/
117 String_64::String_64(const TCHAR* psz)
119 *(text = fixedbuf) = 0;
120 length = FIX_LEN_BUFSIZE;
121 if (psz != 0)
123 ERROR3IF(camStrlen(psz) >= length, "String_64::String_64 overflow");
124 camStrcpy(text, psz);
130 /**************************************************************************************
131 > String_64::String_64(const StringBase& other)
133 Author: Justin_Flude (Xara Group Ltd) <camelotdev@xara.com>
134 Created: 12th August 1993
135 Inputs: A constant reference to another string (can be of any length)
136 Purpose: Duplicates the text of the other string.
137 Errors: ASSERTion failure if this string is not long enough to hold a copy
138 of the other string's text, or if the copied String has not been
139 allocated.
140 Scope: Public
141 ***************************************************************************************/
143 void String_64::CopyConstruct(const StringBase& other)
145 *(text = fixedbuf) = 0;
146 length = FIX_LEN_BUFSIZE;
147 ERROR3IF((const TCHAR*) other == 0, "StringBase to be copied has not been ALLOCated");
148 ERROR3IF(camStrlen((const TCHAR*) other) >= length,
149 "Constructed String_64 not large enough to hold StringBase copy");
150 camStrcpy(text, (const TCHAR*) other);
156 /**************************************************************************************
157 > String_64::String_64(UINT32 resID, UINT32 hinst = 0)
159 Author: Justin_Flude (Xara Group Ltd) <camelotdev@xara.com>
160 Created: 12th August 1993
161 Inputs: A string resource numeric identifier, an optional resource module
162 handle (if not supplied, the default resource module is used).
163 Purpose: Loads the string resource into this String.
164 Errors: ENSURE failure if this string is not long enough to hold the
165 resource, or if the resource cannot be found in the module. If it cannot
166 be found, a very short temp string is built of the form "<%X:%X>" containing
167 the ID and the module number, or if that is too long then simply "!".
168 Scope: Public
169 SeeAlso: SmartLoadString
170 ***************************************************************************************/
172 String_64::String_64(UINT32 resID, UINT32 hinst)
174 *(text = fixedbuf) = 0;
175 length = FIX_LEN_BUFSIZE;
176 if (!Load(resID, hinst))
178 ERROR3("String resource failed to load");
179 TCHAR buf[128];
180 camSnprintf(buf, 128, TEXT("<%X:%X>"), (INT32) resID, (INT32) hinst);
181 camStrcpy(text, (camStrlen(buf) <= 64) ? buf : TEXT("!"));
187 /**************************************************************************************
188 > String_64::String_64(const wxString& wxs)
190 Author: Phil_Martin (Xara Group Ltd) <camelotdev@xara.com>
191 Created: 28th January 2006
192 Inputs: A wxString
193 Purpose: Constructs a string of the appropriate maximum length.
194 Errors: ASSERTion failure if the passed character array is too long for
195 this length of string, or if psz is NULL.
196 Scope: Public
197 ***************************************************************************************/
199 String_64::String_64(const wxString& wxs)
201 *(text = fixedbuf) = 0;
202 length = FIX_LEN_BUFSIZE;
203 ERROR3IF(wxs.Len() >= length, "String_64::String_64 overflow");
204 camStrcpy(text, (LPCTSTR)wxs);
209 /**************************************************************************************
210 > virtual BOOL String_64::Alloc(INT32 nSize)
212 Author: Justin_Flude (Xara Group Ltd) <camelotdev@xara.com> & Andy
213 Created: 12th August 1993
214 Purpose: Fixes Alloc() for fixed-length strings, which CAN be safely changed#
215 to use a buffer on the heap.
216 Scope: Public
217 SeeAlso: StringBase::Alloc
218 ***************************************************************************************/
220 BOOL String_64::Alloc(INT32 nSize)
222 if (text == fixedbuf) text = 0;
223 return StringBase::Alloc(nSize);