xref: /aosp_15_r20/external/cronet/base/win/hstring_reference.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2019 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #ifndef BASE_WIN_HSTRING_REFERENCE_H_
6*6777b538SAndroid Build Coastguard Worker #define BASE_WIN_HSTRING_REFERENCE_H_
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker #include <hstring.h>
9*6777b538SAndroid Build Coastguard Worker 
10*6777b538SAndroid Build Coastguard Worker #include "base/base_export.h"
11*6777b538SAndroid Build Coastguard Worker 
12*6777b538SAndroid Build Coastguard Worker namespace base::win {
13*6777b538SAndroid Build Coastguard Worker 
14*6777b538SAndroid Build Coastguard Worker // HStringReference is an HSTRING representation of a null terminated
15*6777b538SAndroid Build Coastguard Worker // string backed by memory that outlives the HStringReference instance.
16*6777b538SAndroid Build Coastguard Worker //
17*6777b538SAndroid Build Coastguard Worker // If you need an HSTRING class that manages its own memory, you should
18*6777b538SAndroid Build Coastguard Worker // use ScopedHString instead.
19*6777b538SAndroid Build Coastguard Worker //
20*6777b538SAndroid Build Coastguard Worker // Example use:
21*6777b538SAndroid Build Coastguard Worker //
22*6777b538SAndroid Build Coastguard Worker //   HStringReference string(L"abc");
23*6777b538SAndroid Build Coastguard Worker //
24*6777b538SAndroid Build Coastguard Worker class BASE_EXPORT HStringReference {
25*6777b538SAndroid Build Coastguard Worker  public:
26*6777b538SAndroid Build Coastguard Worker   // Creates an HStringReference from `str`, which must be null terminated.
27*6777b538SAndroid Build Coastguard Worker   explicit HStringReference(const wchar_t* str);
28*6777b538SAndroid Build Coastguard Worker 
Get()29*6777b538SAndroid Build Coastguard Worker   HSTRING Get() const { return hstring_; }
30*6777b538SAndroid Build Coastguard Worker 
31*6777b538SAndroid Build Coastguard Worker   // HSTRING_HEADER is a structure that contains a pointer to the string
32*6777b538SAndroid Build Coastguard Worker   // passed into the constructor, along with its length.
33*6777b538SAndroid Build Coastguard Worker 
34*6777b538SAndroid Build Coastguard Worker   // Since HSTRING is a pointer to HSTRING_HEADER, HStringReference
35*6777b538SAndroid Build Coastguard Worker   // cannot be copyable, moveable or assignable, as that would invalidate
36*6777b538SAndroid Build Coastguard Worker   // the HSTRING we're passing out to clients.
37*6777b538SAndroid Build Coastguard Worker 
38*6777b538SAndroid Build Coastguard Worker   // In the future, we can consider implementing these methods by storing
39*6777b538SAndroid Build Coastguard Worker   // the string passed in the constructor and re-creating the HSTRING and
40*6777b538SAndroid Build Coastguard Worker   // HSTRING_HEADER datastructures. For now, we'll keep things simple and
41*6777b538SAndroid Build Coastguard Worker   // forbid these operations.
42*6777b538SAndroid Build Coastguard Worker   HStringReference(const HStringReference&) = delete;
43*6777b538SAndroid Build Coastguard Worker   HStringReference& operator=(const HStringReference&) = delete;
44*6777b538SAndroid Build Coastguard Worker 
45*6777b538SAndroid Build Coastguard Worker  private:
46*6777b538SAndroid Build Coastguard Worker   HSTRING hstring_ = nullptr;
47*6777b538SAndroid Build Coastguard Worker   HSTRING_HEADER hstring_header_;
48*6777b538SAndroid Build Coastguard Worker };
49*6777b538SAndroid Build Coastguard Worker 
50*6777b538SAndroid Build Coastguard Worker }  // namespace base::win
51*6777b538SAndroid Build Coastguard Worker 
52*6777b538SAndroid Build Coastguard Worker #endif  // BASE_WIN_HSTRING_REFERENCE_H_
53