summaryrefslogtreecommitdiffstats
path: root/tdeui/kaccelgen.h
diff options
context:
space:
mode:
Diffstat (limited to 'tdeui/kaccelgen.h')
-rw-r--r--tdeui/kaccelgen.h280
1 files changed, 0 insertions, 280 deletions
diff --git a/tdeui/kaccelgen.h b/tdeui/kaccelgen.h
deleted file mode 100644
index 222d948ba..000000000
--- a/tdeui/kaccelgen.h
+++ /dev/null
@@ -1,280 +0,0 @@
-/* This file is part of the KDE project
- Copyright (C) 2000 Keunwoo Lee <klee@cs.washington.edu>
-
- This program is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public
- License as published by the Free Software Foundation; either
- version 2 of the License, or (at your option) any later version.
-
- This program 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 Library General Public License for more details.
-
- You should have received a copy of the GNU Library General Public License
- along with this library; see the file COPYING.LIB. If not, write to
- the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- Boston, MA 02110-1301, USA.
-*/
-
-#ifndef KACCELGEN_H
-#define KACCELGEN_H
-
-#include <tqmap.h>
-#include <tqstring.h>
-#include <tqstringlist.h>
-
-#include <tdelibs_export.h>
-
-/**
- * Provides functions that, given a collection of QStrings, will
- * automatically and intelligently assign menu accelerators to the
- * QStrings in the collection.
- *
- * NOTE: When this file speaks of "accelerators", we really mean
- * accelerators as defined by the KDE User Interface Guidelines. We
- * do NOT mean "shortcuts", which are what's handled by most other KDE
- * libraries with "accel" in the name.
- *
- * In the Qt library, the mechanism for adding a keyboard accelerator
- * to a menu item is to insert an '&' before the letter. Since we
- * usually don't want to disturb the original collection, the idiom in
- * these functions is to populate a "target" TQStringList parameter
- * with the input collectin's QStrings, plus possibly some added '&'
- * characters.
- *
- * That is the mechanism. Here is the policy, in order of decreasing
- * importance (it may seem like these are implementation details, but
- * IMHO the policy is an important part of the interface):
- *
- * 1. If the string already contains an '&' character, skip this
- * string, because we consider such strings to be "user-specified"
- * accelerators.
- *
- * 2. No accelerator may clash with a previously defined accelerator,
- * including any legal (alphanumeric) user-specified accelerator
- * anywhere in the collection
- *
- * 3. Prefer alphanumerics at the start of the string.
- *
- * 4. Otherwise, prefer alphanumerics at the start of a word.
- *
- * 5. Otherwise, choose any alphanumeric character not already
- * taken. If no such character is available, give up & skip this
- * string.
- *
- * A typical use of these functions would be to automatically assign
- * accelerators to a dynamically populated popup menu. For example,
- * the core code was written to automatically set accelerators for the
- * "Load View Profile" popup menu for Konqueror. We quickly realized
- * that it would be useful to make this facility more generally
- * available, so I abstracted it out into a set of templates.
- *
- * TODO:
- *
- * + Add sugar functions for more collections.
- *
- * + Add more Deref classes so that we can access a wider variety of
- * collections.
- * */
-namespace KAccelGen
-{
-
-// HELPERS
-
-/**
- * Static dereference class, for use as a template parameter.
- */
-template <class Iter>
-class Deref
-{
-public:
- static TQString deref(Iter i) { return *i; }
-};
-
-/**
- * Static dereference class that calls the key() method on its
- * target; for use as a template parameter.
- */
-template <class Iter>
-class Deref_Key
-{
-public:
- static TQString deref(Iter i) { return i.key(); }
-};
-
-/**
- * Helper to determine if the given offset in the string could be a
- * legal alphanumeric accelerator.
- *
- * @param str base string
- * @param index offset to check
- */
-inline bool
-isLegalAccelerator(const TQString& str, uint index)
-{
- return index < str.length()
- && str[index].isLetterOrNumber();
-}
-
-/**
- * Loads all legal predefined accelerators in the (implicitly
- * specified) collection into the given TQMap.
- *
- * @param begin start iterator
- * @param end (last+1) iterator
- * @param keys map to store output
- */
-template <class Iter, class Deref>
-inline void
-loadPredefined(Iter begin, Iter end, TQMap<TQChar,bool>& keys)
-{
- for (Iter i = begin; i != end; ++i) {
- TQString item = Deref::deref(i);
- int user_ampersand = item.find(TQChar('&'));
- if( user_ampersand >= 0 ) {
- // Sanity check. Note that we don't try to find an
- // accelerator if the user shoots him/herself in the foot
- // by adding a bad '&'.
- if( isLegalAccelerator(item, user_ampersand+1) ) {
- keys.insert(item[user_ampersand+1], true);
- }
- }
- }
-}
-
-
-// ///////////////////////////////////////////////////////////////////
-// MAIN USER FUNCTIONS
-
-
-/**
- * Main, maximally flexible template function that assigns
- * accelerators to the elements of a collection of QStrings. Clients
- * will seldom use this directly, as it's usually easier to use one of
- * the wrapper functions that simply takes a collection (see below).
- *
- * The Deref template parameter is a class containing a static
- * dereferencing function, modeled after the comparison class C in
- * Stroustrup 13.4.
- *
- * @param begin (you know)
- * @param end (you know)
- * @param target collection to store generated strings
- */
-template <class Iter, class Iter_Deref >
-void
-generate(Iter begin, Iter end, TQStringList& target)
-{
- // Will keep track of used accelerator chars
- TQMap<TQChar,bool> used_accels;
-
- // Prepass to detect manually user-coded accelerators
- loadPredefined<Iter,Iter_Deref>(begin, end, used_accels);
-
- // Main pass
- for (Iter i = begin; i != end; ++i) {
- TQString item = Iter_Deref::deref(i);
-
- // Attempt to find a good accelerator, but only if the user
- // has not manually hardcoded one.
- int user_ampersand = item.find(TQChar('&'));
- if( user_ampersand < 0 || item[user_ampersand+1] == '&') {
- bool found = false;
- uint found_idx;
- uint j;
-
- // Check word-starting letters first.
- for( j=0; j < item.length(); ++j ) {
- if( isLegalAccelerator(item, j)
- && !used_accels.contains(item[j])
- && (0 == j || (j > 0 && item[j-1].isSpace())) ) {
- found = true;
- found_idx = j;
- break;
- }
- }
-
- if( !found ) {
- // No word-starting letter; search for any letter.
- for( j=0; j < item.length(); ++j ) {
- if( isLegalAccelerator(item, j)
- && !used_accels.contains(item[j]) ) {
- found = true;
- found_idx = j;
- break;
- }
- }
- }
-
- if( found ) {
- // Both upper and lower case marked as used
- used_accels.insert(item[j].upper(),true);
- used_accels.insert(item[j].lower(),true);
- item.insert(j,TQChar('&'));
- }
- }
-
- target.append( item );
- }
-}
-
-/**
- * Another convenience function; looks up the key instead of
- * dereferencing directly for the given iterator.
- *
- * @param begin
- * @param end
- * @param target
- */
-template <class Iter>
-inline void
-generateFromKeys(Iter begin, Iter end, TQStringList& target)
-{
- generate< Iter, Deref_Key<Iter> >(begin, end, target);
-}
-
-
-/**
- * Convenience function; generates accelerators for all the items in
- * a TQStringList.
- *
- * @param source Strings for which to generate accelerators
- * @param target Output for accelerator-added strings */
-inline void
-generate(const TQStringList& source, TQStringList& target)
-{
- generate<TQStringList::ConstIterator, Deref<TQStringList::ConstIterator> >(source.begin(), source.end(), target);
-}
-
-/**
- * Convenience function; generates accelerators for all the values in
- * a TQMap<T,TQString>.
- *
- * @param source Map with input strings as VALUES.
- * @param target Output for accelerator-added strings */
-template <class Key>
-inline void
-generateFromValues(const TQMap<Key,TQString>& source, TQStringList& target)
-{
- generate<TQMapConstIterator<Key,TQString>, Deref_Key<TQMapConstIterator<Key,TQString> > >(source.begin(), source.end(), target);
-}
-
-/**
- * Convenience function; generates an accelerator mapping from all the
- * keys in a TQMap<TQString,T>
- *
- * @param source Map with input strings as KEYS.
- * @param target Output for accelerator-added strings */
-template <class Data>
-inline void
-generateFromKeys(const TQMap<TQString,Data>& source, TQStringList& target)
-{
- generateFromKeys(source.begin(), source.end(), target);
-}
-
-
-} // end namespace KAccelGen
-
-#endif
-