summaryrefslogtreecommitdiff
path: root/pidl/wscript
diff options
context:
space:
mode:
Diffstat (limited to 'pidl/wscript')
-rw-r--r--pidl/wscript11
1 files changed, 11 insertions, 0 deletions
diff --git a/pidl/wscript b/pidl/wscript
index 733a455059..4d7e468a97 100644
--- a/pidl/wscript
+++ b/pidl/wscript
@@ -13,6 +13,10 @@ def configure(conf):
conf.env.PERLMAN3EXT = conf.CHECK_PERL_MANPAGE(section='3')
conf.DEFINE('HAVE_PERL_MAKEMAKER', 1)
+ # yapp is used for building the parser
+ conf.find_program('yapp', var='YAPP')
+
+
def build(bld):
bld.INSTALL_FILES('${BINDIR}', 'pidl', chmod=0755)
@@ -35,6 +39,13 @@ def build(bld):
# use perl to build the manpages
bld.env.pidl_srcdir = os.path.join(bld.srcnode.abspath(), 'pidl')
+ # we want to prefer the git version if we can. Only if the
+ # source has changed do we want to re-run yapp
+ if ('YAPP' in bld.env and (
+ bld.IS_NEWER('idl.yp', 'lib/Parse/Pidl/IDL.pm') or
+ bld.IS_NEWER('expr.yp', 'lib/Parse/Pidl/Expr.pm'))):
+ pidl_src.extend(['idl.yp', 'expr.yp'])
+
bld.SAMBA_GENERATOR('pidl_manpages',
source=pidl_src,
target=pidl_manpages,