Подтвердить что ты не робот

Написание декоратора для функций R

Недавно коллега смотрел на графики вызовов и хотел посмотреть, что называется. Мы отсортировали это с foodweb от mvbutils, но мне было интересно, как лучше всего создать декоратор (в python говорить) в R. Итак, я сделал это:

instrument=function(z){
  force(z) 
  n=deparse(substitute(z)) # get the name
  f=function(...){
   cat("calling ", n,"\n")
   x=z(...)
   cat("done\n")
   return(x)
   }
  return(f)
}

Это позволяет мне:

> foo=function(x,y){x+y}
> foo(1,2)
[1] 3

и теперь я могу сделать сам журнал функций, обернув его:

> foo=instrument(foo)
> foo(1,2)
calling  foo
done
[1] 3

Это было сделано раньше, в пакете, и я пропустил какие-либо ошибки, которые нарушат мой способ сделать это?

4b9b3361

Ответ 1

Функция trace в R делает это. См. ?trace.