Loading...
Searching...
No Matches
validationRegistry.h
Go to the documentation of this file.
1//
2// Copyright 2024 Pixar
3//
4// Licensed under the terms set forth in the LICENSE.txt file available at
5// https://openusd.org/license.
6//
7#ifndef PXR_USD_USD_VALIDATION_REGISTRY_H
8#define PXR_USD_USD_VALIDATION_REGISTRY_H
9
10#include "pxr/pxr.h"
11#include "pxr/usd/usd/api.h"
14
15#include <shared_mutex>
16#include <memory>
17#include <unordered_map>
18
20
21PXR_NAMESPACE_OPEN_SCOPE
22
143{
145 UsdValidationRegistry& operator=(const UsdValidationRegistry&) = delete;
146public:
147 USD_API
148 static UsdValidationRegistry& GetInstance() {
150 }
151
167 USD_API
168 void RegisterPluginValidator(const TfToken &validatorName,
169 const UsdValidateLayerTaskFn &layerTaskFn);
170
186 USD_API
187 void RegisterPluginValidator(const TfToken &validatorName,
188 const UsdValidateStageTaskFn &stageTaskFn);
189
205 USD_API
206 void RegisterPluginValidator(const TfToken &validatorName,
207 const UsdValidatePrimTaskFn &primTaskFn);
208
225 USD_API
227 const UsdValidateLayerTaskFn &layerTaskFn);
228
245 USD_API
247 const UsdValidateStageTaskFn &stageTaskFn);
248
265 USD_API
267 const UsdValidatePrimTaskFn &primTaskFn);
268
288 USD_API
289 void RegisterPluginValidatorSuite(const TfToken &validatorSuiteName,
290 const std::vector<const UsdValidator*>&
291 containedValidators);
292
312 USD_API
314 const std::vector<const UsdValidator*>&
315 containedValidators);
316
319 bool HasValidator(const TfToken &validatorName) const;
320
323 bool HasValidatorSuite(const TfToken &suiteName) const;
324
335 USD_API
336 std::vector<const UsdValidator*> GetOrLoadAllValidators();
337
345 USD_API
346 const UsdValidator* GetOrLoadValidatorByName(const TfToken &validatorName);
347
356 USD_API
357 std::vector<const UsdValidator*>
359
370 USD_API
371 std::vector<const UsdValidatorSuite*> GetOrLoadAllValidatorSuites();
372
380 USD_API
382 const TfToken &suiteName);
383
392 USD_API
393 std::vector<const UsdValidatorSuite*>
395
400 USD_API
401 bool GetValidatorMetadata(const TfToken &name,
402 UsdValidatorMetadata *metadata) const;
403
405 USD_API
406 UsdValidatorMetadataVector GetAllValidatorMetadata() const;
407
415 USD_API
416 UsdValidatorMetadataVector GetValidatorMetadataForPlugin(
417 const TfToken &pluginName) const;
418
426 USD_API
427 UsdValidatorMetadataVector GetValidatorMetadataForKeyword(
428 const TfToken &keyword) const;
429
437 USD_API
438 UsdValidatorMetadataVector GetValidatorMetadataForSchemaType(
439 const TfToken &schemaType) const;
440
451 USD_API
452 UsdValidatorMetadataVector GetValidatorMetadataForPlugins(
453 const TfTokenVector &pluginNames) const;
454
465 USD_API
466 UsdValidatorMetadataVector GetValidatorMetadataForKeywords(
467 const TfTokenVector &keywords) const;
468
479 USD_API
480 UsdValidatorMetadataVector GetValidatorMetadataForSchemaTypes(
481 const TfTokenVector &schemaTypes) const;
482
483private:
485
487
488 // Initialize _validatorNameToMetadata, _keywordToValidatorNames and
489 // _schemaTypeToValidatorNames by parsing all plugInfo.json, find all
490 // Validators.
491 void _PopulateMetadataFromPlugInfo();
492
493 // Templated method to register validator, called by appropriate
494 // RegisterValidator methods, providing UsdValidateLayerTaskFn,
495 // UsdValidateStageTaskFn or UsdValidatePrimTaskFn.
496 template<typename ValidateTaskFn>
497 void _RegisterPluginValidator(const TfToken &validatorName,
498 const ValidateTaskFn &taskFn);
499
500 // Overloaded templated _RegisterValidator, where metadata is explicitly
501 // provided.
502 template<typename ValidateTaskFn>
503 void _RegisterValidator(const UsdValidatorMetadata &metadata,
504 const ValidateTaskFn &taskFn, bool addMetadata = true);
505
506 void _RegisterValidatorSuite(const UsdValidatorMetadata &metadata,
507 const std::vector<const UsdValidator*>& containedValidators,
508 bool addMetadata = true);
509
510 // makes sure metadata provided is legal
511 // checkForPrimTask parameter is used to determine if schemaTypes metadata
512 // is provided and if the task being registered for the validator is
513 // UsdValidatePrimTaskFn.
514 // expectSuite parameter is used to determine if the isSuite metadata is
515 // appropriately set (for UsdValidatorSuite) or not (for UsdValidator).
516 static
517 bool _CheckMetadata(const UsdValidatorMetadata &metadata,
518 bool checkForPrimTask, bool expectSuite = false);
519
520 // Add validator metadata to _validatorNameToMetadata, also updates
521 // _schemaTypeToValidatorNames and _keywordToValidatorNames, for easy access
522 // to what validators are linked to specific schemaTypes or keywords.
523 // _mutex must be acquired before calling this method.
524 bool _AddValidatorMetadata(const UsdValidatorMetadata &metadata);
525
526 using _ValidatorNameToValidatorMap =
527 std::unordered_map<TfToken, std::unique_ptr<UsdValidator>,
529 using _ValidatorSuiteNameToValidatorSuiteMap =
530 std::unordered_map<TfToken, std::unique_ptr<UsdValidatorSuite>,
532 using _ValidatorNameToMetadataMap =
533 std::unordered_map<TfToken, UsdValidatorMetadata, TfToken::HashFunctor>;
534 using _TokenToValidatorNamesMap =
535 std::unordered_map<TfToken, TfTokenVector, TfToken::HashFunctor>;
536
537 // Helper to query
538 UsdValidatorMetadataVector _GetValidatorMetadataForToken(
539 const _TokenToValidatorNamesMap &tokenToValidatorNames,
540 const TfTokenVector &tokens) const;
541
542 // Helper to populate _keywordToValidatorNames and
543 // _schemaTypeToValidatorNames
544 // _mutex must be acquired before calling this method.
545 static
546 void _UpdateValidatorNamesMappings(_TokenToValidatorNamesMap &tokenMap,
547 const TfToken &validatorName, const TfTokenVector &tokens);
548
549 // Main datastructure which holds validatorName to
550 // std::unique_ptr<UsdValidator>
551 _ValidatorNameToValidatorMap _validators;
552 // Main datastructure which holds suiteName to
553 // std::unique_ptr<UsdValidatorSuite>
554 _ValidatorSuiteNameToValidatorSuiteMap _validatorSuites;
555
556 // ValidatorName to ValidatorMetadata map
557 _ValidatorNameToMetadataMap _validatorNameToMetadata;
558
559 // Following 3 are helper data structures to easy lookup for Validators,
560 // when queried for keywords, schemaType or pluginName.
561
562 // This map stores the mapping from keyword to validator names. It may get
563 // updated as validators can be registered dynamically outside of the plugin
564 // infrastructure.
565 _TokenToValidatorNamesMap _keywordToValidatorNames;
566
567 // This map stores the mapping from schemaTypes to validator names. It may
568 // get updated as validators can be registered dynamically outside of the
569 // plugin infrastructure.
570 _TokenToValidatorNamesMap _schemaTypeToValidatorNames;
571
572 // This map stores the mapping from plugin names to validator names.
573 // It is populated during the initialization of UsdValidationRegistry
574 // and remains constant thereafter.
575 _TokenToValidatorNamesMap _pluginNameToValidatorNames;
576
577 // Mutex to protect access to all data members.
578 mutable std::shared_mutex _mutex;
579};
580
581USD_API_TEMPLATE_CLASS(TfSingleton<UsdValidationRegistry>);
582
583PXR_NAMESPACE_CLOSE_SCOPE
584
585#endif // PXR_USD_USD_VALIDATION_REGISTRY_H
Manage a single instance of an object (see.
Definition: singleton.h:105
static T & GetInstance()
Return a reference to an object of type T, creating it if necessary.
Definition: singleton.h:120
Token for efficient comparison, assignment, and hashing of known strings.
Definition: token.h:71
UsdValidationRegistry manages and provides access to UsdValidator / UsdValidatorSuite for USD Validat...
USD_API UsdValidatorMetadataVector GetValidatorMetadataForSchemaType(const TfToken &schemaType) const
Returns vector of UsdValidatorMetadata associated with the Validators which has the schemaType.
bool HasValidator(const TfToken &validatorName) const
Return true if a UsdValidator is registered with the name validatorName; false otherwise.
USD_API void RegisterValidator(const UsdValidatorMetadata &metadata, const UsdValidatePrimTaskFn &primTaskFn)
Register UsdValidator using metadata and primTaskFn with the UsdValidationRegistry.
USD_API std::vector< const UsdValidatorSuite * > GetOrLoadValidatorSuitesByName(const TfTokenVector &suiteNames)
Returns a vector of const pointer to UsdValidatorSuite corresponding to suiteNames found in the regis...
USD_API UsdValidatorMetadataVector GetValidatorMetadataForKeywords(const TfTokenVector &keywords) const
Returns vector of UsdValidatorMetadata associated with the Validators which has at least one of the k...
USD_API void RegisterValidator(const UsdValidatorMetadata &metadata, const UsdValidateLayerTaskFn &layerTaskFn)
Register UsdValidator using metadata and layerTaskFn with the UsdValidationRegistry.
USD_API UsdValidatorMetadataVector GetValidatorMetadataForSchemaTypes(const TfTokenVector &schemaTypes) const
Returns vector of UsdValidatorMetadata associated with the Validators which has at least one of the s...
USD_API UsdValidatorMetadataVector GetValidatorMetadataForPlugin(const TfToken &pluginName) const
Returns vector of UsdValidatorMetadata associated with the Validators which belong to the pluginName.
USD_API UsdValidatorMetadataVector GetValidatorMetadataForPlugins(const TfTokenVector &pluginNames) const
Returns vector of UsdValidatorMetadata associated with the Validators which belong to the pluginNames...
USD_API bool GetValidatorMetadata(const TfToken &name, UsdValidatorMetadata *metadata) const
Returns true if metadata is found in the _validatorNameToMetadata for a validator/suite name,...
USD_API void RegisterValidatorSuite(const UsdValidatorMetadata &metadata, const std::vector< const UsdValidator * > &containedValidators)
Register UsdValidatorSuite using metadata and containedValidators with the UsdValidationRegistry.
USD_API UsdValidatorMetadataVector GetAllValidatorMetadata() const
Return vector of all UsdValidatorMetadata known to the registry.
bool HasValidatorSuite(const TfToken &suiteName) const
Return true if a UsdValidatorSuite is registered with the name validatorSuiteName; false otherwise.
USD_API std::vector< const UsdValidator * > GetOrLoadValidatorsByName(const TfTokenVector &validatorNames)
Returns a vector of const pointer to UsdValidator corresponding to validatorNames found in the regist...
USD_API void RegisterPluginValidatorSuite(const TfToken &validatorSuiteName, const std::vector< const UsdValidator * > &containedValidators)
Register UsdValidatorSuite defined in a plugin using validatorSuiteName and containedValidators with ...
USD_API void RegisterPluginValidator(const TfToken &validatorName, const UsdValidatePrimTaskFn &primTaskFn)
Register UsdValidator defined in a plugin using validatorName and primTaskFn with the UsdValidationRe...
USD_API void RegisterValidator(const UsdValidatorMetadata &metadata, const UsdValidateStageTaskFn &stageTaskFn)
Register UsdValidator using metadata and stageTaskFn with the UsdValidationRegistry.
USD_API void RegisterPluginValidator(const TfToken &validatorName, const UsdValidateLayerTaskFn &layerTaskFn)
Register UsdValidator defined in a plugin using validatorName and layerTaskFn with the UsdValidationR...
USD_API const UsdValidator * GetOrLoadValidatorByName(const TfToken &validatorName)
Returns a const pointer to UsdValidator if validatorName is found in the registry.
USD_API const UsdValidatorSuite * GetOrLoadValidatorSuiteByName(const TfToken &suiteName)
Returns a const pointer to UsdValidatorSuite if suiteName is found in the registry.
USD_API std::vector< const UsdValidator * > GetOrLoadAllValidators()
Returns a vector of const pointer to UsdValidator corresponding to all validators registered in the U...
USD_API std::vector< const UsdValidatorSuite * > GetOrLoadAllValidatorSuites()
Returns a vector of const pointer to UsdValidatorSuite corresponding to all validator suites register...
USD_API UsdValidatorMetadataVector GetValidatorMetadataForKeyword(const TfToken &keyword) const
Returns vector of UsdValidatorMetadata associated with the Validators which has the keyword.
USD_API void RegisterPluginValidator(const TfToken &validatorName, const UsdValidateStageTaskFn &stageTaskFn)
Register UsdValidator defined in a plugin using validatorName and stageTaskFn with the UsdValidationR...
UsdValidator is a class describing a single test.
Definition: validator.h:117
UsdValidatorSuite acts like a suite for a collection of tests, which clients can use to bundle all te...
Definition: validator.h:219
std::function< UsdValidationErrorVector(const UsdStagePtr &)> UsdValidateStageTaskFn
UsdValidateStageTaskFn: Validation logic operating on a given UsdStage.
Definition: validator.h:98
std::function< UsdValidationErrorVector(const SdfLayerHandle &)> UsdValidateLayerTaskFn
UsdValidateLayerTaskFn: Validation logic operating on a given SdfLayerHandle.
Definition: validator.h:95
std::function< UsdValidationErrorVector(const UsdPrim &)> UsdValidatePrimTaskFn
UsdValidatePrimTaskFn: Validation logic operating on a given UsdPrim.
Definition: validator.h:101
Manage a single instance of an object.
Functor to use for hash maps from tokens to other things.
Definition: token.h:149
std::vector< TfToken > TfTokenVector
Convenience types.
Definition: token.h:440
A structure which describes metadata for a UsdValidator.
Definition: validator.h:46