Server IP : 103.119.228.120 / Your IP : 18.118.144.109 Web Server : Apache System : Linux v8.techscape8.com 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64 User : nobody ( 99) PHP Version : 5.6.40 Disable Function : shell_exec,symlink,system,exec,proc_get_status,proc_nice,proc_terminate,define_syslog_variables,syslog,openlog,closelog,escapeshellcmd,passthru,ocinum cols,ini_alter,leak,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dl,dll,myshellexec,proc_open,socket_bind,proc_close,escapeshellarg,parse_ini_filepopen,fpassthru,exec,passthru,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,popen,show_source,proc_nice,proc_terminate,proc_get_status,proc_close,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,dl,symlink,shell_exec,system,dl,passthru,escapeshellarg,escapeshellcmd,myshellexec,c99_buff_prepare,c99_sess_put,fpassthru,getdisfunc,fx29exec,fx29exec2,is_windows,disp_freespace,fx29sh_getupdate,fx29_buff_prepare,fx29_sess_put,fx29shexit,fx29fsearch,fx29ftpbrutecheck,fx29sh_tools,fx29sh_about,milw0rm,imagez,sh_name,myshellexec,checkproxyhost,dosyayicek,c99_buff_prepare,c99_sess_put,c99getsource,c99sh_getupdate,c99fsearch,c99shexit,view_perms,posix_getpwuid,posix_getgrgid,posix_kill,parse_perms,parsesort,view_perms_color,set_encoder_input,ls_setcheckboxall,ls_reverse_all,rsg_read,rsg_glob,selfURL,dispsecinfo,unix2DosTime,addFile,system,get_users,view_size,DirFiles,DirFilesWide,DirPrintHTMLHeaders,GetFilesTotal,GetTitles,GetTimeTotal,GetMatchesCount,GetFileMatchesCount,GetResultFiles,fs_copy_dir,fs_copy_obj,fs_move_dir,fs_move_obj,fs_rmdir,SearchText,getmicrotime MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /usr/lib/rpm/ |
Upload File : |
#!/usr/bin/python # Copyright (c) 2012, Red Hat, Inc # All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the # distribution. # 3. Neither the name of Red Hat nor the names of its # contributors may be used to endorse or promote products derived # from this software without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # # Authors: # Stanislav Ochotnicky <sochotnicky@redhat.com> # import os import sys import signal import traceback from javapackages import Depmap class TagBuilder: def __init__ (self, filelist=None): if filelist == None: filelist = sys.stdin paths = map (lambda x: x.rstrip (), filelist.readlines ()) self.provided_artifacts = [] self.skipped_artifacts = [] if paths: # let's first read all fragment files for provided artifacts fragment_dir = os.path.dirname(paths[0]) for dirname, dirnames, filenames in os.walk(fragment_dir): for filename in filenames: if filename.endswith(".pom"): continue depmap = Depmap(os.path.join(dirname, filename)) self.provided_artifacts.extend(depmap.get_provided_mappings()) self.skipped_artifacts.extend(depmap.get_skipped_artifacts()) for path in paths: if path.endswith(".pom"): continue self.print_mvn_requires(path) def __process_jvm_req(self, name, version): if not version: return try: jsplit = version.split('.') if len(jsplit) != 2: # if we don't have major.minor format, just ignore version raise ValueError("Required Java version not in major.minor format") major = int(jsplit[0]) minor = int(jsplit[1]) if major > 1 or minor > 5: print("{name} >= 1:{major}.{minor}".format(name=name, major=major, minor=minor)) else: print("{name} >= {major}.{minor}".format(name=name, major=major, minor=minor)) except ValueError: # what? not a numbered major/minor java release? print(name) def print_mvn_requires(self, path): depmap = Depmap(path) skipped_but_required = [] base_package_requires=set() for provided in depmap.get_provided_artifacts(): if provided.namespace: base_package_requires.add("{ns}-runtime".format(ns=provided.namespace)) else: base_package_requires.add("jpackage-utils") for basereq in base_package_requires: print basereq unknown_deps = [] for dependency in depmap.get_required_artifacts(): if dependency.version == "UNKNOWN": unknown_deps.append(dependency) continue for skipped in self.skipped_artifacts: if (skipped.groupId == dependency.groupId and skipped.artifactId == dependency.artifactId and skipped.classifier == dependency.classifier and skipped.extension == dependency.extension): skipped_but_required.append(skipped) for m_provided, l_provided in self.provided_artifacts: if (m_provided.groupId == dependency.groupId and m_provided.artifactId == dependency.artifactId and m_provided.classifier == dependency.classifier and m_provided.extension == dependency.extension and m_provided.namespace == dependency.namespace): # if dependency is versioned but another subpackage provides # non-versioned artifact, it's coming from a different package if (dependency.version and dependency.version != l_provided.version): continue # if dependency is not versioned but provides is versioned # the dependency is coming from a different package if not dependency.version and l_provided.version: continue # requires on subpackages are always versioned print("{rpmstr} = {version}".format( rpmstr=dependency.get_rpm_str(dependency.version), version=m_provided.version)) break else: # TODO: remove when not needed # do not generate requires like "a:b:pom:" yet if dependency.extension == "pom": dependency.extension = "" print(dependency.get_rpm_str(dependency.version)) if unknown_deps: unknown_msg = "Following dependencies were not resolved and " \ "requires cannot be generated. Either remove the " \ "dependency from pom.xml or add proper packages to " \ "BuildRequires:\n" for unknown in unknown_deps: unknown_msg = unknown_msg + \ "{art}\n".format(art=unknown) raise Exception(unknown_msg) if skipped_but_required: skipped_msg = "Following artifacts were built " \ "but are not being installed however other " \ "artifacts require them. Either package these " \ "artifacts or do not build them. To package " \ "call %mvn_package in %prep:\n" for skipped in skipped_but_required: skipped_msg = skipped_msg + \ "%mvn_package {art} <package_name>\n".format(art=skipped) raise Exception(skipped_msg) reqs = {'java': depmap.get_java_requires(), 'java-devel': depmap.get_java_devel_requires()} for name, version in reqs.iteritems(): self.__process_jvm_req(name, version) if __name__ == "__main__": try: builder = TagBuilder () except Exception, e: traceback.print_exc(file=sys.stderr) sys.stderr.write(str(e)) # rpmbuild ignores non-zero exit codes but this that is bad. Make sure # the build fails and doesn't silently ignore problems os.kill(os.getppid(), signal.SIGTERM)