Python: add the processing-output functions, too

This commit is contained in:
Adriaan de Groot 2023-09-19 23:00:42 +02:00
parent 42172826ca
commit 3594a64bd1
2 changed files with 72 additions and 3 deletions

View File

@ -17,6 +17,7 @@
#include "python/PythonJob.h" #include "python/PythonJob.h"
#include "utils/Logger.h" #include "utils/Logger.h"
#include "utils/RAII.h" #include "utils/RAII.h"
#include "utils/Runner.h"
#include "utils/String.h" #include "utils/String.h"
#include "utils/System.h" #include "utils/System.h"
#include "utils/Yaml.h" #include "utils/Yaml.h"
@ -285,6 +286,44 @@ raise_on_error( const Calamares::ProcessResult& ec, const QStringList& commandLi
return ec.first; return ec.first;
} }
int
process_output( Calamares::Utils::RunLocation location,
const QStringList& args,
const Calamares::Python::Object& callback,
const std::string& input,
int timeout )
{
Calamares::Utils::Runner r( args );
r.setLocation( location );
if ( !callback.is_none() )
{
if ( py::isinstance< Calamares::Python::List >( callback ) )
{
QObject::connect( &r,
&decltype( r )::output,
[ list_append = callback.attr( "append" ) ]( const QString& s )
{ list_append( s.toStdString() ); } );
}
else
{
QObject::connect(
&r, &decltype( r )::output, [ &callback ]( const QString& s ) { callback( s.toStdString() ); } );
}
r.enableOutputProcessing();
}
if ( !input.empty() )
{
r.setInput( QString::fromStdString( input ) );
}
if ( timeout > 0 )
{
r.setTimeout( std::chrono::seconds( timeout ) );
}
auto result = r.run();
return raise_on_error( result, args );
}
} // namespace } // namespace
/** @namespace /** @namespace
@ -421,6 +460,19 @@ check_target_env_output( const List& args, const std::string& input, int timeout
return ec.second.toStdString(); return ec.second.toStdString();
} }
int
target_env_process_output( const List& args, const Object& callback, const std::string& input, int timeout )
{
return process_output(
Calamares::System::RunLocation::RunInTarget, stringListFromPyList( args ), callback, input, timeout );
}
int
host_env_process_output( const List& args, const Object& callback, const std::string& input, int timeout )
{
return process_output(
Calamares::System::RunLocation::RunInHost, stringListFromPyList( args ), callback, input, timeout );
}
JobProxy::JobProxy( Calamares::Python::Job* parent ) JobProxy::JobProxy( Calamares::Python::Job* parent )
: prettyName( parent->prettyName().toStdString() ) : prettyName( parent->prettyName().toStdString() )
@ -545,6 +597,20 @@ PYBIND11_EMBEDDED_MODULE( utils, m )
py::arg( "command_list" ), py::arg( "command_list" ),
py::arg( "input" ) = std::string(), py::arg( "input" ) = std::string(),
py::arg( "timeout" ) = 0 ); py::arg( "timeout" ) = 0 );
m.def( "target_env_process_output",
&Calamares::Python::target_env_process_output,
"Runs command in target, updating callback and returns standard output or raises on error.",
py::arg( "command_list" ),
py::arg( "callback" ) = pybind11::none(),
py::arg( "input" ) = std::string(),
py::arg( "timeout" ) = 0 );
m.def( "host_env_process_output",
&Calamares::Python::host_env_process_output,
"Runs command in target, updating callback and returns standard output or raises on error.",
py::arg( "command_list" ),
py::arg( "callback" ) = pybind11::none(),
py::arg( "input" ) = std::string(),
py::arg( "timeout" ) = 0 );
m.def( "gettext_languages", m.def( "gettext_languages",
&Calamares::Python::gettext_languages, &Calamares::Python::gettext_languages,

View File

@ -41,9 +41,12 @@ namespace Python __attribute__( ( visibility( "hidden" ) ) )
List gettext_languages(); List gettext_languages();
Object gettext_path(); Object gettext_path();
int target_env_call( const List& args, const std::string& input = std::string(), int timeout = 0 ); int target_env_call( const List& args, const std::string& input, int timeout );
int check_target_env_call( const List& args, const std::string& input = std::string(), int timeout = 0 ); int check_target_env_call( const List& args, const std::string& input, int timeout );
std::string check_target_env_output( const List& args, const std::string& input = std::string(), int timeout = 0 ); std::string check_target_env_output( const List& args, const std::string& input, int timeout );
int target_env_process_output( const List& args, const Object& callback, const std::string& input, int timeout );
int host_env_process_output( const List& args, const Object& callback, const std::string& input, int timeout );
class Job; class Job;