Is it okay to pass self to an external function
Asked Answered
P

1

76

I have a class, A, which is inherited by a bunch of other classes. Some of these have a few functions which are similar and it would be nice to have those functions defined somewhere else and called by the classes that need them. But those functions call functions defined in the super class.

class A():
    def imp_func(*args):
        # called by the child class functions

Class B(A):
    def common_func(self):
        # some stuff
        self.imp_func(*args)

So I have created my helper functions which take the self object as an argument and I can call the imp_func from inside the helper functions.

def helper_func(obj, some_args):
    # some common stuff
    obj.imp_func(*args)

class B(A):
    def common_func(self):
        # unique stuff
        helper_func(self, some_args)

This solves the problem.

But should I be doing this? Is this Pythonic?

Priapus answered 18/4, 2013 at 13:41 Comment(7)
There is absolutely no problem with that. self is just a reference to the instance, it is not private nor is it dangerous to pass it to other functions.Willow
Why do you need to do this? B inherits imp_func from A, so you can call self.imp_func(*args) in B.common_func without a problem.Tautonym
@FlorianBrucker There is not just one function, but a couple which are called from the parent class, and some are called a couple of times, in multiple functions in multiple classes. This leads to very bloated classes and functions. It is also time consuming to write those functions. Using helper classes will save time, effort and make the code clean and more maintainable.Priapus
I don't see how example 2 improves on example 1. In example 1, you have B.common_func calls A.imp_func. In example 2, you have B.common_func calls helper_func calls A.imp.func. You have more code to write in the second scenario.Bryna
@Robᵩ That is a simplistic example to give a gist of what I'm doing, added in case my explanation was not clearPriapus
@elssar: In that case, please update your question with an example that better illustrates your problem. Right now your second example you have both more and harder to understand code, just as Robᵩ said.Tautonym
You haven't given any detail so we can't see whether moving common stuff to helper_func while keeping only unique stuff inside B. common_func() is any better or worse.Rebel
E
113

There is no problem with that whatsoever - self is an object like any other and may be used in any context where object of its type/behavior would be welcome.

In Python, as exemplified by the standard library, instances of self get passed to functions (and also to methods, and even operators) all the time.

Elum answered 18/4, 2013 at 13:48 Comment(2)
+50 for multiple examples in very cool hidden hyper linking.Decencies
hyperlinking almost feels like reading a wikipedia page.Serendipity

© 2022 - 2024 — McMap. All rights reserved.