propfind-pool-notes   [plain text]


This is a rough manual trace of what occurs on a PROPFIND request.

Location of file: M == mod_dav, S == mod_dav_svn

dav_method_propfind [ M:mod_dav.c ]
dav_svn_walk [ S:repos.c ]
dav_svn_do_walk [ S:repos.c ]
  ** may recursively call dav_svn_do_walk for children as depth dictates
  - dav_propfind_walker [ M:mod_dav.c ]
    - dav_open_propdb [ M:props.c ]
      ** sets propdb->p to r->pool
      - dav_svn_db_open [ S:deadprops.c ]
        ** creates db->p
    - dav_get_props [ M:props.c ]
      ** Uses propdb->p.
      ** Appends response to propdb->p
      - may call dav_find_liveprop [ M:props.c ]
        - dav_svn_find_liveprop [ S:liveprops.c ]
          - dav_do_find_liveprop [ M:liveprop.c ]
            ** static storage 
      - dav_insert_liveprop [ M:props.c ]
        - dav_svn_insert_prop [ S:liveprops.c ]
          ** uses resource->info->pool to svn_fs_*
          ** places result in resource->pool
      - dav_svn_db_output_value [ S:deadprops.c ]
        ** uses db->resource->pool
        - get_value [ S:deadprops.c ]
          ** Uses db->p
      - dav_svn_db_define_namespaces [ S:deadprops.c ]
        - calls dav_xmlsns_add with constant storage space.
        - Must live as long as xi->prefix_uri/xi->uri_prefix
          ** Uses propdb->p
    - dav_get_allprops [ M:props.c ]
      ** Uses propdb->p
      - dav_run_insert_all_liveprops [ M:hook ]
        - dav_svn_insert_all_liveprops [ S:liveprops.c ]
          ** Uses resource->info->pool
          - dav_svn_insert_prop [ see above ]
            ** resource->info->pool tweaked to be a temp subpool
    - dav_close_propdb [ M:props.c ]
      - dav_svn_db_close [ S:deadprops.c ]
         ** destroys db->p
    - dav_add_response [ M:mod_dav.c ]
      ** uses wres->pool to store response