padv.builtin.query.FindProjectFile Class
Namespace: padv.builtin.query
Superclasses: padv.Query
Query for finding project file
Description
The padv.builtin.query.FindProjectFile class provides a query that can
      return the current project file.
You can use this query in your process model to have your tasks iterate over the project one time or use the project file as an input.
The padv.builtin.query.FindProjectFile class is a handle class.
Creation
Description
query = padv.builtin.query.FindProjectFile()
Properties
Query title, specified as a string or a character vector.
Example: "Find my current project file"
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: "project"
Example: ["project" "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: "FindMyProjectFile"
Unique identifier for query, specified as a string.
Example: "FindMyProjectFile"
Data Types: string
Show file extensions in the Alias property of returned
            artifacts, 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 artifacts 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 more information, 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 FindProjectFile query in your process
          model to find the project file for your tasks to iterate over
            (IterationQuery) and use as an input
            (addInputQueries). For example, to have a custom task run one time
          for your project and to use the project file as an input to the task, you can specify the
            FindProjectFile as the iteration query and as an input query for the
          task.
Open a project. For this example, open the Process Advisor example project.
processAdvisorExampleStart
Suppose that you have a custom task, MyCustomTask, that you add
            to your process model. You can use the built-in query
              padv.builtin.query.FindProjectFile to find the project file. Edit
            the process model to include this code:
taskObj = addTask(pm, "MyCustomTask",... IterationQuery = padv.builtin.query.FindProjectFile(),... InputQueries = padv.builtin.query.GetIterationArtifact));
InputQueries as
              padv.builtin.query.GetIterationArtifact, that allows the task to
            use the artifacts returned by IterationQuery as inputs to the
            task.In Process Advisor, view the updated Tasks by
            clicking Refresh Tasks and switching to the
              Project view. For the task MyCustomTask, there
            is one task iteration for the project.
Although you typically use a query inside your process model, you can
          run an instance of the FindProjectFile query outside of your process model
          to confirm which artifacts the query returns.
Open a project. For this example, you can open the Process Advisor example project.
processAdvisorExampleStart
Create an instance of the FindProjectFile
            query.
q = padv.builtin.query.FindProjectFile();
Run the query and inspect the array of artifacts that the query returns.
q.run
ans = 
  Artifact with properties:
               Type: "project"
             Parent: [0×0 padv.Artifact]
    ArtifactAddress: [1×1 padv.util.ArtifactAddress]
              Alias: [0×0 string]ArtifactAddress property contains additional information such as
            the OwningProject for projects in a project reference
            hierarchy.Capabilities and Limitations
This table identifies functionality that is supported by the query.
| Functionality | Supported? | 
|---|---|
| Input query for task | Yes. See  | 
| Iteration query for task | Yes. See IterationQuery. | 
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.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- 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)