padv.builtin.query.FindRequirements Class
Namespace: padv.builtin.query
Superclasses: padv.Query, padv.builtin.query.FindArtifacts
Query for finding requirements
Description
The padv.builtin.query.FindRequirements class provides a query that can
      return the requirements files in your project folder. You can automatically include or exclude
      certain files by using the optional name-value arguments.
You can use this query in your process model to find requirements files for your tasks to iterate over or use as inputs.
The padv.builtin.query.FindRequirements class is a handle class.
Creation
Description
query = padv.builtin.query.FindRequirements().slreqx) in
          your project folder.
query = padv.builtin.query.FindRequirements(Name=Value)padv.builtin.query.FindRequirements(IncludePathRegex =
            "HighLevel.*\.slreqx") creates a query that can find SLREQX files where the
          path contains HighLevel.
The padv.builtin.query.FindRequirements class also has other properties, but you cannot set
          those properties during query creation.
Name-Value Arguments
Specify optional pairs of arguments as
      Name1=Value1,...,NameN=ValueN, where Name is
      the argument name and Value is the corresponding value.
      Name-value arguments must appear after other arguments, but the order of the
      pairs does not matter.
    
Example: query = padv.builtin.query.FindRequirements(IncludePathRegex =
            "HighLevel.*\.slreqx")
Unique identifier for query, specified as a string or a character vector.
Example: "FindMyRequirements"
Data Types: char | string
Find requirements with specific project label, specified as a cell array where the first entry is the project label category and the second entry is the project label name.
Example: {"Level","System"}
Data Types: cell
Exclude requirements with specific project label, specified as a cell array where the first entry is the project label category and the second entry is the project label name.
Example: {"Level","System"}
Data Types: cell
Find requirements where the path contains specific text, specified as a string.
                Consider using IncludePathRegex
                instead.
Example: "HighLevel"
Data Types: string
Exclude requirements where the path contains specific text, specified as a
                string or a character vector. Consider using ExcludePathRegex
                instead.
Example: "System"
Data Types: string
Find requirements where the path matches a regular expression pattern, specified
                as a character vector or string.
                  IncludePathRegex expects UNIX®-style path separators.
If you want to use a literal path, use IncludePath instead.
                You can specify either IncludePath or
                  IncludePathRegex but not both.
Example: "reqPrefix.*\.slx"
Data Types: char | string
Exclude requirements where the path matches a regular expression pattern,
                specified as a string or a character vector.
                  ExcludePathRegex expects UNIX-style path separators.
If you want to use a literal path, use ExcludePath instead.
                You can specify either ExcludePath or
                  ExcludePathRegex but not both.
Example: "reqPrefix.*\.slx"
Data Types: char | string
Properties
Type of artifact, specified as one or more of the values in this table. To specify multiple values, use an array.
| Category | Artifact Type | Description | 
|---|---|---|
| MATLAB® | "m_class" | MATLAB class | 
| "m_file" | MATLAB file | |
| "m_func" | MATLAB function | |
| "m_method" | MATLAB class method | |
| "m_property" | MATLAB class property | |
| Model Advisor | "ma_config_file" | Model Advisor configuration file | 
| "ma_justification_file" | Model Advisor justification file | |
| Model Finder | "mf_database" | Model Finder database file | 
| Process Advisor | "padv_dep_artifacts" | Related artifacts that current artifact depends on | 
| "padv_output_file" | Process Advisor output file | |
| Project | "project" | Current project file | 
| Requirements | "mwreq_file" | Requirement file (since R2024b) | 
| "mwreq_item" | Requirement (since R2024b) | |
| 
 | Requirement (for R2024a and earlier) | |
| "sl_req_file" | Requirement file (for R2024a and earlier) | |
| "sl_req_table" | Requirements Table | |
| Stateflow® | "sf_chart" | Stateflow chart | 
| "sf_graphical_fcn" | Stateflow graphical function | |
| "sf_group" | Stateflow group | |
| "sf_state" | Stateflow state | |
| "sf_state_transition_chart" | Stateflow state transition chart | |
| "sf_truth_table" | Stateflow truth table | |
| Simulink® | "sl_block_diagram" | Block diagram | 
| "sl_data_dictionary_file" | Data dictionary file | |
| "sl_embedded_matlab_fcn" | MATLAB function | |
| "sl_block_diagram" | Block diagram | |
| "sl_library_file" | Library file | |
| "sl_model_file" | Simulink model file | |
| "sl_protected_model_file" | Protected Simulink model file | |
| "sl_subsystem" | Subsystem | |
| "sl_subsystem_file" | Subsystem file | |
| System Composer™ | "zc_block_diagram" | System Composer architecture | 
| "zc_component" | System Composer architecture component | |
| "zc_file" | System Composer architecture file | |
| Tests | "harness_info_file" | Harness info file | 
| "sl_harness_block_diagram" | Harness block diagram | |
| "sl_harness_file" | Test harness file | |
| "sl_test_case" | Simulink Test™ case | |
| "sl_test_case_result" | Simulink Test case result | |
| "sl_test_file" | Simulink Test file | |
| "sl_test_iteration" | Simulink Test iteration | |
| "sl_test_iteration_result" | Simulink Test iteration result | |
| "sl_test_report_file" | Simulink Test result report | |
| "sl_test_result_file" | Simulink Test result file | |
| "sl_test_resultset" | Simulink Test result set | |
| "sl_test_seq" | Test Sequence | |
| "sl_test_suite" | Simulink Test suite | |
| "sl_test_suite_result" | Simulink Test suite result | 
Example: "mwreq_file"
Example: ["mwreq_file" "other_file"]
Find requirements with specific project label, specified as a cell array where the first entry is the project label category and the second entry is the project label name.
Example: {"Level","System"}
Data Types: cell
Exclude requirements with specific project label, specified as a cell array where the first entry is the project label category and the second entry is the project label name.
Example: {"Level","System"}
Data Types: cell
Find requirements where the path matches a regular expression pattern, specified as
            a string or character vector. IncludePathRegex
            expects UNIX-style path separators.
If you want to use a literal path, use IncludePath instead. You
            can specify either IncludePath or
              IncludePathRegex but not both.
Example: "HighLevel.*\.slreqx"
Data Types: char | string
Exclude requirements where the path matches a regular expression pattern, specified
            as a string or a character vector. ExcludePathRegex
            expects UNIX-style path separators.
If you want to use a literal path, use ExcludePath instead. You
            can specify either ExcludePath or
              ExcludePathRegex but not both.
Example: "HighLevel.*\.slreqx"
Data Types: char | string
Filter out sub-file artifacts from query results, specified as a numeric or logical
              1 (true) or 0
              (false).
A sub-file is a part of a larger file. For example, a subsystem is a sub-file of a model file.
Example: false
Data Types: logical
Include only requirements files that have been added to current open project or
            referenced projects, specified as a numeric or logical 1
              (true) or 0 (false).
For more information about how to add or remove files from a project, see Manage Project Files.
Note
If you specify InProject as true, you
                cannot use the query as an input query.
Example: true
Attributes:
| Dependent |  | 
Data Types: logical
Include only requirements that have been added to the current open project,
            specified as a numeric or logical 1 (true) or
              0 (false).
Note
If you specify InCurrentProject as true,
                you cannot use the query as an input query.
Example: true
Data Types: logical
Query title, specified as a string or a character vector.
Example: "Find my requirements"
Data Types: string
Default artifact type returned by the query, specified as one or more of the values in this table. To specify multiple values, use an array.
| Category | Artifact Type | Description | 
|---|---|---|
| MATLAB | "m_class" | MATLAB class | 
| "m_file" | MATLAB file | |
| "m_func" | MATLAB function | |
| "m_method" | MATLAB class method | |
| "m_property" | MATLAB class property | |
| Model Advisor | "ma_config_file" | Model Advisor configuration file | 
| "ma_justification_file" | Model Advisor justification file | |
| Model Finder | "mf_database" | Model Finder database file | 
| Process Advisor | "padv_dep_artifacts" | Related artifacts that current artifact depends on | 
| "padv_output_file" | Process Advisor output file | |
| Project | "project" | Current project file | 
| Requirements | "mwreq_file" | Requirement file (since R2024b) | 
| "mwreq_item" | Requirement (since R2024b) | |
| 
 | Requirement (for R2024a and earlier) | |
| "sl_req_file" | Requirement file (for R2024a and earlier) | |
| "sl_req_table" | Requirements Table | |
| Stateflow | "sf_chart" | Stateflow chart | 
| "sf_graphical_fcn" | Stateflow graphical function | |
| "sf_group" | Stateflow group | |
| "sf_state" | Stateflow state | |
| "sf_state_transition_chart" | Stateflow state transition chart | |
| "sf_truth_table" | Stateflow truth table | |
| Simulink | "sl_block_diagram" | Block diagram | 
| "sl_data_dictionary_file" | Data dictionary file | |
| "sl_embedded_matlab_fcn" | MATLAB function | |
| "sl_block_diagram" | Block diagram | |
| "sl_library_file" | Library file | |
| "sl_model_file" | Simulink model file | |
| "sl_protected_model_file" | Protected Simulink model file | |
| "sl_subsystem" | Subsystem | |
| "sl_subsystem_file" | Subsystem file | |
| System Composer | "zc_block_diagram" | System Composer architecture | 
| "zc_component" | System Composer architecture component | |
| "zc_file" | System Composer architecture file | |
| Tests | "harness_info_file" | Harness info file | 
| "sl_harness_block_diagram" | Harness block diagram | |
| "sl_harness_file" | Test harness file | |
| "sl_test_case" | Simulink Test case | |
| "sl_test_case_result" | Simulink Test case result | |
| "sl_test_file" | Simulink Test file | |
| "sl_test_iteration" | Simulink Test iteration | |
| "sl_test_iteration_result" | Simulink Test iteration result | |
| "sl_test_report_file" | Simulink Test result report | |
| "sl_test_result_file" | Simulink Test result file | |
| "sl_test_resultset" | Simulink Test result set | |
| "sl_test_seq" | Test Sequence | |
| "sl_test_suite" | Simulink Test suite | |
| "sl_test_suite_result" | Simulink Test suite result | 
Example: "mwreq_file"
Example: ["mwreq_file" "other_file"]
Initial query that runs before iteration query, specified as either a
              padv.Query object or the Name of a
              padv.Query object. When you specify an iteration query for a task,
            the parent query is the initial query that the build system runs before running the
            specified iteration query.
For information on how to improve Process Advisor load times by sharing query instances across your process model, see Best Practices for Process Model Authoring.
Example: sharedQuery
Example: "FindMyInitialArtifacts"
Show file extensions in the Alias property of returned
            requirements, specified as a numeric or logical 1
              (true) or 0 (false). The
              Alias property controls the display name for the artifact in the
              Tasks column in Process Advisor.
By default, queries strip file extensions from the Alias
            property of each task iteration artifact. To show file extensions for
            all artifacts in the
              Tasks column, select the project setting Show file
              extensions. To keep file extensions in the results for a specific query,
            specify the query property ShowFileExtension as
              true.
Example: true
Data Types: logical
Setting for automatically sorting requirements by address, specified as a numeric or
            logical 1 (true) or 0
              (false). When a query returns artifacts, the artifacts should be in
            a consistent order. By default, the build system sorts artifacts by the artifact
            address.
Alternatively, you can sort artifacts in a different order by overriding the
            internal sortArtifacts method in a subclass that defines a custom sort
            behavior. For an example, see Sort Artifacts in Specific Order.
The build system automatically calls the sortArtifacts method when
            using the process model. The sortArtifacts method expects two input
            arguments: a padv.Query object and a list of
              padv.Artifact objects returned by the run method.
            The sortArtifacts method should return a list of sorted
              padv.Artifact objects.
Example: SortArtifacts = false
Data Types: logical
Handle to the function that a function-based query
            runs, specified as
            a function_handle.
If you define your query functionality inside a function and you or the build system
            call run on the query, the query runs the function specified by the
              function_handle.
The built-in queries are defined inside classes and do not use the
              FunctionHandle.
Example: FunctionHandle = @FunctionForQuery
Data Types: function_handle
Methods
This class overrides the following inherited methods.
| run | Run query to find the artifacts that meet the criteria specified by the query. The query returns a  Note You do not need to manually invoke this method inside your process
                                model. The build system automatically invokes the
                                     
 The  function artifacts = run(obj,~) ... end | 
Examples
You can use the FindRequirements query in your task
          definition to find requirements files that your tasks can iterate over
            (IterationQuery) or use as inputs (InputQueries).
          For example, suppose that you want to add a custom task, MyCustomTask,
          that runs for each requirement in the project.
Open a project. For this example, you can open the Process Advisor example project.
processAdvisorExampleStart
In the process model, you can add a new custom task and have the task iterate over
            each requirement in the project by specifying the task
              IterationQuery as
              padv.builtin.query.FindRequirements.
taskObj = addTask(pm, "MyCustomTask",... IterationQuery = padv.builtin.query.FindRequirements,... InputQueries = padv.builtin.query.GetIterationArtifact);
IterationQuery
            as inputs to the task by specifying InputQueries as
              padv.builtin.query.GetIterationArtifact.For the Process Advisor example project, when you save the process model
            and refresh Process Advisor, the custom task
              MyCustomTask has task iterations for the requirement sets
              HighLevelReqs and SystemReqs.
Capabilities and Limitations
This table identifies functionality that is supported by the query.
| Functionality | Supported? | 
|---|---|
| Input query for task | Only when the query properties  | 
| Iteration query for task | Yes. | 
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Seleccione un país/idioma
Seleccione un país/idioma para obtener contenido traducido, si está disponible, y ver eventos y ofertas de productos y servicios locales. Según su ubicación geográfica, recomendamos que seleccione: .
También puede seleccionar uno de estos países/idiomas:
Cómo obtener el mejor rendimiento
Seleccione China (en idioma chino o inglés) para obtener el mejor rendimiento. Los sitios web de otros países no están optimizados para ser accedidos desde su ubicación geográfica.
América
- América Latina (Español)
- Canada (English)
- United States (English)
Europa
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)