dictiona.c

来自「开放源码的编译器open watcom 1.6.0版的源代码」· C语言 代码 · 共 195 行

C
195
字号
/* Dictionary.c -- implementation of Set of Associations

        THIS SOFTWARE FITS THE DESCRIPTION IN THE U.S. COPYRIGHT ACT OF A
        "UNITED STATES GOVERNMENT WORK".  IT WAS WRITTEN AS A PART OF THE
        AUTHOR'S OFFICIAL DUTIES AS A GOVERNMENT EMPLOYEE.  THIS MEANS IT
        CANNOT BE COPYRIGHTED.  THIS SOFTWARE IS FREELY AVAILABLE TO THE
        PUBLIC FOR USE WITHOUT A COPYRIGHT NOTICE, AND THERE ARE NO
        RESTRICTIONS ON ITS USE, NOW OR SUBSEQUENTLY.

Author:
        K. E. Gorlen
        Bg. 12A, Rm. 2033
        Computer Systems Laboratory
        Division of Computer Research and Technology
        National Institutes of Health
        Bethesda, Maryland 20892
        Phone: (301) 496-1111
        uucp: uunet!nih-csl!kgorlen
        Internet: kgorlen@alw.nih.gov
        September, 1985

Function:
        
A Dictionary is a Set of Associations.  A Dictionary returns the value
of an association given its key.

log:    DICTIONA.C $
Revision 1.1  92/11/10  12:15:20  Anthony_Scian
.

 * Revision 3.0  90/05/20  00:19:26  kgorlen
 * Release for 1st edition.
 * 
*/

#include "Dictionary.h"
#include "LookupKey.h"
#include "Assoc.h"

#define THIS    Dictionary
#define BASE    Set
#define BASE_CLASSES BASE::desc()
#define MEMBER_CLASSES
#define VIRTUAL_BASE_CLASSES

DEFINE_CLASS(Dictionary,0,"header: D:\PLUSTEST\regress\nih\x:\groupdir\cproj\plustest\regress\nih\rcs\DICTIONA.C 1.1 92/11/10 12:15:20 Anthony_Scian Exp Locker: NT_Test_Machine $",NULL,NULL);

extern const int NIHCL_DUPKEY,NIHCL_KEYNOTFOUND;

Dictionary::Dictionary(unsigned size) : BASE(size) {}

void Dictionary::operator=(const Dictionary& d)
{
        this->Set::operator=(d);
}

bool Dictionary::operator==(const Dictionary& d) const
{
        if (size() != d.size()) return NO;
        DO(*this,LookupKey,a) if (!d.includesAssoc(*a)) return NO; OD
        return YES;
}

Object* Dictionary::add(Object& ob)
{
        assertArgClass(ob,*LookupKey::desc(),"add");
        return Set::add(ob);
}

Assoc* Dictionary::addAssoc(Object& key, Object& value)
{
        Assoc* a = new Assoc(key,value);
        Assoc* b = Assoc::castdown(Set::add(*a));
        if (a != b) {
                delete a;
                setError(NIHCL_DUPKEY,DEFAULT,this,className(),"addAssoc",key.className(),&key);
        }
        return b;
}

Collection& Dictionary::addContentsTo(Collection& cltn) const
{
        DO(*this,LookupKey,a) cltn.add(*(a->value())); OD
        return cltn;
}

Object* Dictionary::remove(const Object& ob)
{
        assertArgClass(ob,*LookupKey::desc(),"remove");
        return Set::remove(ob);
}

Object* Dictionary::atKey(const Object& key) const
{
        register Object* p = findObjectWithKey(key);
        if (p==nil) setError(NIHCL_KEYNOTFOUND,DEFAULT,this,className(),key.className(),&key);
        else return LookupKey::castdown(p)->value();
        /* WATCOM */ return 0;
}

Object* Dictionary::atKey(const Object& key, Object& newValue)
{
        register Object* p = findObjectWithKey(key);
        if (p==nil) setError(NIHCL_KEYNOTFOUND,DEFAULT,this,className(),key.className(),&key);
        else return LookupKey::castdown(p)->value(newValue);
        /* WATCOM */ return 0;
}

LookupKey* Dictionary::assocAt(const Object& key) const
{
        Object* lk = findObjectWithKey(key);
        if (lk == nil) return 0;
        return LookupKey::castdown(lk);
}

Collection& Dictionary::addKeysTo(Collection& cltn) const
{
        DO(*this,LookupKey,a) cltn.add(*a->key()); OD
        return cltn;
}

Collection& Dictionary::addValuesTo(Collection& cltn) const
{
        return addContentsTo(cltn);
}

Object* Dictionary::keyAtValue(const Object& val) const
{
        DO(*this,LookupKey,a) if (val.isEqual(*a->value())) return a->key(); OD
        return nil;
}

unsigned Dictionary::occurrencesOf(const Object& val) const
{
        unsigned n =0;
        DO(*this,LookupKey,a) if (val.isEqual(*a->value())) n++; OD
        return n;
}

bool Dictionary::includesAssoc(const LookupKey& asc) const
{
        register Object* p = findObjectWithKey(asc);
        if (p==nil) return NO;
        return asc.value()->isEqual(*(LookupKey::castdown(p)->value()));
}

bool Dictionary::includesKey(const Object& key) const
{
        if (findObjectWithKey(key) == nil) return NO;
        else return YES;
}

bool Dictionary::isEqual(const Object& ob) const
{
        return ob.isSpecies(classDesc) && *this==castdown(ob);
}

const Class* Dictionary::species() const { return &classDesc; }

LookupKey* Dictionary::removeAssoc(const LookupKey& asc)
{
        return LookupKey::castdown(remove(asc));
}

LookupKey* Dictionary::removeKey(const Object& key)
{
        LookupKey* lk = assocAt(key);
        if (lk == 0) setError(NIHCL_KEYNOTFOUND,DEFAULT,this,className(),key.className(),&key);
        return removeAssoc(*lk);
}

Dictionary::Dictionary(OIOifd& fd)
:
#ifdef MI
        Object(fd),
#endif
        BASE(fd)
{
}

Dictionary::Dictionary(OIOin& strm)
:
#ifdef MI
        Object(strm),
#endif
        BASE(strm)
{
}

int Dictionary::compare(const Object&) const
{
        shouldNotImplement("compare");
        return 0;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?