Basic Type Search for Apex language
This is for use in Salesforce Apex code debugging/investigation/refactoring.
Do you want to find lines in your codebase (stored in your local env) wherein
an Opportunity
is Inserted? Updated? Deleted? If yes, then this tool is for you!
In general, given an SObject and a database action, this tool finds lines in Apex classes where there is a database action for a variable of type "that SObject".
By default, this ignores test classes.
This is written to be easy to modify for other purposes, and to be easily understood for porting to other languages.
Instruction for Python prototype:
- Download the whole Apex codebase of your project.
- Download the source code (zip or tarball, whatever's more familiar to you) in Releases.
- Extract bastypsea.py.
- Edit the Python script here:
my_obj = 'Contact' # the SObject
my_act = 'Insert' # the database action
my_path = r'./testdata/*.cls' # the directory path to Apex classes
Note: the use of wildcard *
to get all files is required.
You may disable ignoring test classes (thus also search to those)
by appending False
as argument to the bastypsea()
call:
outputs = bastypsea(file_name, my_obj, my_act, False)
- Just run Python in terminal:
python bastypsea.py
(Windows) orpython3 bastypsea.py
(Linux).
Instruction for JAR file:
- Download the whole Apex codebase of your project.
- Download the JAR file in Releases.
- Just run
java -jar bastypsea.jar
to display usage.
Here's a sample output:
$ java -jar bastypsea.jar Contact Insert ./testdata/
------
ini N: ./testdata/SimpleDML.cls:10
act N: ./testdata/SimpleDML.cls:16
act L: daTabAse.INseRTiMmEDiatE(y, false);
------
ini N: ./testdata/SimpleDML.cls:9
act N: ./testdata/SimpleDML.cls:16
act L: insErT x;
------
Where ini N
is the line number where initialization of variable occurs, act N
is the line number where the database action occurs, and act L
is the actual line of act N
.
The outputs of JAR file are designed so that paths are clickable in VS Code terminals. This leads us to...
Adding JAR file to a VS Code terminal environment variable:
Copy the bastypsea.jar to a directory path, then follow these steps.
Limitations:
- Cannot detect multiline variable declarations and database actions (e.g. when data type and variable name are in different lines). Hence, misses are possible for this. But why would you even do that?
- Cannot detect the SObject as the type of Map keys. Hence, misses are possible for this. Again, why oh why?
- There are no further checks for variable declarations of more complex data types like Inner Classes, Maps, etc. Hence, false positives are possible for this.
- Scope of variable declarations and actions are not considered (e.g. the action is inside which method). Hence, false positives are possible for this.
Distributed under the MIT software license. See the accompanying file LICENSE or https://opensource.org/license/mit/.