Files
renderdoc/qrenderdoc/Code/Interface/QRDInterface.cpp
T
baldurk 0b527fab49 Use rdc types instead of Qt containers in public QRenderDoc interface
* This is to support python bindings - the pyside implementation of
  QVector, QString, etc is not available to SWIG, so SWIG treates these
  all as opaque types.
* Rather than trying to set up bindings that work for rdcarray and
  QList/QVector, or implementing separate bindings, we instead just say
  that the public interface must use the rdc types. In most cases they
  seamlessly convert to/from Qt types anyway.
* In a couple of places we use an array of pairs instead of a map. In
  future we probably want an rdcdict or rdcmap with proper dict bindings
  in python.
2017-12-13 22:43:01 +00:00

170 lines
5.5 KiB
C++

/******************************************************************************
* The MIT License (MIT)
*
* Copyright (c) 2017 Baldur Karlsson
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
******************************************************************************/
#include "QRDInterface.h"
#include <QDir>
#include <QStandardPaths>
#include "Code/QRDUtils.h"
QVariant EnvModToVariant(const EnvironmentModification &env)
{
QVariantMap ret;
ret[lit("variable")] = env.name;
ret[lit("value")] = env.value;
ret[lit("type")] = ToQStr(env.mod);
ret[lit("separator")] = ToQStr(env.sep);
return ret;
}
EnvironmentModification EnvModFromVariant(const QVariant &v)
{
QVariantMap data = v.toMap();
EnvironmentModification ret;
ret.name = data[lit("variable")].toString().toUtf8().data();
ret.value = data[lit("value")].toString().toUtf8().data();
QString t = data[lit("type")].toString();
if(t == ToQStr(EnvMod::Append))
ret.mod = EnvMod::Append;
else if(t == ToQStr(EnvMod::Prepend))
ret.mod = EnvMod::Prepend;
else
ret.mod = EnvMod::Set;
QString s = data[lit("separator")].toString();
if(s == ToQStr(EnvSep::SemiColon))
ret.sep = EnvSep::SemiColon;
else if(s == ToQStr(EnvSep::Colon))
ret.sep = EnvSep::Colon;
else if(s == ToQStr(EnvSep::Platform))
ret.sep = EnvSep::Platform;
else
ret.sep = EnvSep::NoSep;
return ret;
}
CaptureSettings::CaptureSettings()
{
Inject = false;
AutoStart = false;
RENDERDOC_GetDefaultCaptureOptions(&Options);
}
CaptureSettings::operator QVariant() const
{
QVariantMap ret;
ret[lit("Inject")] = Inject;
ret[lit("AutoStart")] = AutoStart;
ret[lit("Executable")] = Executable;
ret[lit("WorkingDir")] = WorkingDir;
ret[lit("CmdLine")] = CmdLine;
QVariantList env;
for(int i = 0; i < Environment.count(); i++)
env.push_back(EnvModToVariant(Environment[i]));
ret[lit("Environment")] = env;
QVariantMap opts;
opts[lit("AllowVSync")] = Options.AllowVSync;
opts[lit("AllowFullscreen")] = Options.AllowFullscreen;
opts[lit("APIValidation")] = Options.APIValidation;
opts[lit("CaptureCallstacks")] = Options.CaptureCallstacks;
opts[lit("CaptureCallstacksOnlyDraws")] = Options.CaptureCallstacksOnlyDraws;
opts[lit("DelayForDebugger")] = Options.DelayForDebugger;
opts[lit("VerifyMapWrites")] = Options.VerifyMapWrites;
opts[lit("HookIntoChildren")] = Options.HookIntoChildren;
opts[lit("RefAllResources")] = Options.RefAllResources;
opts[lit("SaveAllInitials")] = Options.SaveAllInitials;
opts[lit("CaptureAllCmdLists")] = Options.CaptureAllCmdLists;
opts[lit("DebugOutputMute")] = Options.DebugOutputMute;
ret[lit("Options")] = opts;
return ret;
}
CaptureSettings::CaptureSettings(const QVariant &v)
{
QVariantMap data = v.toMap();
Inject = data[lit("Inject")].toBool();
AutoStart = data[lit("AutoStart")].toBool();
Executable = data[lit("Executable")].toString();
WorkingDir = data[lit("WorkingDir")].toString();
CmdLine = data[lit("CmdLine")].toString();
QVariantList env = data[lit("Environment")].toList();
for(int i = 0; i < env.size(); i++)
{
EnvironmentModification e = EnvModFromVariant(env[i]);
Environment.push_back(e);
}
QVariantMap opts = data[lit("Options")].toMap();
Options.AllowVSync = opts[lit("AllowVSync")].toBool();
Options.AllowFullscreen = opts[lit("AllowFullscreen")].toBool();
Options.APIValidation = opts[lit("APIValidation")].toBool();
Options.CaptureCallstacks = opts[lit("CaptureCallstacks")].toBool();
Options.CaptureCallstacksOnlyDraws = opts[lit("CaptureCallstacksOnlyDraws")].toBool();
Options.DelayForDebugger = opts[lit("DelayForDebugger")].toUInt();
Options.VerifyMapWrites = opts[lit("VerifyMapWrites")].toBool();
Options.HookIntoChildren = opts[lit("HookIntoChildren")].toBool();
Options.RefAllResources = opts[lit("RefAllResources")].toBool();
Options.SaveAllInitials = opts[lit("SaveAllInitials")].toBool();
Options.CaptureAllCmdLists = opts[lit("CaptureAllCmdLists")].toBool();
Options.DebugOutputMute = opts[lit("DebugOutputMute")].toBool();
}
rdcstr configFilePath(const rdcstr &filename)
{
QString path = QStandardPaths::writableLocation(QStandardPaths::AppDataLocation);
QDir dir(path);
if(!dir.exists())
dir.mkdir(lit("."));
return QDir::cleanPath(dir.absoluteFilePath(filename));
}
ICaptureContext *getCaptureContext(const QWidget *widget)
{
void *ctxptr = NULL;
while(widget && !ctxptr)
{
ctxptr = widget->property("ICaptureContext").value<void *>();
widget = widget->parentWidget();
}
return (ICaptureContext *)ctxptr;
}