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