Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members | Related Pages

ShPaletteImpl.hpp

00001 // Sh: A GPU metaprogramming language.
00002 //
00003 // Copyright (c) 2003 University of Waterloo Computer Graphics Laboratory
00004 // Project administrator: Michael D. McCool
00005 // Authors: Zheng Qin, Stefanus Du Toit, Kevin Moule, Tiberiu S. Popa,
00006 //          Michael D. McCool
00007 // 
00008 // This software is provided 'as-is', without any express or implied
00009 // warranty. In no event will the authors be held liable for any damages
00010 // arising from the use of this software.
00011 // 
00012 // Permission is granted to anyone to use this software for any purpose,
00013 // including commercial applications, and to alter it and redistribute it
00014 // freely, subject to the following restrictions:
00015 // 
00016 // 1. The origin of this software must not be misrepresented; you must
00017 // not claim that you wrote the original software. If you use this
00018 // software in a product, an acknowledgment in the product documentation
00019 // would be appreciated but is not required.
00020 // 
00021 // 2. Altered source versions must be plainly marked as such, and must
00022 // not be misrepresented as being the original software.
00023 // 
00024 // 3. This notice may not be removed or altered from any source
00025 // distribution.
00027 #ifndef SHPALETTEIMPL_HPP
00028 #define SHPALETTEIMPL_HPP
00029 
00030 namespace SH {
00031 
00032 template<typename T>
00033 ShPalette<T>::ShPalette(std::size_t size)
00034   : m_node(new ShPaletteNode(T::typesize, T::semantic_type, T::value_type, size)),
00035     m_data(new T[size])
00036 {
00037   for (std::size_t i = 0; i < size; i++) {
00038     m_node->set_node(i, m_data[i].node());
00039   }
00040 }
00041 
00042 template<typename T>
00043 ShPalette<T>::~ShPalette()
00044 {
00045   delete [] m_data;
00046 }
00047 
00048 template<typename T>
00049 const T& ShPalette<T>::operator[](std::size_t index) const
00050 {
00051   return m_data[index];
00052 }
00053 
00054 template<typename T>
00055 T& ShPalette<T>::operator[](std::size_t index)
00056 {
00057   return m_data[index];
00058 }
00059 
00060 template<typename T>
00061 template<typename T2>
00062 T ShPalette<T>::operator[](const ShGeneric<1, T2>& index) const
00063 {
00064   if (ShContext::current()->parsing()) {
00065     T t;
00066     ShVariable palVar(m_node);
00067     ShStatement stmt(t, palVar, SH_OP_PAL, index);
00068     ShContext::current()->parsing()->tokenizer.blockList()->addStatement(stmt);
00069     return t;
00070   } else {
00071     return m_data[(std::size_t)index.getValue(0)];
00072   }
00073 }
00074 
00075 }
00076 
00077 #endif

Generated on Mon Jan 24 18:36:34 2005 for Sh by  doxygen 1.4.1