[development] Splitting hook_menu into hook_menu and hook_router

Karoly Negyesi karoly at negyesi.net
Tue Jan 16 22:04:08 UTC 2007


Hi,

We discussed renaming hook_menu and hook_router was a popular choice but  
as Gerhard says "I don't like to rename funtions just for the sake of  
renaming them" so it remained hook_menu .

However, looking at my brain dump at http://drupal4hu.com/node/28 tells me  
that further down the road a split is needed.

hook_router has these things:

-- path as primary key. We use this as an array key, so an alter hook can  
easily be provided.
-- access callback and arguments
-- page callback and arguments
-- map callback and arguments

hook_menu has these:

-- path. This is not unique. It's often requested that one path could have  
more than one visible link.
-- parent. If you omit this, it can be autogenerated but for setting it to  
some arbitrary value, let's say MENU_ROOT can be used to indicate a new  
menu. With this (or via other means if someone has a better idea) we can  
put links into any menu.
-- title.
-- weight.
-- expanded.

With path being unique in one and not unique in the other, I fail to see  
how the two could be unified. And I fail to see the point as well. We  
could lose path being an array key and make it a property again in  
hook_router as it was in old hook_menu but then what shall happen if  
someone defines two router items to the same path? This is a mess. The  
above is nice and clean.

Regards

NK


More information about the development mailing list