Sirikata
libcore/include/sirikata/core/util/MemoryReference.hpp
Go to the documentation of this file.
00001 /*  Sirikata Utilities -- Sirikata Synchronization Utilities
00002  *  MemoryReference.hpp
00003  *
00004  *  Copyright (c) 2009, Daniel Reiter Horn
00005  *  All rights reserved.
00006  *
00007  *  Redistribution and use in source and binary forms, with or without
00008  *  modification, are permitted provided that the following conditions are
00009  *  met:
00010  *  * Redistributions of source code must retain the above copyright
00011  *    notice, this list of conditions and the following disclaimer.
00012  *  * Redistributions in binary form must reproduce the above copyright
00013  *    notice, this list of conditions and the following disclaimer in
00014  *    the documentation and/or other materials provided with the
00015  *    distribution.
00016  *  * Neither the name of Sirikata nor the names of its contributors may
00017  *    be used to endorse or promote products derived from this software
00018  *    without specific prior written permission.
00019  *
00020  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
00021  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
00022  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
00023  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
00024  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00025  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
00026  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
00027  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
00028  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
00029  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00030  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00031  */
00032 
00033 #ifndef _SIRIKATA_MEMORY_REFERENCE_HPP_
00034 #define _SIRIKATA_MEMORY_REFERENCE_HPP_
00035 
00036 #include <cstddef>
00037 #include <stdexcept>
00038 
00039 namespace Sirikata {
00040 template <class T> class DataReference {
00041     T first;
00042     size_t second;
00043 public:
00044     DataReference(T data, size_t size) {
00045         first=data;
00046         second=size;
00047     }
00048     static DataReference null() {
00049         return DataReference(NULL,0);
00050     }
00051     explicit DataReference(const std::string&s) {
00052         first=s.data();
00053         second=s.length();
00054     }
00055     template <class U> explicit DataReference(const std::vector<U> &v) {
00056         if (v.empty()) {
00057             first=NULL;
00058             second=0;
00059         }else {
00060             first=(T)&v[0];
00061             second=v.size();
00062         }
00063     }
00064     T begin() const {
00065         return first;
00066     }
00067     T end() const {
00068         // FIXME: If second really is measured in bytes, why do we use void* and not char*?
00069         return (void*)(((char*)first)+second);
00070     }
00071     T data() const {
00072         return first;
00073     }
00074     size_t size() const {
00075         return second;
00076     }
00077     inline size_t length() const {
00078         return size();
00079     }
00080 };
00081 
00082 typedef DataReference<const void*> MemoryReference;
00083 }
00084 #endif //_SIRIKATA_ARRAY_HPP_