Added ns upload support to distftp step #4695
Needed to refactor the 'figure out platform and ext' code.
This commit is contained in:
		
							parent
							
								
									d175ad5c70
								
							
						
					
					
						commit
						6ba2ddeb7d
					
				|  | @ -840,7 +840,7 @@ class InternalCommands: | ||||||
| 		pwd = lines[0] | 		pwd = lines[0] | ||||||
| 		 | 		 | ||||||
| 		if (dist): | 		if (dist): | ||||||
| 			self.signFile(pfx, pwd, 'bin', self.dist_name('win')) | 			self.signFile(pfx, pwd, 'bin/Release', self.dist_name('win')) | ||||||
| 		else: | 		else: | ||||||
| 			self.signFile(pfx, pwd, 'bin/Release', 'synergy.exe') | 			self.signFile(pfx, pwd, 'bin/Release', 'synergy.exe') | ||||||
| 			self.signFile(pfx, pwd, 'bin/Release', 'synergyc.exe') | 			self.signFile(pfx, pwd, 'bin/Release', 'synergyc.exe') | ||||||
|  | @ -1281,7 +1281,7 @@ class InternalCommands: | ||||||
| 			arch) | 			arch) | ||||||
| 			 | 			 | ||||||
| 		old = "bin/Release/synergy.msi" | 		old = "bin/Release/synergy.msi" | ||||||
| 		new = "bin/%s" % (filename) | 		new = "bin/Release/%s" % (filename) | ||||||
| 		 | 		 | ||||||
| 		try: | 		try: | ||||||
| 			os.remove(new) | 			os.remove(new) | ||||||
|  | @ -1344,56 +1344,48 @@ class InternalCommands: | ||||||
| 
 | 
 | ||||||
| 		return major + '.' + minor + '.' + rev | 		return major + '.' + minor + '.' + rev | ||||||
| 
 | 
 | ||||||
|  | 	def ftpUpload(self, ftp, source, target): | ||||||
|  | 		print "Uploading '%s' as '%s' to FTP server '%s'..." % ( | ||||||
|  | 			source, target, ftp.host) | ||||||
|  | 		ftp.run(source, target) | ||||||
|  | 		print 'Done' | ||||||
|  | 
 | ||||||
| 	def distftp(self, type, ftp): | 	def distftp(self, type, ftp): | ||||||
| 		if not type: | 		if not type: | ||||||
| 			raise Exception('Type not specified.') | 			raise Exception('Platform type not specified.') | ||||||
| 		 |  | ||||||
| 		if not ftp: |  | ||||||
| 			raise Exception('FTP info not defined.') |  | ||||||
| 		 | 		 | ||||||
| 		self.loadConfig() | 		self.loadConfig() | ||||||
| 		src = self.dist_name(type) |  | ||||||
| 		dest = self.dist_name_rev(type) |  | ||||||
| 		print 'Uploading %s to FTP server %s...' % (dest, ftp.host) |  | ||||||
| 
 | 
 | ||||||
| 		binDir = self.getGenerator().getBinDir('Release') | 		binDir = self.getGenerator().getBinDir('Release') | ||||||
| 		ftp.run(binDir + '/' + src, dest)  | 
 | ||||||
| 		print 'Done' | 		packageSource = binDir + '/' + self.dist_name(type) | ||||||
| 	 | 		packageTarget = self.dist_name_rev(type) | ||||||
| 	def getDebianArch(self): | 		self.ftpUpload(ftp, packageSource, packageTarget) | ||||||
| 		if os.uname()[4][:3] == 'arm': | 
 | ||||||
| 			return 'armhf' | 		if (type != 'src'): | ||||||
|  | 			pluginsDir = binDir + '/plugins' | ||||||
|  | 			nsPluginSource = self.findLibraryFile(type, pluginsDir, 'ns') | ||||||
|  | 			nsPluginTarget = self.getLibraryDistFilename(type, pluginsDir, 'ns') | ||||||
|  | 			self.ftpUpload(ftp, nsPluginSource, nsPluginTarget) | ||||||
| 
 | 
 | ||||||
|                 # os_bits should be loaded with '32bit' or '64bit' |                 # os_bits should be loaded with '32bit' or '64bit' | ||||||
|                 import platform |                 import platform | ||||||
|                 (os_bits, other) = platform.architecture() |                 (os_bits, other) = platform.architecture() | ||||||
|  | 	def findLibraryFile(self, type, dir, name): | ||||||
|  | 		(platform, packageExt, libraryExt) = self.getDistributePlatformInfo(type) | ||||||
|  | 		ext = libraryExt | ||||||
|  | 
 | ||||||
|  | 		pattern = name + '\.' + ext | ||||||
|  | 
 | ||||||
|  | 		for filename in os.listdir(dir): | ||||||
|  | 			if re.search(pattern, filename): | ||||||
|  | 				return dir + '/' + filename | ||||||
| 		 | 		 | ||||||
|                 # get platform based on current platform | 		raise Exception('Could not find library name with pattern: ' + pattern) | ||||||
|                 if os_bits == '32bit': |  | ||||||
|                         return 'i386' |  | ||||||
|                 elif os_bits == '64bit': |  | ||||||
|                         return 'amd64' |  | ||||||
|                 else: |  | ||||||
|                         raise Exception("unknown os bits: " + os_bits) |  | ||||||
| 
 | 
 | ||||||
|         def getLinuxPlatform(self): | 	def getDistributePlatformInfo(self, type): | ||||||
| 		if os.uname()[4][:3] == 'arm': |  | ||||||
| 			return 'Linux-armv6l' |  | ||||||
| 
 |  | ||||||
|                 # os_bits should be loaded with '32bit' or '64bit' |  | ||||||
|                 import platform |  | ||||||
|                 (os_bits, other) = platform.architecture() |  | ||||||
| 		 |  | ||||||
|                 # get platform based on current platform |  | ||||||
|                 if os_bits == '32bit': |  | ||||||
|                         return 'Linux-i686' |  | ||||||
|                 elif os_bits == '64bit': |  | ||||||
|                         return 'Linux-x86_64' |  | ||||||
|                 else: |  | ||||||
|                         raise Exception("unknown os bits: " + os_bits) |  | ||||||
| 
 |  | ||||||
| 	def dist_name(self, type): |  | ||||||
| 		ext = None | 		ext = None | ||||||
|  | 		libraryExt = None | ||||||
| 		platform = None | 		platform = None | ||||||
| 		 | 		 | ||||||
| 		if type == 'src': | 		if type == 'src': | ||||||
|  | @ -1401,14 +1393,14 @@ class InternalCommands: | ||||||
| 			platform = 'Source' | 			platform = 'Source' | ||||||
| 			 | 			 | ||||||
| 		elif type == 'rpm' or type == 'deb': | 		elif type == 'rpm' or type == 'deb': | ||||||
| 		 |  | ||||||
| 			ext = type | 			ext = type | ||||||
|                         platform = self.getLinuxPlatform() | 			libraryExt = 'so' | ||||||
|  | 			platform = self.getLinuxPlatform() | ||||||
| 			 | 			 | ||||||
| 		elif type == 'win': | 		elif type == 'win': | ||||||
| 			 |  | ||||||
| 			# get platform based on last generator used | 			# get platform based on last generator used | ||||||
| 			ext = 'msi' | 			ext = 'msi' | ||||||
|  | 			libraryExt = 'dll' | ||||||
| 			generator = self.getGeneratorFromConfig().cmakeName | 			generator = self.getGeneratorFromConfig().cmakeName | ||||||
| 			if generator.find('Win64') != -1: | 			if generator.find('Win64') != -1: | ||||||
| 				platform = 'Windows-x64' | 				platform = 'Windows-x64' | ||||||
|  | @ -1417,18 +1409,23 @@ class InternalCommands: | ||||||
| 			 | 			 | ||||||
| 		elif type == 'mac': | 		elif type == 'mac': | ||||||
| 			ext = "dmg" | 			ext = "dmg" | ||||||
|  | 			libraryExt = 'dylib' | ||||||
| 			platform = self.getMacPackageName() | 			platform = self.getMacPackageName() | ||||||
| 		 | 		 | ||||||
| 		if not platform: | 		if not platform: | ||||||
| 			raise Exception('Unable to detect package platform.') | 			raise Exception('Unable to detect distributable platform.') | ||||||
| 		 |  | ||||||
| 		pattern = re.escape(self.project + '-') + '\d+\.\d+\.\d+' + re.escape('-' + platform + '.' + ext) |  | ||||||
| 		 |  | ||||||
| 		target = '' |  | ||||||
| 		if type == 'mac': |  | ||||||
| 			target = 'Release' |  | ||||||
| 
 | 
 | ||||||
| 		for filename in os.listdir(self.getBinDir(target)): | 		return (platform, ext, libraryExt) | ||||||
|  | 
 | ||||||
|  | 	def dist_name(self, type): | ||||||
|  | 		(platform, packageExt, libraryExt) = self.getDistributePlatformInfo(type) | ||||||
|  | 		ext = packageExt | ||||||
|  | 		 | ||||||
|  | 		pattern = ( | ||||||
|  | 			re.escape(self.project + '-') + '\d+\.\d+\.\d+' + | ||||||
|  | 			re.escape('-' + platform + '.' + ext)) | ||||||
|  | 
 | ||||||
|  | 		for filename in os.listdir(self.getBinDir('Release')): | ||||||
| 			if re.search(pattern, filename): | 			if re.search(pattern, filename): | ||||||
| 				return filename | 				return filename | ||||||
| 		 | 		 | ||||||
|  | @ -1441,6 +1438,15 @@ class InternalCommands: | ||||||
| 		replace = "%s-%s" % ( | 		replace = "%s-%s" % ( | ||||||
| 			self.getGitBranchName(), self.getGitRevision()) | 			self.getGitBranchName(), self.getGitRevision()) | ||||||
| 		return re.sub(pattern, replace, self.dist_name(type)) | 		return re.sub(pattern, replace, self.dist_name(type)) | ||||||
|  | 	 | ||||||
|  | 	def getDebianArch(self): | ||||||
|  | 		if os.uname()[4][:3] == 'arm': | ||||||
|  | 			return 'armhf' | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 		if os.uname()[4][:3] == 'arm': | ||||||
|  | 			return 'Linux-armv6l' | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| 	def dist_usage(self): | 	def dist_usage(self): | ||||||
| 		print ('Usage: %s package [package-type]\n' | 		print ('Usage: %s package [package-type]\n' | ||||||
|  | @ -1913,10 +1919,11 @@ class CommandHandler: | ||||||
| 			elif o == '--dir': | 			elif o == '--dir': | ||||||
| 				dir = a | 				dir = a | ||||||
| 		 | 		 | ||||||
| 		ftp = None | 		if not host: | ||||||
| 		if host: | 			raise Exception('FTP host was not specified.') | ||||||
| 			ftp = ftputil.FtpUploader( | 
 | ||||||
| 				host, user, password, dir) | 		ftp = ftputil.FtpUploader( | ||||||
|  | 			host, user, password, dir) | ||||||
| 		 | 		 | ||||||
| 		self.ic.distftp(type, ftp) | 		self.ic.distftp(type, ftp) | ||||||
| 	 | 	 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue