@ -217,14 +217,11 @@ module WorstCaseCost = struct
 
			
		
	
		
		
			
				
					
					end end  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					module  Check  =  struct module  Check  =  struct  
			
		
	
		
		
			
				
					
					  let  report_threshold  proc_desc  summary  ~ name  ~ location  ~ cost  CostIssues . { expensive_issue } 
  let  report_threshold  pname  summary  ~ name  ~ location  ~ cost  CostIssues . { expensive_issue }  ~ threshold 
 
			
				
				
			
		
	
		
		
			
				
					
					      ~ threshold  ~ is_on_ui_thread  = 
      ~ is_on_ui_thread  = 
 
			
				
				
			
		
	
		
		
			
				
					
					    let  pname  =  Procdesc . get_proc_name  proc_desc  in 
 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					    let  report_issue_type  = 
    let  report_issue_type  = 
 
			
		
	
		
		
			
				
					
					      L . ( debug  Analysis  Medium )  " @ \n \n ++++++ Checking error type for %a **** @ \n "  Procname . pp  pname  ; 
      L . ( debug  Analysis  Medium )  " @ \n \n ++++++ Checking error type for %a **** @ \n "  Procname . pp  pname  ; 
 
			
		
	
		
		
			
				
					
					      let  is_on_cold_start  = 
      let  is_on_cold_start  =  ExternalPerfData . in_profiler_data_map  pname  in 
 
			
				
				
			
		
	
		
		
			
				
					
					        ExternalPerfData . in_profiler_data_map  ( Procdesc . get_proc_name  proc_desc ) 
 
			
		
	
		
		
			
				
					
					      in 
 
			
		
	
		
		
	
		
		
			
				
					
					      expensive_issue  ~ is_on_cold_start  ~ is_on_ui_thread 
      expensive_issue  ~ is_on_cold_start  ~ is_on_ui_thread 
 
			
		
	
		
		
			
				
					
					    in 
    in 
 
			
		
	
		
		
			
				
					
					    let  bigO_str  = 
    let  bigO_str  = 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -250,14 +247,9 @@ module Check = struct
 
			
		
	
		
		
			
				
					
					      ~ extras : ( compute_errlog_extras  cost )  report_issue_type  message 
      ~ extras : ( compute_errlog_extras  cost )  report_issue_type  message 
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  let  report_top_and_bottom  p roc_des c summary  ~ name  ~ cost  CostIssues . { zero_issue ;  infinite_issue }  = 
  let  report_top_and_bottom  p name lo  c summary  ~ name  ~ cost  CostIssues . { zero_issue ;  infinite_issue }  = 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    let  report  issue  suffix  = 
    let  report  issue  suffix  = 
 
			
		
	
		
		
			
				
					
					      let  message  = 
      let  message  =  F . asprintf  " %s of the function %a %s "  name  Procname . pp  pname  suffix  in 
 
			
				
				
			
		
	
		
		
			
				
					
					        F . asprintf  " %s of the function %a %s "  name  Procname . pp 
 
			
		
	
		
		
			
				
					
					          ( Procdesc . get_proc_name  proc_desc ) 
 
			
		
	
		
		
			
				
					
					          suffix 
 
			
		
	
		
		
			
				
					
					      in 
 
			
		
	
		
		
			
				
					
					      let  loc  =  Procdesc . get_start_node  proc_desc  | >  Procdesc . Node . get_loc  in 
 
			
		
	
		
		
	
		
		
			
				
					
					      Reporting . log_error  ~ loc 
      Reporting . log_error  ~ loc 
 
			
		
	
		
		
			
				
					
					        ~ ltr : ( BasicCost . polynomial_traces  cost ) 
        ~ ltr : ( BasicCost . polynomial_traces  cost ) 
 
			
		
	
		
		
			
				
					
					        ~ extras : ( compute_errlog_extras  cost )  summary  issue  message 
        ~ extras : ( compute_errlog_extras  cost )  summary  issue  message 
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -268,17 +260,19 @@ module Check = struct
 
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  let  check_and_report  ~ is_on_ui_thread  WorstCaseCost . { costs ;  reports }  proc_desc  summary  = 
  let  check_and_report  ~ is_on_ui_thread  WorstCaseCost . { costs ;  reports }  proc_desc  summary  = 
 
			
		
	
		
		
			
				
					
					    let  pname  =  Procdesc . get_proc_name  proc_desc  in 
    let  pname  =  Procdesc . get_proc_name  proc_desc  in 
 
			
		
	
		
		
			
				
					
					    let  proc_loc  =  Procdesc . get_start_node  proc_desc  | >  Procdesc . Node . get_loc  in 
 
			
		
	
		
		
			
				
					
					    if  not  ( Procname . is_java_access_method  pname )  then  ( 
    if  not  ( Procname . is_java_access_method  pname )  then  ( 
 
			
		
	
		
		
			
				
					
					      CostIssues . CostKindMap . iter2  CostIssues . enabled_cost_map  reports 
      CostIssues . CostKindMap . iter2  CostIssues . enabled_cost_map  reports 
 
			
		
	
		
		
			
				
					
					        ~ f : ( fun  _ kind  ( CostIssues . { name ;  threshold }  as  kind_spec )  ->  function 
        ~ f : ( fun  _ kind  ( CostIssues . { name ;  threshold }  as  kind_spec )  ->  function 
 
			
		
	
		
		
			
				
					
					        |  ThresholdReports . Threshold  _  -> 
        |  ThresholdReports . Threshold  _  -> 
 
			
		
	
		
		
			
				
					
					            () 
            () 
 
			
		
	
		
		
			
				
					
					        |  ThresholdReports . ReportOn  { location ;  cost }  -> 
        |  ThresholdReports . ReportOn  { location ;  cost }  -> 
 
			
		
	
		
		
			
				
					
					            report_threshold  p roc_desc  summary  ~ name  ~ location  ~ cost  kind_spec 
            report_threshold  p name  summary  ~ name  ~ location  ~ cost  kind_spec 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					              ~ threshold : ( Option . value_exn  threshold )  ~ is_on_ui_thread  )  ; 
              ~ threshold : ( Option . value_exn  threshold )  ~ is_on_ui_thread  )  ; 
 
			
		
	
		
		
			
				
					
					      CostIssues . CostKindMap . iter2  CostIssues . enabled_cost_map  costs 
      CostIssues . CostKindMap . iter2  CostIssues . enabled_cost_map  costs 
 
			
		
	
		
		
			
				
					
					        ~ f : ( fun  _ kind  ( CostIssues . { name ;  top_and_bottom }  as  issue_spec )  cost  -> 
        ~ f : ( fun  _ kind  ( CostIssues . { name ;  top_and_bottom }  as  issue_spec )  cost  -> 
 
			
		
	
		
		
			
				
					
					          if  top_and_bottom  then  report_top_and_bottom  proc_desc  summary  ~ name  ~ cost  issue_spec  )  ) 
          if  top_and_bottom  then  report_top_and_bottom  pname  proc_loc  summary  ~ name  ~ cost  issue_spec 
 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					      )  ) 
 
			
		
	
		
		
			
				
					
					end end  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					type  bound_map  =  BasicCost . t  Node . IdMap . t type  bound_map  =  BasicCost . t  Node . IdMap . t