Opened 12 years ago

Closed 11 years ago

#1940 closed defect (fixed)

wingrass - nsis - script in release mode: !define SVN_REVISION "@GRASS_VERSION_SVN@" not set

Reported by: hellik Owned by: martinl
Priority: critical Milestone: 6.4.3
Component: Packaging Version: 6.4.3 RCs
Keywords: nsis, wingrass Cc: grass-dev@…
CPU: x86-64 Platform: MSWindows 7

Description

http://trac.osgeo.org/grass/browser/grass/branches/releasebranch_6_4/mswindows/GRASS-Installer.nsi.tmpl#L19

19	;Select if you are building a "Development Version" (Devel) or a "Release Version" (Release) of the GRASS Installer
20	
21	!define INSTALLER_TYPE "Devel"

http://trac.osgeo.org/grass/browser/grass/branches/releasebranch_6_4/mswindows/GRASS-Installer.nsi.tmpl#L31

31	;Version variables
32	
33	!define SVN_REVISION "@GRASS_VERSION_SVN@"

in release mode @GRASS_VERSION_SVN@ isn't set:

!define SVN_REVISION "" <=
!define BINARY_REVISION "1"
!define VERSION_NUMBER "6.4.3RC3"
!define GRASS_BASE "GRASS GIS 6.4.3RC3"
[...]

so http://trac.osgeo.org/grass/browser/grass/branches/releasebranch_6_4/mswindows/GRASS-Installer.nsi.tmpl#L251

251	        !define /math VERSION ${SVN_REVISION} + ${BINARY_REVISION}

doesn't work and nsis stopps with an error

Change History (15)

in reply to:  description comment:1 by hellik, 12 years ago

Replying to hellik:

in release mode @GRASS_VERSION_SVN@ isn't set:

source get by a svn checkout

in reply to:  description ; comment:2 by martinl, 12 years ago

Replying to hellik:

http://trac.osgeo.org/grass/browser/grass/branches/releasebranch_6_4/mswindows/GRASS-Installer.nsi.tmpl#L19

> 19	;Select if you are building a "Development Version" (Devel) or a "Release Version" (Release) of the GRASS Installer
> 20	
> 21	!define INSTALLER_TYPE "Devel"

The installer type should be not related to this ticket. At least I didn't encountered any problem when building osgeo4w package source:grass-addons/tools/wingrass-packager/grass_svn_info.sh#L34

http://trac.osgeo.org/grass/browser/grass/branches/releasebranch_6_4/mswindows/GRASS-Installer.nsi.tmpl#L31

> 31	;Version variables
> 32	
> 33	!define SVN_REVISION "@GRASS_VERSION_SVN@"

in release mode @GRASS_VERSION_SVN@ isn't set:

> !define SVN_REVISION "" <=
> !define BINARY_REVISION "1"
> !define VERSION_NUMBER "6.4.3RC3"
> !define GRASS_BASE "GRASS GIS 6.4.3RC3"
> [...]

replacement should be done automatically (source:grass/branches/releasebranch_6_4/mswindows/Makefile#L22) when SVN rev number is defined in source:grass/branches/releasebranch_6_4/include/Make/Grass.make.in#L75. Do you have svnversion in the path (when running configure)?

comment:3 by martinl, 12 years ago

Cc: martinl added

in reply to:  2 ; comment:4 by martinl, 12 years ago

Replying to martinl:

replacement should be done automatically (source:grass/branches/releasebranch_6_4/mswindows/Makefile#L22) when SVN rev number is defined in source:grass/branches/releasebranch_6_4/include/Make/Grass.make.in#L75. Do you have svnversion in the path (when running configure)?

source code downloaded from SVN? If you use tarball, it will fail (missing svn number).

in reply to:  4 comment:5 by hellik, 12 years ago

Replying to martinl:

Replying to martinl:

replacement should be done automatically (source:grass/branches/releasebranch_6_4/mswindows/Makefile#L22) when SVN rev number is defined in source:grass/branches/releasebranch_6_4/include/Make/Grass.make.in#L75. Do you have svnversion in the path (when running configure)?

source code downloaded from SVN? If you use tarball, it will fail (missing svn number).

see #1940#comment:1

source was from a svn check out

in reply to:  2 ; comment:6 by hellik, 12 years ago

Replying to martinl:

Do you have svnversion in the path (when running configure)?

from the msys-cmdline

myricaria@MYRICARIA-HP ~
$ svnversion --version
svnversion, version 1.7.0 (r1176462)
   compiled Oct 10 2011, 22:03:27

comment:7 by hamish, 12 years ago

Hi,

just to note in the release tarball there are no .svn/ dirs present, so svnversion (if installed) should just return "exported" to stdout.

I'm not sure what happens with 'svn export' of a branch, I assume the same, but hellik reports using 'svn checkout', which should have .svn/ dirs, so something else is going on.

If there are things which need to be changed just before release, then changed back just after, automatically-detecting is best but if that is not possible please document what needs to be done in src:doc/howto_release.txt.

fwiw, Hamish

in reply to:  7 comment:8 by hellik, 12 years ago

Replying to hamish:

Hi,

just to note in the release tarball there are no .svn/ dirs present, so svnversion (if installed) should just return "exported" to stdout.

I'm not sure what happens with 'svn export' of a branch, I assume the same, but hellik reports using 'svn checkout', which should have .svn/ dirs, so something else is going on.

Author: neteler Date: 2013-04-20 08:29:47 -0700 (Sat, 20 Apr 2013) New Revision: 55934

myricaria@MYRICARIA-HP /osgeo4w/usr/src/grass643RC3
$ svnversion
55936

in reply to:  6 ; comment:9 by martinl, 12 years ago

Replying to hellik:

Replying to martinl:

Do you have svnversion in the path (when running configure)?

When you launch configure or better package.sh you should get (see package.log)

checking for svnversion... /c/Subversion/svnversion

include/Make/Grass should contain

GRASS_VERSION_SVN     = XXXXXX

In other words, try to check if svnversion is in the path when running package.sh. (?)

in reply to:  9 ; comment:10 by hellik, 12 years ago

Replying to martinl:

Replying to hellik:

Replying to martinl:

Do you have svnversion in the path (when running configure)?

When you launch configure or better package.sh you should get (see package.log)

checking for svnversion... /c/Subversion/svnversion

include/Make/Grass should contain

GRASS_VERSION_SVN     = XXXXXX

In other words, try to check if svnversion is in the path when running package.sh. (?)

from package log

checking for svnversion... no

from osgeo4w-msys from where I start package.sh

myricaria@MYRICARIA-HP ~
$ svnversion --help
usage: svnversion [OPTIONS] [WC_PATH [TRAIL_URL]]

from osgeo4w-msys from where I start package.sh osgeo4w-msys

myricaria@MYRICARIA-HP ~
$ echo $PATH
[...]
/c/Program Files/TortoiseSVN/bin: 
[...]

and in /c/Program Files/TortoiseSVN/bin: there is svnversion

so it's seems it's in $PATH, but not found by configure

in reply to:  10 ; comment:11 by hamish, 12 years ago

Keywords: wingrass added

Replying to hellik:

and in /c/Program Files/TortoiseSVN/bin: there is svnversion

so it's seems it's in $PATH, but not found by configure

from the subject of this bug it seems the issue has to do with building an official versioned release, not with a random svn snapshot build?

In that case the svn rev and thus svnversion are mostly irrelevant; ".svn/" metadata is not in the final tarball, and if a historian is curious what svn rev the version refers to they can always look it up in the tag's log. For versioned releases it already has an official version number, so we know exactly which version of the codebase the user is talking about- the point of including svn revs is to provide that info for non-official-versioned checkouts.

of course the packaging script should handle all the variable setting (or leaving blank) cleanly for you once you change the "Devel" keyword to "Release"...

Hamish

comment:12 by hamish, 12 years ago

I'm not sure what the status of this one is, but it seems that building the RC4 wingrass package will be a good opportunity to field test what happens to the build when there is no .svn/ metadata in the tarball GRASS is built from.

Hamish

in reply to:  11 comment:13 by hellik, 12 years ago

Replying to hamish:

from the subject of this bug it seems the issue has to do with building an official versioned release, not with a random svn snapshot build?

In that case the svn rev and thus svnversion are mostly irrelevant; ".svn/" metadata is not in the final tarball, and if a historian is curious what svn rev the version refers to they can always look it up in the tag's log.

see http://trac.osgeo.org/grass/browser/grass/branches/releasebranch_6_4/mswindows/GRASS-Installer.nsi.tmpl#L251

        !define /math VERSION ${SVN_REVISION} + ${BINARY_REVISION}

${VERSION} is used in the nsis-script/wingrass-installer to check if the installer is newer/older than the already installed

comment:14 by martinl, 11 years ago

Cc: grass-dev@… added; martinl removed
Owner: changed from grass-dev@… to martinl

comment:15 by hellik, 11 years ago

Resolution: fixed
Status: newclosed

fixed by r59313

Note: See TracTickets for help on using tickets.