/*
* PythonClientAPI. Wrapper around P4API.
*
* Copyright (c) 2007-2008, Perforce Software, Inc. All rights reserved.
* Portions Copyright (c) 1999, Mike Meyer. All rights reserved.
* Portions Copyright (c) 2004-2007, Robert Cowham. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL PERFORCE SOFTWARE, INC. BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* $Id: //depot/r09.2/p4-python/PythonClientAPI.h#1 $
*
* Build instructions:
* Use Distutils - see accompanying setup.py
*
* python setup.py install
*
*/
#ifndef PYTHON_CLIENT_API_H
#define PYTHON_CLIENT_API_H
class Enviro;
class PythonClientAPI
{
public:
PythonClientAPI();
~PythonClientAPI();
public:
typedef int (PythonClientAPI::*intsetter)(int);
typedef int (PythonClientAPI::*strsetter)(const char *);
typedef int (PythonClientAPI::*intgetter)();
typedef const char * (PythonClientAPI::*strgetter)();
typedef int (PythonClientAPI::*objsetter)(PyObject *);
typedef PyObject * (PythonClientAPI::*objgetter)();
private:
struct intattribute_t {
const char * attribute;
intsetter setter;
intgetter getter;
};
struct strattribute_t {
const char * attribute;
strsetter setter;
strgetter getter;
};
struct objattribute_t {
const char * attribute;
objsetter setter;
objgetter getter;
};
static intattribute_t intattributes[];
static strattribute_t strattributes[];
static objattribute_t objattributes[];
public:
// Tagged mode - can be enabled/disabled on a per-command basis
int SetTagged( int enable );
int GetTagged();
// Set API level for backwards compatibility
int SetApiLevel( int level );
int SetMaxResults( int v ) { maxResults = v; return 0; }
int SetMaxScanRows( int v ) { maxScanRows = v; return 0; }
int SetMaxLockTime( int v ) { maxLockTime = v; return 0; }
//
// Debugging support. Debug levels are:
//
// 1: Debugs commands being executed
// 2: Debug UI method calls
// 3: Show garbage collection ???
//
int SetDebug( int d );
// Returns 0 on success, otherwise -1 and might raise exception
int SetCharset( const char *c );
int SetClient( const char *c ) { client.SetClient( c ); return 0; }
int SetCwd( const char *c );
int SetHost( const char *h ) { client.SetHost( h ); return 0; }
int SetLanguage( const char *l ) { client.SetLanguage( l ); return 0; }
int SetPassword( const char *p ) { client.SetPassword( p ); return 0; }
int SetPort( const char *p );
int SetProg( const char *p ) { prog = p; return 0; }
int SetTicketFile( const char *p );
int SetUser( const char *u ) { client.SetUser( u ); return 0; }
int SetVersion( const char *v ) { version = v; return 0; }
const char * GetCharset() { return charset.Text(); }
const char * GetClient() { return client.GetClient().Text();}
const char * GetConfig() { return client.GetConfig().Text();}
const char * GetCwd() { return client.GetCwd().Text(); }
const char * GetEnv( const char *var );
const char * GetHost() { return client.GetHost().Text(); }
const char * GetLanguage() { return client.GetLanguage().Text(); }
const char * GetPassword() { return client.GetPassword().Text(); }
const char * GetPort() { return client.GetPort().Text(); }
const char * GetProg() { return prog.Text(); }
const char * GetTicketFile() { return ticketFile.Text(); }
const char * GetUser() { return client.GetUser().Text(); }
const char * GetVersion() { return version.Text(); }
int GetMaxResults() { return maxResults; }
int GetMaxScanRows() { return maxScanRows; }
int GetMaxLockTime() { return maxLockTime; }
int GetDebug() { return debug; }
int GetServerLevel() { return server2; }
int GetApiLevel() { return apiLevel; }
// Session management
PyObject * Connect(); // P4Exception on error
PyObject * Connected(); // Return true if connected and not dropped.
PyObject * Disconnect();
PyObject * ServerCaseInsensitive(); // P4Exception if asked prematurely
// Executing commands.
PyObject * Run( const char *cmd, int argc, char * const *argv );
int SetInput( PyObject * input );
PyObject * GetInput();
int SetResolver( PyObject * resolver );
PyObject * GetResolver();
// Result handling
PyObject * GetErrors() { return ui.GetResults().GetErrors(); }
PyObject * GetWarnings() { return ui.GetResults().GetWarnings();}
// __members__ handling
PyObject * GetMembers();
// Spec parsing
PyObject * ParseSpec( const char * type, const char *form );
PyObject * FormatSpec( const char *type, PyObject * dict );
PyObject * SpecFields( const char * type );
// Protocol
PyObject * SetProtocol( const char * var, const char *val );
PyObject * GetProtocol( const char * var );
// Exception levels:
//
// 0 - No exceptions raised
// 1 - Exceptions raised for errors
// 2 - Exceptions raised for errors and warnings
//
int SetExceptionLevel( int i ) { exceptionLevel = i; return 0; }
int GetExceptionLevel() { return exceptionLevel; }
void Except( const char *func, const char *msg );
void Except( const char *func, Error *e );
void Except( const char *func, const char *msg, const char *cmd );
public:
// setter/getter methods and attributes
static intsetter GetIntSetter(const char * forAttr);
static intgetter GetIntGetter(const char * forAttr);
static strsetter GetStrSetter(const char * forAttr);
static strgetter GetStrGetter(const char * forAttr);
static objsetter GetObjSetter(const char * forAttr);
static objgetter GetObjGetter(const char * forAttr);
// Ownership of returned list is passed to caller!
// Free it, keep it or suffer memory leak!
static const char ** GetAttributes();
private:
void RunCmd(const char *cmd, ClientUser *ui, int argc, char * const *argv);
bool IsConnected();
static intattribute_t * GetInt(const char * forAttr);
static strattribute_t * GetStr(const char * forAttr);
static objattribute_t * GetObj(const char * forAttr);
private:
ClientApi client; // Perforce API Class
PythonClientUser ui;
Enviro * enviro;
SpecMgr specMgr;
StrBufDict specDict;
StrBuf prog;
StrBuf version;
StrBuf charset;
StrBuf ticketFile;
int depth;
bool connected;
int apiLevel;
int debug;
int exceptionLevel;
int server2;
int caseSensitive;
int mode;
int maxResults;
int maxScanRows;
int maxLockTime;
};
#endif