Loading...
Searching...
No Matches
registry.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_VALIDATION_USD_VALIDATION_REGISTRY_H
8#define PXR_USD_VALIDATION_USD_VALIDATION_REGISTRY_H
9
10#include "pxr/pxr.h"
12#include "pxr/usdValidation/usdValidation/api.h"
14#include "pxr/usdValidation/usdValidation/fixer.h"
15
16#include <memory>
17#include <shared_mutex>
18#include <unordered_map>
19
21
22PXR_NAMESPACE_OPEN_SCOPE
23
166{
168 UsdValidationRegistry &operator=(const UsdValidationRegistry &) = delete;
169
170public:
171 USDVALIDATION_API
172 static UsdValidationRegistry &GetInstance()
173 {
175 }
176
194 USDVALIDATION_API
195 void RegisterPluginValidator(const TfToken &validatorName,
196 const UsdValidateLayerTaskFn &layerTaskFn,
197 std::vector<UsdValidationFixer> fixers = {});
198
216 USDVALIDATION_API
217 void RegisterPluginValidator(const TfToken &validatorName,
218 const UsdValidateStageTaskFn &stageTaskFn,
219 std::vector<UsdValidationFixer> fixers = {});
220
238 USDVALIDATION_API
239 void RegisterPluginValidator(const TfToken &validatorName,
240 const UsdValidatePrimTaskFn &primTaskFn,
241 std::vector<UsdValidationFixer> fixers = {});
242
261 USDVALIDATION_API
263 const UsdValidateLayerTaskFn &layerTaskFn,
264 std::vector<UsdValidationFixer> fixers = {});
265
284 USDVALIDATION_API
286 const UsdValidateStageTaskFn &stageTaskFn,
287 std::vector<UsdValidationFixer> fixers = {});
288
307 USDVALIDATION_API
309 const UsdValidatePrimTaskFn &primTaskFn,
310 std::vector<UsdValidationFixer> fixers = {});
311
331 USDVALIDATION_API
333 const TfToken &validatorSuiteName,
334 const std::vector<const UsdValidationValidator *> &containedValidators);
335
355 USDVALIDATION_API
357 const UsdValidationValidatorMetadata &metadata,
358 const std::vector<const UsdValidationValidator *> &containedValidators);
359
362 USDVALIDATION_API
363 bool HasValidator(const TfToken &validatorName) const;
364
367 USDVALIDATION_API
368 bool HasValidatorSuite(const TfToken &suiteName) const;
369
380 USDVALIDATION_API
381 std::vector<const UsdValidationValidator *> GetOrLoadAllValidators();
382
390 USDVALIDATION_API
392 GetOrLoadValidatorByName(const TfToken &validatorName);
393
402 USDVALIDATION_API
403 std::vector<const UsdValidationValidator *>
405
417 USDVALIDATION_API
418 std::vector<const UsdValidationValidatorSuite *>
420
428 USDVALIDATION_API
431
440 USDVALIDATION_API
441 std::vector<const UsdValidationValidatorSuite *>
443
448 USDVALIDATION_API
450 UsdValidationValidatorMetadata *metadata) const;
451
454 USDVALIDATION_API
455 UsdValidationValidatorMetadataVector GetAllValidatorMetadata() const;
456
464 USDVALIDATION_API
465 UsdValidationValidatorMetadataVector
466 GetValidatorMetadataForPlugin(const TfToken &pluginName) const;
467
475 USDVALIDATION_API
476 UsdValidationValidatorMetadataVector
478
486 USDVALIDATION_API
487 UsdValidationValidatorMetadataVector
489
500 USDVALIDATION_API
501 UsdValidationValidatorMetadataVector
503
514 USDVALIDATION_API
515 UsdValidationValidatorMetadataVector
517
528 USDVALIDATION_API
529 UsdValidationValidatorMetadataVector
531
532private:
534
536
537 // Initialize _validatorNameToMetadata, _keywordToValidatorNames and
538 // _schemaTypeToValidatorNames by parsing all plugInfo.json, find all
539 // Validators.
540 void _PopulateMetadataFromPlugInfo();
541
542 // Templated method to register validator, called by appropriate
543 // RegisterValidator methods, providing UsdValidateLayerTaskFn,
544 // UsdValidateStageTaskFn or UsdValidatePrimTaskFn.
545 template <typename ValidateTaskFn>
546 void _RegisterPluginValidator(const TfToken &validatorName,
547 const ValidateTaskFn &taskFn,
548 std::vector<UsdValidationFixer> fixers);
549
550 // Overloaded templated _RegisterValidator, where metadata is explicitly
551 // provided.
552 template <typename ValidateTaskFn>
553 void _RegisterValidator(const UsdValidationValidatorMetadata &metadata,
554 const ValidateTaskFn &taskFn,
555 std::vector<UsdValidationFixer> fixers,
556 bool addMetadata = true);
557
558 void _RegisterValidatorSuite(
559 const UsdValidationValidatorMetadata &metadata,
560 const std::vector<const UsdValidationValidator *> &containedValidators,
561 bool addMetadata = true);
562
563 // makes sure metadata provided is legal
564 // checkForPrimTask parameter is used to determine if schemaTypes metadata
565 // is provided and if the task being registered for the validator is
566 // UsdValidatePrimTaskFn.
567 // expectSuite parameter is used to determine if the isSuite metadata is
568 // appropriately set (for UsdValidationValidatorSuite) or not (for
569 // UsdValidationValidator).
570 static bool _CheckMetadata(const UsdValidationValidatorMetadata &metadata,
571 bool checkForPrimTask, bool expectSuite = false);
572
573 // Add validator metadata to _validatorNameToMetadata, also updates
574 // _schemaTypeToValidatorNames and _keywordToValidatorNames, for easy access
575 // to what validators are linked to specific schemaTypes or keywords.
576 // _mutex must be acquired before calling this method.
577 bool _AddValidatorMetadata(const UsdValidationValidatorMetadata &metadata);
578
579 using _ValidatorNameToValidatorMap
580 = std::unordered_map<TfToken, std::unique_ptr<UsdValidationValidator>,
582 using _ValidatorSuiteNameToValidatorSuiteMap
583 = std::unordered_map<TfToken,
584 std::unique_ptr<UsdValidationValidatorSuite>,
586 using _ValidatorNameToMetadataMap
587 = std::unordered_map<TfToken, UsdValidationValidatorMetadata,
589 using _TokenToValidatorNamesMap
590 = std::unordered_map<TfToken, TfTokenVector, TfToken::HashFunctor>;
591
592 // Helper to query
593 UsdValidationValidatorMetadataVector _GetValidatorMetadataForToken(
594 const _TokenToValidatorNamesMap &tokenToValidatorNames,
595 const TfTokenVector &tokens) const;
596
597 // Helper to populate _keywordToValidatorNames and
598 // _schemaTypeToValidatorNames
599 // _mutex must be acquired before calling this method.
600 static void
601 _UpdateValidatorNamesMappings(_TokenToValidatorNamesMap &tokenMap,
602 const TfToken &validatorName,
603 const TfTokenVector &tokens);
604
605 // Main datastructure which holds validatorName to
606 // std::unique_ptr<UsdValidationValidator>
607 _ValidatorNameToValidatorMap _validators;
608 // Main datastructure which holds suiteName to
609 // std::unique_ptr<UsdValidationValidatorSuite>
610 _ValidatorSuiteNameToValidatorSuiteMap _validatorSuites;
611
612 // ValidatorName to ValidatorMetadata map
613 _ValidatorNameToMetadataMap _validatorNameToMetadata;
614
615 // Following 3 are helper data structures to easy lookup for Validators,
616 // when queried for keywords, schemaType or pluginName.
617
618 // This map stores the mapping from keyword to validator names. It may get
619 // updated as validators can be registered dynamically outside of the plugin
620 // infrastructure.
621 _TokenToValidatorNamesMap _keywordToValidatorNames;
622
623 // This map stores the mapping from schemaTypes to validator names. It may
624 // get updated as validators can be registered dynamically outside of the
625 // plugin infrastructure.
626 _TokenToValidatorNamesMap _schemaTypeToValidatorNames;
627
628 // This map stores the mapping from plugin names to validator names.
629 // It is populated during the initialization of UsdValidationRegistry
630 // and remains constant thereafter.
631 _TokenToValidatorNamesMap _pluginNameToValidatorNames;
632
633 // Mutex to protect access to all data members.
634 mutable std::shared_mutex _mutex;
635};
636
637// Specialize and delete the DeleteInstance function to prevent destruction.
638// This will prevent the singleton instance for UsdValidationRegistry from
639// being destroyed and hence making it immortal.
641
642USDVALIDATION_API_TEMPLATE_CLASS(TfSingleton<UsdValidationRegistry>);
643
644PXR_NAMESPACE_CLOSE_SCOPE
645
646#endif // PXR_USD_VALIDATION_USD_VALIDATION_REGISTRY_H
Manage a single instance of an object (see.
Definition: singleton.h:105
static void DeleteInstance()
Destroy the sole instance object of type T, if it exists.
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 UsdValidationValidator / UsdValidationValidatorS...
Definition: registry.h:166
USDVALIDATION_API std::vector< const UsdValidationValidatorSuite * > GetOrLoadValidatorSuitesByName(const TfTokenVector &suiteNames)
Returns a vector of const pointer to UsdValidationValidatorSuite corresponding to suiteNames found in...
USDVALIDATION_API void RegisterPluginValidatorSuite(const TfToken &validatorSuiteName, const std::vector< const UsdValidationValidator * > &containedValidators)
Register UsdValidationValidatorSuite defined in a plugin using validatorSuiteName and containedValida...
USDVALIDATION_API bool GetValidatorMetadata(const TfToken &name, UsdValidationValidatorMetadata *metadata) const
Returns true if metadata is found in the _validatorNameToMetadata for a validator/suite name,...
USDVALIDATION_API UsdValidationValidatorMetadataVector GetValidatorMetadataForSchemaType(const TfToken &schemaType) const
Returns vector of UsdValidationValidatorMetadata associated with the Validators which has the schemaT...
USDVALIDATION_API bool HasValidatorSuite(const TfToken &suiteName) const
Return true if a UsdValidationValidatorSuite is registered with the name validatorSuiteName; false ot...
USDVALIDATION_API std::vector< const UsdValidationValidator * > GetOrLoadValidatorsByName(const TfTokenVector &validatorNames)
Returns a vector of const pointer to UsdValidationValidator corresponding to validatorNames found in ...
USDVALIDATION_API const UsdValidationValidatorSuite * GetOrLoadValidatorSuiteByName(const TfToken &suiteName)
Returns a const pointer to UsdValidationValidatorSuite if suiteName is found in the registry.
USDVALIDATION_API void RegisterValidatorSuite(const UsdValidationValidatorMetadata &metadata, const std::vector< const UsdValidationValidator * > &containedValidators)
Register UsdValidationValidatorSuite using metadata and containedValidators with the UsdValidationReg...
USDVALIDATION_API bool HasValidator(const TfToken &validatorName) const
Return true if a UsdValidationValidator is registered with the name validatorName; false otherwise.
USDVALIDATION_API UsdValidationValidatorMetadataVector GetAllValidatorMetadata() const
Return vector of all UsdValidationValidatorMetadata known to the registry.
USDVALIDATION_API std::vector< const UsdValidationValidator * > GetOrLoadAllValidators()
Returns a vector of const pointer to UsdValidationValidator corresponding to all validators registere...
USDVALIDATION_API void RegisterPluginValidator(const TfToken &validatorName, const UsdValidateStageTaskFn &stageTaskFn, std::vector< UsdValidationFixer > fixers={})
Register UsdValidationValidator defined in a plugin using validatorName and stageTaskFn with the UsdV...
USDVALIDATION_API void RegisterPluginValidator(const TfToken &validatorName, const UsdValidateLayerTaskFn &layerTaskFn, std::vector< UsdValidationFixer > fixers={})
Register UsdValidationValidator defined in a plugin using validatorName and layerTaskFn with the UsdV...
USDVALIDATION_API UsdValidationValidatorMetadataVector GetValidatorMetadataForSchemaTypes(const TfTokenVector &schemaTypes) const
Returns vector of UsdValidationValidatorMetadata associated with the Validators which has at least on...
USDVALIDATION_API void RegisterValidator(const UsdValidationValidatorMetadata &metadata, const UsdValidateLayerTaskFn &layerTaskFn, std::vector< UsdValidationFixer > fixers={})
Register UsdValidationValidator using metadata and layerTaskFn with the UsdValidationRegistry.
USDVALIDATION_API UsdValidationValidatorMetadataVector GetValidatorMetadataForPlugin(const TfToken &pluginName) const
Returns vector of UsdValidationValidatorMetadata associated with the Validators which belong to the p...
USDVALIDATION_API UsdValidationValidatorMetadataVector GetValidatorMetadataForKeyword(const TfToken &keyword) const
Returns vector of UsdValidationValidatorMetadata associated with the Validators which has the keyword...
USDVALIDATION_API UsdValidationValidatorMetadataVector GetValidatorMetadataForPlugins(const TfTokenVector &pluginNames) const
Returns vector of UsdValidationValidatorMetadata associated with the Validators which belong to the p...
USDVALIDATION_API void RegisterPluginValidator(const TfToken &validatorName, const UsdValidatePrimTaskFn &primTaskFn, std::vector< UsdValidationFixer > fixers={})
Register UsdValidationValidator defined in a plugin using validatorName and primTaskFn with the UsdVa...
USDVALIDATION_API UsdValidationValidatorMetadataVector GetValidatorMetadataForKeywords(const TfTokenVector &keywords) const
Returns vector of UsdValidationValidatorMetadata associated with the Validators which has at least on...
USDVALIDATION_API const UsdValidationValidator * GetOrLoadValidatorByName(const TfToken &validatorName)
Returns a const pointer to UsdValidationValidator if validatorName is found in the registry.
USDVALIDATION_API void RegisterValidator(const UsdValidationValidatorMetadata &metadata, const UsdValidatePrimTaskFn &primTaskFn, std::vector< UsdValidationFixer > fixers={})
Register UsdValidationValidator using metadata and primTaskFn with the UsdValidationRegistry.
USDVALIDATION_API void RegisterValidator(const UsdValidationValidatorMetadata &metadata, const UsdValidateStageTaskFn &stageTaskFn, std::vector< UsdValidationFixer > fixers={})
Register UsdValidationValidator using metadata and stageTaskFn with the UsdValidationRegistry.
USDVALIDATION_API std::vector< const UsdValidationValidatorSuite * > GetOrLoadAllValidatorSuites()
Returns a vector of const pointer to UsdValidationValidatorSuite corresponding to all validator suite...
UsdValidationValidator is a class describing a single test.
Definition: validator.h:138
UsdValidationValidatorSuite acts like a suite for a collection of tests, which clients can use to bun...
Definition: validator.h:318
std::function< UsdValidationErrorVector(const UsdPrim &, const UsdValidationTimeRange)> UsdValidatePrimTaskFn
UsdValidatePrimTaskFn: Validation logic operating on a given UsdPrim.
Definition: validator.h:111
std::function< UsdValidationErrorVector(const SdfLayerHandle &)> UsdValidateLayerTaskFn
UsdValidateLayerTaskFn: Validation logic operating on a given SdfLayerHandle.
Definition: validator.h:105
std::function< UsdValidationErrorVector(const UsdStagePtr &, const UsdValidationTimeRange)> UsdValidateStageTaskFn
UsdValidateStageTaskFn: Validation logic operating on a given UsdStage.
Definition: validator.h:108
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 UsdValidationValidator.
Definition: validator.h:56