]> git.donarmstrong.com Git - cran2deb.git/blob - trunk/R/build.R
add blacklist. build packages already in debian.
[cran2deb.git] / trunk / R / build.R
1
2 build <- function(name,extra_deps,force=F) {
3     # can't, and hence don't need to, build base packages
4     if (name %in% base_pkgs) {
5         return(T)
6     }
7     log_clear()
8     dir <- setup()
9
10     # obtain the Debian version-to-be
11     version <- try(new_build_version(name))
12     if (inherits(version,'try-error')) {
13         error('failed to build',name)
14         return(NULL)
15     }
16
17     result <- try((function() {
18         if (!force && !needs_build(name,version)) {
19             notice('skipping build of',name)
20             return(NULL)
21         }
22
23         if (name %in% db_blacklist_packages()) {
24             fail('package',name,'is blacklisted. consult database for reason.')
25         }
26
27         pkg <- prepare_new_debian(prepare_pkg(dir,name),extra_deps)
28         if (pkg$debversion != version) {
29             fail('expected Debian version',version,'not equal to actual version',pkg$debversion)
30         }
31
32         # delete notes of upload
33         file.remove(Sys.glob(file.path(pbuilder_results,'*.upload')))
34
35         notice('R dependencies:',paste(pkg$depends$r,collapse=', '))
36         build_debian(pkg)
37
38         # upload the package
39         ret = log_system('umask 002;dput','-c',shQuote(dput_config),'local'
40                     ,changesfile(pkg$srcname,pkg$debversion))
41         if (ret != 0) {
42             fail('upload failed!')
43         }
44
45         return(pkg$debversion)
46     })())
47     cleanup(dir)
48     if (is.null(result)) {
49         # nothing was done so escape asap.
50         return(result)
51     }
52
53     # otherwise record progress
54     failed = inherits(result,'try-error')
55     if (failed) {
56         error('failure of',name,'means these packages will fail:'
57                      ,paste(r_dependency_closure(name,forward_arcs=F),collapse=', '))
58     }
59     db_record_build(name, version, log_retrieve(), !failed)
60     return(!failed)
61 }
62
63 needs_build <- function(name,version) {
64     # see if the last build was successful
65     build <- db_latest_build(name)
66     if (!is.null(build) && build$success) {
67         # then something must have changed for us to attempt this
68         # build
69         if (build$r_version == version_upstream(version) &&
70             build$deb_epoch == version_epoch(version) &&
71             build$db_version == db_get_version()) {
72             return(F)
73         }
74     } else {
75         # always rebuild on failure or no record
76         notice('rebuilding',name,': no build record or previous build failed')
77         return(T)
78     }
79     # see if it has already been built
80     srcname <- pkgname_as_debian(name,binary=F)
81     debname <- pkgname_as_debian(name,binary=T)
82     if (file.exists(changesfile(srcname, version))) {
83         notice('already built',srcname,'version',version)
84         return(F)
85     }
86
87     if (build$r_version != version_upstream(version)) {
88         notice('rebuilding',name,': new upstream version',build$r_version,'(old) vs',version_upstream(version),'(new)')
89     }
90     if (build$deb_epoch != version_epoch(version)) {
91         notice('rebuilding',name,': new cran2deb epoch',build$deb_epoch,'(old) vs',version_epoch(version),'(new)')
92     }
93     if (build$db_version != db_get_version()) {
94         notice('rebuilding',name,': new db version',build$db_version,'(old) vs',db_get_version(),'(new)')
95     }
96     rm(debname,srcname)
97     return(T)
98 }
99
100 build_debian <- function(pkg) {
101     wd <- getwd()
102     setwd(pkg$path)
103     notice('building Debian package'
104                  ,pkg$debname
105                  ,paste('(',pkg$debversion,')',sep='')
106                  ,'...')
107
108     cmd = paste('pdebuild --configfile',shQuote(pbuilder_config))
109     if (version_revision(pkg$debversion) > 2) {
110         cmd = paste(cmd,'--debbuildopts','-sd')
111         notice('build should exclude original source')
112     }
113     ret = log_system(cmd)
114     setwd(wd)
115     if (ret != 0) {
116         fail('Failed to build package.')
117     }
118 }
119