Imported Upstream version 14.30.1 16/94616/1
authorDongHun Kwak <dh0128.kwak@samsung.com>
Tue, 1 Nov 2016 01:30:39 +0000 (10:30 +0900)
committerDongHun Kwak <dh0128.kwak@samsung.com>
Tue, 1 Nov 2016 01:30:40 +0000 (10:30 +0900)
Change-Id: I46561d8f46640225df2269c40cb3440c7ab3ac0d
Signed-off-by: DongHun Kwak <dh0128.kwak@samsung.com>
13 files changed:
VERSION.cmake
doc/autoinclude/PatternPackages.doc [new file with mode: 0644]
libzypp.spec.cmake
package/libzypp.changes
po/zypp-po.tar.bz2
tests/zypp/RepoInfo_test.cc
zypp/PathInfo.cc
zypp/PathInfo.h
zypp/RepoInfo.cc
zypp/base/LogTools.h
zypp/media/MediaCurl.cc
zypp/repo/RepoMirrorList.cc
zypp/repo/RepoMirrorList.h

index 2fc3a316e34be88fab4ca6ea18270839357fe34f..52455afeea05805e44465504a985f39267bb3c17 100644 (file)
@@ -61,8 +61,8 @@
 SET(LIBZYPP_MAJOR "14")
 SET(LIBZYPP_COMPATMINOR "30")
 SET(LIBZYPP_MINOR "30")
-SET(LIBZYPP_PATCH "0")
+SET(LIBZYPP_PATCH "1")
 #
-# LAST RELEASED: 14.30.0 (30)
+# LAST RELEASED: 14.30.1 (30)
 # (The number in parenthesis is LIBZYPP_COMPATMINOR)
 #=======
diff --git a/doc/autoinclude/PatternPackages.doc b/doc/autoinclude/PatternPackages.doc
new file mode 100644 (file)
index 0000000..9fc2e0d
--- /dev/null
@@ -0,0 +1,66 @@
+/**
+
+\page zypp-pattern-packages Code 12 Pattern Packages
+
+\author Michael Andres <ma@suse.de>
+
+<HR><!-- ====================================================================== -->
+
+\section zypp-pattern-packages_intro Intro
+
+Since Code12 (SLES-12) we utilizes a new method of defining patterns, as opposed to the older XML-based patterns files. A pattern and it's dependencies are now represented by an rpm package and the few pattern specific properties are provided by the package. No extra XML-file is needed.
+
+By convention a patterns package for a \c pattern:FOO is named \c patterns-*-FOO and is must provide \c pattern() \c = \c apparmor. The pattens content is expressed by dependencies to other packages and patterns-packages.
+
+The list of provides used for the new pattern pseudo-package autogeneration:
+
+\code
+  Provides:  pattern-category() = STRING
+  Provides:  pattern-category(de) = STRING
+            (... other languages ...)
+  Provides:  pattern-includes() = STRING
+  Provides:  pattern-extends() = STRING
+  Provides:  pattern-icon() = STRING
+  Provides:  pattern-order() = STRING
+  Provides:  pattern-visible()
+
+  STRING must be url-hexencoded so that it does not contain any characters
+  that rpm provides can't have. E.g.:
+    ' ' => %20
+    ',' => %2C
+    '-' => %2D
+\endcode
+
+\code
+patterns-sles-Minimal-12-37.1.x86_64.rpm
+ PROVIDES {
+  pattern() == Minimal
+  pattern-icon() == pattern-basis
+  pattern-order() == 1099
+  pattern-visible()
+  pattern-category() == Base%20Technologies
+  pattern-category(ar) == %D8%A7%D9%84%D8%AA%D9%83%D9%86%D9%88%D9%84%D9%88%D8%AC%D9%8A%D8%A7%D8%AA%20%D8%A7%D9%84%D8%A3%D8%B3%D8%A7%D8%B3%D9%8A%D8%A9
+  pattern-category(ca) == Tecnologies%20de%20base
+  pattern-category(cs) == Z%C3%A1kladn%C3%AD%20technologie
+  pattern-category(da) == Basisteknologier
+  pattern-category(de) == Basistechnologien
+  ...
+}
+ REQUIRES {
+  systemd
+  coreutils
+  insserv
+  aaa_base
+  ...
+}
+ RECOMMENDS (22){
+  grub2
+  rpcbind
+  nfs-client
+  rsyslog
+  ...
+}
+\endcode
+
+
+*/
index 346aabcb95e076dde3304c8befad3ca26157a253..ec29e4180d902ea7c09db2a2f74326d3fd4f137e 100644 (file)
 %define force_gcc_46 0
 
 Name:           @PACKAGE@
-BuildRoot:      %{_tmppath}/%{name}-%{version}-build
-Summary:        Package, Patch, Pattern, and Product Management
-License:        GPL-2.0+
-Group:          System/Packages
 Version:        @VERSION@
 Release:        0
+License:        GPL-2.0+
+Url:            git://gitorious.org/opensuse/libzypp.git
+Summary:        Package, Patch, Pattern, and Product Management
+Group:          System/Packages
+BuildRoot:      %{_tmppath}/%{name}-%{version}-build
 Source:         %{name}-%{version}.tar.bz2
 Source1:        %{name}-rpmlintrc
 Provides:       yast2-packagemanager
@@ -145,6 +146,10 @@ Authors:
     Ladislav Slezak <lslezak@suse.cz>
 
 %package devel
+Summary:        Package, Patch, Pattern, and Product Management - developers files
+Group:          Development/Libraries/C and C++
+Provides:       yast2-packagemanager-devel
+Obsoletes:      yast2-packagemanager-devel
 Requires:       boost-devel
 Requires:       bzip2
 Requires:       glibc-devel
@@ -178,25 +183,19 @@ Requires:       libcurl-devel >= %{min_curl_version}
 %else
 Requires:       libsolv-devel
 %endif
+
+%description devel
+Package, Patch, Pattern, and Product Management - developers files
+
+%package devel-doc
 Summary:        Package, Patch, Pattern, and Product Management - developers files
-Group:          System/Packages
+Group:          Documentation/HTML
 Provides:       yast2-packagemanager-devel
 Obsoletes:      yast2-packagemanager-devel
 
-%description -n libzypp-devel
+%description devel-doc
 Package, Patch, Pattern, and Product Management - developers files
 
-Authors:
---------
-    Michael Andres <ma@suse.de>
-    Jiri Srain <jsrain@suse.cz>
-    Stefan Schubert <schubi@suse.de>
-    Duncan Mac-Vicar <dmacvicar@suse.de>
-    Klaus Kaempf <kkaempf@suse.de>
-    Marius Tomaschewski <mt@suse.de>
-    Stanislav Visnovsky <visnov@suse.cz>
-    Ladislav Slezak <lslezak@suse.cz>
-
 %prep
 %setup -q
 
@@ -371,9 +370,12 @@ rm -rf "$RPM_BUILD_ROOT"
 %files devel
 %defattr(-,root,root)
 %{_libdir}/libzypp.so
-%{_docdir}/%{name}
 %{_includedir}/zypp
 %{_datadir}/cmake/Modules/*
 %{_libdir}/pkgconfig/libzypp.pc
 
+%files devel-doc
+%defattr(-,root,root)
+%{_docdir}/%{name}
+
 %changelog
index 5860f40f325dc93b9d5fac4ff77cd92be30011ea..0b2e2f5186b3f31a9431e207042369e12ee05742 100644 (file)
@@ -1,3 +1,18 @@
+-------------------------------------------------------------------
+Mon Oct 27 11:38:00 CET 2014 - ma@suse.de
+
+- doc: add hint to code 12 pattern packages
+- MediaCurl: Fix URL path concatenation (bnc#901590)
+- Move doxygen html doc to libzypp-devel-doc (bnc#901691)
+- Remove non-breaking spaces from changes file
+- Control lifetime of downloaded mirrorlist
+- version 14.30.1 (30)
+
+-------------------------------------------------------------------
+Thu Oct 16 11:03:11 CEST 2014 - ma@suse.de
+
+- Update zypp-po.tar.bz2
+
 -------------------------------------------------------------------
 Wed Oct 15 15:07:09 CEST 2014 - ma@suse.de
 
@@ -89,7 +104,7 @@ Tue Sep 16 10:45:39 CEST 2014 - ma@suse.de
 - DiskUsageCounter: Set growonly on detetcted snapshotting btrfs
   partitions (bnc#896176)
 - DiskUsageCounter: Allow MountPoint to store fstype
-- DiskUsageCounter: Support setting 'growonly' partition hint 
+- DiskUsageCounter: Support setting 'growonly' partition hint
   (bnc#896176)
 - version 14.29.0 (29)
 
@@ -112,7 +127,7 @@ Fri Aug 29 14:46:25 CEST 2014 - ma@suse.de
 
 - PackageProvider: consider toplevel cache if --root or --pkg-cachedir
   is used.
-- Cleanup orpahned cache dirs only at zypp.conf default locations 
+- Cleanup orpahned cache dirs only at zypp.conf default locations
   (bnc#891515)
 - Remove orphaned package caches on refresh (bnc#888919)
 - version 14.27.2 (27)
@@ -191,7 +206,7 @@ Wed May 28 13:41:22 CEST 2014 - ma@suse.de
 -------------------------------------------------------------------
 Tue May 27 16:31:21 CEST 2014 - ma@suse.de
 
-- Let ServiceRefresh en-/disable repos with respect to previous state 
+- Let ServiceRefresh en-/disable repos with respect to previous state
   and user modifications.
 - RepoindexFileReader: support variable substitution
 - Parse optional autorefresh attribute from repoindex.xml
@@ -208,7 +223,7 @@ Wed May 14 13:52:38 CEST 2014 - ma@suse.de
 -------------------------------------------------------------------
 Thu May  8 18:54:25 CEST 2014 - ma@suse.de
 
-- KeyRingReport: New infoVerify callback showing the trusted key 
+- KeyRingReport: New infoVerify callback showing the trusted key
   that will be used for verification.
 - version 14.19.0 (19)
 
@@ -284,7 +299,7 @@ Wed Feb 26 15:06:06 CET 2014 - ma@suse.de
 -------------------------------------------------------------------
 Tue Feb 25 13:42:13 CET 2014 - ma@suse.de
 
-- Remove duplicate code detecting known kinds and move it to 
+- Remove duplicate code detecting known kinds and move it to
   ResKind::explicitBuiltin.
 - version 14.16.0 (16)
 
@@ -385,7 +400,7 @@ Tue Jan 14 18:38:49 CET 2014 - ma@suse.de
 
 - Improve ProgressData reporting.
 - Allow xml::escape directly dumping to a stream.
-- Add support for repo authentication using SSL client certificates 
+- Add support for repo authentication using SSL client certificates
   (bnc#683914)
 - Enhance Queue to perform COW
 - fix documentation
@@ -413,9 +428,9 @@ Thu Dec 12 18:01:18 CET 2013 - ma@suse.de
 -------------------------------------------------------------------
 Wed Dec  4 12:54:30 UTC 2013 - jreidinger@suse.com
 
-- Drop package-manager script as it is already deprecated and 
+- Drop package-manager script as it is already deprecated and
   packagekit usage in desktop invalidates it. If someone really
-  need it, then place it to proper top level package which can 
+  need it, then place it to proper top level package which can
   decide what GUI is proper for given task.
 
 -------------------------------------------------------------------
@@ -423,7 +438,7 @@ Wed Nov 20 16:32:30 CET 2013 - ma@suse.de
 
 - Extend commit plugin to send the transaction list (Fate#316203)
 - Add base/Json.h: JSON encoder for e.g. sending data to plugins
-- Re-evaluate dropped packages list on upgrade, even if product 
+- Re-evaluate dropped packages list on upgrade, even if product
   remains unchanged (bnc#849251).
 - Add ppc64le architecture
 - Add m68k architecture
@@ -8009,7 +8024,7 @@ Fri Aug 11 17:01:33 CEST 2006 - dmacvicar@suse.de
 
 - forward port 3924:3939
 - Add explicit finish callbacks for subtasks during ProvidePackage
 to avoid UI confusion.
 to avoid UI confusion.
 - rev3957
 
 -------------------------------------------------------------------
@@ -8100,7 +8115,7 @@ Tue Jul 18 17:42:45 CEST 2006 - dmacvicar@suse.de
 Tue Jul 18 12:56:17 CEST 2006 - dmacvicar@suse.de
 
 - Digest: Don't read the stream character wise but reading blocks,
-  as advised by matz profiling.
+  as advised by matz profiling.
 - r3819
 
 -------------------------------------------------------------------
@@ -8293,7 +8308,7 @@ Wed Jun  7 01:00:05 CEST 2006 - dmacvicar@suse.de
 - Fixes unneeded file download, and add download callbacks
   (still need yast side) #181204 and #160206
 - Fix stalle tmpdir due to cyclic references, using a master
-  TmpDir for zypp. # 178292
+  TmpDir for zypp. # 178292
 
 -------------------------------------------------------------------
 Wed Jun  7 00:02:18 CEST 2006 - ma@suse.de
@@ -8396,11 +8411,11 @@ Wed May 24 15:30:32 CEST 2006 - dmacvicar@suse.de
 
 - dont pass root on init but before.
 - implement rpm db modification timestamp
-  not used yet
+  not used yet
 - move Helix source to testsuite out of the solver
   so we can use it for target, storage tests
 - add Source_Ref::timestamp(), default to now()
-  in order to implement smart sync of sources by zmd
+  in order to implement smart sync of sources by zmd
 - don't parse desc and summary twice
 - fix a segfault with tranlated text
 - fix broken size tag introduced in rev 3427
@@ -8613,7 +8628,7 @@ Wed May  3 17:40:45 CEST 2006 - dmacvicar@suse.de
 Wed May  3 15:34:00 CEST 2006 - dmacvicar@suse.de
 
 - use --no-default-keyring to avoid creating a
-  default gpg dir in / (#171055)
+  default gpg dir in / (#171055)
 - rev 3335
 
 -------------------------------------------------------------------
index 7f4d4005a363d403d1b352c7a19a4c5ce0146215..0a8911187a2aae00e5e18f8fc528e2fa90a411c5 100644 (file)
Binary files a/po/zypp-po.tar.bz2 and b/po/zypp-po.tar.bz2 differ
index 55ca91c437ef75b8e82c923b85bc244cb475a039..232e238e0ccde5fb83ffe2853e9e9b1b82dd8118 100644 (file)
@@ -38,7 +38,7 @@ BOOST_AUTO_TEST_CASE(repoinfo_test)
 
   ri.setMirrorListUrl(weburl);
 
-  BOOST_CHECK(ri.url().asString() == "ftp://ftp-stud.hs-esslingen.de/pub/fedora/linux/updates/13/x86_64/");
+  BOOST_CHECK(ri.url().asString() == "http://ftp-stud.hs-esslingen.de/pub/fedora/linux/updates/13/x86_64/");
 
   ostringstream ostr;
   ri.dumpAsIniOn(ostr);
index fed07df4e6902b94e0c565a6f08666961e88441e..4334c4e152c9af92d4a059d2ecf376a73c78faa8 100644 (file)
@@ -18,7 +18,7 @@
 #include <fstream>
 #include <iomanip>
 
-#include "zypp/base/Logger.h"
+#include "zypp/base/LogTools.h"
 #include "zypp/base/String.h"
 #include "zypp/base/IOStream.h"
 #include "zypp/base/StrMatcher.h"
@@ -641,6 +641,9 @@ namespace zypp
                         } );
     }
 
+    std::ostream & operator<<( std::ostream & str, const DirContent & obj )
+    { return dumpRange( str, obj.begin(), obj.end() ); }
+
     ///////////////////////////////////////////////////////////////////
     // is_empty_dir
     ///////////////////////////////////////////////////////////////////
index 8209bad4e02ef26fc9701c568081b53849839209..4a594925a4513d77e7b65ddc67d2e7ba32b062fe 100644 (file)
@@ -540,9 +540,14 @@ namespace zypp
       bool operator==( const DirEntry &rhs ) const;
     };
 
+    inline std::ostream & operator<<( std::ostream & str, const DirEntry & obj )
+    { return str << '[' << obj.type << "] " << obj.name; }
+
     /** Returned by readdir. */
     typedef std::list<DirEntry> DirContent;
 
+    std::ostream & operator<<( std::ostream & str, const DirContent & obj );
+
     /**
      * Return content of directory via retlist. If dots is false
      * entries starting with '.' are not reported. "." and ".."
index a8dcaa005207f67cb89e4a7427370f62a1fbef4e..fa5626a4fac7f18ee055212e9686eced434a54ac 100644 (file)
@@ -12,7 +12,7 @@
 #include <iostream>
 #include <vector>
 
-#include "zypp/base/Logger.h"
+#include "zypp/base/LogTools.h"
 #include "zypp/base/DefaultIntegral.h"
 #include "zypp/parser/xml/XmlEscape.h"
 
@@ -80,10 +80,8 @@ namespace zypp
       {
         emptybaseurls = true;
         DBG << "MetadataPath: " << metadatapath << endl;
-       const std::vector<Url> & rmurls( ( metadatapath.empty()
-                                        ? repo::RepoMirrorList( getmirrorListUrl() )
-                                        : repo::RepoMirrorList( getmirrorListUrl(), metadatapath ) ).getUrls() );
-        _baseUrls.insert( _baseUrls.end(), rmurls.begin(), rmurls.end() );
+       repo::RepoMirrorList rmurls( getmirrorListUrl(), metadatapath );
+       _baseUrls.insert( _baseUrls.end(), rmurls.getUrls().begin(), rmurls.getUrls().end() );
       }
       return _baseUrls;
     }
index b73013c3ecac08bed4b4b19661b7d38aea246e17..0e9b9cfaccdeec76b34d33c2933a5d8fdcf065c0 100644 (file)
@@ -120,8 +120,8 @@ namespace zypp
     std::ostream & operator<<( std::ostream & str, const std::vector<_Tp> & obj )
     { return dumpRange( str, obj.begin(), obj.end() ); }
 
-  template<class _Tp>
-    std::ostream & operator<<( std::ostream & str, const std::set<_Tp> & obj )
+  template<class _Tp, class _Cmp, class _Alloc>
+    std::ostream & operator<<( std::ostream & str, const std::set<_Tp,_Cmp,_Alloc> & obj )
     { return dumpRange( str, obj.begin(), obj.end() ); }
 
   template<class _Tp>
index 444bfc784e09c133ec54a340af3410f7c945b7a8..d77be2c207554bcb66eb0e7d0a959c39fe17e65f 100644 (file)
@@ -838,27 +838,15 @@ void MediaCurl::releaseFrom( const std::string & ejectDev )
 
 Url MediaCurl::getFileUrl( const Pathname & filename_r ) const
 {
-  std::string path( _url.getPathName() );
   // Simply extend the URLs pathname. An 'absolute' URL path
-  // is achieved by encoding the 2nd '/' in the URL:
-  //   URL: ftp://user@server  -> ~user
-  //   URL: ftp://user@server/ -> ~user
-  //   URL: ftp://user@server//        -> /
+  // is achieved by encoding the leading '/' in an URL path:
+  //   URL: ftp://user@server          -> ~user
+  //   URL: ftp://user@server/         -> ~user
+  //   URL: ftp://user@server//                -> ~user
+  //   URL: ftp://user@server/%2F      -> /
   //                         ^- this '/' is just a separator
-  if ( path.empty() ||  path == "/" )  // empty URL path; the '/' is just a separator
-  {
-    path = filename_r.absolutename().asString();
-  }
-  else if ( *path.rbegin() == '/' )
-  {
-    path += filename_r.absolutename().asString().substr(1);
-  }
-  else
-  {
-    path += filename_r.absolutename().asString();
-  }
   Url newurl( _url );
-  newurl.setPathName( path );
+  newurl.setPathName( ( Pathname("./"+_url.getPathName()) / filename_r ).asString().substr(1) );
   return newurl;
 }
 
index ed8c81e3e9cb67161689cf68795d6beadeefa328..ad44f259efb9934c97634269ad50e817f01aae80 100644 (file)
@@ -32,15 +32,37 @@ namespace zypp
     ///////////////////////////////////////////////////////////////////
     namespace
     {
-      /** Provide mirrorlist in a local file */
-      Pathname RepoMirrorListProvide( const Url & url_r )
+      ///////////////////////////////////////////////////////////////////
+      /// \class RepoMirrorListTempProvider
+      /// \brief Provide access to downloaded mirror list (in temp space)
+      /// \ingroup g_RAII
+      ///
+      /// Tempspace (and mirror list) are deleted when provider goes out
+      /// of scope.
+      struct RepoMirrorListTempProvider
       {
-       Url abs_url( url_r );
-       abs_url.setPathName( "/" );
-       abs_url.setQueryParam( "mediahandler", "curl" );
-       MediaSetAccess access( abs_url );
-       return access.provideFile( url_r.getPathName() );
-      }
+       RepoMirrorListTempProvider()
+       {}
+       RepoMirrorListTempProvider( const Pathname & localfile_r )
+       : _localfile( localfile_r )
+       {}
+       RepoMirrorListTempProvider( const Url & url_r )
+       {
+         Url abs_url( url_r );
+         abs_url.setPathName( "/" );
+         abs_url.setQueryParam( "mediahandler", "curl" );
+         _access.reset( new MediaSetAccess( abs_url ) );
+         _localfile = _access->provideFile( url_r.getPathName() );
+       }
+
+       const Pathname & localfile() const
+       { return _localfile; }
+
+      private:
+       shared_ptr<MediaSetAccess> _access;
+       Pathname _localfile;
+      };
+      ///////////////////////////////////////////////////////////////////
 
       inline std::vector<Url> RepoMirrorListParseXML( const Pathname &tmpfile )
       {
@@ -65,6 +87,8 @@ namespace zypp
       /** Parse a local mirrorlist \a listfile_r and return usable URLs */
       inline std::vector<Url> RepoMirrorListParse( const Url & url_r, const Pathname & listfile_r )
       {
+       USR << url_r << " " << listfile_r << endl;
+
        std::vector<Url> mirrorurls;
        if ( url_r.asString().find( "/metalink" ) != string::npos )
          mirrorurls = RepoMirrorListParseXML( listfile_r );
@@ -99,11 +123,18 @@ namespace zypp
     {
       if ( url_r.getScheme() == "file" )
       {
-       // no cache for local mirrorlist
+       // never cache for local mirrorlist
        _urls = RepoMirrorListParse( url_r, url_r.getPathName() );
       }
+      else if ( ! PathInfo( metadatapath_r).isDir() )
+      {
+       // no cachedir
+       RepoMirrorListTempProvider provider( url_r );   // RAII: lifetime of any downloaded files
+       _urls = RepoMirrorListParse( url_r, provider.localfile() );
+      }
       else
       {
+       // have cachedir
        Pathname cachefile( metadatapath_r );
        if ( url_r.asString().find( "/metalink" ) != string::npos )
          cachefile /= "mirrorlist.xml";
@@ -114,12 +145,12 @@ namespace zypp
        if ( !cacheinfo.isFile() || cacheinfo.mtime() < time(NULL) - (long) ZConfig::instance().repo_refresh_delay() * 60 )
        {
          DBG << "Getting MirrorList from URL: " << url_r << endl;
-         Pathname localfile( RepoMirrorListProvide( url_r ) );
+         RepoMirrorListTempProvider provider( url_r ); // RAII: lifetime of downloaded file
 
          // Create directory, if not existing
          DBG << "Copy MirrorList file to " << cachefile << endl;
          zypp::filesystem::assert_dir( metadatapath_r );
-         zypp::filesystem::hardlinkCopy( localfile, cachefile );
+         zypp::filesystem::hardlinkCopy( provider.localfile(), cachefile );
        }
 
        _urls = RepoMirrorListParse( url_r, cachefile );
@@ -131,15 +162,6 @@ namespace zypp
       }
     }
 
-    RepoMirrorList::RepoMirrorList( const Url & url_r )
-    {
-      DBG << "Getting MirrorList from URL: " << url_r << endl;
-      Pathname localfile( url_r.getScheme() == "file"
-                        ? url_r.getPathName()
-                       : RepoMirrorListProvide( url_r ) );
-      _urls = RepoMirrorListParse( url_r, localfile );
-    }
-
     /////////////////////////////////////////////////////////////////
   } // namespace repo
   ///////////////////////////////////////////////////////////////////
index 85b285280441869ef89735fc01d945571fcecc70..e6ad1fd8d30df321a321e5fd790bd1d5cd85b0ea 100644 (file)
@@ -21,16 +21,17 @@ namespace zypp
     class RepoMirrorList
     {
       public:
-        RepoMirrorList( const Url & url_r );
-        RepoMirrorList( const Url & url_r, const Pathname & metadatapath_r );
+        RepoMirrorList( const Url & url_r, const Pathname & metadatapath_r = Pathname() );
 
         const std::vector<Url> & getUrls() const
         { return _urls; }
 
+        std::vector<Url> & getUrls()
+        { return _urls; }
+
       private:
         std::vector<Url> _urls;
     };
-
   } // ns repo
 } // ns zypp