diff options
Diffstat (limited to 'linden/indra/newview/viewer_manifest.py')
-rwxr-xr-x | linden/indra/newview/viewer_manifest.py | 197 |
1 files changed, 134 insertions, 63 deletions
diff --git a/linden/indra/newview/viewer_manifest.py b/linden/indra/newview/viewer_manifest.py index ccd6c6e..ecbeda2 100755 --- a/linden/indra/newview/viewer_manifest.py +++ b/linden/indra/newview/viewer_manifest.py | |||
@@ -32,7 +32,7 @@ import re | |||
32 | import tarfile | 32 | import tarfile |
33 | viewer_dir = os.path.dirname(__file__) | 33 | viewer_dir = os.path.dirname(__file__) |
34 | # add llmanifest library to our path so we don't have to muck with PYTHONPATH | 34 | # add llmanifest library to our path so we don't have to muck with PYTHONPATH |
35 | sys.path.append(os.path.join(viewer_dir, '../lib/python/indra')) | 35 | sys.path.append(os.path.join(viewer_dir, '../lib/python/indra/util')) |
36 | from llmanifest import LLManifest, main, proper_windows_path, path_ancestors | 36 | from llmanifest import LLManifest, main, proper_windows_path, path_ancestors |
37 | 37 | ||
38 | class ViewerManifest(LLManifest): | 38 | class ViewerManifest(LLManifest): |
@@ -89,25 +89,42 @@ class ViewerManifest(LLManifest): | |||
89 | self.path("lsl_guide.html") | 89 | self.path("lsl_guide.html") |
90 | self.path("gpu_table.txt") | 90 | self.path("gpu_table.txt") |
91 | 91 | ||
92 | def channel_unique(self): | ||
93 | return self.args['channel'].replace("Second Life", "").strip() | ||
94 | def channel_oneword(self): | ||
95 | return "".join(self.channel_unique().split()) | ||
96 | def channel_lowerword(self): | ||
97 | return self.channel_oneword().lower() | ||
98 | |||
92 | def flags_list(self): | 99 | def flags_list(self): |
93 | """ Convenience function that returns the command-line flags for the grid""" | 100 | """ Convenience function that returns the command-line flags for the grid""" |
94 | if(self.args['grid'] == ''): | 101 | channel_flags = '' |
95 | return "" | 102 | grid_flags = '' |
96 | elif(self.args['grid'] == 'firstlook'): | 103 | if not self.default_grid(): |
97 | return '-settings settings_firstlook.xml' | 104 | if self.default_channel(): |
98 | else: | 105 | # beta grid viewer |
99 | return ("-settings settings_beta.xml --%(grid)s -helperuri http://preview-%(grid)s.secondlife.com/helpers/" % {'grid':self.args['grid']}) | 106 | channel_flags = '-settings settings_beta.xml' |
107 | grid_flags = "--%(grid)s -helperuri http://preview-%(grid)s.secondlife.com/helpers/" % {'grid':self.args['grid']} | ||
108 | |||
109 | if not self.default_channel(): | ||
110 | # some channel on some grid | ||
111 | channel_flags = '-settings settings_%s.xml -channel "%s"' % (self.channel_lowerword(), self.args['channel']) | ||
112 | return " ".join((grid_flags, channel_flags)).strip() | ||
100 | 113 | ||
101 | def login_url(self): | 114 | def login_url(self): |
102 | """ Convenience function that returns the appropriate login url for the grid""" | 115 | """ Convenience function that returns the appropriate login url for the grid""" |
103 | if(self.args.get('login_url')): | 116 | if(self.args.get('login_url')): |
104 | return self.args['login_url'] | 117 | return self.args['login_url'] |
105 | else: | 118 | else: |
106 | if(self.args['grid'] == ''): | 119 | if(self.default_grid()): |
107 | return 'http://secondlife.com/app/login/' | 120 | if(self.default_channel()): |
108 | elif(self.args['grid'] == 'firstlook'): | 121 | # agni release |
109 | return 'http://secondlife.com/app/login/firstlook/' | 122 | return 'http://secondlife.com/app/login/' |
123 | else: | ||
124 | # first look (or other) on agni | ||
125 | return 'http://secondlife.com/app/login/%s/' % self.channel_lowerword() | ||
110 | else: | 126 | else: |
127 | # beta grid | ||
111 | return 'http://secondlife.com/app/login/beta/' | 128 | return 'http://secondlife.com/app/login/beta/' |
112 | 129 | ||
113 | def replace_login_url(self): | 130 | def replace_login_url(self): |
@@ -117,14 +134,14 @@ class ViewerManifest(LLManifest): | |||
117 | 134 | ||
118 | class WindowsManifest(ViewerManifest): | 135 | class WindowsManifest(ViewerManifest): |
119 | def final_exe(self): | 136 | def final_exe(self): |
120 | # *NOTE: these are the only two executable names that the crash reporter recognizes | 137 | if self.default_channel(): |
121 | if self.args['grid'] == '': | 138 | if self.default_grid(): |
122 | return "SecondLife.exe" | 139 | return "SecondLife.exe" |
123 | elif self.args['grid'] == 'firstlook': | 140 | else: |
124 | return "SecondLifeFirstLook.exe" | 141 | return "SecondLifePreview.exe" |
125 | else: | 142 | else: |
126 | return "SecondLifePreview.exe" | 143 | return ''.join(self.args['channel'].split()) + '.exe' |
127 | # return "SecondLifePreview%s.exe" % (self.args['grid'], ) | 144 | |
128 | 145 | ||
129 | def construct(self): | 146 | def construct(self): |
130 | super(WindowsManifest, self).construct() | 147 | super(WindowsManifest, self).construct() |
@@ -174,6 +191,20 @@ class WindowsManifest(ViewerManifest): | |||
174 | self.path("res/*/*") | 191 | self.path("res/*/*") |
175 | self.end_prefix() | 192 | self.end_prefix() |
176 | 193 | ||
194 | # Vivox runtimes | ||
195 | if self.prefix(src="vivox-runtime/i686-win32", dst=""): | ||
196 | self.path("SLVoice.exe") | ||
197 | self.path("SLVoiceAgent.exe") | ||
198 | self.path("libeay32.dll") | ||
199 | self.path("srtp.dll") | ||
200 | self.path("ssleay32.dll") | ||
201 | self.path("tntk.dll") | ||
202 | self.path("alut.dll") | ||
203 | self.path("vivoxsdk.dll") | ||
204 | self.path("ortp.dll") | ||
205 | self.path("wrap_oal.dll") | ||
206 | self.end_prefix() | ||
207 | |||
177 | # # pull in the crash logger and updater from other projects | 208 | # # pull in the crash logger and updater from other projects |
178 | # self.path(src="../win_crash_logger/win_crash_logger.exe", dst="win_crash_logger.exe") | 209 | # self.path(src="../win_crash_logger/win_crash_logger.exe", dst="win_crash_logger.exe") |
179 | self.path(src="../win_updater/updater.exe", dst="updater.exe") | 210 | self.path(src="../win_updater/updater.exe", dst="updater.exe") |
@@ -223,49 +254,75 @@ class WindowsManifest(ViewerManifest): | |||
223 | return result | 254 | return result |
224 | 255 | ||
225 | def package_finish(self): | 256 | def package_finish(self): |
226 | version_vars_template = """ | 257 | # a standard map of strings for replacing in the templates |
258 | substitution_strings = { | ||
259 | 'version' : '.'.join(self.args['version']), | ||
260 | 'version_short' : '.'.join(self.args['version'][:-1]), | ||
261 | 'version_dashes' : '-'.join(self.args['version']), | ||
262 | 'final_exe' : self.final_exe(), | ||
263 | 'grid':self.args['grid'], | ||
264 | 'grid_caps':self.args['grid'].upper(), | ||
265 | # escape quotes becase NSIS doesn't handle them well | ||
266 | 'flags':self.flags_list().replace('"', '$\\"'), | ||
267 | 'channel':self.args['channel'], | ||
268 | 'channel_oneword':self.channel_oneword(), | ||
269 | 'channel_unique':self.channel_unique(), | ||
270 | } | ||
271 | |||
272 | version_vars = """ | ||
227 | !define INSTEXE "%(final_exe)s" | 273 | !define INSTEXE "%(final_exe)s" |
228 | !define VERSION "%(version_short)s" | 274 | !define VERSION "%(version_short)s" |
229 | !define VERSION_LONG "%(version)s" | 275 | !define VERSION_LONG "%(version)s" |
230 | !define VERSION_DASHES "%(version_dashes)s" | 276 | !define VERSION_DASHES "%(version_dashes)s" |
231 | """ | 277 | """ % substitution_strings |
232 | if(self.args['grid'] == ''): | 278 | if self.default_channel(): |
233 | installer_file = "Second Life %(version_dashes)s Setup.exe" | 279 | if self.default_grid(): |
234 | grid_vars_template = """ | 280 | # release viewer |
235 | OutFile "%(outfile)s" | 281 | installer_file = "Second Life %(version_dashes)s Setup.exe" |
236 | !define INSTFLAGS "%(flags)s" | 282 | grid_vars_template = """ |
237 | !define INSTNAME "SecondLife" | 283 | OutFile "%(installer_file)s" |
238 | !define SHORTCUT "Second Life" | 284 | !define INSTFLAGS "%(flags)s" |
239 | !define URLNAME "secondlife" | 285 | !define INSTNAME "SecondLife" |
240 | Caption "Second Life ${VERSION}" | 286 | !define SHORTCUT "Second Life" |
241 | """ | 287 | !define URLNAME "secondlife" |
288 | Caption "Second Life ${VERSION}" | ||
289 | """ | ||
290 | else: | ||
291 | # beta grid viewer | ||
292 | installer_file = "Second Life %(version_dashes)s (%(grid_caps)s) Setup.exe" | ||
293 | grid_vars_template = """ | ||
294 | OutFile "%(installer_file)s" | ||
295 | !define INSTFLAGS "%(flags)s" | ||
296 | !define INSTNAME "SecondLife%(grid_caps)s" | ||
297 | !define SHORTCUT "Second Life (%(grid_caps)s)" | ||
298 | !define URLNAME "secondlife%(grid)s" | ||
299 | !define UNINSTALL_SETTINGS 1 | ||
300 | Caption "Second Life %(grid)s ${VERSION}" | ||
301 | """ | ||
242 | else: | 302 | else: |
243 | installer_file = "Second Life %(version_dashes)s (%(grid_caps)s) Setup.exe" | 303 | # some other channel on some grid |
304 | installer_file = "Second Life %(version_dashes)s %(channel_unique)s Setup.exe" | ||
244 | grid_vars_template = """ | 305 | grid_vars_template = """ |
245 | OutFile "%(outfile)s" | 306 | OutFile "%(installer_file)s" |
246 | !define INSTFLAGS "%(flags)s" | 307 | !define INSTFLAGS "%(flags)s" |
247 | !define INSTNAME "SecondLife%(grid_caps)s" | 308 | !define INSTNAME "SecondLife%(channel_oneword)s" |
248 | !define SHORTCUT "Second Life (%(grid_caps)s)" | 309 | !define SHORTCUT "%(channel)s" |
249 | !define URLNAME "secondlife%(grid)s" | 310 | !define URLNAME "secondlife" |
250 | !define UNINSTALL_SETTINGS 1 | 311 | !define UNINSTALL_SETTINGS 1 |
251 | Caption "Second Life %(grid)s ${VERSION}" | 312 | Caption "%(channel)s ${VERSION}" |
252 | """ | 313 | """ |
253 | if(self.args.has_key('installer_name')): | 314 | if(self.args.has_key('installer_name')): |
254 | installer_file = self.args['installer_name'] | 315 | installer_file = self.args['installer_name'] |
255 | else: | 316 | else: |
256 | installer_file = installer_file % {'version_dashes' : '-'.join(self.args['version']), | 317 | installer_file = installer_file % substitution_strings |
257 | 'grid_caps' : self.args['grid'].upper()} | 318 | substitution_strings['installer_file'] = installer_file |
258 | tempfile = "../secondlife_setup.nsi" | 319 | |
259 | # the following is an odd sort of double-string replacement | 320 | tempfile = "../secondlife_setup_tmp.nsi" |
321 | # the following replaces strings in the nsi template | ||
322 | # it also does python-style % substitution | ||
260 | self.replace_in("installers/windows/installer_template.nsi", tempfile, { | 323 | self.replace_in("installers/windows/installer_template.nsi", tempfile, { |
261 | "%%VERSION%%":version_vars_template%{'version_short' : '.'.join(self.args['version'][:-1]), | 324 | "%%VERSION%%":version_vars, |
262 | 'version' : '.'.join(self.args['version']), | 325 | "%%GRID_VARS%%":grid_vars_template % substitution_strings, |
263 | 'version_dashes' : '-'.join(self.args['version']), | ||
264 | 'final_exe' : self.final_exe()}, | ||
265 | "%%GRID_VARS%%":grid_vars_template%{'grid':self.args['grid'], | ||
266 | 'grid_caps':self.args['grid'].upper(), | ||
267 | 'outfile':installer_file, | ||
268 | 'flags':self.flags_list()}, | ||
269 | "%%INSTALL_FILES%%":self.nsi_file_commands(True), | 326 | "%%INSTALL_FILES%%":self.nsi_file_commands(True), |
270 | "%%DELETE_FILES%%":self.nsi_file_commands(False)}) | 327 | "%%DELETE_FILES%%":self.nsi_file_commands(False)}) |
271 | 328 | ||
@@ -327,16 +384,26 @@ class DarwinManifest(ViewerManifest): | |||
327 | 384 | ||
328 | 385 | ||
329 | def package_finish(self): | 386 | def package_finish(self): |
387 | channel_standin = 'Second Life' # hah, our default channel is not usable on its own | ||
388 | if not self.default_channel(): | ||
389 | channel_standin = self.args['channel'] | ||
390 | |||
330 | imagename="SecondLife_" + '_'.join(self.args['version']) | 391 | imagename="SecondLife_" + '_'.join(self.args['version']) |
331 | if(self.args['grid'] != ''): | 392 | if self.default_channel(): |
332 | imagename = imagename + '_' + self.args['grid'].upper() | 393 | if not self.default_grid(): |
394 | # beta case | ||
395 | imagename = imagename + '_' + self.args['grid'].upper() | ||
396 | else: | ||
397 | # first look, etc | ||
398 | imagename = imagename + '_' + self.channel_oneword().upper() | ||
333 | 399 | ||
334 | sparsename = imagename + ".sparseimage" | 400 | sparsename = imagename + ".sparseimage" |
335 | finalname = imagename + ".dmg" | 401 | finalname = imagename + ".dmg" |
336 | # make sure we don't have stale files laying about | 402 | # make sure we don't have stale files laying about |
337 | self.remove(sparsename, finalname) | 403 | self.remove(sparsename, finalname) |
338 | 404 | ||
339 | self.run_command('hdiutil create "%(sparse)s" -volname "Second Life" -fs HFS+ -type SPARSE -megabytes 300' % {'sparse':sparsename}) | 405 | self.run_command('hdiutil create "%(sparse)s" -volname "Second Life" -fs HFS+ -type SPARSE -megabytes 300' % { |
406 | 'sparse':sparsename}) | ||
340 | 407 | ||
341 | # mount the image and get the name of the mount point and device node | 408 | # mount the image and get the name of the mount point and device node |
342 | hdi_output = self.run_command('hdiutil attach -private "' + sparsename + '"') | 409 | hdi_output = self.run_command('hdiutil attach -private "' + sparsename + '"') |
@@ -344,15 +411,17 @@ class DarwinManifest(ViewerManifest): | |||
344 | volpath = re.search('HFS\s+(.+)', hdi_output).group(1).strip() | 411 | volpath = re.search('HFS\s+(.+)', hdi_output).group(1).strip() |
345 | 412 | ||
346 | # Copy everything in to the mounted .dmg | 413 | # Copy everything in to the mounted .dmg |
347 | # TODO change name of .app once mac_updater can handle it. | 414 | if self.default_channel() and not self.default_grid(): |
348 | for s,d in { | 415 | app_name = "Second Life " + self.args['grid'] |
349 | self.get_dst_prefix():"Second Life.app", | 416 | else: |
350 | "lsl_guide.html":"Linden Scripting Language Guide.html", | 417 | app_name = channel_standin.strip() |
351 | "releasenotes.txt":"Release Notes.txt", | ||
352 | "installers/darwin/mac_image_hidden":".hidden", | ||
353 | "installers/darwin/mac_image_background.tga":"background.tga", | ||
354 | "installers/darwin/mac_image_DS_Store":".DS_Store"}.items(): | ||
355 | 418 | ||
419 | for s,d in {self.get_dst_prefix():app_name + ".app", | ||
420 | "lsl_guide.html":"Linden Scripting Language Guide.html", | ||
421 | "releasenotes.txt":"Release Notes.txt", | ||
422 | "installers/darwin/mac_image_hidden":".hidden", | ||
423 | "installers/darwin/mac_image_background.tga":"background.tga", | ||
424 | "installers/darwin/mac_image_DS_Store":".DS_Store"}.items(): | ||
356 | print "Copying to dmg", s, d | 425 | print "Copying to dmg", s, d |
357 | self.copy_action(self.src_path_of(s), os.path.join(volpath, d)) | 426 | self.copy_action(self.src_path_of(s), os.path.join(volpath, d)) |
358 | 427 | ||
@@ -390,8 +459,8 @@ class LinuxManifest(ViewerManifest): | |||
390 | if(self.args.has_key('installer_name')): | 459 | if(self.args.has_key('installer_name')): |
391 | installer_name = self.args['installer_name'] | 460 | installer_name = self.args['installer_name'] |
392 | else: | 461 | else: |
393 | installer_name = '_'.join('SecondLife_', self.args.get('arch'), *self.args['version']) | 462 | installer_name = '_'.join(['SecondLife', self.args.get('arch'), '_'.join(self.args['version'])]) |
394 | if grid != '': | 463 | if not self.default_grid(): |
395 | installer_name += "_" + grid.upper() | 464 | installer_name += "_" + grid.upper() |
396 | 465 | ||
397 | # temporarily move directory tree so that it has the right name in the tarfile | 466 | # temporarily move directory tree so that it has the right name in the tarfile |
@@ -433,8 +502,10 @@ class Linux_i686Manifest(LinuxManifest): | |||
433 | # self.path("libstdc++.so.6") | 502 | # self.path("libstdc++.so.6") |
434 | self.path("libuuid.so", "libuuid.so.1") | 503 | self.path("libuuid.so", "libuuid.so.1") |
435 | self.path("libSDL-1.2.so.0") | 504 | self.path("libSDL-1.2.so.0") |
436 | #self.path("libtcmalloc.so.0") | 505 | self.path("libELFIO.so") |
437 | #self.path("libstacktrace.so.0") | 506 | #self.path("libresolv.so") - don't bundle |
507 | #self.path("libtcmalloc.so.0") - bugged | ||
508 | #self.path("libstacktrace.so.0") - probably bugged | ||
438 | # self.path("libllkdu.so", "../bin/libllkdu.so") # llkdu goes in bin for some reason | 509 | # self.path("libllkdu.so", "../bin/libllkdu.so") # llkdu goes in bin for some reason |
439 | self.end_prefix("lib") | 510 | self.end_prefix("lib") |
440 | 511 | ||