Return TypeFunction nameArguments
hzEcodehdsNavtree::AddItem(const hzString&,const hzString&,const hzString&,hdsArticle*,bool,)

Declared in file: hzDissemino.h
Defined in file : hdsNavtree.cpp

Function Logic:

0:START 1:!refname 2:Return hzerr(E_ARGUMENT,%s: No item item id supplied,*m_Groupname) 3:!title 4:Return hzerr(E_ARGUMENT,%s: No item headline supplied,*m_Groupname) 5:m_ItemsByName.Exists(refname) 6:Return hzerr(E_DUPLICATE,%s: Duplicate entry attempted: Item %s alredy exists,*m_Groupname,*refname) 7:parent 8:!m_ItemsByName.Count() 9:Return hzerr(E_CORRUPT,%s: Adding first item %s but with non-null parent,*m_Groupname,*title) 10:!m_ItemsByName.Exists(parent) 11:Return hzerr(E_CORRUPT,%s: Supplied parent (%s) does not exist,*m_Groupname,*parent) 12:parItem 13:hzArray::Add hzArray::Count item item 14:bSlct 15:item 16:item 17:!parent 18:item 19:item 20:hzMapM::Insert rc 21:rc!=E_OK 22:Return hzerr(rc,%s: Could not insert parent for article %s,*m_Groupname,*title) 23:hzMapS::Insert rc 24:rc!=E_OK 25:Return hzerr(rc,%s: Could not insert article %s,*m_Groupname,*title) 26:Return rc

Function body:

hzEcode hdsNavtree::AddItem (const hzString& parent, const hzString& refname, const hzString& title, hdsArticle* pArt, bool bSlct)
{
   _hzfunc("hdsNavtree::AddItem") ;
   _navitem    item ;
   _navitem    parItem ;
   hzEcode     rc = E_OK ;
   threadLog("Adding article %p %s\n", pArt, *refname) ;
   if (!refname)   return hzerr(E_ARGUMENT, "%s: No item item id supplied", *m_Groupname) ;
   if (!title)     return hzerr(E_ARGUMENT, "%s: No item headline supplied", *m_Groupname) ;
   if (m_ItemsByName.Exists(refname))
       return hzerr(E_DUPLICATE, "%s: Duplicate entry attempted: Item %s alredy exists", *m_Groupname, *refname) ;
   if (parent)
   {
       if (!m_ItemsByName.Count())
           return hzerr(E_CORRUPT, "%s: Adding first item %s but with non-null parent", *m_Groupname, *title) ;
       if (!m_ItemsByName.Exists(parent))
           return hzerr(E_CORRUPT, "%s: Supplied parent (%s) does not exist", *m_Groupname, *parent) ;
       parItem = m_ItemsByName[parent] ;
   }
   m_Articles.Add(pArt) ;
   item.m_ItemId = m_Articles.Count() ;
   item.m_Title = title ;
   if (bSlct)
       item.m_bFlags |= HZ_TREEITEM_OPEN ;
   item.m_bFlags |= HZ_TREEITEM_LINK ;
   if (!parent)
       item.m_nLevel = 0;
   else
       item.m_nLevel = parItem.m_nLevel + 1;
   rc = m_ItemsByParent.Insert(parent, refname) ;
   if (rc != E_OK)
       return hzerr(rc, "%s: Could not insert parent for article %s", *m_Groupname, *title) ;
   rc = m_ItemsByName.Insert(refname, item) ;
   if (rc != E_OK)
       return hzerr(rc, "%s: Could not insert article %s", *m_Groupname, *title) ;
   return rc ;
}