/* * Copyright 1995, 2000 Perforce Software. All rights reserved. * * This file is part of Perforce - the FAST SCM System. */ /* * ClientUser - user interface primitives * * Public classes: * * ClientUser - user interface for client services * * Note that not all methods are always used. Here's a guideline: * * Used by almost all Perforce commands: * * Finished * HandleError * OutputBinary * OutputError * OutputInfo * OutputText * File * * Used only by commands that read the client's stdin: * * InputData * * Used only by 'p4 fstat' and some other commands when the * protocol variable 'tag' is set: * * OutputStat * * Used only by interactive commands that can generally be avoided: * * Diff * Edit * ErrorPause * Prompt * * Used only by the default ClientUser implementation: * * Help * Merge * * Public methods: * * ClientUser::InputData() - provide data to 'p4 spec-command -i'; * spec-command is branch, change, client, job, label, protect, * user, etc. * * ClientUser::HandleError() - process error data, the result of a failed * command. Default is to format output and call OutputError(). * * ClientUser::Message() - output error or tabular data. This is the * 2002.1 replacement for OutputInfo/Error: earlier servers * will invoke still HandleError() and OutputInfo(). * * ClinetUser::OutputError() - output error data, the result of a failed * command. * * ClientUser::OutputInfo() - output tabular data, the result of most * commands that report metadata. * * ClientUser::OutputBinary() - output binary data, generally the result * of 'p4 print binary_file'. * * ClientUser::OutputText() - output text data, generally the result * of 'p4 print text_file'. * * ClientUser::OutputStat() - output results of 'p4 fstat'; requires * calling StrDict::GetVar() to get the actual variable results. * * ClientUser::Prompt() - prompt the user, and wait for a response. * * ClientUser::ErrorPause() - print an error message and wait for the * user before continuing. * * ClientUser::Edit() - bring the user's editor up on a file; generally * part of 'p4 spec-command'. * * ClientUser::Diff() - diff two files, and display the results; the * result of 'p4 diff'. * * ClientUser::Merge() - merge three files and save the results; the * result of saying 'm' to the resolve dialog of 'p4 resolve'. * * ClientUser::Help() - dump out a block of help text to the user; * used by the resolve dialogs. * * ClientUser::File() - produce a FileSys object for reading * and writing files in client workspace. * * ClientUser::Finished() - called when tagged client call is finished. */ class Enviro; class ClientMerge; class ClientUser { public: ClientUser() { binaryStdout = 0; } virtual ~ClientUser(); virtual void InputData( StrBuf *strbuf, Error *e ); virtual void HandleError( Error *err ); virtual void Message( Error *err ); virtual void OutputError( const_char *errBuf ); virtual void OutputInfo( char level, const_char *data ); virtual void OutputBinary( const_char *data, int length ); virtual void OutputText( const_char *data, int length ); virtual void OutputStat( StrDict *varList ); virtual void Prompt( const StrPtr &msg, StrBuf &rsp, int noEcho, Error *e ); virtual void ErrorPause( char *errBuf, Error *e ); virtual void Edit( FileSys *f1, Error *e ); virtual void Diff( FileSys *f1, FileSys *f2, int doPage, char *diffFlags, Error *e ); virtual void Merge( FileSys *base, FileSys *leg1, FileSys *leg2, FileSys *result, Error *e ); virtual int Resolve( ClientMerge *m, Error *e ); virtual void Help( const_char *const *help ); virtual FileSys *File( FileSysType type ); virtual void Finished() {} StrDict *varList; // (cheesy) access to RPC buffer Enviro *enviro; // (cheesy) access to Client's env static void Edit( FileSys *f1, Enviro * env, Error *e ); static void RunCmd( const char *command, const char *arg1, const char *arg2, const char *arg3, const char *arg4, const char *pager, Error *e ); private: int binaryStdout; // stdout is in binary mode } ; /* * StrDict now provides the GetVar() interface for OutputStat(); * ClientVarList defined for backward compatability. */ typedef StrDict ClientVarList;
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#1 | 7292 | Andrew McDonald | initial submittal | ||
//guest/sam_stafford/p4hl/src/dlls/clientuser.h | |||||
#2 | 1689 | Sam Stafford |
Integrate 02.1 API and code cleanup to P4HL. Lots of work. Phew. |
||
#1 | 937 | Sam Stafford |
Renaming my guest directory to the more conventional sam_stafford. |
||
//guest/samwise/p4hl/src/dlls/clientuser.h | |||||
#1 | 936 | Sam Stafford |
Adding P4HL to the public depot. See relnotes.txt for installation instructions; all relevant files are under p4hl/dist. Source code is under p4hl/src in the form of a VC++ project. |