Compare commits
2 Commits
d11b690708
...
e77b61b1d9
Author | SHA1 | Date | |
---|---|---|---|
e77b61b1d9 | |||
de049cea1a |
@ -18,9 +18,18 @@ namespace cellar {
|
|||||||
bottle_error,
|
bottle_error,
|
||||||
bottle_anonymous,
|
bottle_anonymous,
|
||||||
bottle_labelled,
|
bottle_labelled,
|
||||||
bottle_symlink
|
bottle_symlink,
|
||||||
|
bottle_steam
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum bottle_manager {
|
||||||
|
manager_error,
|
||||||
|
manager_cellar,
|
||||||
|
manager_steam
|
||||||
|
};
|
||||||
|
|
||||||
|
extern std::string bottle_home;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Bottles are the internal name for WINE prefixes. In addition to standard WINE contents,
|
* Bottles are the internal name for WINE prefixes. In addition to standard WINE contents,
|
||||||
* bottles contain a configuration file managed by cellar, which labels the bottle as well
|
* bottles contain a configuration file managed by cellar, which labels the bottle as well
|
||||||
@ -30,6 +39,7 @@ namespace cellar {
|
|||||||
public:
|
public:
|
||||||
// public members
|
// public members
|
||||||
bottle_type type;
|
bottle_type type;
|
||||||
|
bottle_manager manager;
|
||||||
json config;
|
json config;
|
||||||
string path;
|
string path;
|
||||||
string canonical_path;
|
string canonical_path;
|
||||||
|
@ -21,6 +21,8 @@ namespace cellar {
|
|||||||
cog.outl("extern void {0} (int, vector<string>);".format(item[1]))
|
cog.outl("extern void {0} (int, vector<string>);".format(item[1]))
|
||||||
]]]*/
|
]]]*/
|
||||||
//[[[end]]]
|
//[[[end]]]
|
||||||
|
|
||||||
|
extern void setup_bottle_home();
|
||||||
}
|
}
|
||||||
namespace commands {
|
namespace commands {
|
||||||
extern map<string, cellar::commands::CommandFunction> bottles_commands();
|
extern map<string, cellar::commands::CommandFunction> bottles_commands();
|
||||||
|
13
include/internal/steam.hpp
Normal file
13
include/internal/steam.hpp
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include "commands.hpp"
|
||||||
|
|
||||||
|
namespace cellar {
|
||||||
|
namespace steam {
|
||||||
|
extern std::vector<std::string> find_steam_libraries();
|
||||||
|
}
|
||||||
|
}
|
@ -1,26 +0,0 @@
|
|||||||
#pragma once
|
|
||||||
|
|
||||||
#include <map>
|
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include "commands.hpp"
|
|
||||||
|
|
||||||
namespace cellar {
|
|
||||||
namespace steam {
|
|
||||||
extern std::vector<std::string> find_steam_libraries();
|
|
||||||
extern void test_command(int argc, std::vector<std::string> argv);
|
|
||||||
/*[[[cog
|
|
||||||
import cog
|
|
||||||
|
|
||||||
with open("src/steam/commands.txt") as commandsfile:
|
|
||||||
for line in commandsfile:
|
|
||||||
item = line.strip().split(" ")
|
|
||||||
cog.outl("extern void {0} (int, vector<string>);".format(item[1]))
|
|
||||||
]]]*/
|
|
||||||
//[[[end]]]
|
|
||||||
}
|
|
||||||
namespace commands {
|
|
||||||
extern std::map<std::string,cellar::commands::CommandFunction> steam_commands();
|
|
||||||
}
|
|
||||||
}
|
|
@ -17,6 +17,7 @@ void cellar::bottles::print_active_bottle(int argc, vector<string> argv) {
|
|||||||
string bottlepath = active_bottle.canonical_path;
|
string bottlepath = active_bottle.canonical_path;
|
||||||
stringstream outstr;
|
stringstream outstr;
|
||||||
bool cellar_managed = true;
|
bool cellar_managed = true;
|
||||||
|
bool external_managed = false;
|
||||||
if (active_bottle.type == bottle_symlink) {
|
if (active_bottle.type == bottle_symlink) {
|
||||||
outstr << "symlink to ";
|
outstr << "symlink to ";
|
||||||
string homedir = getenv("HOME");
|
string homedir = getenv("HOME");
|
||||||
@ -24,6 +25,8 @@ void cellar::bottles::print_active_bottle(int argc, vector<string> argv) {
|
|||||||
if (active_bottle.canonical_path.substr(0, bottlerack.length()) == bottlerack) {
|
if (active_bottle.canonical_path.substr(0, bottlerack.length()) == bottlerack) {
|
||||||
bottlepath.replace(0, bottlerack.length() + 1, ""); // should convert "/home/someone/.wine.example" to ".wine.example"
|
bottlepath.replace(0, bottlerack.length() + 1, ""); // should convert "/home/someone/.wine.example" to ".wine.example"
|
||||||
active_bottle = bottlemap[bottlepath];
|
active_bottle = bottlemap[bottlepath];
|
||||||
|
active_bottle.set_config("manager", "cellar");
|
||||||
|
active_bottle.save_config();
|
||||||
} else {
|
} else {
|
||||||
outstr << active_bottle.canonical_path;
|
outstr << active_bottle.canonical_path;
|
||||||
cellar_managed = false;
|
cellar_managed = false;
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
#include <filesystem>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <string>
|
#include <string>
|
||||||
@ -33,6 +34,21 @@ Bottle::Bottle() {
|
|||||||
// strings handle themselves
|
// strings handle themselves
|
||||||
config = json({});
|
config = json({});
|
||||||
type = bottle_anonymous;
|
type = bottle_anonymous;
|
||||||
|
manager = manager_error;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string cellar::bottles::bottle_home;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Sets up bottle home.
|
||||||
|
* Called once from early mainloop.
|
||||||
|
* @todo Have this not be an effectively hardcoded path. Respect xdg paths.
|
||||||
|
*/
|
||||||
|
void cellar::bottles::setup_bottle_home() {
|
||||||
|
stringstream sstr_bottle_home;
|
||||||
|
sstr_bottle_home << std::getenv("HOME");
|
||||||
|
sstr_bottle_home << "/.local/share/cellar/bottles";
|
||||||
|
bottle_home = sstr_bottle_home.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -45,20 +61,39 @@ Bottle::Bottle(string patharg) {
|
|||||||
config = json({});
|
config = json({});
|
||||||
path = patharg;
|
path = patharg;
|
||||||
|
|
||||||
boost::filesystem::file_status path_status = boost::filesystem::symlink_status(path);
|
//boost::filesystem::file_status path_status = boost::filesystem::symlink_status(path);
|
||||||
bool symlink = boost::filesystem::is_symlink(path_status);
|
//bool symlink = boost::filesystem::is_symlink(path_status);
|
||||||
|
auto path_status = std::filesystem::path(path);
|
||||||
|
auto path_canon = std::filesystem::canonical(path_status);
|
||||||
|
canonical_path = path_canon.string();
|
||||||
|
|
||||||
if (symlink) {
|
if (std::filesystem::is_symlink(path_canon)) {
|
||||||
boost::filesystem::path realpath = boost::filesystem::canonical(path);
|
|
||||||
canonical_path = realpath.string();
|
|
||||||
type = bottle_symlink;
|
type = bottle_symlink;
|
||||||
} else {
|
} else {
|
||||||
canonical_path = path;
|
|
||||||
try {
|
try {
|
||||||
if (load_config()) {
|
load_config();
|
||||||
type = bottle_labelled;
|
auto cur_manager = get_config("manager");
|
||||||
} else {
|
if (cur_manager == "cellar") {
|
||||||
type = bottle_anonymous;
|
manager = manager_cellar;
|
||||||
|
|
||||||
|
if (get_config("name") != "") {
|
||||||
|
type = bottle_labelled;
|
||||||
|
} else {
|
||||||
|
type = bottle_anonymous;
|
||||||
|
}
|
||||||
|
} else if (path_canon.parent_path() == bottle_home) {
|
||||||
|
manager = manager_cellar;
|
||||||
|
set_config("manager", "cellar"); // migrate from older cellar (or correct for something weird happening)
|
||||||
|
save_config();
|
||||||
|
|
||||||
|
if (get_config("name") != "") {
|
||||||
|
type = bottle_labelled;
|
||||||
|
} else {
|
||||||
|
type = bottle_anonymous;
|
||||||
|
}
|
||||||
|
} else if (cur_manager == "steam") {
|
||||||
|
type = bottle_steam;
|
||||||
|
manager = manager_steam;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (const exception &exc) {
|
catch (const exception &exc) {
|
||||||
@ -163,6 +198,9 @@ void cellar::bottles::print_bottles(int argc, vector<string> argv) {
|
|||||||
case bottle_labelled:
|
case bottle_labelled:
|
||||||
outstr << bottle.config["name"];
|
outstr << bottle.config["name"];
|
||||||
break;
|
break;
|
||||||
|
case bottle_steam:
|
||||||
|
outstr << "Steam managed bottle for " << bottle.config["name"];
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
outstr << "broken or unsupported wine bottle";
|
outstr << "broken or unsupported wine bottle";
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include "nlohmann/json.hpp"
|
#include "nlohmann/json.hpp"
|
||||||
|
|
||||||
#include "bottles.hpp"
|
#include "bottles.hpp"
|
||||||
|
#include "internal/bottles.hpp"
|
||||||
#include "cellar.hpp"
|
#include "cellar.hpp"
|
||||||
#include "commands.hpp"
|
#include "commands.hpp"
|
||||||
#include "output.hpp"
|
#include "output.hpp"
|
||||||
@ -45,6 +46,7 @@ int main(int argc, char* argv[]) {
|
|||||||
cout << "\n(try \"cellar help\" if you're confused)" << endl;
|
cout << "\n(try \"cellar help\" if you're confused)" << endl;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
cellar::bottles::setup_bottle_home();
|
||||||
try {
|
try {
|
||||||
const string desc = "bottle management tool for WINE connoisseurs";
|
const string desc = "bottle management tool for WINE connoisseurs";
|
||||||
const string versionstr = version::short_version();
|
const string versionstr = version::short_version();
|
||||||
@ -70,7 +72,7 @@ int main(int argc, char* argv[]) {
|
|||||||
dryrun = dryrunarg.getValue();
|
dryrun = dryrunarg.getValue();
|
||||||
verbose = dryrun || verbosearg.getValue();
|
verbose = dryrun || verbosearg.getValue();
|
||||||
|
|
||||||
// BULLSHIT: trying to use str.format on this string causes bizarre compiler errors
|
// TODO: i'm sure stdlib has come a long way in formatting strings since this ancient hack was put in
|
||||||
/*[[[cog
|
/*[[[cog
|
||||||
import cog
|
import cog
|
||||||
|
|
||||||
@ -103,7 +105,7 @@ int main(int argc, char* argv[]) {
|
|||||||
if (bottlechoice.substr(0,1) == "/" || bottlechoice.substr(0,1) == ".") { // absolute or relative path
|
if (bottlechoice.substr(0,1) == "/" || bottlechoice.substr(0,1) == ".") { // absolute or relative path
|
||||||
bottles::active_bottle = bottles::Bottle(bottlechoice);
|
bottles::active_bottle = bottles::Bottle(bottlechoice);
|
||||||
} else if (bottlechoice.substr(0,1) == "~") { // "absolute" path in home directory, not expanded by the shell for some reason (i've seen some shit)
|
} else if (bottlechoice.substr(0,1) == "~") { // "absolute" path in home directory, not expanded by the shell for some reason (i've seen some shit)
|
||||||
// this is a naive replacement and will fail if the user tries something like ~nick/.wine
|
// this is a naive replacement and will fail if the user tries something like ~nicole/.wine
|
||||||
// i'm figuring at that point if you're doing that, you'll also recognize if your shell
|
// i'm figuring at that point if you're doing that, you'll also recognize if your shell
|
||||||
// isn't actually expanding your path...
|
// isn't actually expanding your path...
|
||||||
bottlechoice.replace(0,1,getenv("HOME"));
|
bottlechoice.replace(0,1,getenv("HOME"));
|
||||||
|
@ -44,7 +44,9 @@ std::map<std::string, cellar::bottles::Bottle> cellar::steam::get_app_bottles()
|
|||||||
}
|
}
|
||||||
|
|
||||||
auto curbottle = cellar::bottles::Bottle((pth_appid / "pfx").string());
|
auto curbottle = cellar::bottles::Bottle((pth_appid / "pfx").string());
|
||||||
|
curbottle.type = cellar::bottles::bottle_steam;
|
||||||
curbottle.set_config("name", str_gamename);
|
curbottle.set_config("name", str_gamename);
|
||||||
|
curbottle.set_config("manager", "steam");
|
||||||
curbottle.save_config();
|
curbottle.save_config();
|
||||||
result[std::string("steam:" + pth_appid.filename().string())] = curbottle;
|
result[std::string("steam:" + pth_appid.filename().string())] = curbottle;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user