sample2.h
Go to the documentation of this file.
00001 // Copyright 2005, Google Inc.
00002 // All rights reserved.
00003 //
00004 // Redistribution and use in source and binary forms, with or without
00005 // modification, are permitted provided that the following conditions are
00006 // met:
00007 //
00008 //     * Redistributions of source code must retain the above copyright
00009 // notice, this list of conditions and the following disclaimer.
00010 //     * Redistributions in binary form must reproduce the above
00011 // copyright notice, this list of conditions and the following disclaimer
00012 // in the documentation and/or other materials provided with the
00013 // distribution.
00014 //     * Neither the name of Google Inc. nor the names of its
00015 // contributors may be used to endorse or promote products derived from
00016 // this software without specific prior written permission.
00017 //
00018 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00019 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00020 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
00021 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
00022 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00023 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00024 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00025 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00026 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00027 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00028 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00029 
00030 // A sample program demonstrating using Google C++ testing framework.
00031 //
00032 // Author: wan@google.com (Zhanyong Wan)
00033 
00034 #ifndef GTEST_SAMPLES_SAMPLE2_H_
00035 #define GTEST_SAMPLES_SAMPLE2_H_
00036 
00037 #include <string.h>
00038 
00039 
00040 // A simple string class.
00041 class MyString {
00042  private:
00043   const char* c_string_;
00044   const MyString& operator=(const MyString& rhs);
00045 
00046  public:
00047   // Clones a 0-terminated C string, allocating memory using new.
00048   static const char* CloneCString(const char* a_c_string);
00049 
00051   //
00052   // C'tors
00053 
00054   // The default c'tor constructs a NULL string.
00055   MyString() : c_string_(NULL) {}
00056 
00057   // Constructs a MyString by cloning a 0-terminated C string.
00058   explicit MyString(const char* a_c_string) : c_string_(NULL) {
00059     Set(a_c_string);
00060   }
00061 
00062   // Copy c'tor
00063   MyString(const MyString& string) : c_string_(NULL) {
00064     Set(string.c_string_);
00065   }
00066 
00068   //
00069   // D'tor.  MyString is intended to be a final class, so the d'tor
00070   // doesn't need to be virtual.
00071   ~MyString() { delete[] c_string_; }
00072 
00073   // Gets the 0-terminated C string this MyString object represents.
00074   const char* c_string() const { return c_string_; }
00075 
00076   size_t Length() const {
00077     return c_string_ == NULL ? 0 : strlen(c_string_);
00078   }
00079 
00080   // Sets the 0-terminated C string this MyString object represents.
00081   void Set(const char* c_string);
00082 };
00083 
00084 
00085 #endif  // GTEST_SAMPLES_SAMPLE2_H_


ros_opcua_impl_freeopcua
Author(s): Denis Štogl
autogenerated on Sat Jun 8 2019 18:24:56