Why not just extend the View Class itself and add in all the functionality to that class, then you don't clutter up the global namespace and you keep your view files tidy as well then.
create /app/views/app.php <?php class AppView extends View{ function getLink($x){ return $this->Html->link($x,"#".$x); } ... add any other methods } ?> Then in app_controller.php add: var $view = 'app'; // or // public $view = 'app'; Your view.ctp file then calls echo $this->getLink($x); Just my 2 cents on following OOP convention. Regards Simon On Dec 17, 10:41 am, ojonam <manojo10...@gmail.com> wrote: > Hello all, > > I am defining functions in views which use functionality from helpers. > The code in my view is as follows: > > <?php > function getLink($x){ > return $this->Html->link($x,"#".$x); > > } > > echo getLink($x); > ?> > > when I run the view, I get the following message: > Fatal error: Using $this when not in object context in view.ctp > > However, doing simply the following works: > > <?php > echo $this->Html->link($x,"#".$x); > ?> > > What is the scoping problem here? > > Thanks, > ojonam Check out the new CakePHP Questions site http://cakeqs.org and help others with their CakePHP related questions. You received this message because you are subscribed to the Google Groups "CakePHP" group. To post to this group, send email to cake-php@googlegroups.com To unsubscribe from this group, send email to cake-php+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/cake-php?hl=en