mirror of
https://github.com/veracrypt/VeraCrypt.git
synced 2025-11-12 19:38:26 -06:00
Fix issues launching fsck via terminal on Linux (#1086)
Currently on a system without xterm or konsole (like fresh Ubuntu install) the fsck check will not launch. Added gnome-terminal as an alternative and fixed an issue where konsole will always error out as --title and --caption are no longer valid arguments. Previously the error message was simply "xterm not found", so new LangString LINUX_EX2MSG_TERMINALNOTFOUND was added to let the user knows which programs they need to get the feature working.
This commit is contained in:
@@ -1569,6 +1569,7 @@
|
||||
<entry lang="en" key="CANT_INSTALL_WITH_EXE_OVER_MSI">VeraCrypt was previously installed using an MSI package and so it can't be updated using the standard installer.\n\nPlease use the MSI package to update your VeraCrypt installation.</entry>
|
||||
<entry lang="en" key="IDC_USE_ALL_FREE_SPACE">Use all available free space</entry>
|
||||
<entry lang="en" key="SYS_ENCRYPTION_UPGRADE_UNSUPPORTED_ALGORITHM">VeraCrypt cannot be upgraded because the system partition/drive was encrypted using an algorithm that is not supported anymore.\nPlease decrypt your system before upgrading VeraCrypt and then encrypt it again.</entry>
|
||||
<entry lang="en" key="LINUX_EX2MSG_TERMINALNOTFOUND">Supported terminal application could not be found, you need either xterm, konsole or gnome-terminal (with dbus-x11).</entry>
|
||||
</localization>
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<xs:element name="VeraCrypt">
|
||||
|
||||
@@ -78,10 +78,8 @@ namespace VeraCrypt
|
||||
if (stat("/usr/bin/konsole", &sb) == 0)
|
||||
{
|
||||
args.clear ();
|
||||
args.push_back ("--title");
|
||||
args.push_back ("fsck");
|
||||
args.push_back ("--caption");
|
||||
args.push_back ("fsck");
|
||||
args.push_back ("-p");
|
||||
args.push_back ("tabtitle=fsck");
|
||||
args.push_back ("-e");
|
||||
args.push_back ("sh");
|
||||
args.push_back ("-c");
|
||||
@@ -91,8 +89,22 @@ namespace VeraCrypt
|
||||
Process::Execute ("konsole", args, 1000);
|
||||
} catch (TimeOut&) { }
|
||||
}
|
||||
else if (stat("/usr/bin/gnome-terminal", &sb) == 0 && stat("/usr/bin/dbus-launch", &sb) == 0)
|
||||
{
|
||||
args.clear ();
|
||||
args.push_back ("--title");
|
||||
args.push_back ("fsck");
|
||||
args.push_back ("--");
|
||||
args.push_back ("sh");
|
||||
args.push_back ("-c");
|
||||
args.push_back (xargs);
|
||||
try
|
||||
{
|
||||
Process::Execute ("gnome-terminal", args, 1000);
|
||||
} catch (TimeOut&) { }
|
||||
}
|
||||
else
|
||||
throw;
|
||||
throw TerminalNotFound();
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -74,6 +74,7 @@ namespace VeraCrypt
|
||||
VC_CONVERT_EXCEPTION (ParameterTooLarge);
|
||||
VC_CONVERT_EXCEPTION (PartitionDeviceRequired);
|
||||
VC_CONVERT_EXCEPTION (StringConversionFailed);
|
||||
VC_CONVERT_EXCEPTION (TerminalNotFound);
|
||||
VC_CONVERT_EXCEPTION (TestFailed);
|
||||
VC_CONVERT_EXCEPTION (TimeOut);
|
||||
VC_CONVERT_EXCEPTION (UnknownException);
|
||||
|
||||
@@ -481,6 +481,7 @@ namespace VeraCrypt
|
||||
EX2MSG (UnportablePassword, LangString["UNSUPPORTED_CHARS_IN_PWD"]);
|
||||
|
||||
#if defined (TC_LINUX)
|
||||
EX2MSG (TerminalNotFound, LangString["LINUX_EX2MSG_TERMINALNOTFOUND"]);
|
||||
EX2MSG (UnsupportedSectorSize, LangString["SECTOR_SIZE_UNSUPPORTED"]);
|
||||
EX2MSG (UnsupportedSectorSizeHiddenVolumeProtection, LangString["LINUX_EX2MSG_UNSUPPORTEDSECTORSIZEHIDDENVOLUMEPROTECTION"]);
|
||||
EX2MSG (UnsupportedSectorSizeNoKernelCrypto, LangString["LINUX_EX2MSG_UNSUPPORTEDSECTORSIZENOKERNELCRYPTO"]);
|
||||
@@ -1620,6 +1621,7 @@ namespace VeraCrypt
|
||||
VC_CONVERT_EXCEPTION (ParameterTooLarge);
|
||||
VC_CONVERT_EXCEPTION (PartitionDeviceRequired);
|
||||
VC_CONVERT_EXCEPTION (StringConversionFailed);
|
||||
VC_CONVERT_EXCEPTION (TerminalNotFound);
|
||||
VC_CONVERT_EXCEPTION (TestFailed);
|
||||
VC_CONVERT_EXCEPTION (TimeOut);
|
||||
VC_CONVERT_EXCEPTION (UnknownException);
|
||||
|
||||
@@ -92,6 +92,7 @@ namespace VeraCrypt
|
||||
TC_EXCEPTION (ParameterTooLarge); \
|
||||
TC_EXCEPTION (PartitionDeviceRequired); \
|
||||
TC_EXCEPTION (StringConversionFailed); \
|
||||
TC_EXCEPTION (TerminalNotFound); \
|
||||
TC_EXCEPTION (TestFailed); \
|
||||
TC_EXCEPTION (TimeOut); \
|
||||
TC_EXCEPTION (UnknownException); \
|
||||
|
||||
Reference in New Issue
Block a user