[PATCH 1 of 2] setup: compile hg.exe
Mads Kiilerich
mads at kiilerich.com
Fri Jun 29 10:05:34 UTC 2012
On 29/06/12 11:57, Adrian Buehlmann wrote:
> # HG changeset patch
> # User Adrian Buehlmann <adrian at cadifra.com>
> # Date 1340963615 -7200
> # Node ID 77c83a98257a4d77b535f2842a0e1805a8a0dafb
> # Parent fba17a64fa4978bfea19222da5e64a18cfddeecd
> setup: compile hg.exe
>
> This implements a new command
>
> $ python setup.py build_hgexe -i
>
> which places the hg.exe in the root of the source tree.
How will this fly on non-windows?
/Mads
> diff --git a/setup.py b/setup.py
> --- a/setup.py
> +++ b/setup.py
> @@ -335,6 +335,17 @@
> f.write(out)
> f.close()
>
> +class buildhgexe(build_ext):
> + description = 'compile hg.exe from mercurial/exewrapper.c'
> +
> + def build_extensions(self):
> + objects = self.compiler.compile(['mercurial/exewrapper.c'],
> + output_dir=self.build_temp)
> + dir = os.path.dirname(self.get_ext_fullpath('dummy'))
> + target = os.path.join(dir, 'hg')
> + self.compiler.link_executable(objects, target,
> + output_dir=self.build_temp)
> +
> class hginstallscripts(install_scripts):
> '''
> This is a specialization of install_scripts that replaces the @LIBDIR@ with
> @@ -386,7 +397,9 @@
> 'build_ext': hgbuildext,
> 'build_py': hgbuildpy,
> 'build_hgextindex': buildhgextindex,
> - 'install_scripts': hginstallscripts}
> + 'install_scripts': hginstallscripts,
> + 'build_hgexe': buildhgexe,
> + }
>
> packages = ['mercurial', 'mercurial.hgweb', 'mercurial.httpclient',
> 'hgext', 'hgext.convert', 'hgext.highlight', 'hgext.zeroconf',
> _______________________________________________
> Mercurial-devel mailing list
> Mercurial-devel at selenic.com
> http://selenic.com/mailman/listinfo/mercurial-devel
More information about the Mercurial-devel
mailing list