summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ark/arch.cpp25
-rw-r--r--ark/rar.cpp9
2 files changed, 33 insertions, 1 deletions
diff --git a/ark/arch.cpp b/ark/arch.cpp
index 999647a..1916e12 100644
--- a/ark/arch.cpp
+++ b/ark/arch.cpp
@@ -100,6 +100,31 @@ void Arch::verifyUncompressUtilityIsAvailable( const QString &utility )
void Arch::slotOpenExited( KProcess* _kp )
{
+ bool success = ( _kp->normalExit() && ( _kp->exitStatus() == 0 ) );
+
+ if( !success )
+ {
+ if ( passwordRequired() )
+ {
+ QString msg;
+ if ( !m_password.isEmpty() )
+ msg = i18n("The password was incorrect. ");
+ if (KPasswordDialog::getPassword( m_password, msg+i18n("You must enter a password to open the file:") ) == KPasswordDialog::Accepted )
+ {
+ delete _kp;
+ _kp = m_currentProcess = 0;
+ clearShellOutput();
+ open(); // try to open the file again with a password
+ return;
+ }
+ m_password = "";
+ emit sigOpen( this, false, QString::null, 0 );
+ delete _kp;
+ _kp = m_currentProcess = 0;
+ return;
+ }
+ }
+
int exitStatus = 100; // arbitrary bad exit status
if ( _kp->normalExit() )
diff --git a/ark/rar.cpp b/ark/rar.cpp
index 742df1c..071dc9e 100644
--- a/ark/rar.cpp
+++ b/ark/rar.cpp
@@ -128,7 +128,14 @@ void RarArch::open()
m_finished = false;
KProcess *kp = m_currentProcess = new KProcess;
- *kp << m_unarchiver_program << "v" << "-c-" << m_filename;
+ *kp << m_unarchiver_program << "v" << "-c-";
+
+ if ( !m_password.isEmpty() )
+ *kp << "-p" + m_password;
+ else
+ *kp << "-p-";
+
+ *kp << m_filename;
connect( kp, SIGNAL( receivedStdout(KProcess*, char*, int) ),
SLOT( slotReceivedTOC(KProcess*, char*, int) ) );