VBE_Extras can now help you to add, remove and re-order parameters for a Sub, Function or Property (I'm just gonna say "procedure" from now on ... all of the commands described in this post work on Subs, Functions and Properties). When it does this, it doesn't only update the signature of the procedure itself but it also updates all calls of (i.e. references of) the procedure at the same time i.e. arguments are added / removed / re-ordered as required.
Additionally, if you want to promote an existing variable within a procedure to be a parameter then VBE_Extras can help with that ... and if you want to demote an existing parameter of a procedure to be a variable then it can help with that also.
Add parameter
Â
Add a parameter to a procedure and simultaneously add an argument for all references of that procedure.
Â
For the arguments added for the references of the procedure – normally positional arguments will be used, named arguments will be used if a reference already uses one or more named arguments AND if the new argument comes after that named argument
In the 'Add Parameter' dialog, only very limited validation is carried out for the 'Default value' for Optional parameters and for the 'Value to inject at call site(s)' ... and the validation that is carried out for both of these can always be overridden
If the host application is Excel:
If the procedure is 'assigned as a macro' to a Shape then adding a 'required' parameter will break the link from the Shape ... a warning will be shown if this is the case
If the procedure is the target of a keyboard shortcut then adding either a 'required' or an Optional parameter will break the keyboard shortcut ... a warning will be shown if this is the case
data:image/s3,"s3://crabby-images/365e6/365e602ebe6890cc8606df31471bd88204ea4f8e" alt="The 'add parameter' dialog"
Â
Promote local variable to parameter
Â
Promote a local variable within a procedure to be a parameter of that same procedure and simultaneously add an argument for all references of that procedure or Property.
Â
Only variables can be promoted: not Statics, Consts
If the variable is an array, it must be 'dynamic' not 'static' (i.e. it must not be defined with explicit bounds)
Â
data:image/s3,"s3://crabby-images/7ceea/7ceea32ff5198347a43ba04c2a3c7917fba8d9f3" alt="The 'promote parameter' dialog"
Remove parameter
Â
Remove a parameter from a procedure and simultaneously remove the matching argument from all references of that procedure.
data:image/s3,"s3://crabby-images/c2b64/c2b64b325e4477a5ef966244a25a1ea2f45ba339" alt="The 'remove parameter' dialog"
Demote parameter to local variable
Â
Remove a parameter from a procedure and make it a local variable within that same procedure and simultaneously remove the matching argument from all references of that procedure.
Â
Demoting always creates a Dim statement (never a Static or Const)
data:image/s3,"s3://crabby-images/5e22f/5e22fcb34a6e0f4d0f5e7d261296b7af5a91448d" alt="The 'demote parameter' dialog"
Reorder parameters
Â
Reorder one or more parameters of a procedure and simultaneously reorder the matching arguments of all references of that procedure.
Â
A ParamArray parameter cannot be reordered (it must be the last parameter)
The value/reference parameter of a Property Let/Set cannot be reordered (it must be the last parameter)
Parameters can/must be updated from being 'required' to being 'Optional', and vice-versa, depending on the parameter order
data:image/s3,"s3://crabby-images/b40bf/b40bfea9e77aa2450165b7f877700b74110287da" alt="The 'reorder parameters' dialog"
Each of these commands ...
Correctly handles matching Properties (i.e. any matching Get / Let / Set will also be updated)
Correctly handles both positional and named arguments
Correctly handles required, Optional and ParamArray parameters including (for Optional and ParamArray) omitted arguments and arguments that are provided as an 'empty comma'
Will preserve any existing Attributes
To learn more on each of these commands, check out the 'Update parameters' section of the VBE_Extras user guide.
And to give it a try (VBE_Extras currently comes with a 60 day free trial), see the Download VBE_Extras page.