Рекурсия Python со списком возвращает None

def foo(a):
    a.append(1)
    if len(a) > 10:
        print a
        return a
    else:
        foo(a)

Почему эта рекурсивная функция возвращает None (см. стенограмму ниже)? Я не могу понять, что я делаю неправильно.

In [263]: x = []

In [264]: y = foo(x)
[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]

In [265]: print y
None

Ответ 1

Вы ничего не возвращаете в предложении else:

    else:
        return foo(a)