2020-09-30 16:53:55 +02:00

525 lines
14 KiB
C++

// DSColumn.h : Declaration of ds column routines and classes
//
//+-------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1999
//
// File: DSColumn.h
//
// Contents: Static data and column set routines and classes
//
// History: 12-mar-99 jeffjon Created
//
//--------------------------------------------------------------------------
#ifndef _DS_COLUMN_H_
#define _DS_COLUMN_H_
class CDSCookie;
////////////////////////////////////////////////////////////////////////////////
#define DEFAULT_COLUMN_SET L"default"
#define SPECIAL_COLUMN_SET L"special"
typedef enum _ATTRIBUTE_COLUMN_TYPE {
ATTR_COLTYPE_NAME,
ATTR_COLTYPE_CLASS,
ATTR_COLTYPE_DESC,
ATTR_COLTYPE_SPECIAL,
ATTR_COLTYPE_MODIFIED_TIME,
} ATTRIBUTE_COLUMN_TYPE;
typedef BOOL (*COLUMN_EXTRACTION_FUNCTION)(
OUT CString& strref,
IN CDSCookie* pCookie,
IN PADS_SEARCH_COLUMN pColumn);
typedef struct _ATTRIBUTE_COLUMN {
ATTRIBUTE_COLUMN_TYPE coltype;
UINT resid;
int iColumnWidth;
LPCTSTR pcszAttribute;
COLUMN_EXTRACTION_FUNCTION pfnExtract;
} ATTRIBUTE_COLUMN, *PATTRIBUTE_COLUMN;
typedef struct _ColumnsForClass {
LPCTSTR pcszLdapClassName;
LPCTSTR pcszColumnID;
int nColumns;
PATTRIBUTE_COLUMN* apColumns;
} COLUMNS_FOR_CLASS, *PCOLUMNS_FOR_CLASS;
typedef struct _SpecialColumn {
UINT resid;
LPCTSTR ptszAttribute;
int iColumnWidth;
} SPECIAL_COLUMN, *PSPECIAL_COLUMN;
////////////////////////////////////////////////////////////////////////////////
// CColumn
class CColumn
{
public:
CColumn(LPCWSTR lpszColumnHeader,
int nFormat,
int nWidth,
int nColumnNum,
BOOL bDefaultVisible)
{
m_lpszColumnHeader = NULL;
SetHeader(lpszColumnHeader);
m_nFormat = nFormat;
m_nWidth = nWidth;
m_nColumnNum = nColumnNum;
m_bDefaultVisible = bDefaultVisible;
m_bVisible = bDefaultVisible;
}
virtual ~CColumn()
{
if (m_lpszColumnHeader != NULL)
free(m_lpszColumnHeader);
}
protected:
CColumn() {}
private:
//
// Do nothing copy constructor and operator =
//
CColumn(CColumn&) {}
CColumn& operator=(CColumn&) {}
public:
LPCWSTR GetHeader() { return (LPCWSTR)m_lpszColumnHeader; }
void SetHeader(LPCWSTR lpszColumnHeader)
{
if (m_lpszColumnHeader != NULL)
{
free(m_lpszColumnHeader);
}
size_t iLen = wcslen(lpszColumnHeader);
m_lpszColumnHeader = (LPWSTR)malloc(sizeof(WCHAR) * (iLen + 1));
if (m_lpszColumnHeader != NULL)
{
wcscpy(m_lpszColumnHeader, lpszColumnHeader);
}
}
int GetFormat() { return m_nFormat; }
void SetFormat(int nFormat) { m_nFormat = nFormat; }
int GetWidth() { return m_nWidth; }
void SetWidth(int nWidth) { m_nWidth = nWidth; }
int GetColumnNum() { return m_nColumnNum; }
void SetColumnNum(int nColumnNum) { m_nColumnNum = nColumnNum; }
void SetVisible(BOOL bVisible) { m_bVisible = bVisible; }
BOOL IsVisible() { return m_bVisible; }
void SetDefaultVisibility() { m_bVisible = m_bDefaultVisible; }
protected:
LPWSTR m_lpszColumnHeader;
int m_nFormat;
int m_nWidth;
int m_nColumnNum;
BOOL m_bVisible;
BOOL m_bDefaultVisible;
};
////////////////////////////////////////////////////////////////////////////////
// CDSColumn
class CDSColumn : public CColumn
{
public:
CDSColumn(LPCWSTR lpszColumnHeader,
int nFormat,
int nWidth,
UINT nColumnNum,
BOOL bDefaultVisible,
LPCWSTR lpszAttribute,
ATTRIBUTE_COLUMN_TYPE type,
COLUMN_EXTRACTION_FUNCTION pfnExtract)
: CColumn(lpszColumnHeader, nFormat, nWidth, nColumnNum, bDefaultVisible)
{
if (lpszAttribute != NULL)
{
// Make a copy of the attribute
size_t iLen = wcslen(lpszAttribute);
m_lpszAttribute = (LPWSTR)malloc(sizeof(WCHAR) * (iLen + 1));
//NTRAID#NTBUG9-572012-2002/03/10-jmessec malloc may have failed, leaving m_lpszAttribute == NULL for following wcscpy
wcscpy(m_lpszAttribute, lpszAttribute);
}
else
{
m_lpszAttribute = NULL;
}
m_type = type;
m_pfnExtract = pfnExtract;
}
virtual ~CDSColumn()
{
if (m_lpszAttribute != NULL)
{
free(m_lpszAttribute);
}
}
protected:
CDSColumn() {}
private:
//
// Do nothing copy constructor and operator =
//
CDSColumn(CDSColumn&) {}
CDSColumn& operator=(CDSColumn&) {}
public:
LPCWSTR GetColumnAttribute() { return (LPCWSTR)m_lpszAttribute; }
ATTRIBUTE_COLUMN_TYPE GetColumnType() { return m_type; }
COLUMN_EXTRACTION_FUNCTION GetExtractionFunction() { return m_pfnExtract; }
private :
LPWSTR m_lpszAttribute;
ATTRIBUTE_COLUMN_TYPE m_type;
COLUMN_EXTRACTION_FUNCTION m_pfnExtract;
};
////////////////////////////////////////////////////////////////////////////////
// CColumnSet
typedef CList<CColumn*, CColumn*> CColumnList;
class CColumnSet : public CColumnList
{
public :
CColumnSet(LPCWSTR lpszColumnID)
{
// Make a copy of the column set ID
if (lpszColumnID)
{
size_t iLen = wcslen(lpszColumnID);
m_lpszColumnID = (LPWSTR)malloc(sizeof(WCHAR) * (iLen + 1));
if (m_lpszColumnID != NULL)
{
wcscpy(m_lpszColumnID, lpszColumnID);
}
//NTRAID#NTBUG9-571988-2002/03/10-jmessec If malloc fails, object is left in unexpected state
}
else
{
//NTRAID#NTBUG9-567482-2002/03/10-jmessec This does nothing! in release code. Back it up with code.
ASSERT(FALSE);
}
}
virtual ~CColumnSet()
{
while(!IsEmpty())
{
CColumn* pColumn = RemoveTail();
delete pColumn;
}
if (m_lpszColumnID != NULL)
free(m_lpszColumnID);
}
protected:
CColumnSet() {}
private:
//
// Do nothing copy constructor and operator =
//
CColumnSet(CColumnSet&) {}
CColumnSet& operator=(CColumnSet&) {}
public:
void AddColumn(LPCWSTR lpszHeader, int nFormat, int nWidth, UINT nCol, BOOL bDefaultVisible)
{
CColumn* pNewColumn = new CColumn(lpszHeader, nFormat, nWidth, nCol, bDefaultVisible);
AddTail(pNewColumn);
}
void AddColumn(CColumn* pNewColumn) { AddTail(pNewColumn); }
LPCWSTR GetColumnID() { return (LPCWSTR)m_lpszColumnID; }
void SetColumnID(LPCWSTR lpszColumnID)
{
if (m_lpszColumnID != NULL)
{
free(m_lpszColumnID);
}
// Make a copy of the column set ID
size_t iLen = wcslen(lpszColumnID);
m_lpszColumnID = (LPWSTR)malloc(sizeof(WCHAR) * (iLen + 1));
//NTRAID#NTBUG9-571988-2002/03/10-jmessec malloc may have failed, leaving m_lpszColumnID == NULL for following wcscpy
wcscpy(m_lpszColumnID, lpszColumnID);
}
int GetNumCols() { return (int)GetCount(); }
CColumn* GetColumnAt(int idx)
{
POSITION pos = GetHeadPosition();
while (pos != NULL)
{
CColumn* pCol = GetNext(pos);
if (pCol->GetColumnNum() == idx)
return pCol;
}
return NULL;
}
void ClearVisibleColumns()
{
POSITION pos = GetHeadPosition();
while (pos != NULL)
{
CColumn* pCol = GetNext(pos);
pCol->SetVisible(FALSE);
}
}
void AddVisibleColumns(MMC_COLUMN_DATA* pColumnData, int nNumCols)
{
TRACE(L"CColumnSet::AddVisibleColumns(MMC_COLUMN_DATA*) GetColumnID() = %s\n", GetColumnID());
if (pColumnData == NULL)
{
ASSERT(pColumnData != NULL);
return;
}
for (int idx = 0; idx < nNumCols; idx++)
{
TRACE(L"====================\n");
TRACE(L"pColumnData[%d].nColIndex = %d\n", idx, pColumnData[idx].nColIndex);
TRACE(L"pColumnData[%d].dwFlags = 0x%x\n", idx, pColumnData[idx].dwFlags);
CColumn* pCol = GetColumnAt(pColumnData[idx].nColIndex);
ASSERT(pCol != NULL);
if (pCol == NULL)
{
continue;
}
LPCWSTR lpszHeader = pCol->GetHeader();
TRACE(L"Column Header = %s, IsVisible() = %d\n", lpszHeader, pCol->IsVisible());
if (!(pColumnData[idx].dwFlags & HDI_HIDDEN))
{
TRACE(L"pCol->SetVisible(TRUE);\n");
pCol->SetVisible(TRUE);
}
}
}
void AddVisibleColumns(MMC_VISIBLE_COLUMNS* pVisibleColumns)
{
TRACE(L"CColumnSet::AddVisibleColumns(MMC_VISIBLE_COLUMNS*) GetColumnID() = %s\n", GetColumnID());
if (pVisibleColumns == NULL)
{
ASSERT(pVisibleColumns != NULL);
return;
}
for (int idx = 0; idx < pVisibleColumns->nVisibleColumns; idx++)
{
TRACE(L"====================\n");
TRACE(L"pVisibleColumns->rgVisibleCols[%d] = %d\n", idx, pVisibleColumns->rgVisibleCols[idx]);
if (pVisibleColumns->rgVisibleCols[idx] < GetCount())
{
CColumn* pCol = GetColumnAt(pVisibleColumns->rgVisibleCols[idx]);
ASSERT (pCol != NULL);
if (pCol == NULL)
{
continue;
}
LPCWSTR lpszHeader = pCol->GetHeader();
TRACE(L"Column Header = %s, IsVisible() = %d\n", lpszHeader, pCol->IsVisible());
pCol->SetVisible(TRUE);
}
}
}
void SetAllColumnsToDefaultVisibility()
{
POSITION pos = GetHeadPosition();
while (pos != NULL)
{
CColumn* pCol = GetNext(pos);
ASSERT(pCol != NULL);
pCol->SetDefaultVisibility();
}
}
HRESULT LoadFromColumnData(IColumnData* pColumnData)
{
TRACE(L"CColumnSet::LoadFromColumnData(), GetColumnID() = %s\n", GetColumnID());
LPCWSTR lpszID = GetColumnID();
size_t iLen = wcslen(lpszID);
// allocate enough memory for the struct and the column ID
SColumnSetID* pNodeID = (SColumnSetID*)new BYTE[sizeof(SColumnSetID) + (iLen * sizeof(WCHAR))];
if (!pNodeID)
{
return E_OUTOFMEMORY;
}
memset(pNodeID, 0, sizeof(SColumnSetID) + (iLen * sizeof(WCHAR)));
pNodeID->cBytes = static_cast<DWORD>(iLen * sizeof(WCHAR));
memcpy(pNodeID->id, lpszID, static_cast<UINT>(iLen * sizeof(WCHAR)));
MMC_COLUMN_SET_DATA* pColumnSetData = NULL;
HRESULT hr = pColumnData->GetColumnConfigData(pNodeID, &pColumnSetData);
if (hr == S_OK)
{
// the API returns S_OK or S_FALSE, so we check for S_OK
ASSERT(pColumnSetData != NULL);
if (pColumnSetData != NULL)
{
AddVisibleColumns(pColumnSetData->pColData, pColumnSetData->nNumCols);
::CoTaskMemFree(pColumnSetData);
}
} // if
delete[] pNodeID;
pNodeID = 0;
return hr;
}
HRESULT Save(IStream* pStm);
HRESULT Load(IStream* pStm);
private :
LPWSTR m_lpszColumnID;
};
////////////////////////////////////////////////////////////////////////////////
// CDSColumnSet
class CDSColumnSet : public CColumnSet
{
public:
CDSColumnSet(LPCWSTR lpszColumnID, LPCWSTR lpszClassName) : CColumnSet(lpszColumnID)
{
if (lpszClassName != NULL)
{
// Make a copy of the column class name
size_t iLen = wcslen(lpszClassName);
m_lpszClassName = (LPWSTR)malloc(sizeof(WCHAR) * (iLen + 1));
//NTRAID#NTBUG9-571990-2002/03/10-jmessec malloc may have failed, leaving m_lpszClassName == NULL for following wcscpy
wcscpy(m_lpszClassName, lpszClassName);
}
else
{
m_lpszClassName = NULL;
}
}
virtual ~CDSColumnSet()
{
if (m_lpszClassName != NULL)
free(m_lpszClassName);
}
protected:
CDSColumnSet() {}
private:
CDSColumnSet(CDSColumnSet&) {}
CDSColumnSet& operator=(CDSColumnSet&) {}
public:
LPCWSTR GetClassName() { return (LPCWSTR)m_lpszClassName; }
static CDSColumnSet* CreateColumnSet(PCOLUMNS_FOR_CLASS pColsForClass, SnapinType snapinType);
static CDSColumnSet* CreateColumnSetFromString(LPCWSTR lpszClassName, SnapinType snapinType);
static CDSColumnSet* CreateDescriptionColumnSet();
static CDSColumnSet* CreateColumnSetFromDisplaySpecifiers(PCWSTR pszClassName,
SnapinType snapinType,
MyBasePathsInfo* pBasePathsInfo);
private:
LPWSTR m_lpszClassName;
};
////////////////////////////////////////////////////////////////////////////////
// CColumnSetList
class CColumnSetList : public CList<CColumnSet*, CColumnSet*>
{
public :
CColumnSetList() : m_pDefaultColumnSet(NULL), m_pSpecialColumnSet(NULL) {}
private:
CColumnSetList(CColumnSetList&) {}
CColumnSetList& operator=(CColumnSetList&) {}
public:
void Initialize(SnapinType snapinType, MyBasePathsInfo* pBasePathsInfo);
// Find the column set given a column set ID
CColumnSet* FindColumnSet(LPCWSTR lpszColumnID);
void RemoveAndDeleteAllColumnSets()
{
while (!IsEmpty())
{
CColumnSet* pTempSet = RemoveTail();
delete pTempSet;
}
delete m_pDefaultColumnSet;
m_pDefaultColumnSet = NULL;
delete m_pSpecialColumnSet;
m_pSpecialColumnSet = NULL;
}
HRESULT Save(IStream* pStm);
HRESULT Load(IStream* pStm);
CColumnSet* GetDefaultColumnSet();
CColumnSet* GetSpecialColumnSet();
private :
CColumnSet* m_pDefaultColumnSet;
CColumnSet* m_pSpecialColumnSet;
SnapinType m_snapinType;
MyBasePathsInfo* m_pBasePathsInfo;
};
/////////////////////////////////////////////////////////////////////////////////////
//COLUMNS_FOR_CLASS* GetColumnsForClass( LPCTSTR i_pcszLdapClassName );
BOOL ColumnExtractString(
OUT CString& strref,
IN CDSCookie* pCookie,
IN PADS_SEARCH_COLUMN pColumn);
#endif // _DS_COLUMN_H_