mirror of
https://github.com/parchlinux/calamares.git
synced 2025-06-29 18:35:37 -04:00
Add conversion utilities from QHash to py dict. When translating from pydict, however, translate into a QMap as before to keep current behaviour.
This commit is contained in:
parent
058c7d8913
commit
2349f7125e
2 changed files with 45 additions and 13 deletions
|
@ -29,7 +29,8 @@
|
|||
|
||||
namespace bp = boost::python;
|
||||
|
||||
namespace CalamaresPython {
|
||||
namespace CalamaresPython
|
||||
{
|
||||
|
||||
|
||||
boost::python::object
|
||||
|
@ -40,6 +41,9 @@ variantToPyObject( const QVariant& variant )
|
|||
case QVariant::Map:
|
||||
return variantMapToPyDict( variant.toMap() );
|
||||
|
||||
case QVariant::Hash:
|
||||
return variantHashToPyDict( variant.toHash() );
|
||||
|
||||
case QVariant::List:
|
||||
case QVariant::StringList:
|
||||
return variantListToPyList( variant.toList() );
|
||||
|
@ -94,9 +98,7 @@ variantListToPyList( const QVariantList& variantList )
|
|||
{
|
||||
bp::list pyList;
|
||||
foreach ( const QVariant& variant, variantList )
|
||||
{
|
||||
pyList.append( variantToPyObject( variant ) );
|
||||
}
|
||||
return pyList;
|
||||
}
|
||||
|
||||
|
@ -106,9 +108,7 @@ variantListFromPyList( const boost::python::list& pyList )
|
|||
{
|
||||
QVariantList list;
|
||||
for ( int i = 0; i < bp::len( pyList ); ++i )
|
||||
{
|
||||
list.append( variantFromPyObject( pyList[ i ] ) );
|
||||
}
|
||||
return list;
|
||||
}
|
||||
|
||||
|
@ -118,9 +118,7 @@ variantMapToPyDict( const QVariantMap& variantMap )
|
|||
{
|
||||
bp::dict pyDict;
|
||||
for ( auto it = variantMap.constBegin(); it != variantMap.constEnd(); ++it )
|
||||
{
|
||||
pyDict[ it.key().toStdString() ] = variantToPyObject( it.value() );
|
||||
}
|
||||
return pyDict;
|
||||
}
|
||||
|
||||
|
@ -148,6 +146,40 @@ variantMapFromPyDict( const boost::python::dict& pyDict )
|
|||
return map;
|
||||
}
|
||||
|
||||
boost::python::dict
|
||||
variantHashToPyDict( const QVariantHash& variantHash )
|
||||
{
|
||||
bp::dict pyDict;
|
||||
for ( auto it = variantHash.constBegin(); it != variantHash.constEnd(); ++it )
|
||||
pyDict[ it.key().toStdString() ] = variantToPyObject( it.value() );
|
||||
return pyDict;
|
||||
}
|
||||
|
||||
|
||||
QVariantHash
|
||||
variantHashFromPyDict( const boost::python::dict& pyDict )
|
||||
{
|
||||
QVariantHash hash;
|
||||
bp::list keys = pyDict.keys();
|
||||
for ( int i = 0; i < bp::len( keys ); ++i )
|
||||
{
|
||||
bp::extract< std::string > extracted_key( keys[ i ] );
|
||||
if ( !extracted_key.check() )
|
||||
{
|
||||
cDebug() << "Key invalid, map might be incomplete.";
|
||||
continue;
|
||||
}
|
||||
|
||||
std::string key = extracted_key;
|
||||
|
||||
bp::object obj = pyDict[ key ];
|
||||
|
||||
hash.insert( QString::fromStdString( key ), variantFromPyObject( obj ) );
|
||||
}
|
||||
return hash;
|
||||
}
|
||||
|
||||
|
||||
|
||||
Helper* Helper::s_instance = nullptr;
|
||||
|
||||
|
@ -165,20 +197,16 @@ Helper::Helper( QObject* parent )
|
|||
// If we're running from the build dir
|
||||
QFileInfo fi( QDir::current().absoluteFilePath( "libcalamares.so" ) );
|
||||
if ( fi.exists() && fi.isReadable() )
|
||||
{
|
||||
m_pythonPaths.append( fi.dir().absolutePath() );
|
||||
}
|
||||
|
||||
QDir calaPythonPath( CalamaresUtils::systemLibDir().absolutePath() +
|
||||
QDir::separator() + "calamares" );
|
||||
if ( calaPythonPath.exists() &&
|
||||
calaPythonPath.isReadable() )
|
||||
calaPythonPath.isReadable() )
|
||||
{
|
||||
QFileInfo fi( calaPythonPath.absoluteFilePath( "libcalamares.so" ) );
|
||||
if ( fi.exists() && fi.isReadable() )
|
||||
{
|
||||
m_pythonPaths.append( fi.dir().absolutePath() );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue