You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

127 lines
3.2 KiB

/*
* Copyright (C) 2011-2012 Daniel Scharrer
*
* This software is provided 'as-is', without any express or implied
* warranty. In no event will the author(s) be held liable for any damages
* arising from the use of this software.
*
* Permission is granted to anyone to use this software for any purpose,
* including commercial applications, and to alter it and redistribute it
* freely, subject to the following restrictions:
*
* 1. The origin of this software must not be misrepresented; you must not
* claim that you wrote the original software. If you use this software
* in a product, an acknowledgment in the product documentation would be
* appreciated but is not required.
* 2. Altered source versions must be plainly marked as such, and must not be
* misrepresented as being the original software.
* 3. This notice may not be removed or altered from any source distribution.
*/
#include "setup/run.hpp"
#include <stdint.h>
#include "setup/version.hpp"
15 years ago
#include "util/load.hpp"
#include "util/storedenum.hpp"
namespace setup {
namespace {
STORED_ENUM_MAP(stored_run_wait_condition, run_entry::WaitUntilTerminated,
run_entry::WaitUntilTerminated,
run_entry::NoWait,
run_entry::WaitUntilIdle,
);
} // anonymous namespace
void run_entry::load(std::istream & is, const version & version) {
if(version < INNO_VERSION(1, 3, 21)) {
::load<uint32_t>(is); // uncompressed size of the directory entry structure
}
15 years ago
is >> encoded_string(name, version.codepage());
is >> encoded_string(parameters, version.codepage());
is >> encoded_string(working_dir, version.codepage());
if(version >= INNO_VERSION(1, 3, 21)) {
is >> encoded_string(run_once_id, version.codepage());
} else {
run_once_id.clear();
}
if(version >= INNO_VERSION(2, 0, 2)) {
is >> encoded_string(status_message, version.codepage());
} else {
status_message.clear();
}
if(version >= INNO_VERSION(5, 1, 13)) {
15 years ago
is >> encoded_string(verb, version.codepage());
} else {
verb.clear();
}
if(version >= INNO_VERSION(2, 0, 0)) {
15 years ago
is >> encoded_string(description, version.codepage());
}
load_condition_data(is, version);
load_version_data(is, version);
if(version >= INNO_VERSION(1, 3, 21)) {
show_command = load_number<int32_t>(is);
} else {
show_command = 0;
}
wait = stored_enum<stored_run_wait_condition>(is).get();
stored_flag_reader<flags> flags(is, version.bits);
flags.add(ShellExec);
if(version >= INNO_VERSION(1, 3, 21)) {
flags.add(SkipIfDoesntExist);
}
if(version >= INNO_VERSION(2, 0, 0)) {
flags.add(PostInstall);
flags.add(Unchecked);
flags.add(SkipIfSilent);
15 years ago
flags.add(Skipif_not_equalSilent);
}
if(version >= INNO_VERSION(2, 0, 8)) {
flags.add(HideWizard);
}
if(version >= INNO_VERSION(5, 1, 10)) {
flags.add(Bits32);
flags.add(Bits64);
}
if(version >= INNO_VERSION(5, 2, 0)) {
flags.add(RunAsOriginalUser);
}
15 years ago
options = flags;
}
} // namespace setup
NAMES(setup::run_entry::flags, "Run Option",
"shell exec",
"skip if doesn't exist",
"post install",
"unchecked",
"skip if silent",
"skip if not silent",
"hide wizard",
"32 bit",
"64 bit",
"run as original user",
)
NAMES(setup::run_entry::wait_condition, "Run Wait Type",
"wait until terminated",
"no wait",
"wait until idle",
)