VirtualBox

source: vbox/trunk/include/VBox/com/string.h@ 49076

Last change on this file since 49076 was 49039, checked in by vboxsync, 11 years ago

IPRT: Filename extension versus suffix cleanup, long overdue.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 24.2 KB
Line 
1/* $Id: string.h 49039 2013-10-10 18:27:32Z vboxsync $ */
2/** @file
3 * MS COM / XPCOM Abstraction Layer - Smart string classes declaration.
4 */
5
6/*
7 * Copyright (C) 2006-2012 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27#ifndef ___VBox_com_string_h
28#define ___VBox_com_string_h
29
30/* Make sure all the stdint.h macros are included - must come first! */
31#ifndef __STDC_LIMIT_MACROS
32# define __STDC_LIMIT_MACROS
33#endif
34#ifndef __STDC_CONSTANT_MACROS
35# define __STDC_CONSTANT_MACROS
36#endif
37
38#if defined(VBOX_WITH_XPCOM)
39# include <nsMemory.h>
40#endif
41
42#include "VBox/com/defs.h"
43#include "VBox/com/assert.h"
44
45#include <iprt/mem.h>
46#include <iprt/cpp/ministring.h>
47
48namespace com
49{
50
51class Utf8Str;
52
53// global constant in glue/string.cpp that represents an empty BSTR
54extern const BSTR g_bstrEmpty;
55
56/**
57 * String class used universally in Main for COM-style Utf-16 strings.
58 *
59 * Unfortunately COM on Windows uses UTF-16 everywhere, requiring conversions
60 * back and forth since most of VirtualBox and our libraries use UTF-8.
61 *
62 * To make things more obscure, on Windows, a COM-style BSTR is not just a
63 * pointer to a null-terminated wide character array, but the four bytes (32
64 * bits) BEFORE the memory that the pointer points to are a length DWORD. One
65 * must therefore avoid pointer arithmetic and always use SysAllocString and
66 * the like to deal with BSTR pointers, which manage that DWORD correctly.
67 *
68 * For platforms other than Windows, we provide our own versions of the Sys*
69 * functions in Main/xpcom/helpers.cpp which do NOT use length prefixes though
70 * to be compatible with how XPCOM allocates string parameters to public
71 * functions.
72 *
73 * The Bstr class hides all this handling behind a std::string-like interface
74 * and also provides automatic conversions to RTCString and Utf8Str instances.
75 *
76 * The one advantage of using the SysString* routines is that this makes it
77 * possible to use it as a type of member variables of COM/XPCOM components and
78 * pass their values to callers through component methods' output parameters
79 * using the #cloneTo() operation. Also, the class can adopt (take ownership
80 * of) string buffers returned in output parameters of COM methods using the
81 * #asOutParam() operation and correctly free them afterwards.
82 *
83 * Starting with VirtualBox 3.2, like Utf8Str, Bstr no longer differentiates
84 * between NULL strings and empty strings. In other words, Bstr("") and
85 * Bstr(NULL) behave the same. In both cases, Bstr allocates no memory,
86 * reports a zero length and zero allocated bytes for both, and returns an
87 * empty C wide string from raw().
88 *
89 * @note All Bstr methods ASSUMES valid UTF-16 or UTF-8 input strings.
90 * The VirtualBox policy in this regard is to validate strings coming
91 * from external sources before passing them to Bstr or Utf8Str.
92 */
93class Bstr
94{
95public:
96
97 Bstr()
98 : m_bstr(NULL)
99 { }
100
101 Bstr(const Bstr &that)
102 {
103 copyFrom((const OLECHAR *)that.m_bstr);
104 }
105
106 Bstr(CBSTR that)
107 {
108 copyFrom((const OLECHAR *)that);
109 }
110
111#if defined(VBOX_WITH_XPCOM)
112 Bstr(const wchar_t *that)
113 {
114 AssertCompile(sizeof(wchar_t) == sizeof(OLECHAR));
115 copyFrom((const OLECHAR *)that);
116 }
117#endif
118
119 Bstr(const RTCString &that)
120 {
121 copyFrom(that.c_str());
122 }
123
124 Bstr(const char *that)
125 {
126 copyFrom(that);
127 }
128
129 Bstr(const char *a_pThat, size_t a_cchMax)
130 {
131 copyFromN(a_pThat, a_cchMax);
132 }
133
134 ~Bstr()
135 {
136 setNull();
137 }
138
139 Bstr& operator=(const Bstr &that)
140 {
141 cleanup();
142 copyFrom((const OLECHAR *)that.m_bstr);
143 return *this;
144 }
145
146 Bstr& operator=(CBSTR that)
147 {
148 cleanup();
149 copyFrom((const OLECHAR *)that);
150 return *this;
151 }
152
153#if defined(VBOX_WITH_XPCOM)
154 Bstr& operator=(const wchar_t *that)
155 {
156 cleanup();
157 copyFrom((const OLECHAR *)that);
158 return *this;
159 }
160#endif
161
162 Bstr& setNull()
163 {
164 cleanup();
165 return *this;
166 }
167
168#ifdef _MSC_VER
169# if _MSC_VER >= 1400
170 RTMEMEF_NEW_AND_DELETE_OPERATORS();
171# endif
172#else
173 RTMEMEF_NEW_AND_DELETE_OPERATORS();
174#endif
175
176 /** Case sensitivity selector. */
177 enum CaseSensitivity
178 {
179 CaseSensitive,
180 CaseInsensitive
181 };
182
183 /**
184 * Compares the member string to str.
185 * @param str
186 * @param cs Whether comparison should be case-sensitive.
187 * @return
188 */
189 int compare(CBSTR str, CaseSensitivity cs = CaseSensitive) const
190 {
191 if (cs == CaseSensitive)
192 return ::RTUtf16Cmp((PRTUTF16)m_bstr, (PRTUTF16)str);
193 return ::RTUtf16LocaleICmp((PRTUTF16)m_bstr, (PRTUTF16)str);
194 }
195
196 int compare(BSTR str, CaseSensitivity cs = CaseSensitive) const
197 {
198 return compare((CBSTR)str, cs);
199 }
200
201 int compare(const Bstr &that, CaseSensitivity cs = CaseSensitive) const
202 {
203 return compare(that.m_bstr, cs);
204 }
205
206 bool operator==(const Bstr &that) const { return !compare(that.m_bstr); }
207 bool operator==(CBSTR that) const { return !compare(that); }
208 bool operator==(BSTR that) const { return !compare(that); }
209 bool operator!=(const Bstr &that) const { return !!compare(that.m_bstr); }
210 bool operator!=(CBSTR that) const { return !!compare(that); }
211 bool operator!=(BSTR that) const { return !!compare(that); }
212 bool operator<(const Bstr &that) const { return compare(that.m_bstr) < 0; }
213 bool operator<(CBSTR that) const { return compare(that) < 0; }
214 bool operator<(BSTR that) const { return compare(that) < 0; }
215 bool operator<=(const Bstr &that) const { return compare(that.m_bstr) <= 0; }
216 bool operator<=(CBSTR that) const { return compare(that) <= 0; }
217 bool operator<=(BSTR that) const { return compare(that) <= 0; }
218 bool operator>(const Bstr &that) const { return compare(that.m_bstr) > 0; }
219 bool operator>(CBSTR that) const { return compare(that) > 0; }
220 bool operator>(BSTR that) const { return compare(that) > 0; }
221 bool operator>=(const Bstr &that) const { return compare(that.m_bstr) >= 0; }
222 bool operator>=(CBSTR that) const { return compare(that) >= 0; }
223 bool operator>=(BSTR that) const { return compare(that) >= 0; }
224
225 /**
226 * Returns true if the member string has no length.
227 * This is true for instances created from both NULL and "" input strings.
228 *
229 * @note Always use this method to check if an instance is empty. Do not
230 * use length() because that may need to run through the entire string
231 * (Bstr does not cache string lengths).
232 */
233 bool isEmpty() const { return m_bstr == NULL || *m_bstr == 0; }
234
235 /**
236 * Returns true if the member string has a length of one or more.
237 *
238 * @returns true if not empty, false if empty (NULL or "").
239 */
240 bool isNotEmpty() const { return m_bstr != NULL && *m_bstr != 0; }
241
242 size_t length() const { return isEmpty() ? 0 : ::RTUtf16Len((PRTUTF16)m_bstr); }
243
244#if defined(VBOX_WITH_XPCOM)
245 /**
246 * Returns a pointer to the raw member UTF-16 string. If the member string is empty,
247 * returns a pointer to a global variable containing an empty BSTR with a proper zero
248 * length prefix so that Windows is happy.
249 */
250 CBSTR raw() const
251 {
252 if (m_bstr)
253 return m_bstr;
254
255 return g_bstrEmpty;
256 }
257#else
258 /**
259 * Windows-only hack, as the automatically generated headers use BSTR.
260 * So if we don't want to cast like crazy we have to be more loose than
261 * on XPCOM.
262 *
263 * Returns a pointer to the raw member UTF-16 string. If the member string is empty,
264 * returns a pointer to a global variable containing an empty BSTR with a proper zero
265 * length prefix so that Windows is happy.
266 */
267 BSTR raw() const
268 {
269 if (m_bstr)
270 return m_bstr;
271
272 return g_bstrEmpty;
273 }
274#endif
275
276 /**
277 * Returns a non-const raw pointer that allows to modify the string directly.
278 * As opposed to raw(), this DOES return NULL if the member string is empty
279 * because we cannot return a mutable pointer to the global variable with the
280 * empty string.
281 *
282 * @warning
283 * Be sure not to modify data beyond the allocated memory! The
284 * guaranteed size of the allocated memory is at least #length()
285 * bytes after creation and after every assignment operation.
286 */
287 BSTR mutableRaw() { return m_bstr; }
288
289 /**
290 * Intended to assign copies of instances to |BSTR| out parameters from
291 * within the interface method. Transfers the ownership of the duplicated
292 * string to the caller.
293 *
294 * If the member string is empty, this allocates an empty BSTR in *pstr
295 * (i.e. makes it point to a new buffer with a null byte).
296 *
297 * @deprecated Use cloneToEx instead to avoid throwing exceptions.
298 */
299 void cloneTo(BSTR *pstr) const
300 {
301 if (pstr)
302 {
303 *pstr = ::SysAllocString((const OLECHAR *)raw()); // raw() returns a pointer to "" if empty
304#ifdef RT_EXCEPTIONS_ENABLED
305 if (!*pstr)
306 throw std::bad_alloc();
307#endif
308 }
309 }
310
311 /**
312 * A version of cloneTo that does not throw any out of memory exceptions, but
313 * returns E_OUTOFMEMORY intead.
314 * @returns S_OK or E_OUTOFMEMORY.
315 */
316 HRESULT cloneToEx(BSTR *pstr) const
317 {
318 if (!pstr)
319 return S_OK;
320 *pstr = ::SysAllocString((const OLECHAR *)raw()); // raw() returns a pointer to "" if empty
321 return pstr ? S_OK : E_OUTOFMEMORY;
322 }
323
324 /**
325 * Intended to assign instances to |BSTR| out parameters from within the
326 * interface method. Transfers the ownership of the original string to the
327 * caller and resets the instance to null.
328 *
329 * As opposed to cloneTo(), this method doesn't create a copy of the
330 * string.
331 *
332 * If the member string is empty, this allocates an empty BSTR in *pstr
333 * (i.e. makes it point to a new buffer with a null byte).
334 *
335 * @param pbstrDst The BSTR variable to detach the string to.
336 *
337 * @throws std::bad_alloc if we failed to allocate a new empty string.
338 */
339 void detachTo(BSTR *pbstrDst)
340 {
341 if (m_bstr)
342 {
343 *pbstrDst = m_bstr;
344 m_bstr = NULL;
345 }
346 else
347 {
348 // allocate null BSTR
349 *pbstrDst = ::SysAllocString((const OLECHAR *)g_bstrEmpty);
350#ifdef RT_EXCEPTIONS_ENABLED
351 if (!*pbstrDst)
352 throw std::bad_alloc();
353#endif
354 }
355 }
356
357 /**
358 * A version of detachTo that does not throw exceptions on out-of-memory
359 * conditions, but instead returns E_OUTOFMEMORY.
360 *
361 * @param pbstrDst The BSTR variable to detach the string to.
362 * @returns S_OK or E_OUTOFMEMORY.
363 */
364 HRESULT detachToEx(BSTR *pbstrDst)
365 {
366 if (m_bstr)
367 {
368 *pbstrDst = m_bstr;
369 m_bstr = NULL;
370 }
371 else
372 {
373 // allocate null BSTR
374 *pbstrDst = ::SysAllocString((const OLECHAR *)g_bstrEmpty);
375 if (!*pbstrDst)
376 return E_OUTOFMEMORY;
377 }
378 return S_OK;
379 }
380
381 /**
382 * Intended to pass instances as |BSTR| out parameters to methods.
383 * Takes the ownership of the returned data.
384 */
385 BSTR *asOutParam()
386 {
387 cleanup();
388 return &m_bstr;
389 }
390
391 /**
392 * Static immutable empty-string object. May be used for comparison purposes.
393 */
394 static const Bstr Empty;
395
396protected:
397
398 void cleanup()
399 {
400 if (m_bstr)
401 {
402 ::SysFreeString(m_bstr);
403 m_bstr = NULL;
404 }
405 }
406
407 /**
408 * Protected internal helper to copy a string. This ignores the previous object
409 * state, so either call this from a constructor or call cleanup() first.
410 *
411 * This variant copies from a zero-terminated UTF-16 string (which need not
412 * be a BSTR, i.e. need not have a length prefix).
413 *
414 * If the source is empty, this sets the member string to NULL.
415 *
416 * @param a_bstrSrc The source string. The caller guarantees
417 * that this is valid UTF-16.
418 *
419 * @throws std::bad_alloc - the object is representing an empty string.
420 */
421 void copyFrom(const OLECHAR *a_bstrSrc)
422 {
423 if (a_bstrSrc && *a_bstrSrc)
424 {
425 m_bstr = ::SysAllocString(a_bstrSrc);
426#ifdef RT_EXCEPTIONS_ENABLED
427 if (!m_bstr)
428 throw std::bad_alloc();
429#endif
430 }
431 else
432 m_bstr = NULL;
433 }
434
435 /**
436 * Protected internal helper to copy a string. This ignores the previous object
437 * state, so either call this from a constructor or call cleanup() first.
438 *
439 * This variant copies and converts from a zero-terminated UTF-8 string.
440 *
441 * If the source is empty, this sets the member string to NULL.
442 *
443 * @param a_pszSrc The source string. The caller guarantees
444 * that this is valid UTF-8.
445 *
446 * @throws std::bad_alloc - the object is representing an empty string.
447 */
448 void copyFrom(const char *a_pszSrc)
449 {
450 copyFromN(a_pszSrc, RTSTR_MAX);
451 }
452
453 /**
454 * Variant of copyFrom for sub-string constructors.
455 *
456 * @param a_pszSrc The source string. The caller guarantees
457 * that this is valid UTF-8.
458 * @param a_cchMax The maximum number of chars (not
459 * codepoints) to copy. If you pass RTSTR_MAX
460 * it'll be exactly like copyFrom().
461 *
462 * @throws std::bad_alloc - the object is representing an empty string.
463 */
464 void copyFromN(const char *a_pszSrc, size_t a_cchSrc);
465
466 BSTR m_bstr;
467
468 friend class Utf8Str; /* to access our raw_copy() */
469};
470
471/* symmetric compare operators */
472inline bool operator==(CBSTR l, const Bstr &r) { return r.operator==(l); }
473inline bool operator!=(CBSTR l, const Bstr &r) { return r.operator!=(l); }
474inline bool operator==(BSTR l, const Bstr &r) { return r.operator==(l); }
475inline bool operator!=(BSTR l, const Bstr &r) { return r.operator!=(l); }
476
477
478
479
480/**
481 * String class used universally in Main for UTF-8 strings.
482 *
483 * This is based on RTCString, to which some functionality has been
484 * moved. Here we keep things that are specific to Main, such as conversions
485 * with UTF-16 strings (Bstr).
486 *
487 * Like RTCString, Utf8Str does not differentiate between NULL strings
488 * and empty strings. In other words, Utf8Str("") and Utf8Str(NULL) behave the
489 * same. In both cases, RTCString allocates no memory, reports
490 * a zero length and zero allocated bytes for both, and returns an empty
491 * C string from c_str().
492 *
493 * @note All Utf8Str methods ASSUMES valid UTF-8 or UTF-16 input strings.
494 * The VirtualBox policy in this regard is to validate strings coming
495 * from external sources before passing them to Utf8Str or Bstr.
496 */
497class Utf8Str : public RTCString
498{
499public:
500
501 Utf8Str() {}
502
503 Utf8Str(const RTCString &that)
504 : RTCString(that)
505 {}
506
507 Utf8Str(const char *that)
508 : RTCString(that)
509 {}
510
511 Utf8Str(const Bstr &that)
512 {
513 copyFrom(that.raw());
514 }
515
516 Utf8Str(CBSTR that)
517 {
518 copyFrom(that);
519 }
520
521 Utf8Str(const char *a_pszSrc, size_t a_cchSrc)
522 : RTCString(a_pszSrc, a_cchSrc)
523 {
524 }
525
526 /**
527 * Constructs a new string given the format string and the list of the
528 * arguments for the format string.
529 *
530 * @param a_pszFormat Pointer to the format string (UTF-8),
531 * @see pg_rt_str_format.
532 * @param a_va Argument vector containing the arguments
533 * specified by the format string.
534 * @sa RTCString::printfV
535 */
536 Utf8Str(const char *a_pszFormat, va_list a_va)
537 : RTCString(a_pszFormat, a_va)
538 {
539 }
540
541 Utf8Str& operator=(const RTCString &that)
542 {
543 RTCString::operator=(that);
544 return *this;
545 }
546
547 Utf8Str& operator=(const char *that)
548 {
549 RTCString::operator=(that);
550 return *this;
551 }
552
553 Utf8Str& operator=(const Bstr &that)
554 {
555 cleanup();
556 copyFrom(that.raw());
557 return *this;
558 }
559
560 Utf8Str& operator=(CBSTR that)
561 {
562 cleanup();
563 copyFrom(that);
564 return *this;
565 }
566
567 bool operator<(const RTCString &that) const { return RTCString::operator<(that); }
568
569 /**
570 * Extended assignment method that returns a COM status code instead of an
571 * exception on failure.
572 *
573 * @returns S_OK or E_OUTOFMEMORY.
574 * @param a_rSrcStr The source string
575 */
576 HRESULT assignEx(Utf8Str const &a_rSrcStr)
577 {
578 return copyFromExNComRC(a_rSrcStr.m_psz, a_rSrcStr.m_cch);
579 }
580
581 /**
582 * Extended assignment method that returns a COM status code instead of an
583 * exception on failure.
584 *
585 * @returns S_OK, E_OUTOFMEMORY or E_INVALIDARG.
586 * @param a_pcszSrc The source string
587 * @param a_offSrc The character (byte) offset of the substring.
588 * @param a_cchSrc The number of characters (bytes) to copy from the source
589 * string.
590 */
591 HRESULT assignEx(Utf8Str const &a_rSrcStr, size_t a_offSrc, size_t a_cchSrc)
592 {
593 if ( a_offSrc + a_cchSrc > a_rSrcStr.m_cch
594 || a_offSrc > a_rSrcStr.m_cch)
595 return E_INVALIDARG;
596 return copyFromExNComRC(a_rSrcStr.m_psz, a_rSrcStr.m_cch);
597 }
598
599 /**
600 * Extended assignment method that returns a COM status code instead of an
601 * exception on failure.
602 *
603 * @returns S_OK or E_OUTOFMEMORY.
604 * @param a_pcszSrc The source string
605 */
606 HRESULT assignEx(const char *a_pcszSrc)
607 {
608 return copyFromExNComRC(a_pcszSrc, a_pcszSrc ? strlen(a_pcszSrc) : 0);
609 }
610
611 /**
612 * Extended assignment method that returns a COM status code instead of an
613 * exception on failure.
614 *
615 * @returns S_OK or E_OUTOFMEMORY.
616 * @param a_pcszSrc The source string
617 * @param a_cchSrc The number of characters (bytes) to copy from the source
618 * string.
619 */
620 HRESULT assignEx(const char *a_pcszSrc, size_t a_cchSrc)
621 {
622 return copyFromExNComRC(a_pcszSrc, a_cchSrc);
623 }
624
625 RTMEMEF_NEW_AND_DELETE_OPERATORS();
626
627#if defined(VBOX_WITH_XPCOM)
628 /**
629 * Intended to assign instances to |char *| out parameters from within the
630 * interface method. Transfers the ownership of the duplicated string to the
631 * caller.
632 *
633 * This allocates a single 0 byte in the target if the member string is empty.
634 *
635 * This uses XPCOM memory allocation and thus only works on XPCOM. MSCOM doesn't
636 * like char* strings anyway.
637 */
638 void cloneTo(char **pstr) const;
639
640 /**
641 * A version of cloneTo that does not throw allocation errors but returns
642 * E_OUTOFMEMORY instead.
643 * @returns S_OK or E_OUTOFMEMORY (COM status codes).
644 */
645 HRESULT cloneToEx(char **pstr) const;
646#endif
647
648 /**
649 * Intended to assign instances to |BSTR| out parameters from within the
650 * interface method. Transfers the ownership of the duplicated string to the
651 * caller.
652 */
653 void cloneTo(BSTR *pstr) const
654 {
655 if (pstr)
656 {
657 Bstr bstr(*this);
658 bstr.cloneTo(pstr);
659 }
660 }
661
662 /**
663 * A version of cloneTo that does not throw allocation errors but returns
664 * E_OUTOFMEMORY instead.
665 *
666 * @param pbstr Where to store a clone of the string.
667 * @returns S_OK or E_OUTOFMEMORY (COM status codes).
668 */
669 HRESULT cloneToEx(BSTR *pbstr) const
670 {
671 if (!pbstr)
672 return S_OK;
673 Bstr bstr(*this);
674 return bstr.detachToEx(pbstr);
675 }
676
677 /**
678 * Safe assignment from BSTR.
679 *
680 * @param pbstrSrc The source string.
681 * @returns S_OK or E_OUTOFMEMORY (COM status codes).
682 */
683 HRESULT cloneEx(CBSTR pbstrSrc)
684 {
685 cleanup();
686 return copyFromEx(pbstrSrc);
687 }
688
689 /**
690 * Removes a trailing slash from the member string, if present.
691 * Calls RTPathStripTrailingSlash() without having to mess with mutableRaw().
692 */
693 Utf8Str& stripTrailingSlash();
694
695 /**
696 * Removes a trailing filename from the member string, if present.
697 * Calls RTPathStripFilename() without having to mess with mutableRaw().
698 */
699 Utf8Str& stripFilename();
700
701 /**
702 * Removes the path component from the member string, if present.
703 * Calls RTPathFilename() without having to mess with mutableRaw().
704 */
705 Utf8Str& stripPath();
706
707 /**
708 * Removes a trailing file name suffix from the member string, if present.
709 * Calls RTPathStripSuffix() without having to mess with mutableRaw().
710 */
711 Utf8Str& stripSuffix();
712
713 /**
714 * Static immutable empty-string object. May be used for comparison purposes.
715 */
716 static const Utf8Str Empty;
717protected:
718
719 void copyFrom(CBSTR a_pbstr);
720 HRESULT copyFromEx(CBSTR a_pbstr);
721 HRESULT copyFromExNComRC(const char *a_pcszSrc, size_t a_cchSrc);
722
723 friend class Bstr; /* to access our raw_copy() */
724};
725
726/**
727 * Class with RTCString::printf as constructor for your convenience.
728 *
729 * Constructing a Utf8Str string object from a format string and a variable
730 * number of arguments can easily be confused with the other Utf8Str
731 * constructures, thus this child class.
732 *
733 * The usage of this class is like the following:
734 * @code
735 Utf8StrFmt strName("program name = %s", argv[0]);
736 @endcode
737 */
738class Utf8StrFmt : public Utf8Str
739{
740public:
741
742 /**
743 * Constructs a new string given the format string and the list of the
744 * arguments for the format string.
745 *
746 * @param a_pszFormat Pointer to the format string (UTF-8),
747 * @see pg_rt_str_format.
748 * @param ... Ellipsis containing the arguments specified by
749 * the format string.
750 */
751 explicit Utf8StrFmt(const char *a_pszFormat, ...)
752 {
753 va_list va;
754 va_start(va, a_pszFormat);
755 printfV(a_pszFormat, va);
756 va_end(va);
757 }
758
759 RTMEMEF_NEW_AND_DELETE_OPERATORS();
760
761protected:
762 Utf8StrFmt()
763 { }
764
765private:
766};
767
768/**
769 * The BstrFmt class is a shortcut to <tt>Bstr(Utf8StrFmt(...))</tt>.
770 */
771class BstrFmt : public Bstr
772{
773public:
774
775 /**
776 * Constructs a new string given the format string and the list of the
777 * arguments for the format string.
778 *
779 * @param aFormat printf-like format string (in UTF-8 encoding).
780 * @param ... List of the arguments for the format string.
781 */
782 explicit BstrFmt(const char *aFormat, ...)
783 {
784 va_list args;
785 va_start(args, aFormat);
786 copyFrom(Utf8Str(aFormat, args).c_str());
787 va_end(args);
788 }
789
790 RTMEMEF_NEW_AND_DELETE_OPERATORS();
791};
792
793/**
794 * The BstrFmtVA class is a shortcut to <tt>Bstr(Utf8Str(format,va))</tt>.
795 */
796class BstrFmtVA : public Bstr
797{
798public:
799
800 /**
801 * Constructs a new string given the format string and the list of the
802 * arguments for the format string.
803 *
804 * @param aFormat printf-like format string (in UTF-8 encoding).
805 * @param aArgs List of arguments for the format string
806 */
807 BstrFmtVA(const char *aFormat, va_list aArgs)
808 {
809 copyFrom(Utf8Str(aFormat, aArgs).c_str());
810 }
811
812 RTMEMEF_NEW_AND_DELETE_OPERATORS();
813};
814
815} /* namespace com */
816
817#endif /* !___VBox_com_string_h */
818
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette