annotate R/rdyncall/demo/factorial.R @ 0:0cfcc391201f

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:26:28 +0100
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
1 f <- function(i,fun)
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
2 {
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
3 if (i > 1) i * .dyncall(fun,"ip)i",i-1,fun) else i
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
4 }
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
5 e <- new.env()
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 cb <- new.callback("ip)i", f,e)
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
7 e <- NULL
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
8 f <- NULL
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
9 gc()
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
10 r <- .dyncall(cb,"ip)i",12,cb)
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
11 r == factorial(12)
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
12 cb <- NULL
0cfcc391201f initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
13 gc()