diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-02-25 15:01:38 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-02-25 22:43:34 +0000 |
commit | 3edadc98025ef5f4c166ad5fd7981bae1be2c943 (patch) | |
tree | 0171b04f004ade79556d281813a0d50262483480 /meta | |
parent | e26e8ea364fdceb7a5829ea91bde782ba4626023 (diff) | |
download | poky-3edadc98025ef5f4c166ad5fd7981bae1be2c943.tar.gz |
package.bbclass: Rewrite package_do_filedeps() to reduce the amount of subprocesses created and improve speed
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
-rw-r--r-- | meta/classes/package.bbclass | 77 |
1 files changed, 44 insertions, 33 deletions
diff --git a/meta/classes/package.bbclass b/meta/classes/package.bbclass index c8adbb0564..137de09bc0 100644 --- a/meta/classes/package.bbclass +++ b/meta/classes/package.bbclass | |||
@@ -822,55 +822,66 @@ RPMDEPS = "${STAGING_LIBDIR_NATIVE}/rpm/bin/rpmdeps" | |||
822 | # FILERDEPENDS_filepath_pkg - per file dep | 822 | # FILERDEPENDS_filepath_pkg - per file dep |
823 | 823 | ||
824 | python package_do_filedeps() { | 824 | python package_do_filedeps() { |
825 | import os | 825 | import os, re |
826 | 826 | ||
827 | pkgdest = bb.data.getVar('PKGDEST', d, True) | 827 | pkgdest = bb.data.getVar('PKGDEST', d, True) |
828 | packages = bb.data.getVar('PACKAGES', d, True) | 828 | packages = bb.data.getVar('PACKAGES', d, True) |
829 | 829 | ||
830 | cmd = bb.data.expand("${STAGING_LIBDIR_NATIVE}/rpm/perfile_rpmdeps.sh", d) | ||
831 | rpmdeps = bb.data.expand("${RPMDEPS}", d) | 830 | rpmdeps = bb.data.expand("${RPMDEPS}", d) |
831 | r = re.compile(r'[<>=]+ +[^ ]*') | ||
832 | 832 | ||
833 | # Quick routine to process the results of the rpmdeps call... | 833 | # Quick routine to process the results of the rpmdeps call... |
834 | def process_deps(pipe, pkg, varname): | 834 | def process_deps(pipe, pkg, f, provides_files, requires_files): |
835 | dep_files = "" | 835 | provides = [] |
836 | requires = [] | ||
837 | file = f.replace(pkgdest + "/" + pkg, "") | ||
838 | file = file.replace("@", "@at@") | ||
839 | file = file.replace(" ", "@space@") | ||
840 | file = file.replace("\t", "@tab@") | ||
841 | file = file.replace("[", "@openbrace@") | ||
842 | file = file.replace("]", "@closebrace@") | ||
843 | file = file.replace("_", "@underscore@") | ||
844 | |||
836 | for line in pipe: | 845 | for line in pipe: |
837 | key = "" | 846 | if line.startswith("Requires:"): |
838 | value = "" | 847 | i = requires |
839 | # We expect two items on each line | 848 | elif line.startswith("Provides:"): |
840 | # 1 - filepath | 849 | i = provides |
841 | # 2 - dep list | 850 | else: |
842 | line_list = line.rstrip().split(None,1); | 851 | continue |
843 | if len(line_list) <= 0 or len(line_list) > 2: | 852 | value = line.split(":", 1)[1].strip() |
844 | bb.error("deps list length error! " + len(line_list)); | 853 | value = r.sub(r'(\g<0>)', value) |
845 | if len(line_list) == 2: | 854 | if value.startswith("rpmlib("): |
846 | file = line_list[0]; | 855 | continue |
847 | value = line_list[1] | 856 | i.append(value) |
848 | file = file.replace(pkgdest + "/" + pkg, "") | 857 | |
849 | file = file.replace("@", "@at@") | 858 | if len(provides) > 0: |
850 | file = file.replace(" ", "@space@") | 859 | provides_files.append(file) |
851 | file = file.replace("\t", "@tab@") | 860 | key = "FILERPROVIDES_" + file + "_" + pkg |
852 | file = file.replace("[", "@openbrace@") | 861 | bb.data.setVar(key, " ".join(provides), d) |
853 | file = file.replace("]", "@closebrace@") | 862 | |
854 | file = file.replace("_", "@underscore@") | 863 | if len(requires) > 0: |
855 | dep_files = dep_files + " " + file | 864 | requires_files.append(file) |
856 | key = "FILE" + varname + "_" + file + "_" + pkg | 865 | key = "FILERDEPENDS_" + file + "_" + pkg |
857 | bb.data.setVar(key, value, d) | 866 | bb.data.setVar(key, " ".join(requires), d) |
858 | bb.data.setVar("FILE" + varname + "FLIST_" + pkg, dep_files, d) | ||
859 | 867 | ||
860 | # Determine dependencies | 868 | # Determine dependencies |
861 | for pkg in packages.split(): | 869 | for pkg in packages.split(): |
862 | if pkg.endswith('-dbg') or pkg.endswith('-doc') or pkg.find('-locale-') != -1 or pkg.find('-localedata-') != -1 or pkg.find('-gconv-') != -1 or pkg.find('-charmap-') != -1 or pkg.startswith('kernel-module-'): | 870 | if pkg.endswith('-dbg') or pkg.endswith('-doc') or pkg.find('-locale-') != -1 or pkg.find('-localedata-') != -1 or pkg.find('-gconv-') != -1 or pkg.find('-charmap-') != -1 or pkg.startswith('kernel-module-'): |
863 | continue | 871 | continue |
864 | 872 | ||
865 | # Process provides | 873 | provides_files = [] |
866 | dep_pipe = os.popen(cmd + " --rpmdeps " + rpmdeps + " --provides " + pkgdest + "/" + pkg) | 874 | requires_files = [] |
875 | for root, dirs, files in os.walk(pkgdest + "/" + pkg): | ||
876 | for file in files: | ||
877 | f = os.path.join(root, file) | ||
867 | 878 | ||
868 | process_deps(dep_pipe, pkg, 'RPROVIDES') | 879 | dep_pipe = os.popen(rpmdeps + " --provides --requires -v " + f) |
869 | 880 | ||
870 | # Process requirements | 881 | process_deps(dep_pipe, pkg, f, provides_files, requires_files) |
871 | dep_pipe = os.popen(cmd + " --rpmdeps " + rpmdeps + " --requires " + pkgdest + "/" + pkg) | ||
872 | 882 | ||
873 | process_deps(dep_pipe, pkg, 'RDEPENDS') | 883 | bb.data.setVar("FILERDEPENDSFLIST_" + pkg, " ".join(requires_files), d) |
884 | bb.data.setVar("FILERPROVIDESFLIST_" + pkg, " ".join(provides_files), d) | ||
874 | } | 885 | } |
875 | 886 | ||
876 | SHLIBSDIR = "${STAGING_DIR_HOST}/shlibs" | 887 | SHLIBSDIR = "${STAGING_DIR_HOST}/shlibs" |