2 build <- function(name,extra_deps,force=F,do_cleanup=T) {
3 # can't, and hence don't need to, build base packages
4 if (name %in% base_pkgs) {
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 in new_build_version: ',name)
17 result <- try((function() {
18 if (!force && !needs_build(name,version)) {
19 notice('skipping build of',name)
23 if (name %in% db_blacklist_packages()) {
24 #fail('package',name,'is blacklisted. consult database for reason.')
25 notice('package',name,'is blacklisted. consult database for reason.')
29 pkg <- prepare_new_debian(prepare_pkg(dir,name),extra_deps)
30 if (pkg$debversion != version) {
31 fail('expected Debian version',version,'not equal to actual version',pkg$debversion)
34 # delete notes of upload
35 file.remove(Sys.glob(file.path(pbuilder_results,'*.upload')))
37 notice('R dependencies:',paste(pkg$depends$r,collapse=', '))
38 #if (debug) notice(paste("build_debian(",pkg,") invoked\n",sep=""))
40 #if (debug) notice(paste("build_debian(",pkg,") completed.\n",sep=""))
44 notice("Package upload")
45 ## ret = log_system('umask 002;dput','-c',shQuote(dput_config),'local' ,changesfile(pkg$srcname,pkg$debversion))
47 cmd = paste('umask 002; cd /var/www/cran2deb/rep && reprepro -b . include testing', changesfile(pkg$srcname,pkg$debversion),sep=" ")
48 #if (verbose) notice('Executing: ',cmd)
51 #fail('upload failed!')
52 notice("Upload failed, ignored.")
54 notice("Upload successful.")
56 ## # wait for mini-dinstall to get to work
57 ## upload_success = FALSE
58 ## for (i in seq(1,12)) {
59 ## if (file.exists(file.path(dinstall_archive,'testing',paste(pkg$srcname, '_', pkg$version, '.orig.tar.gz', sep='')))) {
60 ## upload_success = TRUE
63 ## warn(i,'/12: does not exist',file.path(dinstall_archive,'testing',paste(pkg$srcname, '_', pkg$version, '.orig.tar.gz', sep='')))
67 ## if (!upload_success) {
68 ## warn('upload took too long; continuing as normal (some builds may fail temporarily)')
70 return(pkg$debversion)
75 notice('output is in',dir,'. you must clean this up yourself.')
77 if (is.null(result)) {
78 # nothing was done so escape asap.
82 # otherwise record progress
83 failed = inherits(result,'try-error')
85 error('failure of',name,'means these packages will fail:'
86 ,paste(r_dependency_closure(name,forward_arcs=F),collapse=', '))
88 db_record_build(name, version, log_retrieve(), !failed)
92 needs_build <- function(name,version) {
93 # see if the last build was successful
94 build <- db_latest_build(name)
95 if (!is.null(build) && build$success) {
96 # then something must have changed for us to attempt this
98 if (build$r_version == version_upstream(version) &&
99 build$deb_epoch == version_epoch(version) &&
100 build$db_version == db_get_version()) {
104 # always rebuild on failure or no record
105 notice('rebuilding',name,': no build record or previous build failed')
108 # see if it has already been built *and* successfully uploaded
109 srcname <- pkgname_as_debian(name,binary=F)
110 debname <- pkgname_as_debian(name,binary=T)
111 if (file.exists(changesfile(srcname, version))) {
112 notice('already built',srcname,'version',version)
116 if (build$r_version != version_upstream(version)) {
117 notice('rebuilding',name,': new upstream version',build$r_version,'(old) vs',version_upstream(version),'(new)')
119 if (build$deb_epoch != version_epoch(version)) {
120 notice('rebuilding',name,': new cran2deb epoch',build$deb_epoch,'(old) vs',version_epoch(version),'(new)')
122 if (build$db_version != db_get_version()) {
123 notice('rebuilding',name,': new db version',build$db_version,'(old) vs',db_get_version(),'(new)')
125 notice(paste("Now deleting ",debname,", ",srcname,".\n",sep=""))
130 build_debian <- function(pkg) {
132 #notice(paste("Now in path ",wd,"\n",sep=""))
135 notice('building Debian package'
137 ,paste('(',pkg$debversion,')',sep='')
141 cmd = paste('pdebuild --configfile',shQuote(pbuilder_config))
142 if (version_revision(pkg$debversion) > 2) {
143 cmd = paste(cmd,'--debbuildopts','-sd')
144 notice('build should exclude original source')
146 notice(paste("Executing '",cmd,"' from directory '",getwd(),"'.\n",sep=""))
147 ret = log_system(cmd)
150 fail('Failed to build package.')