tigervnc/vncviewer/MRU.h
Peter Åstrand 9fb4e0e6b9 Tightified sources:
* Changed description in README files.

* Added our copyright.

* The HTTP server presents itself as TightVNC, rather than RealVNC.

* Using registry path Software\TightVNC\WinVNC4

* Updated descriptions in resource files.


git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@67 3789f03b-4d11-0410-bbf8-ca57d06f2519
2004-12-30 10:03:00 +00:00

141 rinda
3.8 KiB
C++

/* Copyright (C) 2002-2003 RealVNC Ltd. All Rights Reserved.
*
* This is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this software; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
* USA.
*/
#ifndef __VIEWER_MRU_H__
#define __VIEWER_MRU_H__
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include <list>
#include <set>
#include <rfb_win32/Registry.h>
#include <rfb/util.h>
#include <rdr/HexOutStream.h>
namespace rfb {
namespace win32 {
namespace MRU {
static const RegKey RegRoot = HKEY_CURRENT_USER;
static const TCHAR* RegPath = _T("Software\\TightVNC\\VNCViewer4\\MRU");
static const int MaxMRUEntries = 256;
static const int MRUEntries = 10;
static std::list<char*> getEntries() {
std::list<char*> mru;
try {
RegKey key;
key.openKey(RegRoot, RegPath);
CharArray order;
int length;
key.getBinary(_T("Order"), (void**)&order.buf, &length);
for (int i=0; i<length; i++) {
TCharArray keyname = rdr::HexOutStream::binToHexStr(&order.buf[i], 1);
try {
TCharArray entry = key.getString(keyname.buf);
mru.push_back(strDup(entry.buf));
} catch (rdr::Exception) {
}
}
} catch (rdr::Exception) {
}
return mru;
}
static void addToMRU(const char* name) {
RegKey key;
key.createKey(RegRoot, RegPath);
BYTE keycode;
CharArray old_order;
char order[MaxMRUEntries];
int orderlen;
try {
key.getBinary(_T("Order"), (void**)&old_order.buf, &orderlen);
if (orderlen)
memcpy(order, old_order.buf, orderlen);
std::set<int> ordercodes;
keycode = 0;
bool found = false;
for (int i=0; i<orderlen; i++) {
TCharArray keyname = rdr::HexOutStream::binToHexStr(&order[i], 1);
try {
TCharArray hostname = key.getString(keyname.buf);
if (strcmp(name, CStr(hostname.buf)) == 0) {
keycode = order[i];
found = true;
break;
}
} catch (rdr::Exception) {
}
ordercodes.insert(order[i]);
}
if (!found) {
if (orderlen <= MRUEntries) {
while (ordercodes.find(keycode) != ordercodes.end()) keycode++;
} else {
keycode = order[orderlen-1];
orderlen--;
}
}
} catch (rdr::Exception) {
keycode = 0;
orderlen = 0;
}
printf("keycode=%d\n", (int)keycode);
orderlen++;
int i, j=orderlen-1;
for (i=0; i<orderlen-1; i++) {
if (order[i] == keycode) {
j = i;
orderlen--;
break;
}
}
for (i=j; i>0; i--)
order[i] = order[i-1];
order[0] = keycode;
printf("selected %d\n", (int)keycode);
TCharArray keyname = rdr::HexOutStream::binToHexStr((char*)&keycode, 1);
key.setString(keyname.buf, TStr(name));
key.setBinary(_T("Order"), order, orderlen);
}
};
};
};
#endif