Chromium Code Reviews

Side by Side Diff: command_buffer/client/cross/effect_helper.h

Issue 234002: More work in Command Buffers... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/o3d/
Patch Set: Created 11 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright 2009, Google Inc. 2 * Copyright 2009, Google Inc.
3 * All rights reserved. 3 * All rights reserved.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are 6 * modification, are permitted provided that the following conditions are
7 * met: 7 * met:
8 * 8 *
9 * * Redistributions of source code must retain the above copyright 9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer. 10 * notice, this list of conditions and the following disclaimer.
(...skipping 32 matching lines...)
43 43
44 class FencedAllocatorWrapper; 44 class FencedAllocatorWrapper;
45 class IdAllocator; 45 class IdAllocator;
46 class CommandBufferHelper; 46 class CommandBufferHelper;
47 47
48 // A helper class to find parameters in an effect. 48 // A helper class to find parameters in an effect.
49 class EffectHelper { 49 class EffectHelper {
50 public: 50 public:
51 // A more usable version of effect_param::Desc 51 // A more usable version of effect_param::Desc
52 struct EffectParamDesc { 52 struct EffectParamDesc {
53 ResourceID id; // The resource ID for the param. 53 ResourceId id; // The resource ID for the param.
54 String name; // The name of the param. 54 String name; // The name of the param.
55 String semantic; // The semantic of the param. 55 String semantic; // The semantic of the param.
56 effect_param::DataType data_type; // The data type of a param. 56 effect_param::DataType data_type; // The data type of a param.
57 unsigned int data_size; // The size of the data for a param. 57 unsigned int data_size; // The size of the data for a param.
58 int num_elements; // The number of array entries if the 58 int num_elements; // The number of array entries if the
59 // parameter is an array, 0 otherwise. 59 // parameter is an array, 0 otherwise.
60 unsigned int cmd_desc_size; // The size of the effect_param::Desc 60 unsigned int cmd_desc_size; // The size of the effect_param::Desc
61 // structure (counting strings) for a 61 // structure (counting strings) for a
62 // param. 62 // param.
63 }; 63 };
(...skipping 21 matching lines...)
85 // strings with a single command within GetParamStrings, so it should be left 85 // strings with a single command within GetParamStrings, so it should be left
86 // alone. 86 // alone.
87 // 87 //
88 // The ResourceIDs will be allocated in the param_id_allocator. 88 // The ResourceIDs will be allocated in the param_id_allocator.
89 // Temporary buffers will be allocated in the shm_allocator, but they will be 89 // Temporary buffers will be allocated in the shm_allocator, but they will be
90 // freed before the function returns (possibly pending a token). At least 90 // freed before the function returns (possibly pending a token). At least
91 // sizeof(effect_param::Desc) must be available for this function to succeed. 91 // sizeof(effect_param::Desc) must be available for this function to succeed.
92 // This function will call Finish(), hence will block. 92 // This function will call Finish(), hence will block.
93 // 93 //
94 // Parameters: 94 // Parameters:
95 // effect_id: the ResourceID of the effect. 95 // effect_id: the ResourceId of the effect.
96 // descs: A pointer to a vector containing the returned descriptions. 96 // descs: A pointer to a vector containing the returned descriptions.
97 // The pointed vector will be cleared. 97 // The pointed vector will be cleared.
98 // Returns: 98 // Returns:
99 // true if successful. Reasons for failure are: 99 // true if successful. Reasons for failure are:
100 // - invalid effect_id, 100 // - invalid effect_id,
101 // - not enough memory in the shm_allocator_. 101 // - not enough memory in the shm_allocator_.
102 bool CreateEffectParameters(ResourceID effect_id, 102 bool CreateEffectParameters(ResourceId effect_id,
103 std::vector<EffectParamDesc> *descs); 103 std::vector<EffectParamDesc> *descs);
104 104
105 // Gets the strings for a desc. This will fill in the values for the name and 105 // Gets the strings for a desc. This will fill in the values for the name and
106 // semantic fields. 106 // semantic fields.
107 // Temporary buffers will be allocated in the shm_allocator, but they will be 107 // Temporary buffers will be allocated in the shm_allocator, but they will be
108 // freed before the function returns (possibly pending a token). At least 108 // freed before the function returns (possibly pending a token). At least
109 // desc.cmd_desc_size (as returned by CreateEffectParameters) must be 109 // desc.cmd_desc_size (as returned by CreateEffectParameters) must be
110 // available for this function to succeed. 110 // available for this function to succeed.
111 // This function will call Finish(), hence will block. 111 // This function will call Finish(), hence will block.
112 // 112 //
113 // Parameters: 113 // Parameters:
114 // desc: a pointer to the description for a parameter. The id field should 114 // desc: a pointer to the description for a parameter. The id field should
115 // be set to the ResourceID of the parameter. 115 // be set to the ResourceId of the parameter.
116 // Returns: 116 // Returns:
117 // true if successful. Reasons for failure are: 117 // true if successful. Reasons for failure are:
118 // - invalid parameter ResourceID, 118 // - invalid parameter ResourceId,
119 // - not enough memory in the shm_allocator_. 119 // - not enough memory in the shm_allocator_.
120 bool GetParamStrings(EffectParamDesc *desc); 120 bool GetParamStrings(EffectParamDesc *desc);
121 121
122 // Destroys all parameter resources referenced by the descriptions. The 122 // Destroys all parameter resources referenced by the descriptions. The
123 // ResourceID will be freed from the param_id_allocator. 123 // ResourceId will be freed from the param_id_allocator.
124 // Parameters: 124 // Parameters:
125 // descs: the vector of descriptions containing the ResourceIDs of the 125 // descs: the vector of descriptions containing the ResourceIDs of the
126 // parameters to destroy. 126 // parameters to destroy.
127 void DestroyEffectParameters(const std::vector<EffectParamDesc> &descs); 127 void DestroyEffectParameters(const std::vector<EffectParamDesc> &descs);
128 128
129 // Gets all the input stream semantics and semantic indices in an 129 // Gets all the input stream semantics and semantic indices in an
130 // array. These will be retrieved as many as possible at a time. At least 130 // array. These will be retrieved as many as possible at a time. At least
131 // sizeof(effect_param::Desc) must be available for this function to succeed. 131 // sizeof(effect_param::Desc) must be available for this function to succeed.
132 // This function will call Finish(), hence will block. 132 // This function will call Finish(), hence will block.
133 // 133 //
134 // Parameters: 134 // Parameters:
135 // effect_id: the ResourceID of the effect. 135 // effect_id: the ResourceId of the effect.
136 // descs: A pointer to a vector containing the returned descriptions. 136 // descs: A pointer to a vector containing the returned descriptions.
137 // The pointed vector will be cleared. 137 // The pointed vector will be cleared.
138 // Returns: 138 // Returns:
139 // true if successful. Reasons for failure are: 139 // true if successful. Reasons for failure are:
140 // - invalid effect_id, 140 // - invalid effect_id,
141 // - not enough memory in the shm_allocator_. 141 // - not enough memory in the shm_allocator_.
142 bool GetEffectStreams(ResourceID effect_id, 142 bool GetEffectStreams(ResourceId effect_id,
143 std::vector<EffectStreamDesc> *descs); 143 std::vector<EffectStreamDesc> *descs);
144 144
145 private: 145 private:
146 CommandBufferHelper *helper_; 146 CommandBufferHelper *helper_;
147 FencedAllocatorWrapper *shm_allocator_; 147 FencedAllocatorWrapper *shm_allocator_;
148 unsigned int shm_id_; 148 unsigned int shm_id_;
149 IdAllocator *param_id_allocator_; 149 IdAllocator *param_id_allocator_;
150 150
151 DISALLOW_COPY_AND_ASSIGN(EffectHelper); 151 DISALLOW_COPY_AND_ASSIGN(EffectHelper);
152 }; 152 };
153 153
154 } // namespace command_buffer 154 } // namespace command_buffer
155 } // namespace o3d 155 } // namespace o3d
156 156
157 #endif // O3D_COMMAND_BUFFER_CLIENT_CROSS_EFFECT_HELPER_H_ 157 #endif // O3D_COMMAND_BUFFER_CLIENT_CROSS_EFFECT_HELPER_H_
OLDNEW
« no previous file with comments | « command_buffer/client/cross/cmd_buffer_helper.h ('k') | command_buffer/client/cross/effect_helper.cc » ('j') | no next file with comments »

Powered by Google App Engine