Raw File
init.R
.onLoad <- function(libname, pkgName) {
	# Ugly tricks to put own replacement methods on top (don't try this at home):
	asNeeded <- function(pkgName, fun) {
		if(paste("package", pkgName, sep = ":") %in% search()) fun() else 
			setHook(packageEvent(pkgName, "attach"), fun)
	}
	
	regmethod <- function(funname, classname, s4 = FALSE,
		fun = get(paste0(funname, ".", classname), getNamespace(.packageName)),
		envir = .GlobalEnv)
		do.call(if(s4) "setMethod" else "registerS3method", list(funname, classname, fun),
			envir = envir)	
	
	asNeeded("unmarked", function(...) regmethod("logLik", "unmarkedFit", TRUE))
	#asNeeded("lme4", function(...) regmethod("predict", "merMod"))
	asNeeded("nlme", function(...) regmethod("predict", "lme"))
	asNeeded("nlme", function(...) regmethod("predict", "gls"))
	
	### Done here and not in NAMESPACE as I don't want to link to xtable:
	asNeeded("xtable", function(...) regmethod("xtable", "summary.averaging"))
	asNeeded("xtable", function(...) regmethod("xtable", "averaging"))
	asNeeded("xtable", function(...) regmethod("xtable", "model.selection"))

}
back to top