public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-05-28 17:00 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-05-28 17:00 UTC (permalink / raw
  To: gentoo-commits

commit:     339c39cf65cf554514ea5865c91deb6c3a7c90ce
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon May 28 15:51:12 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon May 28 15:51:12 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=339c39cf

Add name property.

---
 gpackages/libs/porttree.py |    4 ++++
 1 files changed, 4 insertions(+), 0 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index c10995f..a2ff2a1 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -146,6 +146,10 @@ class Package(ToStrMixin):
     def package_path(self):
         return os.path.join(self.category.porttree.porttree_path, self.package)
 
+    @property
+    def name(self):
+        return self.package.split('/')[1]
+
     manifest_path = property(_file_path('Manifest'))
     changelog_path = property(_file_path('ChangeLog'))
     manifest_sha1 = property(_file_hash('manifest_path'))



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-05-29 13:38 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-05-29 13:38 UTC (permalink / raw
  To: gentoo-commits

commit:     f747541be80d425bee895c28e6a9268a49aab9ce
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Tue May 29 12:57:34 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Tue May 29 12:57:34 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=f747541b

Fix bug in licenses property

---
 gpackages/libs/porttree.py |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 96cbe0b..475a642 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -210,7 +210,7 @@ class Ebuild(ToStrMixin):
 
     @property
     def licenses(self):
-        return filter(_license_filter, self.license)
+        return filter(_license_filter, self.license.split())
 
     @property
     def ebuild_path(self):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-05-29 21:34 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-05-29 21:34 UTC (permalink / raw
  To: gentoo-commits

commit:     cfec6827730879bf843ef4f9c4e176a01c6a46de
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Tue May 29 17:37:26 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Tue May 29 17:37:26 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=cfec6827

Fix bug in get_keywords

---
 gpackages/libs/porttree.py |    4 +++-
 1 files changed, 3 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index c50b74d..a54ef12 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -12,6 +12,8 @@ BINDB = portage.db[portage.root]["bintree"].dbapi
 PORTDB = portage.db[portage.root]["porttree"].dbapi
 VARDB = portage.db[portage.root]["vartree"].dbapi
 
+ARCHES = PORTDB.settings["PORTAGE_ARCHLIST"].split()
+
 _license_filter = lambda x: False if x.startswith('|') or x.startswith('(') or \
                                      x.endswith('?') or x.startswith(')') \
                                   else True
@@ -174,7 +176,7 @@ class Ebuild(ToStrMixin):
         
     def get_keywords(self):
         l = []
-        for keyword in self.iter_keyworkds():
+        for keyword in self.iter_keywords():
             l.append(keyword)
         return l
 



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-05-31 15:28 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-05-31 15:28 UTC (permalink / raw
  To: gentoo-commits

commit:     2cc54c310d4bf1ffc6ce0904f10559ad16bd2672
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Thu May 31 14:42:05 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Thu May 31 14:42:05 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=2cc54c31

Fix bug with bad keywords.

---
 gpackages/libs/porttree.py |    6 +++++-
 1 files changed, 5 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 160aa6b..2c45249 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -178,9 +178,13 @@ class Ebuild(ToStrMixin):
         self.package = package
         self.ebuild = ebuild
         self.package_object = PackageInfo(ebuild)
+
+    @property
+    def keywords(self):
+        return self.package_object.environment("KEYWORDS", prefer_vdb = False)
     
     def iter_keywords(self):
-        keywords = self.package_object.environment("KEYWORDS").split()
+        keywords = self.keywords.split()
         for keyword in keywords:
             yield Keyword(keyword)
         



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-05-31 15:28 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-05-31 15:28 UTC (permalink / raw
  To: gentoo-commits

commit:     671230a8b3eb3b6fbae4dea2061b9e82c7fc2dec
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Thu May 31 15:28:21 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Thu May 31 15:28:21 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=671230a8

Litle change in API

---
 gpackages/libs/porttree.py |   12 ++++++++++--
 1 files changed, 10 insertions(+), 2 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 2c45249..bfd4859 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -80,6 +80,10 @@ class Keyword(ToStrMixin):
     def __unicode__(self):
         return self.status_repr[self.status] + self.name
 
+    @property
+    def arch(self):
+        return self.name
+
 
 class Portage(object):
     
@@ -180,11 +184,15 @@ class Ebuild(ToStrMixin):
         self.package_object = PackageInfo(ebuild)
 
     @property
-    def keywords(self):
+    def keywords_env(self):
         return self.package_object.environment("KEYWORDS", prefer_vdb = False)
+
+    @property
+    def keywords(self):
+        return list(frozenset(self.keywords_env.split()))
     
     def iter_keywords(self):
-        keywords = self.keywords.split()
+        keywords = self.keywords
         for keyword in keywords:
             yield Keyword(keyword)
         



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-01 21:28 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-01 21:28 UTC (permalink / raw
  To: gentoo-commits

commit:     2ff1d2399d0d6fb40823546170295f24105d7189
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Fri Jun  1 16:16:59 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Fri Jun  1 16:16:59 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=2ff1d239

Layer for work with herds.

---
 gpackages/libs/herds.py |   51 +++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 51 insertions(+), 0 deletions(-)

diff --git a/gpackages/libs/herds.py b/gpackages/libs/herds.py
new file mode 100644
index 0000000..c123814
--- /dev/null
+++ b/gpackages/libs/herds.py
@@ -0,0 +1,51 @@
+try:
+    import xml.etree.cElementTree as etree
+except (ImportError, SystemError):
+    import xml.etree.ElementTree as etree
+
+
+def _gen_func(name):
+    return lambda self: getattr(self, name)
+
+class AbstarctXmlObject(object):
+    attrs = ()
+    
+    def __new__(cls, *args, **kwargs):
+        for val in cls.attrs:
+            setattr(cls, val, property(_gen_func('_'+val)))
+        ins = super(AbstarctXmlObject, cls).__new__(cls, *args, **kwargs) 
+        #attrs = getattr(ins, 'attrs')
+        return ins
+    
+    def __init__(self, xml_object):
+        for val in self.attrs:
+            obj_xml = xml_object.find(val) 
+            setattr(self, '_' + val, None)
+            if obj_xml is not None:
+                setattr(self, '_' + val, obj_xml.text)
+
+class Maintainer(AbstarctXmlObject):
+    attrs = ('name', 'email', 'role')
+
+class Herd(AbstarctXmlObject):
+    # create name, email and description property
+    attrs = ('name', 'email', 'description')
+
+    def __init__(self, xml_object):
+        super(Herd, self).__init__(xml_object) 
+        self._iter_maintainer = xml_object.iterfind('maintainer')
+
+    def iter_mainteiner(self):
+        for maintainer_tree in self._iter_maintainer:
+            yield Maintainer(maintainer_tree)
+
+
+class Herds(object):
+    def __init__(self, herd_path='/usr/portage/metadata/herds.xml'):
+        self._herd_path = herd_path
+        self._herd_parse = etree.parse(herd_path)
+        self._iter_herd = self._herd_parse.iterfind('herd')
+
+    def iter_herd(self):
+        for herd_tree in self._iter_herd:
+            yield Herd(herd_tree)



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-01 21:28 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-01 21:28 UTC (permalink / raw
  To: gentoo-commits

commit:     08e1a509346904e4ac6146511d1f5f342455e551
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Fri Jun  1 16:16:38 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Fri Jun  1 16:16:38 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=08e1a509

Add metadata access.

---
 gpackages/libs/porttree.py |   12 ++++++++++++
 1 files changed, 12 insertions(+), 0 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index d8b3da3..3faa150 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -5,6 +5,7 @@ from portage.exception import PortageException, FileNotFound, InvalidAtom, \
                               InvalidDependString, InvalidPackageName
 
 from gentoolkit.package import Package as PackageInfo
+from gentoolkit.metadata import MetaData
 from datetime import datetime
 import hashlib
 import os
@@ -163,6 +164,7 @@ class Package(ToStrMixin):
     def __init__(self, category, package):
         self.category = category
         self.package = package
+        self._metadata = None
 
     def iter_ebuilds(self):
         ebuilds = PORTDB.cp_list(self.package, mytree=self.category.porttree.porttree)
@@ -176,6 +178,12 @@ class Package(ToStrMixin):
     def package_path(self):
         return os.path.join(self.category.porttree.porttree_path, self.package)
 
+    @property
+    def metadata(self):
+        if self._metadata is None:
+            self._metadata = MetaData( self.metadata_path)
+        return self._metadata
+
     mtime = property(_file_mtime("package_path"))
 
     @property
@@ -184,12 +192,16 @@ class Package(ToStrMixin):
 
     manifest_path = property(_file_path('Manifest'))
     changelog_path = property(_file_path('ChangeLog'))
+    metadata_path = property(_file_path('metadata.xml'))
+
     #Hashes
     manifest_sha1 = property(_file_hash('manifest_path'))
     changelog_sha1 = property(_file_hash('changelog_path'))
+    metadata_sha1 = property(_file_hash('metadata_path'))
     # Modify times
     manifest_mtime = property(_file_mtime("manifest_path"))
     changelog_mtime = property(_file_mtime("changelog_path"))
+    metadata_mtime = property(_file_mtime("metadata_path"))
 
 
 class Ebuild(ToStrMixin):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-02 16:04 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-02 16:04 UTC (permalink / raw
  To: gentoo-commits

commit:     b236cb55afe0279395efa3bfee797a6cbdb7963b
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sat Jun  2 15:53:56 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sat Jun  2 15:53:56 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=b236cb55

Litle optimization with slots

---
 gpackages/libs/porttree.py |   11 +++++++++++
 1 files changed, 11 insertions(+), 0 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 6ed2629..0a5b0fc 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -55,6 +55,8 @@ class ToStrMixin(object):
         return '<%s %s>' % (type(self).__name__, self.__str__())
 
 class Use(ToStrMixin):
+    __slots__ = ('name',)
+
     def __init__(self, name):
         if name.startswith('+') or name.startswith('-'):
             name = name[1:]
@@ -75,6 +77,7 @@ class Use(ToStrMixin):
 
 
 class Keyword(ToStrMixin):
+    __slots__ = ('name', 'status')
     status_repr = ['','~','-']
     
     def __init__(self, name, status = 0):
@@ -135,6 +138,8 @@ class PortTree(ToStrMixin):
 
 
 class Category(ToStrMixin):
+
+    __slots__ = ('porttree', 'category')
     
     def __init__(self, porttree, category):
         self.porttree = porttree
@@ -161,6 +166,9 @@ class Category(ToStrMixin):
 
 
 class Package(ToStrMixin):
+
+    __slots__ = ('category', 'package', '_metadata')
+
     def __init__(self, category, package):
         self.category = category
         self.package = package
@@ -205,6 +213,9 @@ class Package(ToStrMixin):
 
 
 class Ebuild(ToStrMixin):
+
+    __slots__ = ('package', 'ebuild', 'package_object')
+
     def __init__(self, package, ebuild):
         self.package = package
         self.ebuild = ebuild



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-03 13:19 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-03 13:19 UTC (permalink / raw
  To: gentoo-commits

commit:     578144075b13c6e755525dd8565d706baf7d7bff
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sun Jun  3 12:46:18 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sun Jun  3 12:46:18 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=57814407

Changes in herds layer.

---
 gpackages/libs/herds.py |   27 ++++++++++++++++++++++++---
 1 files changed, 24 insertions(+), 3 deletions(-)

diff --git a/gpackages/libs/herds.py b/gpackages/libs/herds.py
index b1e596b..02d2782 100644
--- a/gpackages/libs/herds.py
+++ b/gpackages/libs/herds.py
@@ -29,6 +29,11 @@ class AbstarctXmlObject(object):
 class Maintainer(AbstarctXmlObject, ToStrMixin):
     attrs = ('name', 'email', 'role')
 
+    def __init__(self, *args, **kwargs):
+        super(Maintainer, self).__init__(*args, **kwargs)
+        if self._email is not None:
+            self._email = self._email.lower()
+
     def __eq__(self, other):
         return self.email == other.email
 
@@ -47,21 +52,31 @@ class Herd(AbstarctXmlObject, ToStrMixin):
 
     def __init__(self, xml_object):
         super(Herd, self).__init__(xml_object) 
-        self._iter_maintainer = xml_object.iterfind('maintainer')
+        self._xml_object = xml_object
+
+    def __eq__(self, other):
+        return self.name == other.name
+
+    def __ne__(self, other):
+        return self.name != other.name
+
+    def __hash__(self):
+        return hash(self.name)
 
     def iter_mainteiner(self):
-        for maintainer_tree in self._iter_maintainer:
+        for maintainer_tree in self._xml_object.iterfind('maintainer'):
             yield Maintainer(maintainer_tree)
 
     def __unicode__(self):
         return self.name
 
 
-class Herds(object):
+class Herds(ToStrMixin):
     def __init__(self, herd_path='/usr/portage/metadata/herds.xml'):
         self._herd_path = herd_path
         self._herd_parse = etree.parse(herd_path)
         self._herds_dict = None
+        self._maintainers_dict = None
 
     def iter_herd(self):
         for herd_tree in self._herd_parse.iterfind('herd'):
@@ -77,9 +92,15 @@ class Herds(object):
         return res
 
     def get_maintainers_with_hers(self):
+        if self._maintainers_dict is not None:
+            return self._maintainers_dict
         herd_dict = self.get_herds_indict()
         maintainer_dict = defaultdict(list)
         for herd in herd_dict.itervalues():
             for maintainer in herd.iter_mainteiner():
                 maintainer_dict[maintainer].append(herd.name)
+        self._maintainers_dict = maintainer_dict
         return maintainer_dict
+
+    def __unicode__(self):
+        return self._herd_path



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-03 13:19 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-03 13:19 UTC (permalink / raw
  To: gentoo-commits

commit:     50d5fdbe69872b2bf509cf9c8a9efb4845bd924c
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sat Jun  2 19:24:17 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sat Jun  2 19:24:17 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=50d5fdbe

Changes in libs for working with portage tree.

---
 gpackages/libs/generic.py  |    8 ++++++++
 gpackages/libs/herds.py    |   42 ++++++++++++++++++++++++++++++++++++++----
 gpackages/libs/porttree.py |    8 +-------
 3 files changed, 47 insertions(+), 11 deletions(-)

diff --git a/gpackages/libs/generic.py b/gpackages/libs/generic.py
new file mode 100644
index 0000000..7fe9cc8
--- /dev/null
+++ b/gpackages/libs/generic.py
@@ -0,0 +1,8 @@
+
+class ToStrMixin(object):
+    def __str__(self):
+        return unicode(self).encode('utf-8')
+
+    def __repr__(self):
+        return '<%s %s>' % (type(self).__name__, self.__str__())
+

diff --git a/gpackages/libs/herds.py b/gpackages/libs/herds.py
index c123814..b1e596b 100644
--- a/gpackages/libs/herds.py
+++ b/gpackages/libs/herds.py
@@ -3,6 +3,8 @@ try:
 except (ImportError, SystemError):
     import xml.etree.ElementTree as etree
 
+from collections import defaultdict
+from generic import ToStrMixin
 
 def _gen_func(name):
     return lambda self: getattr(self, name)
@@ -24,10 +26,22 @@ class AbstarctXmlObject(object):
             if obj_xml is not None:
                 setattr(self, '_' + val, obj_xml.text)
 
-class Maintainer(AbstarctXmlObject):
+class Maintainer(AbstarctXmlObject, ToStrMixin):
     attrs = ('name', 'email', 'role')
 
-class Herd(AbstarctXmlObject):
+    def __eq__(self, other):
+        return self.email == other.email
+
+    def __ne__(self, other):
+        return self.email != other.email
+
+    def __hash__(self):
+        return hash(self.email)
+
+    def __unicode__(self):
+        return self.email
+
+class Herd(AbstarctXmlObject, ToStrMixin):
     # create name, email and description property
     attrs = ('name', 'email', 'description')
 
@@ -39,13 +53,33 @@ class Herd(AbstarctXmlObject):
         for maintainer_tree in self._iter_maintainer:
             yield Maintainer(maintainer_tree)
 
+    def __unicode__(self):
+        return self.name
+
 
 class Herds(object):
     def __init__(self, herd_path='/usr/portage/metadata/herds.xml'):
         self._herd_path = herd_path
         self._herd_parse = etree.parse(herd_path)
-        self._iter_herd = self._herd_parse.iterfind('herd')
+        self._herds_dict = None
 
     def iter_herd(self):
-        for herd_tree in self._iter_herd:
+        for herd_tree in self._herd_parse.iterfind('herd'):
             yield Herd(herd_tree)
+
+    def get_herds_indict(self):
+        if self._herds_dict is not None:
+            return self._herds_dict
+        res = {}
+        for herd in self.iter_herd():
+            res[herd.name] = herd
+        self._herds_dict = res
+        return res
+
+    def get_maintainers_with_hers(self):
+        herd_dict = self.get_herds_indict()
+        maintainer_dict = defaultdict(list)
+        for herd in herd_dict.itervalues():
+            for maintainer in herd.iter_mainteiner():
+                maintainer_dict[maintainer].append(herd.name)
+        return maintainer_dict

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 0a5b0fc..3f1f1f6 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -6,6 +6,7 @@ from portage.exception import PortageException, FileNotFound, InvalidAtom, \
 
 from gentoolkit.package import Package as PackageInfo
 from gentoolkit.metadata import MetaData
+from generic import ToStrMixin
 from datetime import datetime
 import hashlib
 import os
@@ -47,13 +48,6 @@ def file_mtime(file_path):
     else:
         return None
 
-class ToStrMixin(object):
-    def __str__(self):
-        return unicode(self).encode('utf-8')
-
-    def __repr__(self):
-        return '<%s %s>' % (type(self).__name__, self.__str__())
-
 class Use(ToStrMixin):
     __slots__ = ('name',)
 



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-03 16:19 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-03 16:19 UTC (permalink / raw
  To: gentoo-commits

commit:     0589e7d67f07e81f1971e972b046cf8e14d37adf
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sun Jun  3 16:14:52 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sun Jun  3 16:14:52 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=0589e7d6

Iter categories in alphabetic order.

---
 gpackages/libs/porttree.py |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 3f1f1f6..8bee3dd 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -110,7 +110,7 @@ class PortTree(ToStrMixin):
         self.porttree = porttree # TODO: it should be read-only
 
     def iter_categories(self):
-        for category in PORTDB.settings.categories:
+        for category in sorted(PORTDB.settings.categories):
             yield Category(self, category)
 
     def iter_packages(self):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-03 19:34 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-03 19:34 UTC (permalink / raw
  To: gentoo-commits

commit:     5d48506679f27c041450088918e4357366cc4c24
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sun Jun  3 18:44:47 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sun Jun  3 18:44:47 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=5d485066

Add module to colect use flag info.

---
 gpackages/libs/use_info.py |   32 ++++++++++++++++++++++++++++++++
 1 files changed, 32 insertions(+), 0 deletions(-)

diff --git a/gpackages/libs/use_info.py b/gpackages/libs/use_info.py
new file mode 100644
index 0000000..faa95ef
--- /dev/null
+++ b/gpackages/libs/use_info.py
@@ -0,0 +1,32 @@
+import re
+from collections import defaultdict
+
+USES_RE = r'(?P<use>[^#].*) - (?P<description>.*)'
+USES_DESC_RE = r'^%s$' % USES_RE
+USES_LOCAL_DESC_RE = r'^(?P<package>[^#].*):%s$' % USES_RE
+
+use_re = re.compile(USES_DESC_RE)
+use_local_re = re.compile(USES_LOCAL_DESC_RE)
+
+def _get_info(filename, re_string, modify_function, res_var = {}):
+    use_desc = open(filename, 'r').read()
+    uses_desc = use_desc.split("\n")
+    res_dict = res_var
+    for use_str in uses_desc:
+        res_match = re_string.match(use_str)
+        if res_match is not None:
+            modify_function(res_dict, res_match.groupdict())
+
+    return res_dict
+
+def get_uses_info(filename = '/usr/portage/profiles/use.desc'):
+    def action(res_dict, match):
+        res_dict[match['use']] = match['description']
+
+    return _get_info(filename, use_re, action)
+
+def get_local_uses_info(filename = '/usr/portage/profiles/use.local.desc'):
+    def action(res_dict, match):
+        res_dict[match['use']][match['package']] = match['description']
+
+    return _get_info(filename, use_local_re, action, defaultdict(dict))



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-04 16:16 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-04 16:16 UTC (permalink / raw
  To: gentoo-commits

commit:     7cdf9ea4302dd6999d481abc252d87a26590ae7a
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon Jun  4 16:16:20 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon Jun  4 16:16:20 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=7cdf9ea4

Fix typo in herds.py

---
 gpackages/libs/herds.py |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/herds.py b/gpackages/libs/herds.py
index 02d2782..89574a2 100644
--- a/gpackages/libs/herds.py
+++ b/gpackages/libs/herds.py
@@ -9,7 +9,7 @@ from generic import ToStrMixin
 def _gen_func(name):
     return lambda self: getattr(self, name)
 
-class AbstarctXmlObject(object):
+class AbstractXmlObject(object):
     attrs = ()
     
     def __new__(cls, *args, **kwargs):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-04 16:16 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-04 16:16 UTC (permalink / raw
  To: gentoo-commits

commit:     fdf39f15710d6bf978ed97ffe0fc80404cf5448c
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon Jun  4 16:07:13 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon Jun  4 16:07:13 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=fdf39f15

Check if category exists in repo.

---
 gpackages/libs/porttree.py |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index e1a7dcc..9b5bb9b 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -111,7 +111,8 @@ class PortTree(ToStrMixin):
 
     def iter_categories(self):
         for category in sorted(PORTDB.settings.categories):
-            yield Category(self, category)
+            if os.path.isdir(os.path.join(self.porttree_path, category)):
+                    yield Category(self, category)
 
     def iter_packages(self):
         for category in self.iter_categories():



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-04 22:18 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-04 22:18 UTC (permalink / raw
  To: gentoo-commits

commit:     4a9e85eab23a8d0c4e64d0658637a7d85db7b0ae
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon Jun  4 22:18:28 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon Jun  4 22:18:28 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=4a9e85ea

Add some docstrings.

---
 gpackages/libs/generic.py  |    3 +++
 gpackages/libs/herds.py    |   28 +++++++++++++++++++++++++++-
 gpackages/libs/porttree.py |   14 +++++++++++++-
 gpackages/libs/use_info.py |   19 +++++++++++++++++++
 4 files changed, 62 insertions(+), 2 deletions(-)

diff --git a/gpackages/libs/generic.py b/gpackages/libs/generic.py
index 7fe9cc8..dc15a65 100644
--- a/gpackages/libs/generic.py
+++ b/gpackages/libs/generic.py
@@ -1,5 +1,8 @@
 
 class ToStrMixin(object):
+    """Abstract class for inheritence, allow add simple `__str__` and `__repr__`
+    methods
+    """
     def __str__(self):
         return unicode(self).encode('utf-8')
 

diff --git a/gpackages/libs/herds.py b/gpackages/libs/herds.py
index 70ce071..7626d03 100644
--- a/gpackages/libs/herds.py
+++ b/gpackages/libs/herds.py
@@ -10,6 +10,10 @@ def _gen_func(name):
     return lambda self: getattr(self, name)
 
 class AbstractXmlObject(object):
+    """Abstract class for iheritance, 
+    dynamicly generate properties by `attrs` param
+    each generated param return value of `_` + property name variable.
+    """
     attrs = ()
     
     def __new__(cls, *args, **kwargs):
@@ -20,6 +24,7 @@ class AbstractXmlObject(object):
         return ins
     
     def __init__(self, xml_object):
+        "Set internal value for each value in attrs parameter"
         for val in self.attrs:
             obj_xml = xml_object.find(val) 
             setattr(self, '_' + val, None)
@@ -27,6 +32,12 @@ class AbstractXmlObject(object):
                 setattr(self, '_' + val, obj_xml.text)
 
 class Maintainer(AbstractXmlObject, ToStrMixin):
+    """Have 3 atributes:
+
+        - name -- maintainer name
+        - email -- maintainer email
+        - role -- maintainer role
+    """
     attrs = ('name', 'email', 'role')
 
     def __init__(self, *args, **kwargs):
@@ -47,6 +58,11 @@ class Maintainer(AbstractXmlObject, ToStrMixin):
         return self.email
 
 class Herd(AbstractXmlObject, ToStrMixin):
+    """Have 3 atributes:
+        - name -- herd name
+        - email -- herd email
+        - description -- herd description
+    """
     # create name, email and description property
     attrs = ('name', 'email', 'description')
 
@@ -72,7 +88,8 @@ class Herd(AbstractXmlObject, ToStrMixin):
 
 
 class Herds(ToStrMixin):
-    def __init__(self, herd_path='/usr/portage/metadata/herds.xml'):
+    "Object that represent herds.xml file "
+    def __init__(self, herd_path = '/usr/portage/metadata/herds.xml'):
         self._herd_path = herd_path
         self._herd_parse = etree.parse(herd_path)
         self._herds_dict = None
@@ -83,6 +100,9 @@ class Herds(ToStrMixin):
             yield Herd(herd_tree)
 
     def get_herds_indict(self):
+        """Returns:
+            dict with herd name as key and herd object as value
+        """
         if self._herds_dict is not None:
             return self._herds_dict
         res = {}
@@ -92,6 +112,12 @@ class Herds(ToStrMixin):
         return res
 
     def get_maintainers_with_herds(self):
+        """Returns:
+            defaultdict(list) with maintainer object as key, and list of herds
+            as value.
+        Example:
+            {'<Maintainers example@gentoo.org>': ['mozilla','base'], ...}
+        """
         if self._maintainers_dict is not None:
             return self._maintainers_dict
         herd_dict = self.get_herds_indict()

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 9b5bb9b..0bf329b 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -49,9 +49,13 @@ def file_mtime(file_path):
         return None
 
 class Use(ToStrMixin):
+    "Represend Use flag as object"
     __slots__ = ('name',)
 
     def __init__(self, name):
+        """Args:
+            name -- name of use flag, may start with + or -
+        """
         if name.startswith('+') or name.startswith('-'):
             name = name[1:]
         self.name = name
@@ -69,12 +73,19 @@ class Use(ToStrMixin):
         return hash(self.name)
         
 
-
 class Keyword(ToStrMixin):
     __slots__ = ('name', 'status')
     status_repr = ['','~','-']
     
     def __init__(self, name, status = 0):
+        """Args:
+            name -- name of keyword, it may start with ~ or -, if so than 
+                    status will be auto seting.
+            status -- status of keyword: 0 - stable, 
+                                         1 - utested '~',
+                                         2 - unstable '-'
+                    Also may get by name parameter.
+        """
         if name.startswith('~'):
             name = name[1:]
             status = 1
@@ -89,6 +100,7 @@ class Keyword(ToStrMixin):
 
     @property
     def arch(self):
+        "Return arch name"
         return self.name
 
 

diff --git a/gpackages/libs/use_info.py b/gpackages/libs/use_info.py
index faa95ef..b45cda7 100644
--- a/gpackages/libs/use_info.py
+++ b/gpackages/libs/use_info.py
@@ -20,12 +20,31 @@ def _get_info(filename, re_string, modify_function, res_var = {}):
     return res_dict
 
 def get_uses_info(filename = '/usr/portage/profiles/use.desc'):
+    """Args:
+        filename -- full path to use.desc file
+    Returns:
+        dict with use flag as key, and description as value
+    Example:
+        {'doc': 'Doc description', ...}
+    Notice:
+        In portage public api `get_use_flag_dict`
+    """
     def action(res_dict, match):
         res_dict[match['use']] = match['description']
 
     return _get_info(filename, use_re, action)
 
 def get_local_uses_info(filename = '/usr/portage/profiles/use.local.desc'):
+    """Args:
+        filename -- full path to use.local.desc file
+    Returns:
+        defaultdict(dict) with use flag as first key, package name as second
+        key, and description as value
+    Example:
+        {'api': {'app-emulation/xen-tools': 'Use descr', ...} , ...}
+    Notice:
+        In portage public api `get_use_flag_dict`
+    """
     def action(res_dict, match):
         res_dict[match['use']][match['package']] = match['description']
 



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-05 15:49 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-05 15:49 UTC (permalink / raw
  To: gentoo-commits

commit:     5b7efed420bdcf338f5743614bcd1ebfc3a4bc4f
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Tue Jun  5 12:27:20 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Tue Jun  5 12:27:20 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=5b7efed4

Add caching propertys

---
 gpackages/libs/porttree.py |   67 ++++++++++++++++++++++++++-----------------
 1 files changed, 40 insertions(+), 27 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 0bf329b..6781d4e 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -48,6 +48,24 @@ def file_mtime(file_path):
     else:
         return None
 
+class cached_property(object):
+    def __init__(self, func, name = None):
+        self.func = func
+        if name is None:
+            name = func.__name__
+        self.__name__ = name
+        self.__module__ = func.__module__
+
+    def __get__(self, inst, owner):
+        try:
+            value = inst._cache[self.__name__]
+        except (KeyError, AttributeError):
+            value = self.func(inst)
+            if not hasattr(inst, '_cache'):
+                inst._cache = {}
+            inst._cache[self.__name__] = value
+        return value
+
 class Use(ToStrMixin):
     "Represend Use flag as object"
     __slots__ = ('name',)
@@ -174,13 +192,12 @@ class Category(ToStrMixin):
 
 class Package(ToStrMixin):
 
-    __slots__ = ('category', 'package', '_metadata', '_changelog')
+    __slots__ = ('category', 'package', '_cache')
 
     def __init__(self, category, package):
         self.category = category
         self.package = package
-        self._metadata = None
-        self._changelog = None
+        self._cache = {}
 
     def iter_ebuilds(self):
         ebuilds = PORTDB.cp_list(self.package, mytree=self.category.porttree.porttree)
@@ -194,11 +211,9 @@ class Package(ToStrMixin):
     def package_path(self):
         return os.path.join(self.category.porttree.porttree_path, self.package)
 
-    @property
+    @cached_property
     def metadata(self):
-        if self._metadata is None:
-            self._metadata = MetaData( self.metadata_path)
-        return self._metadata
+        return MetaData( self.metadata_path)
 
     mtime = property(_file_mtime("package_path"))
 
@@ -211,30 +226,28 @@ class Package(ToStrMixin):
     metadata_path = property(_file_path('metadata.xml'))
 
     #Hashes
-    manifest_sha1 = property(_file_hash('manifest_path'))
-    changelog_sha1 = property(_file_hash('changelog_path'))
-    metadata_sha1 = property(_file_hash('metadata_path'))
+    manifest_sha1 = cached_property(_file_hash('manifest_path'), name = 'manifest_sha1')
+    changelog_sha1 = cached_property(_file_hash('changelog_path'), name = 'changelog_sha1')
+    metadata_sha1 = cached_property(_file_hash('metadata_path'), name = 'metadata_sha1')
     # Modify times
     manifest_mtime = property(_file_mtime("manifest_path"))
     changelog_mtime = property(_file_mtime("changelog_path"))
     metadata_mtime = property(_file_mtime("metadata_path"))
 
-    @property
+    @cached_property
     def changelog(self):
-        if self._changelog is not None:
-            return self._changelog
-        self._changelog = open(self.changelog_path,'r').read()
-        return self._changelog
+        return open(self.changelog_path,'r').read()
 
 
 class Ebuild(ToStrMixin):
 
-    __slots__ = ('package', 'ebuild', 'package_object')
+    __slots__ = ('package', 'ebuild', 'package_object', '_cache')
 
     def __init__(self, package, ebuild):
         self.package = package
         self.ebuild = ebuild
         self.package_object = PackageInfo(ebuild)
+        self._cache = {}
 
     @property
     def keywords_env(self):
@@ -270,7 +283,7 @@ class Ebuild(ToStrMixin):
         return l
 
     #Could be faster
-    @property
+    @cached_property
     def is_masked(self):
         return self.package_object.is_masked()
 
@@ -290,22 +303,22 @@ class Ebuild(ToStrMixin):
     def ebuild_path(self):
         return self.package_object.ebuild_path()
 
-    homepage_val = property(_ebuild_environment('HOMEPAGE'))
-    license = property(_ebuild_environment('LICENSE'))
-    description = property(_ebuild_environment('DESCRIPTION'))
-    eapi = property(_ebuild_environment('EAPI'))
-    slot = property(_ebuild_environment('SLOT'))
+    homepage_val = cached_property(_ebuild_environment('HOMEPAGE'), name = 'homepage_val')
+    license = cached_property(_ebuild_environment('LICENSE'), name = 'license')
+    description = cached_property(_ebuild_environment('DESCRIPTION'), name = 'description')
+    eapi = cached_property(_ebuild_environment('EAPI'), name = 'eapi')
+    slot = cached_property(_ebuild_environment('SLOT'), name = 'slot')
 
-    @property
+    @cached_property
     def homepages(self):
         return self.homepage_val.split()
 
-    @property
+    @cached_property
     def homepage(self):
         return self.homepages[0] if len(self.homepages)>=1 else ''
 
 
-    @property
+    @cached_property
     def licenses(self):
         return filter(_license_filter, self.license.split())
 
@@ -313,8 +326,8 @@ class Ebuild(ToStrMixin):
     def ebuild_path(self):
         return self.package_object.ebuild_path()
 
-    sha1 = property(_file_hash("ebuild_path"))
-    mtime = property(_file_mtime("ebuild_path"))
+    sha1 = cached_property(_file_hash("ebuild_path"), name = 'sha1')
+    mtime = cached_property(_file_mtime("ebuild_path"), name = 'mtime')
 
     def __unicode__(self):
         return self.ebuild



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-05 15:49 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-05 15:49 UTC (permalink / raw
  To: gentoo-commits

commit:     ef8e618691ad6b42bc52ebdfe86c064d03f34464
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Tue Jun  5 15:11:31 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Tue Jun  5 15:11:31 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=ef8e6186

Move some code to generic.py

---
 gpackages/libs/generic.py  |   35 ++++++++++++++++++++++++
 gpackages/libs/porttree.py |   62 +++++++++++++++++---------------------------
 2 files changed, 59 insertions(+), 38 deletions(-)

diff --git a/gpackages/libs/generic.py b/gpackages/libs/generic.py
index dc15a65..ed08d93 100644
--- a/gpackages/libs/generic.py
+++ b/gpackages/libs/generic.py
@@ -1,3 +1,6 @@
+import os.path
+import hashlib
+from datetime import datetime
 
 class ToStrMixin(object):
     """Abstract class for inheritence, allow add simple `__str__` and `__repr__`
@@ -9,3 +12,35 @@ class ToStrMixin(object):
     def __repr__(self):
         return '<%s %s>' % (type(self).__name__, self.__str__())
 
+
+def file_sha1(file_path):
+    sha1 = 'NULL'
+    if os.path.exists(file_path):
+        f = open(file_path, 'r')
+        sha1 = hashlib.sha1(f.read()).hexdigest()
+        f.close()
+    return sha1
+
+def file_mtime(file_path):
+    if os.path.exists(file_path):
+        return datetime.fromtimestamp(os.path.getmtime(file_path))
+    else:
+        return None
+
+class cached_property(object):
+    def __init__(self, func, name = None):
+        self.func = func
+        if name is None:
+            name = func.__name__
+        self.__name__ = name
+        self.__module__ = func.__module__
+
+    def __get__(self, inst, owner):
+        try:
+            value = inst._cache[self.__name__]
+        except (KeyError, AttributeError):
+            value = self.func(inst)
+            if not hasattr(inst, '_cache'):
+                inst._cache = {}
+            inst._cache[self.__name__] = value
+        return value

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 6781d4e..f18387b 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -6,9 +6,7 @@ from portage.exception import PortageException, FileNotFound, InvalidAtom, \
 
 from gentoolkit.package import Package as PackageInfo
 from gentoolkit.metadata import MetaData
-from generic import ToStrMixin
-from datetime import datetime
-import hashlib
+from generic import ToStrMixin, file_sha1, file_mtime, cached_property
 import os
 
 BINDB = portage.db[portage.root]["bintree"].dbapi
@@ -34,37 +32,6 @@ def _file_mtime(attr):
 def _ebuild_environment(name):
     return lambda self: self.package_object.environment(name)
 
-def file_sha1(file_path):
-    sha1 = 'NULL'
-    if os.path.exists(file_path):
-        f = open(file_path, 'r')
-        sha1 = hashlib.sha1(f.read()).hexdigest()
-        f.close()
-    return sha1
-
-def file_mtime(file_path):
-    if os.path.exists(file_path):
-        return datetime.fromtimestamp(os.path.getmtime(file_path))
-    else:
-        return None
-
-class cached_property(object):
-    def __init__(self, func, name = None):
-        self.func = func
-        if name is None:
-            name = func.__name__
-        self.__name__ = name
-        self.__module__ = func.__module__
-
-    def __get__(self, inst, owner):
-        try:
-            value = inst._cache[self.__name__]
-        except (KeyError, AttributeError):
-            value = self.func(inst)
-            if not hasattr(inst, '_cache'):
-                inst._cache = {}
-            inst._cache[self.__name__] = value
-        return value
 
 class Use(ToStrMixin):
     "Represend Use flag as object"
@@ -92,6 +59,7 @@ class Use(ToStrMixin):
         
 
 class Keyword(ToStrMixin):
+    "Represend ebuild Keyword as object"
     __slots__ = ('name', 'status')
     status_repr = ['','~','-']
     
@@ -135,8 +103,12 @@ class Portage(object):
     
 
 class PortTree(ToStrMixin):
+    "Represent portage tree as object"
     
     def __init__(self, porttree = '/usr/portage'):
+        """Args:
+            porttree -- full path to portage tree as str
+        """
         self.porttree = porttree # TODO: it should be read-only
 
     def iter_categories(self):
@@ -159,14 +131,20 @@ class PortTree(ToStrMixin):
     
     @property
     def porttree_path(self):
+        "Full path to portage tree"
         return self.porttree
 
 
 class Category(ToStrMixin):
+    "Represent category of portage tree as object"
 
     __slots__ = ('porttree', 'category')
     
     def __init__(self, porttree, category):
+        """Args:
+            porttree -- PortTree object
+            category -- category name as str
+        """
         self.porttree = porttree
         self.category = category
     
@@ -187,10 +165,12 @@ class Category(ToStrMixin):
     
     @property
     def category_path(self):
+        "Full path to category"
         return os.path.join(self.porttree.porttree_path, self.category)
 
 
 class Package(ToStrMixin):
+    "Represent package as object"
 
     __slots__ = ('category', 'package', '_cache')
 
@@ -215,6 +195,10 @@ class Package(ToStrMixin):
     def metadata(self):
         return MetaData( self.metadata_path)
 
+    @property
+    def cp(self):
+        return self.package
+
     mtime = property(_file_mtime("package_path"))
 
     @property
@@ -240,6 +224,7 @@ class Package(ToStrMixin):
 
 
 class Ebuild(ToStrMixin):
+    "Represent ebuild as object"
 
     __slots__ = ('package', 'ebuild', 'package_object', '_cache')
 
@@ -297,10 +282,12 @@ class Ebuild(ToStrMixin):
 
     @property
     def fullversion(self):
+        "Version with revision"
         return self.package_object.fullversion
 
     @property
     def ebuild_path(self):
+        "Full path to ebuild"
         return self.package_object.ebuild_path()
 
     homepage_val = cached_property(_ebuild_environment('HOMEPAGE'), name = 'homepage_val')
@@ -311,21 +298,20 @@ class Ebuild(ToStrMixin):
 
     @cached_property
     def homepages(self):
+        "List of homepages"
         return self.homepage_val.split()
 
     @cached_property
     def homepage(self):
+        "First homepage in list"
         return self.homepages[0] if len(self.homepages)>=1 else ''
 
 
     @cached_property
     def licenses(self):
+        "List of licenses used in ebuild"
         return filter(_license_filter, self.license.split())
 
-    @property
-    def ebuild_path(self):
-        return self.package_object.ebuild_path()
-
     sha1 = cached_property(_file_hash("ebuild_path"), name = 'sha1')
     mtime = cached_property(_file_mtime("ebuild_path"), name = 'mtime')
 



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-05 20:48 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-05 20:48 UTC (permalink / raw
  To: gentoo-commits

commit:     a6a33725de7805677a1d86a5c6f9d2d18eb13915
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Tue Jun  5 17:20:45 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Tue Jun  5 17:20:45 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=a6a33725

Changes for PEP8

---
 gpackages/libs/porttree.py |   27 ++++++++++++++++++---------
 1 files changed, 18 insertions(+), 9 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index f18387b..e4a3359 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -180,7 +180,8 @@ class Package(ToStrMixin):
         self._cache = {}
 
     def iter_ebuilds(self):
-        ebuilds = PORTDB.cp_list(self.package, mytree=self.category.porttree.porttree)
+        ebuilds = PORTDB.cp_list(self.package,
+                                 mytree = self.category.porttree.porttree)
         for ebuild in ebuilds:
             yield Ebuild(self ,ebuild)
 
@@ -210,9 +211,12 @@ class Package(ToStrMixin):
     metadata_path = property(_file_path('metadata.xml'))
 
     #Hashes
-    manifest_sha1 = cached_property(_file_hash('manifest_path'), name = 'manifest_sha1')
-    changelog_sha1 = cached_property(_file_hash('changelog_path'), name = 'changelog_sha1')
-    metadata_sha1 = cached_property(_file_hash('metadata_path'), name = 'metadata_sha1')
+    manifest_sha1 = cached_property(_file_hash('manifest_path'),
+                                    name = 'manifest_sha1')
+    changelog_sha1 = cached_property(_file_hash('changelog_path'),
+                                     name = 'changelog_sha1')
+    metadata_sha1 = cached_property(_file_hash('metadata_path'),
+                                    name = 'metadata_sha1')
     # Modify times
     manifest_mtime = property(_file_mtime("manifest_path"))
     changelog_mtime = property(_file_mtime("changelog_path"))
@@ -290,11 +294,16 @@ class Ebuild(ToStrMixin):
         "Full path to ebuild"
         return self.package_object.ebuild_path()
 
-    homepage_val = cached_property(_ebuild_environment('HOMEPAGE'), name = 'homepage_val')
-    license = cached_property(_ebuild_environment('LICENSE'), name = 'license')
-    description = cached_property(_ebuild_environment('DESCRIPTION'), name = 'description')
-    eapi = cached_property(_ebuild_environment('EAPI'), name = 'eapi')
-    slot = cached_property(_ebuild_environment('SLOT'), name = 'slot')
+    homepage_val = cached_property(_ebuild_environment('HOMEPAGE'),
+                                   name = 'homepage_val')
+    license = cached_property(_ebuild_environment('LICENSE'),
+                              name = 'license')
+    description = cached_property(_ebuild_environment('DESCRIPTION'),
+                                  name = 'description')
+    eapi = cached_property(_ebuild_environment('EAPI'),
+                           name = 'eapi')
+    slot = cached_property(_ebuild_environment('SLOT'),
+                           name = 'slot')
 
     @cached_property
     def homepages(self):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-05 21:46 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-05 21:46 UTC (permalink / raw
  To: gentoo-commits

commit:     d986533d1aee9e79a33da4aeac2508fc946e69e0
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Tue Jun  5 21:45:57 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Tue Jun  5 21:45:57 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=d986533d

Changes in layer over portage

---
 gpackages/libs/porttree.py |   62 ++++++++++++++++++++++++++++++++++++++++---
 gpackages/libs/use_info.py |    2 +
 2 files changed, 59 insertions(+), 5 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index fe2c9cf..5a4da3a 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -7,6 +7,7 @@ from portage.exception import PortageException, FileNotFound, InvalidAtom, \
 from gentoolkit.package import Package as PackageInfo
 from gentoolkit.metadata import MetaData
 from generic import ToStrMixin, file_sha1, file_mtime, cached_property
+from use_info import get_uses_info, get_local_uses_info
 import os
 
 BINDB = portage.db[portage.root]["bintree"].dbapi
@@ -33,6 +34,13 @@ def _ebuild_environment(name):
     return lambda self: self.package_object.environment(name)
 
 
+def _get_info_by_func(func, path1, path2):
+        path = os.path.join(path1, path2)
+        try:
+            return func(path)
+        except IOError:
+            return None
+
 class Use(ToStrMixin):
     "Represend Use flag as object"
     __slots__ = ('name',)
@@ -89,27 +97,59 @@ class Keyword(ToStrMixin):
         "Return arch name"
         return self.name
 
+def _gen_all_use(func, iterator):
+    use_g = iterator
+    use_all_dict = next(use_g)
+    for use_dict in use_g:
+        if use_dict is not None:
+            func(use_all_dict, use_dict)
+    return use_all_dict
 
 class Portage(object):
     
     def iter_trees(self):
-        for tree in PORTDB.porttrees:
-            yield PortTree(tree)
+        tree_dict = PORTDB.repositories.treemap
+        for tree_name in PORTDB.repositories.prepos_order:
+            yield PortTree(tree_dict[tree_name], tree_name)
+
+    def iter_packages():
+        for tree in self.iter_trees():
+            for package in tree.iter_package():
+                yield package
 
     def iter_ebuilds():
         for tree in self.iter_trees():
             for ebuild in tree.iter_ebuilds():
                 yield ebuild
     
+    def iter_use_desc(self):
+        for tree in self.iter_trees():
+            yield tree.use_desc
+
+    def iter_use_local_desc(self):
+        for tree in self.iter_trees():
+            yield tree.use_local_desc
+
+    def get_all_use_desc(self):
+        return _gen_all_use(lambda x,y: x.update(y), self.iter_use_desc())
+
+    def get_all_use_local_desc(self):
+        def action(all_dict, use_dict):
+            for key, value in use_dict.iteritems():
+                all_dict[key].update(value)
+
+        return _gen_all_use(action, self.iter_use_local_desc())
+
 
 class PortTree(ToStrMixin):
     "Represent portage tree as object"
     
-    def __init__(self, porttree = '/usr/portage'):
+    def __init__(self, tree_path = '/usr/portage', name = 'main'):
         """Args:
-            porttree -- full path to portage tree as str
+            tree_path -- full path to portage tree as str
         """
-        self.porttree = porttree # TODO: it should be read-only
+        self.porttree = tree_path
+        self.name = name
 
     def iter_categories(self):
         for category in sorted(PORTDB.settings.categories):
@@ -134,6 +174,18 @@ class PortTree(ToStrMixin):
         "Full path to portage tree"
         return self.porttree
 
+    @cached_property
+    def use_desc(self):
+        return _get_info_by_func(get_uses_info,
+                                 self.porttree_path,
+                                 'profiles/use.desc')
+
+    @cached_property
+    def use_local_desc(self):
+        return _get_info_by_func(get_local_uses_info,
+                                 self.porttree_path,
+                                 'profiles/use.local.desc')
+
 
 class Category(ToStrMixin):
     "Represent category of portage tree as object"

diff --git a/gpackages/libs/use_info.py b/gpackages/libs/use_info.py
index b45cda7..c89dfe6 100644
--- a/gpackages/libs/use_info.py
+++ b/gpackages/libs/use_info.py
@@ -1,6 +1,8 @@
 import re
 from collections import defaultdict
 
+__all__ = ('get_uses_info', 'get_local_uses_info')
+
 USES_RE = r'(?P<use>[^#].*) - (?P<description>.*)'
 USES_DESC_RE = r'^%s$' % USES_RE
 USES_LOCAL_DESC_RE = r'^(?P<package>[^#].*):%s$' % USES_RE



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-06 22:48 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-06 22:48 UTC (permalink / raw
  To: gentoo-commits

commit:     36caba23fa7a8a9ceb05170d8acbc0e9b61d3c6c
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Wed Jun  6 22:48:35 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Wed Jun  6 22:48:35 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=36caba23

Fix typo

---
 gpackages/libs/porttree.py |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index dec4867..8e8bb83 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -141,7 +141,7 @@ class Portage(object):
 
     def iter_packages(self):
         for tree in self.iter_trees():
-            for package in tree.iter_package():
+            for package in tree.iter_packages():
                 yield package
 
     def iter_ebuilds(self):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-07 22:48 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-07 22:48 UTC (permalink / raw
  To: gentoo-commits

commit:     ff8c32e541a7c5482417ed909fb14ced2920a4c3
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Thu Jun  7 19:52:19 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Thu Jun  7 19:52:19 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=ff8c32e5

Add more docstrings to porttree.py

---
 gpackages/libs/porttree.py |   10 +++++++++-
 1 files changed, 9 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 8e8bb83..3bb6b6b 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -195,7 +195,7 @@ class PortTree(ToStrMixin):
                 yield ebuild
 
     def __unicode__(self):
-        return self.porttree
+        return self.name
     
     @property
     def porttree_path(self):
@@ -280,6 +280,7 @@ class Package(ToStrMixin):
 
     @cached_property
     def metadata(self):
+        "Return `MetaData` object that represent package metadata.xml file"
         try:
             return MetaData( self.metadata_path)
         except IOError:
@@ -317,6 +318,7 @@ class Package(ToStrMixin):
 
     @property
     def description(self):
+        "Return first description in package metadata.xml"
         if len(self.descriptions)>0:
             return self.descriptions[0]
         else:
@@ -324,6 +326,7 @@ class Package(ToStrMixin):
 
     @cached_property
     def changelog(self):
+        "Return ChangeLog content"
         return file_get_content(self.changelog_path)
 
 
@@ -344,6 +347,7 @@ class Ebuild(ToStrMixin):
 
     @property
     def is_valid(self):
+        "Check if ebuild is valid"
         try:
             self.package_object.environment("EAPI")
         except errors.GentoolkitFatalError:
@@ -357,6 +361,7 @@ class Ebuild(ToStrMixin):
         return list(set(self.keywords_env.split()))
     
     def iter_keywords(self):
+        "Iterate over keywords, yields Keyword object"
         keywords = self.keywords
         for keyword in keywords:
             yield Keyword(keyword)
@@ -372,6 +377,7 @@ class Ebuild(ToStrMixin):
     
 
     def iter_uses(self):
+        "Iterator over all uses, yiels `Use` object"
         for use in self.get_uses_names():
             yield Use(use)
 
@@ -388,10 +394,12 @@ class Ebuild(ToStrMixin):
 
     @property
     def version(self):
+        "Ebuild version"
         return self.package_object.version
 
     @property
     def revision(self):
+        "Ebuild revision"
         return self.package_object.revision
 
     @property



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-07 22:48 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-07 22:48 UTC (permalink / raw
  To: gentoo-commits

commit:     0157fd160bb40c5039308d1947f2b9620e467514
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Thu Jun  7 22:48:08 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Thu Jun  7 22:48:08 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=0157fd16

Add droping repeating keyword in porttree

---
 gpackages/libs/porttree.py |   42 +++++++++++++++++++++++++++++++++++++++---
 1 files changed, 39 insertions(+), 3 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 3bb6b6b..af7b513 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -1,3 +1,5 @@
+from functools import total_ordering
+from collections import defaultdict
 import portage
 from portage.util.listdir import listdir
 from portage.dep import Atom
@@ -74,15 +76,15 @@ class Use(ToStrMixin):
         return self.name
 
     def __eq__(self, other):
-        self.name == other.name
+        return self.name == other.name
 
     def __ne__(self, other):
-        self.name != other.name
+        return self.name != other.name
 
     def __hash__(self):
         return hash(self.name)
         
-
+@total_ordering
 class Keyword(ToStrMixin):
     "Represend ebuild Keyword as object"
     __slots__ = ('name', 'status')
@@ -109,11 +111,42 @@ class Keyword(ToStrMixin):
     def __unicode__(self):
         return self.status_repr[self.status] + self.name
 
+    def __hash__(self):
+        return hash((self.name, self.status))
+
+    def is_same(self, other):
+        return self.name == other.name
+
+    def is_higer(self, other):
+        return self.status < other.status
+
+    def is_lower(self, other):
+        return self.status > other.status
+
+    def __eq__(self, other):
+        return (self.arch, self.status) == (other.arch, other.status)
+
+    def __lt__(self, other):
+        return (self.status, self.arch) > (other.status, other.arch)
+
     @property
     def arch(self):
         "Return arch name"
         return self.name
 
+class KeywordsSet(set):
+    def __init__(self, init_list):
+        start = defaultdict(list)
+        for item in init_list:
+            start[item.arch].append(item)
+
+        to_create = []
+        for item in start.itervalues():
+            item.sort(reverse = True)
+            if len(item)>=1:
+                to_create.append(item[0])
+        super(KeywordsSet, self).__init__(to_create)
+
 def _gen_all_use(func, iterator):
     use_g = iterator
     use_all_dict = next(use_g)
@@ -372,6 +405,9 @@ class Ebuild(ToStrMixin):
             l.append(keyword)
         return l
 
+    def get_uniq_keywords(self):
+        return KeywordsSet(self.get_keywords)
+
     def get_uses_names(self):
         return self.package_object.environment("IUSE").split()
     



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-07 22:48 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-07 22:48 UTC (permalink / raw
  To: gentoo-commits

commit:     46d86e941ef13ea688ed96072bae6e924d758157
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Thu Jun  7 22:12:01 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Thu Jun  7 22:12:01 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=46d86e94

Litle bugfix for some objects.

---
 gpackages/libs/generic.py |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/generic.py b/gpackages/libs/generic.py
index 0629ed6..6d330e0 100644
--- a/gpackages/libs/generic.py
+++ b/gpackages/libs/generic.py
@@ -33,7 +33,7 @@ class StrThatIgnoreCase(unicode):
 
     def __init__(self, value):
         super(StrThatIgnoreCase, self).__init__(value)
-        self._forcmp = value.lower()
+        self._forcmp = self.lower()
 
     def __hash__(self):
         return hash(self._forcmp)



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-09 18:19 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-09 18:19 UTC (permalink / raw
  To: gentoo-commits

commit:     7a67e6580f068b9c7d356625198f61652cf3f70d
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sat Jun  9 11:05:52 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sat Jun  9 11:05:52 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=7a67e658

Add __all__ to porttree.py

---
 gpackages/libs/porttree.py |    2 ++
 1 files changed, 2 insertions(+), 0 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index af7b513..b5037cf 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -14,6 +14,8 @@ from generic import ToStrMixin, file_sha1, file_mtime, cached_property, \
 from use_info import get_uses_info, get_local_uses_info
 import os
 
+__all__ = ('Portage','PortTree', 'Category', 'Package', 'Ebuild')
+
 BINDB = portage.db[portage.root]["bintree"].dbapi
 PORTDB = portage.db[portage.root]["porttree"].dbapi
 VARDB = portage.db[portage.root]["vartree"].dbapi



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-09 18:19 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-09 18:19 UTC (permalink / raw
  To: gentoo-commits

commit:     189113dafa353390092cd35c087f8ff57ab2798a
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sat Jun  9 10:33:20 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sat Jun  9 10:33:20 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=189113da

Fix bug

---
 gpackages/libs/generic.py |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/gpackages/libs/generic.py b/gpackages/libs/generic.py
index 6d330e0..f1751b0 100644
--- a/gpackages/libs/generic.py
+++ b/gpackages/libs/generic.py
@@ -19,10 +19,10 @@ def get_from_kwargs_and_del(list_what, kwargs):
         list_what = (list_what, )
     for item in list_what:
         if item in kwargs:
-            ret_list.append(v)
+            ret_list.append(kwargs[item])
         else:
             ret_list.append(None)
-    del_from_dict(ret_list, kwargs)
+    del_from_dict(list_what, kwargs)
     if len(ret_list)==1:
         return ret_list[0]
     else:



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-10 17:51 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-10 17:51 UTC (permalink / raw
  To: gentoo-commits

commit:     bdc9a42234f5f4e8f6877437f185cebb3036014d
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Sun Jun 10 17:07:04 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Sun Jun 10 17:07:04 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=bdc9a422

Change exception type in porttree

---
 gpackages/libs/porttree.py |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index b5037cf..e71a806 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -167,7 +167,7 @@ class Portage(object):
         if tree_name in self.treemap:
             return PortTree(self.treemap[tree_name], tree_name)
         else:
-            raise AttributeError
+            raise ValueError
     
     def iter_trees(self):
         tree_dict = self.treemap



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-12 18:34 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-12 18:34 UTC (permalink / raw
  To: gentoo-commits

commit:     09c5d76cec81accff270fa33ba09e4092103ae85
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon Jun 11 22:22:58 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon Jun 11 22:22:58 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=09c5d76c

Add methods that always return uniq list to porttree

---
 gpackages/libs/porttree.py |   11 ++++++++++-
 1 files changed, 10 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index effb144..b5b90d8 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -416,7 +416,7 @@ class Ebuild(ToStrMixin):
         return l
 
     def get_uniq_keywords(self):
-        return KeywordsSet(self.get_keywords)
+        return KeywordsSet(self.get_keywords())
 
     def get_uses_names(self):
         return self.package_object.environment("IUSE").split()
@@ -433,6 +433,9 @@ class Ebuild(ToStrMixin):
             l.append(use)
         return l
 
+    def get_uniq_uses(self):
+        return frozenset(self.get_uses())
+
     #Could be faster
     @cached_property
     def is_masked(self):
@@ -478,6 +481,9 @@ class Ebuild(ToStrMixin):
             ret_list.append(StrThatIgnoreCase(ho))
         return ret_list
 
+    def get_uniq_homepages(self):
+        return frozenset(self.homepages)
+
     @cached_property
     def homepage(self):
         "First homepage in list"
@@ -493,6 +499,9 @@ class Ebuild(ToStrMixin):
             ret_list.append(StrThatIgnoreCase(lic))
         return ret_list
 
+    def get_uniq_licenses(self):
+        return frozenset(self.licenses)
+
     sha1 = cached_property(_file_hash("ebuild_path"), name = 'sha1')
     mtime = cached_property(_file_mtime("ebuild_path"), name = 'mtime')
 



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-12 18:34 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-12 18:34 UTC (permalink / raw
  To: gentoo-commits

commit:     ad5103886839a96fa67b7108140b2d6350b19040
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Tue Jun 12 12:45:12 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Tue Jun 12 12:45:12 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=ad510388

Get category description from category metadata

---
 gpackages/libs/porttree.py |   42 +++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 41 insertions(+), 1 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 6beac52..47d766a 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -14,6 +14,12 @@ from generic import ToStrMixin, file_sha1, file_mtime, cached_property, \
 from use_info import get_uses_info, get_local_uses_info
 import os
 
+#XML
+try:
+    import xml.etree.cElementTree as etree
+except (ImportError, SystemError):
+    import xml.etree.ElementTree as etree
+
 # Validators
 from django.core.validators import URLValidator, validate_email 
 from django.core.exceptions import ValidationError
@@ -180,6 +186,11 @@ class Portage(object):
         for tree_name in self.tree_order:
             yield PortTree(tree_dict[tree_name], tree_name)
 
+    def iter_categories(self):
+        for tree in self.iter_trees():
+            for category in tree.iter_categories():
+                yield category
+
     def iter_packages(self):
         for tree in self.iter_trees():
             for package in tree.iter_packages():
@@ -263,11 +274,31 @@ class PortTree(ToStrMixin):
                                  self.porttree_path,
                                  'profiles/use.local.desc')
 
+class CategoryMetadata(object):
+
+    def __init__(self, metadata_path):
+        self._metadata_xml = etree.parse(metadata_path)
+        self._descrs = {}
+        self._parse_descrs()
+
+    def _parse_descrs(self):
+        for descr_xml in self._metadata_xml.iterfind('longdescription'):
+            lang = descr_xml.attrib.get('lang', 'en')
+            self._descrs[lang] = descr_xml.text
+
+    @property
+    def descrs(self):
+        return self._descrs
+
+    @property
+    def default_descr(self):
+        return self._descrs.get('en')
+
 
 class Category(ToStrMixin):
     "Represent category of portage tree as object"
 
-    __slots__ = ('porttree', 'category')
+    __slots__ = ('porttree', 'category', '_cache')
     
     def __init__(self, porttree, category):
         """Args:
@@ -276,6 +307,7 @@ class Category(ToStrMixin):
         """
         self.porttree = porttree
         self.category = category
+        self._cache = {}
     
     def iter_packages(self):
         packages = listdir(self.porttree.porttree + '/'+ self.category,
@@ -298,6 +330,14 @@ class Category(ToStrMixin):
         return os.path.join(self.porttree.porttree_path, self.category)
 
     @property
+    def metadata_path(self):
+        return os.path.join(self.category_path, 'metadata.xml')
+
+    @cached_property
+    def metadata(self):
+        return CategoryMetadata(self.metadata_path)
+
+    @property
     def porttree_path(self):
         return self.porttree.porttree
 



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-14 19:10 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-14 19:10 UTC (permalink / raw
  To: gentoo-commits

commit:     0d1cacdb7f1b863dba7c7110aaf03e59c3169f7f
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Thu Jun 14 18:14:02 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Thu Jun 14 18:14:02 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=0d1cacdb

Fix bug in categories metadata

---
 gpackages/libs/porttree.py |    8 ++++++--
 1 files changed, 6 insertions(+), 2 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index c33c159..0e4f352 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -275,9 +275,13 @@ class CategoryMetadata(ToStrMixin):
 
     def __init__(self, metadata_path):
         self._metadata_path = metadata_path
-        self._metadata_xml = etree.parse(metadata_path)
         self._descrs = {}
-        self._parse_descrs()
+        try:
+            self._metadata_xml = etree.parse(metadata_path)
+        except IOError:
+            pass
+        else:
+            self._parse_descrs()
 
     def _parse_descrs(self):
         for descr_xml in self._metadata_xml.iterfind('longdescription'):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-18 21:26 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-18 21:26 UTC (permalink / raw
  To: gentoo-commits

commit:     2a28d1f1ff674b2fdfe2cdbab28cd9e19e58635f
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon Jun 18 15:18:29 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon Jun 18 16:37:36 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=2a28d1f1

Add repo info layer

---
 gpackages/libs/repo_info.py |   93 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 93 insertions(+), 0 deletions(-)

diff --git a/gpackages/libs/repo_info.py b/gpackages/libs/repo_info.py
new file mode 100644
index 0000000..4deee56
--- /dev/null
+++ b/gpackages/libs/repo_info.py
@@ -0,0 +1,93 @@
+# Layman API
+from layman.api import LaymanAPI
+layman_api = LaymanAPI()
+
+# Validators
+from validators import validate_url, validate_email, ValidationError
+
+__all__ = ('TreeMetadata',)
+
+def _gen_funct(name):
+    func = lambda self: self._dct.get(name)
+    func.__name__ = name
+    return func
+
+class TreeMetadataMetaclass(type):
+    
+    def __init__(cls, name, bases, dct):
+        super(TreeMetadataMetaclass, cls).__init__(name, bases, dct)
+        for v in cls.simple_attrs:
+            setattr(cls, v, property(_gen_funct(v)))
+
+class TreeMetadata(object):
+    __metaclass__ = TreeMetadataMetaclass
+
+    simple_attrs = ( 'name', 'description', 'supported', 'owner_name',
+                     'official', 'irc'
+                   )
+    statuses = {'official': 0, 'unofficial': 1}
+    qualities = {'stable': 0 , 'testing': 1, 'experimental': 2}
+
+    def __init__(self, repo_name, dct = None):
+        if dct is None:
+            dct = self._get_info(repo_name)
+
+        self._dct = dct
+
+    def _get_info(self, repo_name):
+        if repo_name != 'gentoo':
+            return layman_api.get_all_info(repo_name)[repo_name]
+        else:
+            return {'name': 'gentoo',
+                    'description': 'Gentoo main repository',
+                    'supported': True,
+                    'owner_name': None,
+                    'owner_email': None,
+                    'official': True,
+                    'irc': None,
+                    'homepage': 'http://gentoo.org/',
+                    'quality': 'stable',
+                    'status': 'official',
+                    'feeds': [],
+                   }
+
+    @property
+    def int_status(self):
+        return self.statuses.get(self._dct['status'], 1)
+
+    @property
+    def homepage(self):
+        homepage = self._dct.get('homepage')
+        try:
+            validate_url(homepage)
+        except ValidationError:
+            return None
+        else:
+            return homepage
+
+    @property
+    def owner_email(self):
+        email = self._dct.get('owner_email')
+        try:
+            validate_email(email)
+        except ValidationError:
+            return None
+        else:
+            return email
+
+    @property
+    def feeds(self):
+        ret = []
+        for feed in self._dct.get('feeds', ()):
+            try:
+                validate_url(feed)
+            except ValidationError:
+                pass
+            else:
+                ret.append(feed)
+        return ret
+
+    @property
+    def int_quality(self):
+        return self.qualities.get(self._dct['quality'], 2)
+



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-18 21:26 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-18 21:26 UTC (permalink / raw
  To: gentoo-commits

commit:     17490f6c41099108f5f5d7280044ddd1accfde08
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon Jun 18 15:18:09 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon Jun 18 15:18:09 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=17490f6c

Move validators to module

---
 gpackages/libs/porttree.py   |    5 +----
 gpackages/libs/validators.py |    7 +++++++
 2 files changed, 8 insertions(+), 4 deletions(-)

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 0e4f352..995ef91 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -18,10 +18,7 @@ import os
 from my_etree import etree
 
 # Validators
-from django.core.validators import URLValidator, validate_email 
-from django.core.exceptions import ValidationError
-
-validate_url = URLValidator()
+from validators import validate_url, validate_url, ValidationError
 
 __all__ = ('Portage','PortTree', 'Category', 'Package', 'Ebuild')
 

diff --git a/gpackages/libs/validators.py b/gpackages/libs/validators.py
new file mode 100644
index 0000000..d86e7b8
--- /dev/null
+++ b/gpackages/libs/validators.py
@@ -0,0 +1,7 @@
+# Validators
+from django.core.validators import URLValidator, validate_email 
+from django.core.exceptions import ValidationError
+
+validate_url = URLValidator()
+
+__all__ = ('validate_email', 'validate_url', 'ValidationError')



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-18 21:26 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-18 21:26 UTC (permalink / raw
  To: gentoo-commits

commit:     34849f4bb9114c2921de17b5cd587353e8aa602a
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Mon Jun 18 21:25:55 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Mon Jun 18 21:25:55 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=34849f4b

Add repo_name checking

---
 gpackages/libs/repo_info.py |   27 ++++++++++++++++++++++++---
 1 files changed, 24 insertions(+), 3 deletions(-)

diff --git a/gpackages/libs/repo_info.py b/gpackages/libs/repo_info.py
index cce3d4f..ac4b744 100644
--- a/gpackages/libs/repo_info.py
+++ b/gpackages/libs/repo_info.py
@@ -87,6 +87,7 @@ class TreeMetadata(ToStrMixin):
     qualities = {'stable': 0 , 'testing': 1, 'experimental': 2}
 
     def __init__(self, repo_name, dct = None):
+        repo_name = self._find_real_repo_name(repo_name)
         self.repo_name = repo_name
 
         if dct is None:
@@ -94,10 +95,24 @@ class TreeMetadata(ToStrMixin):
 
         self._dct = dct
 
+    def _find_real_repo_name(self, repo_name):
+        gen_str = 'gentoo-'
+
+        if repo_name == 'gentoo':
+            return repo_name
+        elif layman_api.is_repo(repo_name):
+            return repo_name
+        elif layman_api.is_repo(gen_str + repo_name):
+            return gen_str + repo_name
+        elif repo_name.startswith(gen_str) and \
+            layman_api.is_repo(repo_name[len(gen_str):]):
+
+            return repo_name[len(gen_str):]
+
+        return None
+
     def _get_info(self, repo_name):
-        if repo_name != 'gentoo':
-            return layman_api.get_all_info(repo_name)[repo_name]
-        else:
+        if repo_name == 'gentoo':
             return {'name': 'gentoo',
                     'description': 'Gentoo main repository',
                     'supported': True,
@@ -111,6 +126,12 @@ class TreeMetadata(ToStrMixin):
                     'feeds': [],
                     'sources': [],
                    }
+        elif repo_name is None:
+            return {'name': 'none',
+                    'description': None,
+                   }
+        else:
+            return layman_api.get_all_info(repo_name)[repo_name]
 
     @property
     def int_status(self):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-20 23:23 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-20 23:23 UTC (permalink / raw
  To: gentoo-commits

commit:     ddba123a5a29de786959a5a548b89991738cb2fe
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Wed Jun 20 12:50:53 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Wed Jun 20 12:50:53 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=ddba123a

Refactor porttree

---
 gpackages/libs/generic.py  |    8 ++++-
 gpackages/libs/porttree.py |   64 ++++++++++++++++++++++++--------------------
 2 files changed, 41 insertions(+), 31 deletions(-)

diff --git a/gpackages/libs/generic.py b/gpackages/libs/generic.py
index 409ec09..b8312c4 100644
--- a/gpackages/libs/generic.py
+++ b/gpackages/libs/generic.py
@@ -3,9 +3,13 @@ import hashlib
 import types
 from datetime import datetime
 
-__all__ = ('StrThatIgnoreCase', 'ToStrMixin', 'file_get_content', 'file_sha1', \
-           'file_mtime', 'cached_property' )
+__all__ = ('StrThatIgnoreCase', 'ToStrMixin', 'file_get_content', 'file_sha1',\
+           'file_mtime', 'cached_property', 'iter_over_gen', 'lofstr_to_ig')
 
+def iter_over_gen(iterat, name):
+    for obj in iterat:
+        for item in getattr(obj, name)():
+            yield item
 def del_from_dict(what_list, dict_todel):
     for item in what_list:
         if item in dict_todel:

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 75812ab..637e198 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -10,7 +10,9 @@ from gentoolkit.package import Package as PackageInfo
 from gentoolkit.metadata import MetaData
 from gentoolkit import errors
 from generic import ToStrMixin, file_sha1, file_mtime, cached_property, \
-                    file_get_content, StrThatIgnoreCase, lofstr_to_ig
+                    file_get_content, StrThatIgnoreCase, lofstr_to_ig, \
+                    iter_over_gen
+
 from use_info import get_uses_info, get_local_uses_info
 import os
 
@@ -166,7 +168,27 @@ def _gen_all_use(func, iterator):
             func(use_all_dict, use_dict)
     return use_all_dict
 
-class Portage(object):
+
+def gen_generator_over_gen(gen_name, name):
+    return lambda self: iter_over_gen(getattr(self, gen_name)(), name)
+
+class IteratorAddMetaclass(type):
+    
+    def __init__(cls, name, bases, dct):
+        super(IteratorAddMetaclass, cls).__init__(name, bases, dct)
+        for name in cls.generator_names:
+            setattr(cls, name, gen_generator_over_gen(cls.main_iterator, name))
+
+class AutoGeneratorMixin(object):
+
+    __metaclass__ = IteratorAddMetaclass
+    generator_names = ()
+    #main_iterator = 'generator_name'
+
+class Portage(ToStrMixin, AutoGeneratorMixin):
+
+    generator_names = ('iter_categories', 'iter_packages', 'iter_ebuilds')
+    main_iterator = 'iter_trees'
 
     def __init__(self):
         self.treemap = PORTDB.repositories.treemap
@@ -183,21 +205,6 @@ class Portage(object):
         for tree_name in self.tree_order:
             yield PortTree(tree_dict[tree_name], tree_name)
 
-    def iter_categories(self):
-        for tree in self.iter_trees():
-            for category in tree.iter_categories():
-                yield category
-
-    def iter_packages(self):
-        for tree in self.iter_trees():
-            for package in tree.iter_packages():
-                yield package
-
-    def iter_ebuilds(self):
-        for tree in self.iter_trees():
-            for ebuild in tree.iter_ebuilds():
-                yield ebuild
-    
     def iter_use_desc(self):
         for tree in self.iter_trees():
             yield tree.use_desc
@@ -224,9 +231,15 @@ class Portage(object):
     def dict_repos(self):
         return self.treemap
 
+    def __unicode__(self):
+        return u'portage'
+
 
-class PortTree(ToStrMixin):
+class PortTree(ToStrMixin, AutoGeneratorMixin):
     "Represent portage tree as object"
+
+    main_iterator = 'iter_categories'
+    generator_names = ('iter_packages', 'iter_ebuilds')
     
     def __init__(self, tree_path = '/usr/portage', name = 'main'):
         """Args:
@@ -241,16 +254,6 @@ class PortTree(ToStrMixin):
             if os.path.isdir(os.path.join(self.porttree_path, category)):
                     yield Category(self, category)
 
-    def iter_packages(self):
-        for category in self.iter_categories():
-            for package in category.iter_packages():
-                yield package
-    
-    def iter_ebuilds(self):
-        for package in self.iter_packages():
-            for ebuild in package.iter_ebuilds():
-                yield ebuild
-
     def __unicode__(self):
         return self.name
     
@@ -304,10 +307,13 @@ class CategoryMetadata(ToStrMixin):
         return unicode(self._metadata_path)
 
 
-class Category(ToStrMixin):
+class Category(ToStrMixin, AutoGeneratorMixin):
     "Represent category of portage tree as object"
 
     __slots__ = ('porttree', 'category', '_cache')
+
+    main_iterator = 'iter_packages'
+    generator_names = ('iter_ebuilds', )
     
     def __init__(self, porttree, category):
         """Args:



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-20 23:23 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-20 23:23 UTC (permalink / raw
  To: gentoo-commits

commit:     b178ac66b1bb8bba1cf5037076ca401784a19be5
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Wed Jun 20 17:28:48 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Wed Jun 20 17:28:48 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=b178ac66

Add basic pkgcore layer

---
 gpackages/libs/pkgcore_porttree.py |  147 ++++++++++++++++++++++++++++++++++++
 gpackages/libs/porttree.py         |    4 +-
 2 files changed, 149 insertions(+), 2 deletions(-)

diff --git a/gpackages/libs/pkgcore_porttree.py b/gpackages/libs/pkgcore_porttree.py
new file mode 100644
index 0000000..ac15e2f
--- /dev/null
+++ b/gpackages/libs/pkgcore_porttree.py
@@ -0,0 +1,147 @@
+from pkgcore.config import load_config
+from pkgcore.ebuild.repository import UnconfiguredTree, SlavedTree
+from pkgcore.util.repo_utils import get_raw_repos, get_virtual_repos
+from pkgcore.ebuild.atom import atom
+
+from generic import ToStrMixin
+
+from porttree import AutoGeneratorMixin
+
+import os.path
+
+
+class Portage(AutoGeneratorMixin):
+
+    generator_names = ('iter_categories', 'iter_packages', 'iter_ebuilds')
+    main_iterator = 'iter_trees'
+
+    def __init__(self):
+        self._config = load_config()
+        self._domains = self._config.domain
+        self._set_default_domain('livefs domain')
+        self._get_repos()
+
+    def _set_default_domain(self, domain_name):
+        domain = None
+        try:
+            domain = self._domains[domain_name]
+        except KeyError:
+            raise ValueError("Bad domain name - '%s'" % domain_name)
+        finally:
+            self._domain = domain
+
+    def _get_repos(self):
+        repo_dict = {}
+        repo_list = []
+        repos = get_virtual_repos(get_raw_repos(self._domain.repos), False)
+        for repo in repos:
+            if isinstance(repo, UnconfiguredTree) or isinstance(repo, SlavedTree):
+                repo_dict[repo.repo_id] = repo
+                repo_list.append(repo)
+        repo_list.reverse()
+        self.repo_list = repo_list
+        self.repo_dict = repo_dict
+
+    def iter_trees(self):
+        for tree in self.repo_list:
+            yield PortTree(tree)
+
+    def get_tree_by_name(self, tree_name):
+        if tree_name in self.repo_dict:
+            return PortTree(self.tree_dict[tree_name])
+        else:
+            raise ValueError
+        
+class PortTree(ToStrMixin, AutoGeneratorMixin):
+
+    generator_names = ('iter_packages', 'iter_ebuilds')
+    main_iterator = 'iter_categories'
+
+    def __init__(self, repo_obj):
+        self._repo_obj = repo_obj
+        self.name = repo_obj.repo_id
+        self.categories = sorted(repo_obj.categories)
+
+    def iter_categories(self):
+        for category in self.categories:
+            yield Category(category, self)
+
+    @property
+    def porttree_path(self):
+        "Full path to portage tree"
+        return self._repo_obj.location
+
+    def __unicode__(self):
+        return self.name
+
+    @property
+    def _packages(self):
+        return self._repo_obj.packages
+
+    def _itermatch(self, res):
+        return self._repo_obj.itermatch(res)
+
+    @property
+    def _versions(self):
+        return self._repo_obj.versions
+
+class Category(ToStrMixin, AutoGeneratorMixin):
+
+    generator_names = ('iter_ebuilds', )
+    main_iterator = 'iter_packages'
+    
+    def __init__(self, category_name, repo_obj):
+        self._repo_obj = repo_obj
+        self.name = category_name
+
+    def iter_packages(self):
+        for package_name in self._get_packages_names():
+            yield Package(package_name, self)
+
+    @property
+    def category_path(self):
+        "Full path to category"
+        return os.path.join(self.porttree_path, self.category)
+
+    def _get_packages_names(self):
+        return self._repo_obj._packages[self.name]
+
+    def _get_ebuilds_names_by_name(self, package_name):
+        return self._repo_obj._versions[(self.name, package_name)]
+
+    def __unicode__(self):
+        return self.name
+
+class Package(ToStrMixin):
+    
+    def __init__(self, package_name, category_obj):
+        self.name = package_name
+        self.category_obj = category_obj
+
+    def iter_ebuilds(self):
+        for ebuild in self.category_obj._repo_obj._itermatch(atom(self.cp)):
+            yield Ebuild(ebuild, self)
+
+    def __unicode__(self):
+        return self.cp
+
+    def _get_ebuilds_versions(self):
+        return self.category_obj._get_ebuilds_names_by_name(self.name)
+
+    @property
+    def cp(self):
+        return '%s/%s' % (self.category_obj.name, self.name)
+
+
+class Ebuild(ToStrMixin):
+    
+    def __init__(self, ebuild, package_obj):
+        self._ebuild = ebuild
+        self.package_obj = package_obj
+
+    def __unicode__(self):
+        return self.cpv
+
+    @property
+    def cpv(self):
+        return self._ebuild.cpvstr

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 637e198..8adb502 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -342,7 +342,7 @@ class Category(ToStrMixin, AutoGeneratorMixin):
     @property
     def category_path(self):
         "Full path to category"
-        return os.path.join(self.porttree.porttree_path, self.category)
+        return os.path.join(self.porttree_path, self.category)
 
     @property
     def metadata_path(self):
@@ -380,7 +380,7 @@ class Package(ToStrMixin):
                 yield ebuild_obj
 
     def __unicode__(self):
-        return '%s' % self.package
+        return unicode(self.cp)
 
     @property
     def package_path(self):



^ permalink raw reply related	[flat|nested] 35+ messages in thread

* [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/
@ 2012-06-20 23:23 Slava Bacherikov
  0 siblings, 0 replies; 35+ messages in thread
From: Slava Bacherikov @ 2012-06-20 23:23 UTC (permalink / raw
  To: gentoo-commits

commit:     8e5aaa4fd9b8b9a5ff4ff6aebedb1b60d49d1408
Author:     Slava Bacherikov <slava <AT> bacher09 <DOT> org>
AuthorDate: Wed Jun 20 23:23:30 2012 +0000
Commit:     Slava Bacherikov <slava <AT> bacherikov <DOT> org <DOT> ua>
CommitDate: Wed Jun 20 23:23:30 2012 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/gentoo-packages.git;a=commit;h=8e5aaa4f

Divide porttree to mixins

---
 gpackages/libs/category_metadata.py |   49 ++++++
 gpackages/libs/generic_objects.py   |   92 ++++++++++
 gpackages/libs/mixins.py            |  194 +++++++++++++++++++++
 gpackages/libs/porttree.py          |  317 +++--------------------------------
 4 files changed, 356 insertions(+), 296 deletions(-)

diff --git a/gpackages/libs/category_metadata.py b/gpackages/libs/category_metadata.py
new file mode 100644
index 0000000..a834895
--- /dev/null
+++ b/gpackages/libs/category_metadata.py
@@ -0,0 +1,49 @@
+from generic import ToStrMixin
+#XML
+from my_etree import etree
+
+__all__ = ('CategoryMetadata', )
+
+class CategoryMetadata(ToStrMixin):
+
+    def __init__(self, metadata_path):
+        self._metadata_path = metadata_path
+        self._descrs = {}
+        try:
+            self._metadata_xml = etree.parse(metadata_path)
+        except IOError:
+            pass
+        else:
+            self._parse_descrs()
+
+    def _parse_descrs(self):
+        for descr_xml in self._metadata_xml.iterfind('longdescription'):
+            lang = descr_xml.attrib.get('lang', 'en')
+            self._descrs[lang] = descr_xml.text
+
+    @property
+    def descrs(self):
+        return self._descrs
+
+    @property
+    def default_descr(self):
+        return self._descrs.get('en')
+
+    def __unicode__(self):
+        return unicode(self._metadata_path)
+
+
+class FakeMetaData(ToStrMixin):
+
+    def herds(self):
+        return []
+
+    def maintainers(self):
+        return []
+
+    def descriptions(self):
+        return []
+    
+    def __unicode__(self):
+        return 'fake'
+

diff --git a/gpackages/libs/generic_objects.py b/gpackages/libs/generic_objects.py
new file mode 100644
index 0000000..1e82d3a
--- /dev/null
+++ b/gpackages/libs/generic_objects.py
@@ -0,0 +1,92 @@
+from generic import StrThatIgnoreCase, ToStrMixin
+from functools import total_ordering
+from collections import defaultdict
+
+__all__ = ('Use', 'Keyword', 'KeywordsSet')
+
+class Use(ToStrMixin):
+    "Represend Use flag as object"
+    __slots__ = ('name',)
+
+    def __init__(self, name):
+        """Args:
+            name -- name of use flag, may start with + or -
+        """
+        if name.startswith('+') or name.startswith('-'):
+            name = name[1:]
+        self.name = StrThatIgnoreCase(name)
+
+    def __unicode__(self):
+        return self.name
+
+    def __eq__(self, other):
+        return self.name == other.name
+
+    def __ne__(self, other):
+        return self.name != other.name
+
+    def __hash__(self):
+        return hash(self.name)
+        
+@total_ordering
+class Keyword(ToStrMixin):
+    "Represend ebuild Keyword as object"
+    __slots__ = ('name', 'status')
+    status_repr = ['','~','-']
+    
+    def __init__(self, name, status = 0):
+        """Args:
+            name -- name of keyword, it may start with ~ or -, if so than 
+                    status will be auto seting.
+            status -- status of keyword: 0 - stable, 
+                                         1 - utested '~',
+                                         2 - unstable '-'
+                    Also may get by name parameter.
+        """
+        if name.startswith('~'):
+            name = name[1:]
+            status = 1
+        elif name.startswith('-'):
+            name = name[1:]
+            status = 2
+        self.name = name
+        self.status = status
+
+    def __unicode__(self):
+        return self.status_repr[self.status] + self.name
+
+    def __hash__(self):
+        return hash((self.name, self.status))
+
+    def is_same(self, other):
+        return self.name == other.name
+
+    def is_higer(self, other):
+        return self.status < other.status
+
+    def is_lower(self, other):
+        return self.status > other.status
+
+    def __eq__(self, other):
+        return (self.arch, self.status) == (other.arch, other.status)
+
+    def __lt__(self, other):
+        return (self.status, self.arch) > (other.status, other.arch)
+
+    @property
+    def arch(self):
+        "Return arch name"
+        return self.name
+
+class KeywordsSet(set):
+    def __init__(self, init_list):
+        start = defaultdict(list)
+        for item in init_list:
+            start[item.arch].append(item)
+
+        to_create = []
+        for item in start.itervalues():
+            item.sort(reverse = True)
+            if len(item)>=1:
+                to_create.append(item[0])
+        super(KeywordsSet, self).__init__(to_create)

diff --git a/gpackages/libs/mixins.py b/gpackages/libs/mixins.py
new file mode 100644
index 0000000..3c35a3c
--- /dev/null
+++ b/gpackages/libs/mixins.py
@@ -0,0 +1,194 @@
+from generic import ToStrMixin, file_sha1, file_mtime, cached_property, \
+                    file_get_content, iter_over_gen
+
+from use_info import get_uses_info, get_local_uses_info
+# Repo info
+from repo_info import TreeMetadata
+import os.path
+
+def _file_path(file_name):
+    return lambda self: os.path.join(self.package_path, file_name)
+
+def _file_hash(attr):
+    return lambda self: file_sha1(getattr(self, attr))
+
+def _file_mtime(attr):
+    return lambda self: file_mtime(getattr(self, attr))
+
+
+def gen_generator_over_gen(gen_name, name):
+    return lambda self: iter_over_gen(getattr(self, gen_name)(), name)
+
+class IteratorAddMetaclass(type):
+    
+    def __init__(cls, name, bases, dct):
+        super(IteratorAddMetaclass, cls).__init__(name, bases, dct)
+        for name in cls.generator_names:
+            setattr(cls, name, gen_generator_over_gen(cls.main_iterator, name))
+
+class AutoGeneratorMixin(object):
+
+    __metaclass__ = IteratorAddMetaclass
+    generator_names = ()
+    #main_iterator = 'generator_name'
+
+
+class PortageBaseMixin(ToStrMixin):
+    def iter_use_desc(self):
+        for tree in self.iter_trees():
+            yield tree.use_desc
+
+    def iter_use_local_desc(self):
+        for tree in self.iter_trees():
+            yield tree.use_local_desc
+
+    def get_all_use_desc(self):
+        return _gen_all_use(lambda x,y: x.update(y), self.iter_use_desc())
+
+    def get_all_use_local_desc(self):
+        def action(all_dict, use_dict):
+            for key, value in use_dict.iteritems():
+                all_dict[key].update(value)
+
+        return _gen_all_use(action, self.iter_use_local_desc())
+
+    def __unicode__(self):
+        return u'portage'
+
+class PortageIteratorMixin(AutoGeneratorMixin):
+    main_iterator = 'iter_trees'
+    generator_names = ('iter_categories', 'iter_packages', 'iter_ebuilds')
+
+class PortTreeBaseMixin(ToStrMixin):
+
+    @cached_property
+    def metadata(self):
+        return TreeMetadata(self.name)
+
+    @cached_property
+    def use_desc(self):
+        return _get_info_by_func(get_uses_info,
+                                 self.porttree_path,
+                                 'profiles/use.desc')
+
+    @cached_property
+    def use_local_desc(self):
+        return _get_info_by_func(get_local_uses_info,
+                                 self.porttree_path,
+                                 'profiles/use.local.desc')
+
+    def __unicode__(self):
+        return self.name
+
+class PortTreeIteratorMixin(AutoGeneratorMixin):
+    main_iterator = 'iter_categories'
+    generator_names = ('iter_packages', 'iter_ebuilds')
+    
+class MetaDataPath(object):
+
+    @property
+    def metadata_path(self):
+        raise NotImplementedError
+
+class CategoryBaseMixin(ToStrMixin):
+
+    @property
+    def metadata_path(self):
+        return os.path.join(self.category_path, 'metadata.xml')
+
+    @cached_property
+    def metadata_sha1(self):
+        return file_sha1(self.metadata_path)
+
+    @cached_property
+    def metadata(self):
+        return CategoryMetadata(self.metadata_path)
+
+    def __unicode__(self):
+        return self.name
+
+class CategoryIteratorMixin(AutoGeneratorMixin):
+    main_iterator = 'iter_packages'
+    generator_names = ('iter_ebuilds', )
+    
+class PackageBaseMixin(ToStrMixin, MetaDataPath):
+
+    @cached_property
+    def metadata(self):
+        "Return `MetaData` object that represent package metadata.xml file"
+        try:
+            return MetaData( self.metadata_path)
+        except IOError:
+            return FakeMetaData()
+
+    @cached_property
+    def descriptions(self):
+        return self.metadata.descriptions()
+
+    @property
+    def description(self):
+        "Return first description in package metadata.xml"
+        if len(self.descriptions)>0:
+            return self.descriptions[0]
+        else:
+            return None
+    @property
+    def cp(self):
+        raise NotImplementedError
+
+    def __unicode__(self):
+        return unicode(self.cp)
+
+class PackageFilesMixin(object):
+    #Paths 
+    manifest_path = property(_file_path('Manifest'))
+    changelog_path = property(_file_path('ChangeLog'))
+    metadata_path = property(_file_path('metadata.xml'))
+
+    #Hashes
+    manifest_sha1 = cached_property(_file_hash('manifest_path'),
+                                    name = 'manifest_sha1')
+    changelog_sha1 = cached_property(_file_hash('changelog_path'),
+                                     name = 'changelog_sha1')
+    metadata_sha1 = cached_property(_file_hash('metadata_path'),
+                                    name = 'metadata_sha1')
+
+    # Modify times
+    manifest_mtime = property(_file_mtime("manifest_path"))
+    changelog_mtime = property(_file_mtime("changelog_path"))
+    metadata_mtime = property(_file_mtime("metadata_path"))
+
+    mtime = property(_file_mtime("package_path"))
+
+    @cached_property
+    def changelog(self):
+        "Return ChangeLog content"
+        return file_get_content(self.changelog_path)
+
+class EbuildBaseMixin(ToStrMixin):
+
+    sha1 = cached_property(_file_hash("ebuild_path"), name = 'sha1')
+    mtime = cached_property(_file_mtime("ebuild_path"), name = 'mtime')
+    
+    @property
+    def cpv(self):
+        raise NotImplementedError
+
+    def __unicode__(self):
+        return unicode(self.cpv)
+
+#Main mixins
+class PortageMixin(PortageBaseMixin, PortageIteratorMixin):
+    pass
+
+class PortTreeMixin(PortTreeBaseMixin, PortTreeIteratorMixin):
+    pass
+
+class CategoryMixin(CategoryBaseMixin, CategoryIteratorMixin):
+    pass
+
+class PackageMixin(PackageBaseMixin, PackageFilesMixin):
+    pass
+
+class EbuildMixin(EbuildBaseMixin):
+    pass

diff --git a/gpackages/libs/porttree.py b/gpackages/libs/porttree.py
index 8adb502..74a6e6e 100644
--- a/gpackages/libs/porttree.py
+++ b/gpackages/libs/porttree.py
@@ -1,5 +1,3 @@
-from functools import total_ordering
-from collections import defaultdict
 import portage
 from portage.util.listdir import listdir
 from portage.dep import Atom
@@ -9,21 +7,21 @@ from portage.exception import PortageException, FileNotFound, InvalidAtom, \
 from gentoolkit.package import Package as PackageInfo
 from gentoolkit.metadata import MetaData
 from gentoolkit import errors
-from generic import ToStrMixin, file_sha1, file_mtime, cached_property, \
-                    file_get_content, StrThatIgnoreCase, lofstr_to_ig, \
-                    iter_over_gen
+from generic import cached_property, lofstr_to_ig 
 
-from use_info import get_uses_info, get_local_uses_info
-import os
+import os.path
 
-#XML
-from my_etree import etree
+#Generic objects
+from generic_objects import Use, Keyword, KeywordsSet
+
+#Mixins
+from mixins import PortageMixin, PortTreeMixin, CategoryMixin, PackageMixin, \
+                   EbuildMixin
 
 # Validators
 from validators import validate_url, validate_url, ValidationError
 
-# Repo info
-from repo_info import TreeMetadata
+from category_metadata import CategoryMetadata, FakeMetaData
 
 __all__ = ('Portage','PortTree', 'Category', 'Package', 'Ebuild')
 
@@ -37,16 +35,6 @@ _license_filter = lambda x: False if x.startswith('|') or x.startswith('(') or \
                                      x.endswith('?') or x.startswith(')') \
                                   else True
 
-def _file_path(file_name):
-    return lambda self: os.path.join(self.package_path, file_name)
-
-
-def _file_hash(attr):
-    return lambda self: file_sha1(getattr(self, attr))
-
-def _file_mtime(attr):
-    return lambda self: file_mtime(getattr(self, attr))
-
 def _ebuild_environment(name):
     return lambda self: self.package_object.environment(name)
 
@@ -58,108 +46,6 @@ def _get_info_by_func(func, path1, path2):
         except IOError:
             return None
 
-class FakeMetaData(ToStrMixin):
-
-    def herds(self):
-        return []
-
-    def maintainers(self):
-        return []
-
-    def descriptions(self):
-        return []
-    
-    def __unicode__(self):
-        return 'fake'
-
-
-class Use(ToStrMixin):
-    "Represend Use flag as object"
-    __slots__ = ('name',)
-
-    def __init__(self, name):
-        """Args:
-            name -- name of use flag, may start with + or -
-        """
-        if name.startswith('+') or name.startswith('-'):
-            name = name[1:]
-        self.name = StrThatIgnoreCase(name)
-
-    def __unicode__(self):
-        return self.name
-
-    def __eq__(self, other):
-        return self.name == other.name
-
-    def __ne__(self, other):
-        return self.name != other.name
-
-    def __hash__(self):
-        return hash(self.name)
-        
-@total_ordering
-class Keyword(ToStrMixin):
-    "Represend ebuild Keyword as object"
-    __slots__ = ('name', 'status')
-    status_repr = ['','~','-']
-    
-    def __init__(self, name, status = 0):
-        """Args:
-            name -- name of keyword, it may start with ~ or -, if so than 
-                    status will be auto seting.
-            status -- status of keyword: 0 - stable, 
-                                         1 - utested '~',
-                                         2 - unstable '-'
-                    Also may get by name parameter.
-        """
-        if name.startswith('~'):
-            name = name[1:]
-            status = 1
-        elif name.startswith('-'):
-            name = name[1:]
-            status = 2
-        self.name = name
-        self.status = status
-
-    def __unicode__(self):
-        return self.status_repr[self.status] + self.name
-
-    def __hash__(self):
-        return hash((self.name, self.status))
-
-    def is_same(self, other):
-        return self.name == other.name
-
-    def is_higer(self, other):
-        return self.status < other.status
-
-    def is_lower(self, other):
-        return self.status > other.status
-
-    def __eq__(self, other):
-        return (self.arch, self.status) == (other.arch, other.status)
-
-    def __lt__(self, other):
-        return (self.status, self.arch) > (other.status, other.arch)
-
-    @property
-    def arch(self):
-        "Return arch name"
-        return self.name
-
-class KeywordsSet(set):
-    def __init__(self, init_list):
-        start = defaultdict(list)
-        for item in init_list:
-            start[item.arch].append(item)
-
-        to_create = []
-        for item in start.itervalues():
-            item.sort(reverse = True)
-            if len(item)>=1:
-                to_create.append(item[0])
-        super(KeywordsSet, self).__init__(to_create)
-
 def _gen_all_use(func, iterator):
     use_g = iterator
     use_all_dict = next(use_g)
@@ -168,27 +54,7 @@ def _gen_all_use(func, iterator):
             func(use_all_dict, use_dict)
     return use_all_dict
 
-
-def gen_generator_over_gen(gen_name, name):
-    return lambda self: iter_over_gen(getattr(self, gen_name)(), name)
-
-class IteratorAddMetaclass(type):
-    
-    def __init__(cls, name, bases, dct):
-        super(IteratorAddMetaclass, cls).__init__(name, bases, dct)
-        for name in cls.generator_names:
-            setattr(cls, name, gen_generator_over_gen(cls.main_iterator, name))
-
-class AutoGeneratorMixin(object):
-
-    __metaclass__ = IteratorAddMetaclass
-    generator_names = ()
-    #main_iterator = 'generator_name'
-
-class Portage(ToStrMixin, AutoGeneratorMixin):
-
-    generator_names = ('iter_categories', 'iter_packages', 'iter_ebuilds')
-    main_iterator = 'iter_trees'
+class Portage(PortageMixin):
 
     def __init__(self):
         self.treemap = PORTDB.repositories.treemap
@@ -205,24 +71,6 @@ class Portage(ToStrMixin, AutoGeneratorMixin):
         for tree_name in self.tree_order:
             yield PortTree(tree_dict[tree_name], tree_name)
 
-    def iter_use_desc(self):
-        for tree in self.iter_trees():
-            yield tree.use_desc
-
-    def iter_use_local_desc(self):
-        for tree in self.iter_trees():
-            yield tree.use_local_desc
-
-    def get_all_use_desc(self):
-        return _gen_all_use(lambda x,y: x.update(y), self.iter_use_desc())
-
-    def get_all_use_local_desc(self):
-        def action(all_dict, use_dict):
-            for key, value in use_dict.iteritems():
-                all_dict[key].update(value)
-
-        return _gen_all_use(action, self.iter_use_local_desc())
-
     @property
     def list_repos(self):
         return self.tree_order
@@ -231,16 +79,9 @@ class Portage(ToStrMixin, AutoGeneratorMixin):
     def dict_repos(self):
         return self.treemap
 
-    def __unicode__(self):
-        return u'portage'
-
-
-class PortTree(ToStrMixin, AutoGeneratorMixin):
+class PortTree(PortTreeMixin):
     "Represent portage tree as object"
 
-    main_iterator = 'iter_categories'
-    generator_names = ('iter_packages', 'iter_ebuilds')
-    
     def __init__(self, tree_path = '/usr/portage', name = 'main'):
         """Args:
             tree_path -- full path to portage tree as str
@@ -253,115 +94,48 @@ class PortTree(ToStrMixin, AutoGeneratorMixin):
         for category in sorted(PORTDB.settings.categories):
             if os.path.isdir(os.path.join(self.porttree_path, category)):
                     yield Category(self, category)
-
-    def __unicode__(self):
-        return self.name
     
     @property
     def porttree_path(self):
         "Full path to portage tree"
         return self.porttree
 
-    @cached_property
-    def metadata(self):
-        return TreeMetadata(self.name)
-
-    @cached_property
-    def use_desc(self):
-        return _get_info_by_func(get_uses_info,
-                                 self.porttree_path,
-                                 'profiles/use.desc')
-
-    @cached_property
-    def use_local_desc(self):
-        return _get_info_by_func(get_local_uses_info,
-                                 self.porttree_path,
-                                 'profiles/use.local.desc')
-
-class CategoryMetadata(ToStrMixin):
-
-    def __init__(self, metadata_path):
-        self._metadata_path = metadata_path
-        self._descrs = {}
-        try:
-            self._metadata_xml = etree.parse(metadata_path)
-        except IOError:
-            pass
-        else:
-            self._parse_descrs()
-
-    def _parse_descrs(self):
-        for descr_xml in self._metadata_xml.iterfind('longdescription'):
-            lang = descr_xml.attrib.get('lang', 'en')
-            self._descrs[lang] = descr_xml.text
-
-    @property
-    def descrs(self):
-        return self._descrs
-
-    @property
-    def default_descr(self):
-        return self._descrs.get('en')
-
-    def __unicode__(self):
-        return unicode(self._metadata_path)
-
-
-class Category(ToStrMixin, AutoGeneratorMixin):
+class Category(CategoryMixin):
     "Represent category of portage tree as object"
 
     __slots__ = ('porttree', 'category', '_cache')
 
-    main_iterator = 'iter_packages'
-    generator_names = ('iter_ebuilds', )
-    
     def __init__(self, porttree, category):
         """Args:
             porttree -- PortTree object
             category -- category name as str
         """
         self.porttree = porttree
-        self.category = category
+        self.name = category
         self._cache = {}
     
     def iter_packages(self):
-        packages = listdir(self.porttree.porttree + '/'+ self.category,
+        packages = listdir(self.porttree.porttree + '/'+ self.name,
                            EmptyOnError=1, ignorecvs=1, dirsonly=1) 
         for package in packages:
             try:
-                atom = Atom(self.category + '/' + package)
+                atom = Atom(self.name + '/' + package)
             except InvalidAtom:
                 continue
             if atom != atom.cp:
                 continue
             yield Package(self, atom)
 
-    def __unicode__(self):
-        return self.category
-    
     @property
     def category_path(self):
         "Full path to category"
-        return os.path.join(self.porttree_path, self.category)
-
-    @property
-    def metadata_path(self):
-        return os.path.join(self.category_path, 'metadata.xml')
-
-    @cached_property
-    def metadata_sha1(self):
-        return file_sha1(self.metadata_path)
-
-    @cached_property
-    def metadata(self):
-        return CategoryMetadata(self.metadata_path)
+        return os.path.join(self.porttree_path, self.name)
 
     @property
     def porttree_path(self):
         return self.porttree.porttree
 
-
-class Package(ToStrMixin):
+class Package(PackageMixin):
     "Represent package as object"
 
     __slots__ = ('category', 'package', '_cache')
@@ -379,66 +153,20 @@ class Package(ToStrMixin):
             if ebuild_obj.is_valid:
                 yield ebuild_obj
 
-    def __unicode__(self):
-        return unicode(self.cp)
-
     @property
     def package_path(self):
         return os.path.join(self.category.porttree.porttree_path, self.package)
 
-    @cached_property
-    def metadata(self):
-        "Return `MetaData` object that represent package metadata.xml file"
-        try:
-            return MetaData( self.metadata_path)
-        except IOError:
-            return FakeMetaData()
-
     @property
     def cp(self):
         return self.package
 
-    mtime = property(_file_mtime("package_path"))
-
     @property
     def name(self):
         return self.package.split('/')[1]
 
-    manifest_path = property(_file_path('Manifest'))
-    changelog_path = property(_file_path('ChangeLog'))
-    metadata_path = property(_file_path('metadata.xml'))
-
-    #Hashes
-    manifest_sha1 = cached_property(_file_hash('manifest_path'),
-                                    name = 'manifest_sha1')
-    changelog_sha1 = cached_property(_file_hash('changelog_path'),
-                                     name = 'changelog_sha1')
-    metadata_sha1 = cached_property(_file_hash('metadata_path'),
-                                    name = 'metadata_sha1')
-    # Modify times
-    manifest_mtime = property(_file_mtime("manifest_path"))
-    changelog_mtime = property(_file_mtime("changelog_path"))
-    metadata_mtime = property(_file_mtime("metadata_path"))
-
-    @cached_property
-    def descriptions(self):
-        return self.metadata.descriptions()
-
-    @property
-    def description(self):
-        "Return first description in package metadata.xml"
-        if len(self.descriptions)>0:
-            return self.descriptions[0]
-        else:
-            return None
-
-    @cached_property
-    def changelog(self):
-        "Return ChangeLog content"
-        return file_get_content(self.changelog_path)
-
 
-class Ebuild(ToStrMixin):
+class Ebuild(EbuildMixin):
     "Represent ebuild as object"
 
     __slots__ = ('package', 'ebuild', 'package_object', '_cache')
@@ -572,9 +300,6 @@ class Ebuild(ToStrMixin):
     def licenses(self):
         return tuple(set(lofstr_to_ig(self._licenses)))
 
-    sha1 = cached_property(_file_hash("ebuild_path"), name = 'sha1')
-    mtime = cached_property(_file_mtime("ebuild_path"), name = 'mtime')
-
-    def __unicode__(self):
-        return self.ebuild
-    
+    @property
+    def cpv(self):
+        return self.package



^ permalink raw reply related	[flat|nested] 35+ messages in thread

end of thread, other threads:[~2012-06-20 23:24 UTC | newest]

Thread overview: 35+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-05-29 13:38 [gentoo-commits] proj/gentoo-packages:master commit in: gpackages/libs/ Slava Bacherikov
  -- strict thread matches above, loose matches on Subject: below --
2012-06-20 23:23 Slava Bacherikov
2012-06-20 23:23 Slava Bacherikov
2012-06-20 23:23 Slava Bacherikov
2012-06-18 21:26 Slava Bacherikov
2012-06-18 21:26 Slava Bacherikov
2012-06-18 21:26 Slava Bacherikov
2012-06-14 19:10 Slava Bacherikov
2012-06-12 18:34 Slava Bacherikov
2012-06-12 18:34 Slava Bacherikov
2012-06-10 17:51 Slava Bacherikov
2012-06-09 18:19 Slava Bacherikov
2012-06-09 18:19 Slava Bacherikov
2012-06-07 22:48 Slava Bacherikov
2012-06-07 22:48 Slava Bacherikov
2012-06-07 22:48 Slava Bacherikov
2012-06-06 22:48 Slava Bacherikov
2012-06-05 21:46 Slava Bacherikov
2012-06-05 20:48 Slava Bacherikov
2012-06-05 15:49 Slava Bacherikov
2012-06-05 15:49 Slava Bacherikov
2012-06-04 22:18 Slava Bacherikov
2012-06-04 16:16 Slava Bacherikov
2012-06-04 16:16 Slava Bacherikov
2012-06-03 19:34 Slava Bacherikov
2012-06-03 16:19 Slava Bacherikov
2012-06-03 13:19 Slava Bacherikov
2012-06-03 13:19 Slava Bacherikov
2012-06-02 16:04 Slava Bacherikov
2012-06-01 21:28 Slava Bacherikov
2012-06-01 21:28 Slava Bacherikov
2012-05-31 15:28 Slava Bacherikov
2012-05-31 15:28 Slava Bacherikov
2012-05-29 21:34 Slava Bacherikov
2012-05-28 17:00 Slava Bacherikov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox