15 #include <sys/utsname.h>
16 #if __GLIBC_PREREQ (2,16)
20 #include <solv/solvversion.h>
39 using namespace zypp::filesystem;
40 using namespace zypp::parser;
42 #undef ZYPP_BASE_LOGGER_LOGGROUP
43 #define ZYPP_BASE_LOGGER_LOGGROUP "zconfig"
63 Arch _autodetectSystemArchitecture()
66 if ( ::uname( &buf ) < 0 )
68 ERR <<
"Can't determine system architecture" << endl;
72 Arch architecture( buf.machine );
73 MIL <<
"Uname architecture is '" << buf.machine <<
"'" << endl;
75 if ( architecture == Arch_i686 )
80 std::ifstream cpuinfo(
"/proc/cpuinfo" );
83 for( iostr::EachLine in( cpuinfo ); in; in.next() )
87 if ( in->find(
"cx8" ) == std::string::npos
88 || in->find(
"cmov" ) == std::string::npos )
90 architecture = Arch_i586;
91 WAR <<
"CPU lacks 'cx8' or 'cmov': architecture downgraded to '" << architecture <<
"'" << endl;
99 ERR <<
"Cant open " <<
PathInfo(
"/proc/cpuinfo") << endl;
102 else if ( architecture == Arch_sparc || architecture == Arch_sparc64 )
105 std::ifstream cpuinfo(
"/proc/cpuinfo" );
108 for( iostr::EachLine in( cpuinfo ); in; in.next() )
112 if ( in->find(
"sun4v" ) != std::string::npos )
114 architecture = ( architecture == Arch_sparc64 ? Arch_sparc64v : Arch_sparcv9v );
115 WAR <<
"CPU has 'sun4v': architecture upgraded to '" << architecture <<
"'" << endl;
117 else if ( in->find(
"sun4u" ) != std::string::npos )
119 architecture = ( architecture == Arch_sparc64 ? Arch_sparc64 : Arch_sparcv9 );
120 WAR <<
"CPU has 'sun4u': architecture upgraded to '" << architecture <<
"'" << endl;
122 else if ( in->find(
"sun4m" ) != std::string::npos )
124 architecture = Arch_sparcv8;
125 WAR <<
"CPU has 'sun4m': architecture upgraded to '" << architecture <<
"'" << endl;
133 ERR <<
"Cant open " <<
PathInfo(
"/proc/cpuinfo") << endl;
136 else if ( architecture == Arch_armv7l || architecture == Arch_armv6l )
138 std::ifstream platform(
"/etc/rpm/platform" );
141 for( iostr::EachLine in( platform ); in; in.next() )
145 architecture = Arch_armv7hl;
146 WAR <<
"/etc/rpm/platform contains armv7hl-: architecture upgraded to '" << architecture <<
"'" << endl;
151 architecture = Arch_armv6hl;
152 WAR <<
"/etc/rpm/platform contains armv6hl-: architecture upgraded to '" << architecture <<
"'" << endl;
158 #if __GLIBC_PREREQ (2,16)
159 else if ( architecture == Arch_ppc64 )
161 const char * platform = (
const char *)getauxval( AT_PLATFORM );
163 if ( platform && sscanf( platform,
"power%d", &powerlvl ) == 1 && powerlvl > 6 )
164 architecture = Arch_ppc64p7;
187 Locale _autodetectTextLocale()
189 Locale ret( Locale::enCode );
190 const char * envlist[] = {
"LC_ALL",
"LC_MESSAGES",
"LANG", NULL };
191 for (
const char ** envvar = envlist; *envvar; ++envvar )
193 const char * envlang = getenv( *envvar );
196 std::string envstr( envlang );
197 if ( envstr !=
"POSIX" && envstr !=
"C" )
199 Locale lang( envstr );
202 MIL <<
"Found " << *envvar <<
"=" << envstr << endl;
209 MIL <<
"Default text locale is '" << ret <<
"'" << endl;
210 #warning HACK AROUND BOOST_TEST_CATCH_SYSTEM_ERRORS
211 setenv(
"BOOST_TEST_CATCH_SYSTEM_ERRORS",
"no", 1 );
216 inline Pathname _autodetectSystemRoot()
219 return target ? target->root() :
Pathname();
222 inline Pathname _autodetectZyppConfPath()
224 const char *env_confpath = getenv(
"ZYPP_CONF" );
225 return env_confpath ? env_confpath :
"/etc/zypp/zypp.conf";
271 :
Option<Tp>( initial_r ), _default( initial_r )
275 void restoreToDefault()
276 { this->
set( _default.get() ); }
284 {
return _default.get(); }
288 { _default.set( newval_r ); }
308 Impl(
const Pathname & override_r = Pathname() )
309 : _parsedZyppConf ( override_r )
310 , cfg_arch ( defaultSystemArchitecture() )
311 , cfg_textLocale ( defaultTextLocale() )
312 , updateMessagesNotify (
"" )
313 , repo_add_probe ( false )
314 , repo_refresh_delay ( 10 )
315 , repoLabelIsAlias ( false )
316 , download_use_deltarpm ( true )
317 , download_use_deltarpm_always ( false )
318 , download_media_prefer_download( true )
319 , download_mediaMountdir (
"/var/adm/mount" )
320 , download_max_concurrent_connections( 5 )
321 , download_min_download_speed ( 0 )
322 , download_max_download_speed ( 0 )
323 , download_max_silent_tries ( 5 )
324 , download_transfer_timeout ( 180 )
327 , repoGpgCheck ( indeterminate )
328 , pkgGpgCheck ( indeterminate )
329 , solver_onlyRequires ( false )
330 , solver_allowVendorChange ( false )
331 , solver_dupAllowDowngrade ( true )
332 , solver_dupAllowNameChange ( true )
333 , solver_dupAllowArchChange ( true )
334 , solver_dupAllowVendorChange ( true )
335 , solver_cleandepsOnRemove ( false )
336 , solver_upgradeTestcasesToKeep ( 2 )
337 , solverUpgradeRemoveDroppedPackages( true )
338 , apply_locks_file ( true )
339 , pluginsPath (
"/usr/lib/zypp/plugins" )
341 MIL <<
"libzypp: " << VERSION << endl;
344 if ( _parsedZyppConf.empty() )
346 _parsedZyppConf = _autodetectZyppConfPath();
352 INT <<
"Reconfigure to " << _parsedZyppConf << endl;
353 ZConfig::instance()._pimpl.reset(
this );
355 if ( PathInfo(_parsedZyppConf).isExist() )
362 string section(*sit);
368 string entry(it->first);
369 string value(it->second);
371 if ( section ==
"main" )
373 if ( entry ==
"arch" )
376 if ( carch != cfg_arch )
378 WAR <<
"Overriding system architecture (" << cfg_arch <<
"): " << carch << endl;
382 else if ( entry ==
"cachedir" )
384 cfg_cache_path = Pathname(value);
386 else if ( entry ==
"metadatadir" )
388 cfg_metadata_path = Pathname(value);
390 else if ( entry ==
"solvfilesdir" )
392 cfg_solvfiles_path = Pathname(value);
394 else if ( entry ==
"packagesdir" )
396 cfg_packages_path = Pathname(value);
398 else if ( entry ==
"configdir" )
400 cfg_config_path = Pathname(value);
402 else if ( entry ==
"reposdir" )
404 cfg_known_repos_path = Pathname(value);
406 else if ( entry ==
"servicesdir" )
408 cfg_known_services_path = Pathname(value);
410 else if ( entry ==
"varsdir" )
412 cfg_vars_path = Pathname(value);
414 else if ( entry ==
"repo.add.probe" )
418 else if ( entry ==
"repo.refresh.delay" )
422 else if ( entry ==
"repo.refresh.locales" )
424 std::vector<std::string> tmp;
425 str::split( value, back_inserter( tmp ),
", \t" );
427 boost::function<Locale(const std::string &)> transform(
428 [](
const std::string & str_r)->
Locale{
return Locale(str_r); }
430 repoRefreshLocales.insert( make_transform_iterator( tmp.begin(), transform ),
431 make_transform_iterator( tmp.end(), transform ) );
433 else if ( entry ==
"download.use_deltarpm" )
435 download_use_deltarpm =
str::strToBool( value, download_use_deltarpm );
437 else if ( entry ==
"download.use_deltarpm.always" )
439 download_use_deltarpm_always =
str::strToBool( value, download_use_deltarpm_always );
441 else if ( entry ==
"download.media_preference" )
443 download_media_prefer_download.restoreToDefault(
str::compareCI( value,
"volatile" ) != 0 );
446 else if ( entry ==
"download.media_mountdir" )
448 download_mediaMountdir.restoreToDefault( Pathname(value) );
451 else if ( entry ==
"download.max_concurrent_connections" )
455 else if ( entry ==
"download.min_download_speed" )
459 else if ( entry ==
"download.max_download_speed" )
463 else if ( entry ==
"download.max_silent_tries" )
467 else if ( entry ==
"download.transfer_timeout" )
470 if ( download_transfer_timeout < 0 ) download_transfer_timeout = 0;
471 else if ( download_transfer_timeout > 3600 ) download_transfer_timeout = 3600;
473 else if ( entry ==
"commit.downloadMode" )
475 commit_downloadMode.set( deserializeDownloadMode( value ) );
477 else if ( entry ==
"gpgcheck" )
481 else if ( entry ==
"repo_gpgcheck" )
485 else if ( entry ==
"pkg_gpgcheck" )
489 else if ( entry ==
"vendordir" )
491 cfg_vendor_path = Pathname(value);
493 else if ( entry ==
"multiversiondir" )
495 cfg_multiversion_path = Pathname(value);
497 else if ( entry ==
"solver.onlyRequires" )
499 solver_onlyRequires.set(
str::strToBool( value, solver_onlyRequires ) );
501 else if ( entry ==
"solver.allowVendorChange" )
503 solver_allowVendorChange.set(
str::strToBool( value, solver_allowVendorChange ) );
505 else if ( entry ==
"solver.dupAllowDowngrade" )
507 solver_dupAllowDowngrade.set(
str::strToBool( value, solver_dupAllowDowngrade ) );
509 else if ( entry ==
"solver.dupAllowNameChange" )
511 solver_dupAllowNameChange.set(
str::strToBool( value, solver_dupAllowNameChange ) );
513 else if ( entry ==
"solver.dupAllowArchChange" )
515 solver_dupAllowArchChange.set(
str::strToBool( value, solver_dupAllowArchChange ) );
517 else if ( entry ==
"solver.dupAllowVendorChange" )
519 solver_dupAllowVendorChange.set(
str::strToBool( value, solver_dupAllowVendorChange ) );
521 else if ( entry ==
"solver.cleandepsOnRemove" )
523 solver_cleandepsOnRemove.set(
str::strToBool( value, solver_cleandepsOnRemove ) );
525 else if ( entry ==
"solver.upgradeTestcasesToKeep" )
527 solver_upgradeTestcasesToKeep.set( str::strtonum<unsigned>( value ) );
529 else if ( entry ==
"solver.upgradeRemoveDroppedPackages" )
531 solverUpgradeRemoveDroppedPackages.restoreToDefault(
str::strToBool( value, solverUpgradeRemoveDroppedPackages.getDefault() ) );
533 else if ( entry ==
"solver.checkSystemFile" )
535 solver_checkSystemFile = Pathname(value);
537 else if ( entry ==
"solver.checkSystemFileDir" )
539 solver_checkSystemFileDir = Pathname(value);
541 else if ( entry ==
"multiversion" )
546 else if ( entry ==
"locksfile.path" )
548 locks_file = Pathname(value);
550 else if ( entry ==
"locksfile.apply" )
554 else if ( entry ==
"update.datadir" )
556 update_data_path = Pathname(value);
558 else if ( entry ==
"update.scriptsdir" )
560 update_scripts_path = Pathname(value);
562 else if ( entry ==
"update.messagessdir" )
564 update_messages_path = Pathname(value);
566 else if ( entry ==
"update.messages.notify" )
568 updateMessagesNotify.set( value );
570 else if ( entry ==
"rpm.install.excludedocs" )
575 else if ( entry ==
"history.logfile" )
577 history_log_path = Pathname(value);
579 else if ( entry ==
"credentials.global.dir" )
581 credentials_global_dir_path = Pathname(value);
583 else if ( entry ==
"credentials.global.file" )
585 credentials_global_file_path = Pathname(value);
595 MIL << _parsedZyppConf <<
" not found, using defaults instead." << endl;
596 _parsedZyppConf = _parsedZyppConf.extend(
" (NOT FOUND)" );
600 if ( getenv(
"ZYPP_TESTSUITE_FAKE_ARCH" ) )
602 Arch carch( getenv(
"ZYPP_TESTSUITE_FAKE_ARCH" ) );
603 if ( carch != cfg_arch )
605 WAR <<
"ZYPP_TESTSUITE_FAKE_ARCH: Overriding system architecture (" << cfg_arch <<
"): " << carch << endl;
609 MIL <<
"ZConfig singleton created." << endl;
700 typedef std::map<Pathname,MultiversionSpec>
SpecMap;
708 if ( root_r.empty() )
710 bool cacheHit = _specMap.count( root_r );
716 ret.swap( _specMap[Pathname()] );
718 scanConfAt( root_r, ret, zConfImpl_r );
719 scanDirAt( root_r, ret, zConfImpl_r );
720 using zypp::operator<<;
721 MIL <<
"MultiversionSpec '" << root_r <<
"' = " << ret << endl;
727 {
return _specMap[Pathname()]; }
732 static const str::regex rx(
"^multiversion *= *(.*)" );
735 [&](
int num_r, std::string line_r )->
bool
750 if ( multiversionDir.empty() )
752 ? Pathname(
"/etc/zypp")
756 [&spec_r](
const Pathname & dir_r,
const char *
const & name_r )->
bool
758 MIL <<
"Parsing " << dir_r/name_r << endl;
760 [&spec_r](
int num_r, std::string line_r )->
bool
762 DBG <<
" found " << line_r << endl;
763 spec_r.insert( std::move(line_r) );
775 {
return _multiversionMap.getSpec( _autodetectSystemRoot(), *
this ); }
794 ZConfig & ZConfig::instance()
796 static ZConfig _instance;
820 {
return _autodetectSystemRoot(); }
840 static Arch _val( _autodetectSystemArchitecture() );
851 WAR <<
"Overriding system architecture (" <<
_pimpl->
cfg_arch <<
"): " << arch_r << endl;
864 static Locale _val( _autodetectTextLocale() );
877 #warning prefer signal
894 for_( ch, str_r.begin(), str_r.end() )
896 if ( *ch <
' ' && *ch !=
'\t' )
898 ERR <<
"New user data string rejectded: char " << (int)*ch <<
" at position " << (ch - str_r.begin()) << endl;
902 MIL <<
"Set user data string to '" << str_r <<
"'" << endl;
1102 inline void sigMultiversionSpecChanged()
1171 {
return "system-release"; }
1182 str <<
"libzypp: " << VERSION << endl;
1184 str <<
"libsolv: " << solv_version;
1185 if ( ::strcmp( solv_version, LIBSOLV_VERSION_STRING ) )
1186 str <<
" (built against " << LIBSOLV_VERSION_STRING <<
")";