Eli Zaretskii writes: >> This function returns nil if no custom theme specifies a value for VARIABLE." >> (let ((theme-value (get variable 'theme-value))) >> - (if theme-value >> - (cdr (car theme-value))))) >> + (if theme-value ; ((THEME VALUE)) >> + (list (cadar theme-value))))) > > This will look strange without some comment explaining why we do this. True. I can add that comment. > And I have a question is: isn't it better not to use setcar in > custom-push-theme instead? I thought of doing that, and use setf with alist-get to make the change instead. But I think we'll be better off if we avoid sharing the cons cell inadvertedly, since that is prone to have bugs like this one. Alternatively, we could create the list in custom-theme-recalc-variable, to accomplish the same thing without changing the return value of custom-variable-theme-value. In that case, I think it would be convenient to change the doc string of custom-variable-theme-value, to say it returns some cdr. To me, either the patch I posted (with an additional explanatory comment, of course) or the latter option sound better, but I won't argue too much if you think otherwise. Best regards, Mauro.