3 * Copyright (C) 1993, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
4 * 2003, 2004, 2005, 2006, 2007, 2008, 2009, by Larry Wall and others
6 * You may distribute under the terms of either the GNU General Public
7 * License or the Artistic License, as specified in the README file.
11 #ifndef __PATCHLEVEL_H_INCLUDED__
13 /* do not adjust the whitespace! Configure expects the numbers to be
14 * exactly on the third column */
16 #define PERL_REVISION 5 /* age */
17 #define PERL_VERSION 11 /* epoch */
18 #define PERL_SUBVERSION 0 /* generation */
20 #define PERL_VERSION_STRING STRINGIFY(PERL_REVISION) "." \
21 STRINGIFY(PERL_VERSION) "." \
22 STRINGIFY(PERL_SUBVERSION)
24 /* The following numbers describe the earliest compatible version of
25 Perl ("compatibility" here being defined as sufficient binary/API
26 compatibility to run XS code built with the older version).
27 Normally this should not change across maintenance releases.
29 Note that this only refers to an out-of-the-box build. Many non-default
30 options such as usemultiplicity tend to break binary compatibility
33 This is used by Configure et al to figure out
34 PERL_INC_VERSION_LIST, which lists version libraries
35 to include in @INC. See INSTALL for how this works.
37 #define PERL_API_REVISION 5 /* Adjust manually as needed. */
38 #define PERL_API_VERSION 11 /* Adjust manually as needed. */
39 #define PERL_API_SUBVERSION 0 /* Adjust manually as needed. */
41 XXX Note: The selection of non-default Configure options, such
42 as -Duselonglong may invalidate these settings. Currently, Configure
43 does not adequately test for this. A.D. Jan 13, 2000
46 #define __PATCHLEVEL_H_INCLUDED__
50 local_patches -- list of locally applied less-than-subversion patches.
51 If you're distributing such a patch, please give it a name and a
52 one-line description, placed just before the last NULL in the array
53 below. If your patch fixes a bug in the perlbug database, please
54 mention the bugid. If your patch *IS* dependent on a prior patch,
55 please place your applied patch line after its dependencies. This
56 will help tracking of patch dependencies.
58 Please either use 'diff --unified=0' if your diff supports
59 that or edit the hunk of the diff output which adds your patch
60 to this list, to remove context lines which would give patch
61 problems. For instance, if the original context diff is
63 *** patchlevel.h.orig <date here>
64 --- patchlevel.h <date here>
67 ,"FOO1235 - some patch"
68 ,"BAR3141 - another patch"
69 ,"BAZ2718 - and another patch"
70 + ,"MINE001 - my new patch"
75 *** patchlevel.h.orig <date here>
76 --- patchlevel.h <date here>
79 + ,"MINE001 - my new patch"
83 (Note changes to line numbers as well as removal of context lines.)
84 This will prevent patch from choking if someone has previously
85 applied different patches than you.
87 History has shown that nobody distributes patches that also
88 modify patchlevel.h. Do it yourself. The following perl
89 program can be used to add a comment to patchlevel.h:
92 die "Usage: perl -x patchlevel.h comment ..." unless @ARGV;
93 open PLIN, "patchlevel.h" or die "Couldn't open patchlevel.h : $!";
94 open PLOUT, ">patchlevel.new" or die "Couldn't write on patchlevel.new : $!";
97 if (/\t,NULL/ and $seen) {
98 while (my $c = shift @ARGV){
99 print PLOUT qq{\t,"$c"\n};
102 $seen++ if /local_patches\[\]/;
105 close PLOUT or die "Couldn't close filehandle writing to patchlevel.new : $!";
106 close PLIN or die "Couldn't close filehandle reading from patchlevel.h : $!";
107 close DATA; # needed to allow unlink to work win32.
108 unlink "patchlevel.bak" or warn "Couldn't unlink patchlevel.bak : $!"
109 if -e "patchlevel.bak";
110 rename "patchlevel.h", "patchlevel.bak" or
111 die "Couldn't rename patchlevel.h to patchlevel.bak : $!";
112 rename "patchlevel.new", "patchlevel.h" or
113 die "Couldn't rename patchlevel.new to patchlevel.h : $!";
116 Please keep empty lines below so that context diffs of this file do
117 not ever collect the lines belonging to local_patches() into the same
122 #if !defined(PERL_PATCHLEVEL_H_IMPLICIT) && !defined(LOCAL_PATCH_COUNT)
123 # if defined(PERL_IS_MINIPERL)
124 # define PERL_PATCHNUM "UNKNOWN-miniperl"
125 # define PERL_GIT_UNCOMMITTED_CHANGES ,"UNKNOWN"
126 # define PERL_GIT_UNPUSHED_COMMITS /*leave-this-comment*/
127 # elif defined(PERL_MICRO)
128 # define PERL_PATCHNUM "UNKNOWN-microperl"
129 # define PERL_GIT_UNCOMMITTED_CHANGES ,"UNKNOWN"
130 # define PERL_GIT_UNPUSHED_COMMITS /*leave-this-comment*/
132 #include "git_version.h"
134 static const char * const local_patches[] = {
136 PERL_GIT_UNPUSHED_COMMITS /* do not remove this line */
137 PERL_GIT_UNCOMMITTED_CHANGES /* do not remove this line */
143 /* Initial space prevents this variable from being inserted in config.sh */
144 # define LOCAL_PATCH_COUNT \
145 ((int)(sizeof(local_patches)/sizeof(local_patches[0])-2))
147 /* the old terms of reference, add them only when explicitly included */
148 #define PATCHLEVEL PERL_VERSION
149 #undef SUBVERSION /* OS/390 has a SUBVERSION in a system header */
150 #define SUBVERSION PERL_SUBVERSION