6 # Ben Maurer (bmaurer@ximian.com)
7 # Wade Berrier (wberrier@novell.com)
9 # (C) 2008 Novell (http://www.novell.com)
13 filelist=($(grep -Ev '/usr/doc/|/usr/share/doc/'))
14 monolist=($(printf "%s\n" "${filelist[@]}" | egrep "\\.(exe|dll)\$"))
16 # parse .config files to find which native libraries to depend on
17 # (target attribute must have double quotes for this to work, ie: target="file" )
18 # Add /etc/mono/config ?
19 configlist=($(printf "%s\n" "${filelist[@]}" | egrep "\\.config\$"))
21 # Set the prefix, unless it is overriden (used when building mono rpms)
24 libdir=$prefix/@reloc_libdir@
27 # Bail out if monodis or libmono is missing
28 if [ ! -x $bindir/monodis ] || [ ! -f $libdir/libmono.so ] ; then
29 echo "monodis missing or unusable, exiting..." 1>&2
33 # special case for 64bit archs
34 if test "x@reloc_libdir@" = "xlib64" ; then
37 # (note, this works on ppc64 since we only have 32bit mono)
43 # ia64 doesn't use lib64 for 'libdir' (sles 9 rpm used to provide both... no longer)
44 ia64) libext="()(64bit)" ;;
47 # set LD_LIBRARY_PATH to ensure that libmono.so is found
48 export LD_LIBRARY_PATH=$libdir${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}
51 for i in "${monolist[@]}"; do
52 ($bindir/monodis --assemblyref $i | awk '
53 BEGIN { START=0; LIBNAME=""; VERSION=""; }
54 (START==0) && /^[0-9]+: Version=/ {
56 sub(/Version=/, "", $2);
60 (START==1) && /^\tName=/ {
63 # Allow rpm deps to be resolved for 1.0 profile version
64 if (VERSION=="1.0.3300.0")
68 print "mono(" LIBNAME ") " OP " " VERSION
75 rpm_config_REQUIRES=$(
76 # Parse the xml .config files to see what native binaries we call into
77 # TODO: also check monodis --moduleref
78 for i in "${configlist[@]}"; do
79 awk 'match($_, /<dllmap .*target=.*/) {
84 for(tok in toks) { toks_size++ }
85 for(i=1; i <= toks_size; i++) {
86 if(toks[i] ~ /target=/) {
95 attr=substr(attr, 2, length(attr)-1)
99 split(attr, os_targets, ",")
101 for(os_target in os_targets) { os_targets_size++ }
102 for(j=1; j <= os_targets_size; j++) {
103 if(os_targets[j] == "linux") {
123 # Resolve provides to packages, warning on missing to stderr
125 for i in ${rpm_config_REQUIRES[@]} ; do
126 out=$(rpm -q --whatprovides --queryformat "%{NAME}\n" $i)
127 if [ $? -eq 0 ] ; then
131 echo "mono-find-requires: Warning, could not find package that provides: $i" >&2
137 # Use to do: system("rpm -q --whatprovides --queryformat \"%{NAME}\n\" ""\""req"'$libext'""\"")
138 # rpmlint prefers to have lib names instead of package names. There was a reason I was using package names but it slips me now...
139 # Ah... now I remember... it's for noarch packs. The noarch packages can be built on either 32 or 64 bit... so we have to depend
140 # on the package name instead.
143 for i in "${monolist[@]}"; do
144 ($bindir/monodis --assembly $i | awk '
145 BEGIN { LIBNAME=""; VERSION=""; }
146 /^Version:/ { VERSION=$2 }
147 /^Name:/ { LIBNAME=$2 }
149 if (VERSION && LIBNAME)
150 print "mono(" LIBNAME ") = " VERSION
156 # This is a little magic trick to get all REQUIRES that are not
157 # in PROVIDES. While RPM functions correctly when such deps exist,
158 # they make the metadata a bit bloated.
160 # TODO: make this use the mono-find-provides script, to share code
162 # Filter out dups from both lists
163 REQUIRES=$(echo "$REQUIRES" "$config_REQUIRES" | sort | uniq)
164 PROVIDES=$(echo "$PROVIDES" | sort | uniq)
167 # Get a list of elements that exist in exactly one of PROVIDES or REQUIRES
169 UNIQ=$(echo "$PROVIDES
170 $REQUIRES" | sort | uniq -u)
173 # Of those, only choose the ones that are in REQUIRES
176 $REQUIRES" | sort | uniq -d