diff options
| author | Avra Sengupta <asengupt@redhat.com> | 2013-06-01 16:17:57 +0530 | 
|---|---|---|
| committer | Vijay Bellur <vbellur@redhat.com> | 2013-07-26 13:18:57 -0700 | 
| commit | b13c483dca20e4015b958f8959328e665a357f60 (patch) | |
| tree | 2af62fc50bae39e930fcbe09101d3e51c76eb6fc /geo-replication/syncdaemon/libcxattr.py | |
| parent | 4944fc943efc41df1841e4e559180171f6541112 (diff) | |
gsyncd: distribute the crawling load
* also consume changelog for change detection.
* Status fixes
* Use new libgfchangelog done API
* process (and sync) one changelog at a time
Change-Id: I24891615bb762e0741b1819ddfdef8802326cb16
BUG: 847839
Original Author: Csaba Henk <csaba@redhat.com>
Original Author: Aravinda VK <avishwan@redhat.com>
Original Author: Venky Shankar <vshankar@redhat.com>
Original Author: Amar Tumballi <amarts@redhat.com>
Original Author: Avra Sengupta <asengupt@redhat.com>
Signed-off-by: Avra Sengupta <asengupt@redhat.com>
Reviewed-on: http://review.gluster.org/5131
Reviewed-by: Vijay Bellur <vbellur@redhat.com>
Tested-by: Vijay Bellur <vbellur@redhat.com>
Diffstat (limited to 'geo-replication/syncdaemon/libcxattr.py')
| -rw-r--r-- | geo-replication/syncdaemon/libcxattr.py | 15 | 
1 files changed, 15 insertions, 0 deletions
| diff --git a/geo-replication/syncdaemon/libcxattr.py b/geo-replication/syncdaemon/libcxattr.py index f0a9d22920a..b5b6956aea6 100644 --- a/geo-replication/syncdaemon/libcxattr.py +++ b/geo-replication/syncdaemon/libcxattr.py @@ -43,6 +43,16 @@ class Xattr(object):          return cls._query_xattr( path, siz, 'lgetxattr', attr)      @classmethod +    def lgetxattr_buf(cls, path, attr): +        """lgetxattr variant with size discovery""" +        size = cls.lgetxattr(path, attr) +        if size == -1: +            cls.raise_oserr() +        if size == 0: +            return '' +        return cls.lgetxattr(path, attr, size) + +    @classmethod      def llistxattr(cls, path, siz=0):          ret = cls._query_xattr(path, siz, 'llistxattr')          if isinstance(ret, str): @@ -56,6 +66,11 @@ class Xattr(object):              cls.raise_oserr()      @classmethod +    def lsetxattr_l(cls, path, attr, val): +        """ lazy lsetxattr(): caller handles errno """ +        cls.libc.lsetxattr(path, attr, val, len(val), 0) + +    @classmethod      def lremovexattr(cls, path, attr):          ret = cls.libc.lremovexattr(path, attr)          if ret == -1: | 
