I am currently working with the nopCommerce source code and trying my best to avoid editing the source at all, but instead using partial classes and plugins that are separat
Not entirely clear what you want, but maybe you can use a partial
method?
So the "party" responsible for the first "part" of the class can give the signature alone in:
"Orignal Source Code":
namespace Nop.Services.Orders {
public partial class OrderProcessingService : IOrderProcessingService {
partial void PlaceOrder(ProcessPaymentRequest processPaymentRequest,
ref PlaceOrderResult result);
Then the "party" responsible for the other "part" may or may not choose to supply an implementation of the method. If they supply one, that will look like:
"My partial class":
namespace Nop.Services.Orders {
public partial class OrderProcessingService : IOrderProcessingService {
partial void PlaceOrder(ProcessPaymentRequest processPaymentRequest,
ref PlaceOrderResult result) {
// actual code goes here
}
Things to note:
partial
method cannot be public
; it must be private and it is illegal to even specify the private
keyword. And a private method is not allowed to be virtual
.partial
method must return void
and cannot have parameters marked with out
, so we put the result
as a ref
parameter;
instead of a body{ ... }
Now in "Orignal Source Code" the method can be called like this:
// ...
PlaceOrderResult result = null;
PlaceOrder(someRequest, ref result);
// check if 'result' was changed to something non-null, and if so use 'result'
Be aware:
PlaceOrder
, the method (including all calls to it!) is (mentally) removed from all parts of the class before compilation. This also removes the evaluations of the arguments in the calls, which could be important if that evaluation had side effects (e.g. PlaceOrder(FindRequestAndCauseOtherEffects(), ref result);
).void
and have no out
parameters can be understood as a consequence thereof.End of today's lesson on partial void
methods.