A dozen of functions like concat, foldr, mapM, have been generalized through BBP.
Then, why do we leave `map` just for lists? Obviously `map` can be generalized, so
map :: Functor f => (a -> b) -> f a -> f b
map = fmap
The current definition of `map` looks too special to be a special case of mapM (map f = runIdentity . mapM (Identity . f)).