source-engine/public/vgui_controls/PerforceFileList.h

115 lines
3.3 KiB
C
Raw Permalink Normal View History

2020-04-22 12:56:21 -04:00
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose: Contains a list of files, determines their perforce status
//
// $NoKeywords: $
//===========================================================================//
#ifndef PERFORCEFILELIST_H
#define PERFORCEFILELIST_H
#ifdef _WIN32
#pragma once
#endif
#include "tier1/utlstring.h"
#include "tier1/UtlStringMap.h"
#include "vgui_controls/ListPanel.h"
//-----------------------------------------------------------------------------
// Forward declarations
//-----------------------------------------------------------------------------
struct P4File_t;
namespace vgui
{
class ListPanel;
}
namespace vgui
{
//-----------------------------------------------------------------------------
// Contains a list of files, determines their perforce status
//-----------------------------------------------------------------------------
class PerforceFileList : public vgui::ListPanel
{
DECLARE_CLASS_SIMPLE( PerforceFileList, ListPanel );
public:
// The context keyvalues are added to all messages sent by this dialog if they are specified
PerforceFileList( Panel *parent, const char *pPanelName );
~PerforceFileList();
// Add a file to the file list. Note that this file may exist on disk or not
// and it may exist in perforce or not. It's specified as a full path on disk though.
// In the case where a file doesn't exist on disk, but it does exist in perforce
// specify where that file would appear on disk.
// This function returns the itemID of the added file
// If you already know the file exists or is a directory (or not), specify that in the call.
// -1 means autodetect whether the file exists or is a directory
int AddFile( const char *pFullPath, int nFileExists = -1, int nIsDirectory = -1 );
// Is a file already in the list?
bool IsFileInList( const char *pFullPath );
// Find the item ID associated with a particular file
int FindFile( const char *pFullPath );
// Remove all files from the list
void RemoveAllFiles();
// Refresh perforce information
void Refresh();
// Refresh perforce information manually
void RefreshPerforceState( int nItemID, bool bFileExists, P4File_t *pFileInfo );
// Is a particular list item a directory?
bool IsDirectoryItem( int nItemID );
// Returns the file associated with a particular item ID
const char *GetFile( int nItemID );
// Toggle showing deleted files or not
void ShowDeletedFiles( bool bShowDeletedFiles );
// Inherited from vgui::EditablePanel
virtual void ApplySchemeSettings( IScheme *pScheme );
virtual void OnMouseDoublePressed( MouseCode code );
/*
messages sent:
"ItemDoubleClicked" // Called when an item is double-clicked
*/
protected:
struct DirectoryInfo_t
{
CUtlString m_ClientSpec;
CUtlVector< int > m_ItemIDs;
};
// Add a file to the file list.
int AddFileToFileList( const char *pFullPath, bool bExistsOnDisk );
// Add a directory to the file list.
int AddDirectoryToFileList( const char *pFullPath, bool bExistsOnDisk );
// Add a directory to the directory list, returns client spec
void AddItemToDirectoryList( const char *pFullPath, int nItemID, bool bIsDirectory );
// Used to look up directories -> client specs
CUtlStringMap< DirectoryInfo_t > m_Directories;
// Show deleted files?
bool m_bShowDeletedFiles;
};
} // namespace vgui
#endif // PERFORCEFILELIST_H