|
RTOpPack: Extra C/C++ Code for Vector Reduction/Transformation Operators
Version of the Day
|
00001 /* 00002 // @HEADER 00003 // *********************************************************************** 00004 // 00005 // Moocho: Multi-functional Object-Oriented arCHitecture for Optimization 00006 // Copyright (2003) Sandia Corporation 00007 // 00008 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive 00009 // license for use of this work by or on behalf of the U.S. Government. 00010 // 00011 // Redistribution and use in source and binary forms, with or without 00012 // modification, are permitted provided that the following conditions are 00013 // met: 00014 // 00015 // 1. Redistributions of source code must retain the above copyright 00016 // notice, this list of conditions and the following disclaimer. 00017 // 00018 // 2. Redistributions in binary form must reproduce the above copyright 00019 // notice, this list of conditions and the following disclaimer in the 00020 // documentation and/or other materials provided with the distribution. 00021 // 00022 // 3. Neither the name of the Corporation nor the names of the 00023 // contributors may be used to endorse or promote products derived from 00024 // this software without specific prior written permission. 00025 // 00026 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY 00027 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00028 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 00029 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE 00030 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00031 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00032 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00033 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00034 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00035 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00036 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00037 // 00038 // Questions? Contact Roscoe A. Bartlett (rabartl@sandia.gov) 00039 // 00040 // *********************************************************************** 00041 // @HEADER 00042 */ 00043 00044 #include "RTOp_obj_index_vtbl.h" 00045 #include "RTOp_obj_free_free.h" 00046 00047 #include <stdlib.h> 00048 00049 /* Local function definitions */ 00050 00051 static int get_obj_type_num_entries( 00052 const struct RTOp_obj_type_vtbl_t* vtbl 00053 ,const void* instance_data 00054 ,int* num_values 00055 ,int* num_indexes 00056 ,int* num_chars 00057 ) 00058 { 00059 *num_values = 0; 00060 *num_indexes = 1; 00061 *num_chars = 0; 00062 return 0; 00063 } 00064 00065 static int obj_create( const struct RTOp_obj_type_vtbl_t* vtbl, const void* instance_data, void** obj ) 00066 { 00067 const int mem_size = sizeof(RTOp_index_type); 00068 *obj = malloc( mem_size ); 00069 *((RTOp_index_type*)*obj) = 0; 00070 return 0; 00071 } 00072 00073 static int obj_reinit( const struct RTOp_obj_type_vtbl_t* vtbl, const void* instance_data, void* obj ) 00074 { 00075 *((RTOp_index_type*)obj) = 0; 00076 return 0; 00077 } 00078 00079 static int extract_state( 00080 const struct RTOp_obj_type_vtbl_t* vtbl 00081 ,const void * instance_data 00082 ,void * obj 00083 ,int num_values 00084 ,RTOp_value_type value_data[] 00085 ,int num_indexes 00086 ,RTOp_index_type index_data[] 00087 ,int num_chars 00088 ,RTOp_char_type char_data[] 00089 ) 00090 { 00091 assert(obj); 00092 assert( num_values == 0 ); 00093 assert( num_indexes == 1 ); 00094 assert( num_chars == 0 ); 00095 index_data[0] = *((RTOp_index_type*)obj); 00096 return 0; 00097 } 00098 00099 static int load_state( 00100 const struct RTOp_obj_type_vtbl_t* vtbl 00101 ,const void * instance_data 00102 ,int num_values 00103 ,const RTOp_value_type value_data[] 00104 ,int num_indexes 00105 ,const RTOp_index_type index_data[] 00106 ,int num_chars 00107 ,const RTOp_char_type char_data[] 00108 ,void ** obj 00109 ) 00110 { 00111 assert(obj); 00112 assert( num_values == 0 ); 00113 assert( num_indexes == 1 ); 00114 assert( num_chars == 0 ); 00115 if(*obj == NULL) 00116 obj_create(NULL,NULL,obj); 00117 *((RTOp_index_type*)*obj) = index_data[0]; 00118 return 0; 00119 } 00120 00121 const struct RTOp_obj_type_vtbl_t RTOp_obj_index_vtbl = 00122 { 00123 get_obj_type_num_entries 00124 ,obj_create 00125 ,obj_reinit 00126 ,RTOp_obj_free_free 00127 ,extract_state 00128 ,load_state 00129 };
1.7.6.1