mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-26 03:30:30 +00:00 
			
		
		
		
	Configure the namespace of native implementation in api.json
Make ValidationUtils flexible for other generation. BUG=dawn:1201 Change-Id: I42ccbd3d9c2fe37abec4b8f7eb395583dbe1dc8d Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/72980 Reviewed-by: Austin Eng <enga@chromium.org> Commit-Queue: Junwei Fu <junwei.fu@intel.com>
This commit is contained in:
		
							parent
							
								
									8921987f08
								
							
						
					
					
						commit
						a2241d402e
					
				| @ -22,6 +22,7 @@ | |||||||
|         "c_prefix": "WGPU", |         "c_prefix": "WGPU", | ||||||
|         "namespace": "wgpu", |         "namespace": "wgpu", | ||||||
|         "proc_table_prefix": "Dawn", |         "proc_table_prefix": "Dawn", | ||||||
|  |         "native_namespace": "dawn native", | ||||||
|         "copyright_year": "2019" |         "copyright_year": "2019" | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -28,8 +28,10 @@ The `"_metadata"` key in the JSON file is used by flexible templates for generat | |||||||
|  - `"api"` a string, the name of the Web API |  - `"api"` a string, the name of the Web API | ||||||
|  - `"namespace"` a string, the namespace of C++ wrapper |  - `"namespace"` a string, the namespace of C++ wrapper | ||||||
|  - `"c_prefix"` (optional) a string, the prefix of C function and data type, it will default to upper-case of `"namespace"` if it's not provided. |  - `"c_prefix"` (optional) a string, the prefix of C function and data type, it will default to upper-case of `"namespace"` if it's not provided. | ||||||
|   - `"proc_table_prefix"` a string, the prefix of proc table. |  - `"proc_table_prefix"` a string, the prefix of proc table. | ||||||
|  - `"copyright_year"` (optional) a string, templates will use the the year of copyright. |  - `"impl_dir"` a string, the directory of API implementation | ||||||
|  |  - `"native_namespace"` a string, the namespace of native implementation | ||||||
|  |  - `"copyright_year"` (optional) a string, templates will use the year of copyright. | ||||||
| 
 | 
 | ||||||
| The basic schema is that every entry is a thing with a `"category"` key what determines the sub-schema to apply to that thing. Categories and their sub-shema are defined below. Several parts of the schema use the concept of "record" which is a list of "record members" which are a combination of a type, a name and other metadata. For example the list of arguments of a function is a record. The list of structure members is a record. This combined concept is useful for the dawn_wire generator to generate code for structure and function calls in a very similar way. | The basic schema is that every entry is a thing with a `"category"` key what determines the sub-schema to apply to that thing. Categories and their sub-shema are defined below. Several parts of the schema use the concept of "record" which is a list of "record members" which are a combination of a type, a name and other metadata. For example the list of arguments of a function is a record. The list of structure members is a record. This combined concept is useful for the dawn_wire generator to generate code for structure and function calls in a very similar way. | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -29,6 +29,8 @@ class Metadata: | |||||||
|         self.namespace = metadata['namespace'] |         self.namespace = metadata['namespace'] | ||||||
|         self.c_prefix = metadata.get('c_prefix', self.namespace.upper()) |         self.c_prefix = metadata.get('c_prefix', self.namespace.upper()) | ||||||
|         self.proc_table_prefix = metadata['proc_table_prefix'] |         self.proc_table_prefix = metadata['proc_table_prefix'] | ||||||
|  |         self.impl_dir = metadata.get('impl_dir', '') | ||||||
|  |         self.native_namespace = metadata['native_namespace'] | ||||||
|         self.copyright_year = metadata.get('copyright_year', None) |         self.copyright_year = metadata.get('copyright_year', None) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -856,13 +858,15 @@ class MultiGeneratorFromDawnJSON(Generator): | |||||||
|                 } |                 } | ||||||
|             ] |             ] | ||||||
| 
 | 
 | ||||||
|  |             impl_dir = metadata.impl_dir + '/' if metadata.impl_dir else '' | ||||||
|  |             native_dir = impl_dir + Name(metadata.native_namespace).snake_case() | ||||||
|             renders.append( |             renders.append( | ||||||
|                 FileRender('dawn_native/ValidationUtils.h', |                 FileRender('dawn_native/ValidationUtils.h', | ||||||
|                            'src/dawn_native/ValidationUtils_autogen.h', |                            'src/' + native_dir + '/ValidationUtils_autogen.h', | ||||||
|                            frontend_params)) |                            frontend_params)) | ||||||
|             renders.append( |             renders.append( | ||||||
|                 FileRender('dawn_native/ValidationUtils.cpp', |                 FileRender('dawn_native/ValidationUtils.cpp', | ||||||
|                            'src/dawn_native/ValidationUtils_autogen.cpp', |                            'src/' + native_dir + '/ValidationUtils_autogen.cpp', | ||||||
|                            frontend_params)) |                            frontend_params)) | ||||||
|             renders.append( |             renders.append( | ||||||
|                 FileRender('dawn_native/dawn_platform.h', |                 FileRender('dawn_native/dawn_platform.h', | ||||||
|  | |||||||
| @ -12,15 +12,19 @@ | |||||||
| //* See the License for the specific language governing permissions and
 | //* See the License for the specific language governing permissions and
 | ||||||
| //* limitations under the License.
 | //* limitations under the License.
 | ||||||
| 
 | 
 | ||||||
| #include "dawn_native/ValidationUtils_autogen.h" | {% set native_namespace = Name(metadata.native_namespace).snake_case() %} | ||||||
|  | {% set impl_dir = metadata.impl_dir + "/" if metadata.impl_dir else "" %} | ||||||
|  | {% set native_dir = impl_dir + native_namespace %} | ||||||
|  | #include "{{native_dir}}/ValidationUtils_autogen.h" | ||||||
| 
 | 
 | ||||||
| namespace dawn_native { | namespace {{native_namespace}} { | ||||||
| 
 | 
 | ||||||
|  |     {% set namespace = metadata.namespace %} | ||||||
|     {% for type in by_category["enum"] %} |     {% for type in by_category["enum"] %} | ||||||
|         MaybeError Validate{{type.name.CamelCase()}}(wgpu::{{as_cppType(type.name)}} value) { |         MaybeError Validate{{type.name.CamelCase()}}({{namespace}}::{{as_cppType(type.name)}} value) { | ||||||
|             switch (value) { |             switch (value) { | ||||||
|                 {% for value in type.values if value.valid %} |                 {% for value in type.values if value.valid %} | ||||||
|                     case wgpu::{{as_cppType(type.name)}}::{{as_cppEnum(value.name)}}: |                     case {{namespace}}::{{as_cppType(type.name)}}::{{as_cppEnum(value.name)}}: | ||||||
|                         return {}; |                         return {}; | ||||||
|                 {% endfor %} |                 {% endfor %} | ||||||
|                 default: |                 default: | ||||||
| @ -31,8 +35,8 @@ namespace dawn_native { | |||||||
|     {% endfor %} |     {% endfor %} | ||||||
| 
 | 
 | ||||||
|     {% for type in by_category["bitmask"] %} |     {% for type in by_category["bitmask"] %} | ||||||
|         MaybeError Validate{{type.name.CamelCase()}}(wgpu::{{as_cppType(type.name)}} value) { |         MaybeError Validate{{type.name.CamelCase()}}({{namespace}}::{{as_cppType(type.name)}} value) { | ||||||
|             if ((value & static_cast<wgpu::{{as_cppType(type.name)}}>(~{{type.full_mask}})) == 0) { |             if ((value & static_cast<{{namespace}}::{{as_cppType(type.name)}}>(~{{type.full_mask}})) == 0) { | ||||||
|                 return {}; |                 return {}; | ||||||
|             } |             } | ||||||
|             return DAWN_VALIDATION_ERROR("Invalid value for {{as_cType(type.name)}}"); |             return DAWN_VALIDATION_ERROR("Invalid value for {{as_cType(type.name)}}"); | ||||||
| @ -40,4 +44,4 @@ namespace dawn_native { | |||||||
| 
 | 
 | ||||||
|     {% endfor %} |     {% endfor %} | ||||||
| 
 | 
 | ||||||
| } // namespace dawn_native
 | } // namespace {{native_namespace}}
 | ||||||
|  | |||||||
| @ -15,17 +15,22 @@ | |||||||
| #ifndef BACKEND_VALIDATIONUTILS_H_ | #ifndef BACKEND_VALIDATIONUTILS_H_ | ||||||
| #define BACKEND_VALIDATIONUTILS_H_ | #define BACKEND_VALIDATIONUTILS_H_ | ||||||
| 
 | 
 | ||||||
| #include "dawn/webgpu_cpp.h" | {% set api = metadata.api.lower() %} | ||||||
|  | #include "dawn/{{api}}_cpp.h" | ||||||
| 
 | 
 | ||||||
| #include "dawn_native/Error.h" | {% set native_namespace = Name(metadata.native_namespace).snake_case() %} | ||||||
|  | {% set impl_dir = metadata.impl_dir + "/" if metadata.impl_dir else "" %} | ||||||
|  | {% set native_dir = impl_dir + native_namespace %} | ||||||
|  | #include "{{native_dir}}/Error.h" | ||||||
| 
 | 
 | ||||||
| namespace dawn_native { | namespace {{native_namespace}} { | ||||||
| 
 | 
 | ||||||
|     // Helper functions to check the value of enums and bitmasks
 |     // Helper functions to check the value of enums and bitmasks
 | ||||||
|     {% for type in by_category["enum"] + by_category["bitmask"] %} |     {% for type in by_category["enum"] + by_category["bitmask"] %} | ||||||
|         MaybeError Validate{{type.name.CamelCase()}}(wgpu::{{as_cppType(type.name)}} value); |         {% set namespace = metadata.namespace %} | ||||||
|  |         MaybeError Validate{{type.name.CamelCase()}}({{namespace}}::{{as_cppType(type.name)}} value); | ||||||
|     {% endfor %} |     {% endfor %} | ||||||
| 
 | 
 | ||||||
| } // namespace dawn_native
 | } // namespace {{native_namespace}}
 | ||||||
| 
 | 
 | ||||||
| #endif  // BACKEND_VALIDATIONUTILS_H_
 | #endif  // BACKEND_VALIDATIONUTILS_H_
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user