$(SIGNAL_OBJS) \
$(MODOBJS) \
$(srcdir)/Modules/getbuildinfo.c
- if test -d .svn; then \
- svnversion . >buildno; \
- elif test -f buildno; then \
- expr `cat buildno` + 1 >buildno1; \
- mv -f buildno1 buildno; \
- else echo 1 >buildno; fi
+ if test -d $(srcdir)/.svn; then \
+ svnversion $(srcdir) >buildno; \
+ fi
# Build static library
# avoid long command lines, same as LIBRARY_OBJS
# Special rules for object files
Modules/getbuildinfo.o: $(srcdir)/Modules/getbuildinfo.c buildno
- $(CC) -c $(PY_CFLAGS) -DBUILD=\"`cat buildno`\" -o $@ $(srcdir)/Modules/getbuildinfo.c
+ if test -f buildno; then \
+ $(CC) -c $(PY_CFLAGS) -DBUILD=\"`cat buildno`\" -o $@ $(srcdir)/Modules/getbuildinfo.c ;\
+ else \
+ $(CC) -c $(PY_CFLAGS) -o $@ $(srcdir)/Modules/getbuildinfo.c ;\
+ fi
Modules/getpath.o: $(srcdir)/Modules/getpath.c Makefile
$(CC) -c $(PY_CFLAGS) -DPYTHONPATH='"$(PYTHONPATH)"' \
#endif
#ifndef BUILD
-#define BUILD "0"
+#define BUILD "$Revision$"
#endif
const char *
-Py_GetBuildInfo(void)
+Py_GetBuildNumber(void)
{
- static char buildinfo[50];
- PyOS_snprintf(buildinfo, sizeof(buildinfo),
- "%s, %.20s, %.9s", BUILD, DATE, TIME);
- return buildinfo;
+ static char buildno[20];
+ static int buildno_okay;
+
+ if (!buildno_okay) {
+ char *build = BUILD;
+ int len = strlen(build);
+
+ if (len > 13 &&
+ !strncmp(build, "$Revision: ", 11) &&
+ !strcmp(build + len - 2, " $"))
+ {
+ memcpy(buildno, build + 11, len - 13);
+ }
+ else {
+ memcpy(buildno, build, 19);
+ }
+ buildno_okay = 1;
+ }
+ return buildno;
}
const char *
-Py_GetBuildNumber(void)
+Py_GetBuildInfo(void)
{
- return BUILD;
+ static char buildinfo[50];
+ PyOS_snprintf(buildinfo, sizeof(buildinfo),
+ "#%s, %.20s, %.9s", Py_GetBuildNumber(), DATE, TIME);
+ return buildinfo;
}