Uploaded image for project: 'MyFaces Core'
  1. MyFaces Core
  2. MYFACES-2737

Cache FacesContext on UIComponentBase instances

    XMLWordPrintableJSON

Details

    • Improvement
    • Status: Closed
    • Major
    • Resolution: Fixed
    • 2.0.0
    • 1.1.8, 1.2.9, 2.0.1
    • JSR-314
    • None

    Description

      Right now, the implementation of UIComponentBase.getFacesContext() is this:

      @Override
      protected FacesContext getFacesContext()

      { return FacesContext.getCurrentInstance(); }

      I think it is possible to create a variable like this:

      private transient FacesContext _facesContext;

      and change the current implementation to:

      void setCachedFacesContext(FacesContext facesContext)

      { _facesContext = facesContext; }

      @Override
      protected FacesContext getFacesContext()
      {
      if (_facesContext == null)

      { return FacesContext.getCurrentInstance(); }

      else

      { return _facesContext; }

      }

      Then we do this on methods like processXXX, encodeXXX (not on encodeAll), visitTree and invokeOnComponent:

      @Override
      public void processDecodes(FacesContext context)
      {
      try

      { setCachedFacesContext(context); /*...... do what is required ........*/ }

      finally

      { popComponentFromEL(context); setCachedFacesContext(null); }

      In few words, set and release temporally the variable while those operations are executed. This change will reduce the amount of calls to FacesContext.getCurrentInstance() without side effects, because we are caching only on safe places and enclosing everything in a try finally block.

      If no objections I'll commit this code soon.

      Attachments

        1. MYFACES-2737-jsf20.patch
          32 kB
          Leonardo Uribe
        2. MYFACES-2737-jsf12.patch
          22 kB
          Leonardo Uribe
        3. MYFACES-2737-jsf11.patch
          12 kB
          Leonardo Uribe
        4. MYFACES-2737-1.patch
          31 kB
          Leonardo Uribe

        Activity

          People

            lu4242 Leonardo Uribe
            lu4242 Leonardo Uribe
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: