changed: DirContainer - uses std::list instead of std::vector as the main container
we do not have to rebuild indexes after deleting some items added: DirContainer::DelById(long id) changed: Dirs::CheckRootDir() addes the root dir if there is no one added: Dirs::DeleteDir(long id) - deletes specified directory (and its contents) (from the cache and the database) added: Db::DelDirById(long id) - deletes a dir from the database and its first children added: standard function rm can delete directories git-svn-id: svn://ttmath.org/publicrep/cmslu/trunk@487 e52654a7-88a9-db11-a3e9-0013d4bc506e
This commit is contained in:
parent
7d73d048c8
commit
951d0e8653
|
@ -65,6 +65,8 @@ void Content::SetDefaultFunction()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
request.session->IncrementTimersIfExist();
|
||||||
|
|
||||||
log << log3 << "Content: Default item: id: " << default_item << logend;
|
log << log3 << "Content: Default item: id: " << default_item << logend;
|
||||||
RedirectTo(default_item);
|
RedirectTo(default_item);
|
||||||
}
|
}
|
||||||
|
@ -169,7 +171,7 @@ void Content::Make()
|
||||||
{
|
{
|
||||||
if( request.dir_table.empty() )
|
if( request.dir_table.empty() )
|
||||||
{
|
{
|
||||||
log << log1 << "Content: there is no a root dir" << logend;
|
log << log1 << "Content: there is no a root dir (dir_table is empty)" << logend;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -194,6 +196,13 @@ void Content::Make()
|
||||||
if( request.result == Request::redirect )
|
if( request.result == Request::redirect )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
||||||
|
if( request.dir_table.empty() )
|
||||||
|
{
|
||||||
|
log << log1 << "Content: there is no a root dir (dir_table is empty -- after calling some standard functions)" << logend;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
templates.Generate();
|
templates.Generate();
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,11 @@ class Content
|
||||||
void FunLs();
|
void FunLs();
|
||||||
void FunEmacs();
|
void FunEmacs();
|
||||||
void FunPriv();
|
void FunPriv();
|
||||||
|
|
||||||
|
void FunRmDirRecursive();
|
||||||
|
void FunRmDir();
|
||||||
void FunRm();
|
void FunRm();
|
||||||
|
|
||||||
void FunNode();
|
void FunNode();
|
||||||
void FunMkdir();
|
void FunMkdir();
|
||||||
void FunDefault();
|
void FunDefault();
|
||||||
|
|
|
@ -10,21 +10,88 @@
|
||||||
#include "content.h"
|
#include "content.h"
|
||||||
|
|
||||||
|
|
||||||
|
void Content::FunRmDirRecursive()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void Content::FunRm()
|
|
||||||
{
|
{
|
||||||
// !! narazie usuwanie tylko dla plikow
|
data.dirs.MakePath(request.dir_table.back()->id, request.session->dir_old);
|
||||||
|
|
||||||
if( !request.is_item )
|
// this method deletes recursively all directories
|
||||||
|
data.dirs.DeleteDir(request.dir_table.back()->id);
|
||||||
|
|
||||||
|
request.dir_table.erase(--request.dir_table.end());
|
||||||
|
|
||||||
|
if( request.dir_table.empty() )
|
||||||
|
{
|
||||||
|
// we have deleted the root directory
|
||||||
|
|
||||||
|
data.dirs.CheckRootDir();
|
||||||
|
|
||||||
|
Item * proot = data.dirs.GetRootDir();
|
||||||
|
|
||||||
|
if( proot )
|
||||||
|
request.dir_table.push_back(proot);
|
||||||
|
else
|
||||||
|
// there is no a root dir
|
||||||
|
// CheckRootDir() didn't add the root dir (probably problem with the database)
|
||||||
|
// make sure that Content::Make() will check that the dir_table is empty and returns
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
request.session->done = Done::deleted_dir;
|
||||||
|
request.session->done_status = Error::ok;
|
||||||
|
request.session->done_timer = 2;
|
||||||
|
|
||||||
|
// redirect to the last valid directory
|
||||||
|
RedirectTo(**(--request.dir_table.end()));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Content::FunRmDir()
|
||||||
|
{
|
||||||
|
if( request.dir_table.size() == 1 )
|
||||||
|
{
|
||||||
|
// rm for the root dir
|
||||||
|
// only the superuser can do it
|
||||||
|
if( !request.session->puser || !request.session->puser->super_user )
|
||||||
{
|
{
|
||||||
request.status = Error::permision_denied;
|
request.status = Error::permision_denied;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Item * last_but_one_dir = *(--(--request.dir_table.end()));
|
||||||
|
|
||||||
if( !request.HasWriteAccess(*request.dir_table.back()) || !request.HasWriteAccess(request.item) )
|
if( !request.HasWriteAccess(*last_but_one_dir) )
|
||||||
|
{
|
||||||
|
request.status = Error::permision_denied;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if( request.param_table.empty() )
|
||||||
|
request.status = Error::permision_denied;
|
||||||
|
else
|
||||||
|
if( request.IsParam("confirm") )
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
if( request.IsParam("r") )
|
||||||
|
FunRmDirRecursive();
|
||||||
|
else
|
||||||
|
request.status = Error::unknown_param;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Content::FunRm()
|
||||||
|
{
|
||||||
|
if( !request.is_item )
|
||||||
|
{
|
||||||
|
FunRmDir();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !request.HasWriteAccess(*request.dir_table.back()) )
|
||||||
{
|
{
|
||||||
request.status = Error::permision_denied;
|
request.status = Error::permision_denied;
|
||||||
return;
|
return;
|
||||||
|
@ -49,16 +116,15 @@ void Content::FunRm()
|
||||||
}
|
}
|
||||||
|
|
||||||
request.session->done = Done::deleted_item;
|
request.session->done = Done::deleted_item;
|
||||||
request.result = Request::redirect;
|
|
||||||
|
|
||||||
RedirectTo(*request.dir_table.back());
|
RedirectTo(*request.dir_table.back());
|
||||||
|
|
||||||
request.session->done_timer = 2;
|
request.session->done_timer = 2;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if( !request.IsParam("confirm") )
|
if( !request.IsParam("confirm") )
|
||||||
request.result = Request::err404;
|
//request.result = Request::err404;
|
||||||
|
request.status = Error::unknown_param;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
40
core/db.cpp
40
core/db.cpp
|
@ -986,6 +986,46 @@ return result;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Error Db::DelDirById(long id)
|
||||||
|
{
|
||||||
|
Error result = Error::ok;
|
||||||
|
PGresult * r = 0;
|
||||||
|
const char * crows;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
AssertConnection();
|
||||||
|
std::ostringstream query, query2;
|
||||||
|
|
||||||
|
query << "delete from core.content where content.id in (select content_id from core.item where parent_id='" << id << "');";
|
||||||
|
r = AssertQuery( query.str() );
|
||||||
|
AssertResultStatus(r, PGRES_COMMAND_OK);
|
||||||
|
|
||||||
|
crows = PQcmdTuples(r);
|
||||||
|
if( crows )
|
||||||
|
log << log2 << "Db: deleted " << atol(crows) << " rows from core.content" << logend;
|
||||||
|
|
||||||
|
query2 << "delete from core.item where id='" << id << "' or parent_id='" << id << "';";
|
||||||
|
r = AssertQuery( query2.str() );
|
||||||
|
AssertResultStatus(r, PGRES_COMMAND_OK);
|
||||||
|
|
||||||
|
crows = PQcmdTuples(r);
|
||||||
|
if( crows )
|
||||||
|
log << log1 << "Db: deleted dir: " << id << " (deleted: " << atol(crows) << " rows)" << logend;
|
||||||
|
}
|
||||||
|
catch(const Error & e)
|
||||||
|
{
|
||||||
|
result = e;
|
||||||
|
}
|
||||||
|
|
||||||
|
ClearResult(r);
|
||||||
|
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool Db::DelItemDelItem(const Item & item)
|
bool Db::DelItemDelItem(const Item & item)
|
||||||
{
|
{
|
||||||
|
|
|
@ -53,6 +53,8 @@ public:
|
||||||
bool GetPriv(Item & item, long id);
|
bool GetPriv(Item & item, long id);
|
||||||
Error EditPrivById(Item & item, long id);
|
Error EditPrivById(Item & item, long id);
|
||||||
|
|
||||||
|
Error DelDirById(long id);
|
||||||
|
|
||||||
bool DelItem(const Item & item);
|
bool DelItem(const Item & item);
|
||||||
void GetDirs(DirContainer & dir_table);
|
void GetDirs(DirContainer & dir_table);
|
||||||
void GetUsers(UGContainer<User> & user_table);
|
void GetUsers(UGContainer<User> & user_table);
|
||||||
|
|
|
@ -23,7 +23,7 @@ DirContainer::Iterator DirContainer::GetRoot()
|
||||||
if( !is_root )
|
if( !is_root )
|
||||||
return table.end();
|
return table.end();
|
||||||
|
|
||||||
return table.begin() + root_index;
|
return root_iter;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -54,31 +54,26 @@ bool DirContainer::Empty()
|
||||||
|
|
||||||
void DirContainer::PushBack(const Item & item)
|
void DirContainer::PushBack(const Item & item)
|
||||||
{
|
{
|
||||||
bool rebuild_indexes = false;
|
if( item.parent_id == -1 && is_root )
|
||||||
|
{
|
||||||
if( table.size() == table.capacity() )
|
log << log1 << "DirCont: more than one root dir - skipped, id: " << item.id << logend;
|
||||||
rebuild_indexes = true;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Iterator last_iter = table.insert(table.end(), item);
|
||||||
|
|
||||||
if( item.parent_id == -1 )
|
if( item.parent_id == -1 )
|
||||||
{
|
|
||||||
if( is_root )
|
|
||||||
log << log1 << "DirCont: more than one root dir - skipped, id: " << item.id << logend;
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
is_root = true;
|
is_root = true;
|
||||||
root_index = table.size();
|
root_iter = last_iter;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
table.push_back(item);
|
|
||||||
log << log2 << "DirCont: added dir, url: " << item.url << ", id: " << item.id << ", parent_id: " << item.parent_id << logend;
|
log << log2 << "DirCont: added dir, url: " << item.url << ", id: " << item.id << ", parent_id: " << item.parent_id << logend;
|
||||||
|
|
||||||
|
table_id.insert( std::make_pair(last_iter->id, last_iter) );
|
||||||
|
table_parent.insert( std::make_pair(last_iter->parent_id, last_iter) );
|
||||||
|
|
||||||
if( rebuild_indexes )
|
log << log3 << "DirCont: added indexes to dir, id: " << last_iter->id << ", parent_id: " << last_iter->parent_id << logend;
|
||||||
RebuildIndexes();
|
|
||||||
else
|
|
||||||
AddIndexes( --table.end() );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -90,6 +85,7 @@ void DirContainer::Clear()
|
||||||
table.clear();
|
table.clear();
|
||||||
table_id.clear();
|
table_id.clear();
|
||||||
table_parent.clear();
|
table_parent.clear();
|
||||||
|
is_root = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -107,34 +103,6 @@ return i->second;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void DirContainer::AddIndexes(Iterator item)
|
|
||||||
{
|
|
||||||
table_id.insert( std::make_pair(item->id, item) );
|
|
||||||
table_parent.insert( std::make_pair(item->parent_id, item) );
|
|
||||||
|
|
||||||
log << log2 << "DirCont: added indexes to dir, id: " << item->id << ", parent_id: " << item->parent_id << logend;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void DirContainer::RebuildIndexes()
|
|
||||||
{
|
|
||||||
Iterator i;
|
|
||||||
|
|
||||||
log << log2 << "DirCont: rebuilding indexes" << logend;
|
|
||||||
|
|
||||||
table_id.clear();
|
|
||||||
table_parent.clear();
|
|
||||||
|
|
||||||
for(i=table.begin() ; i!=table.end() ; ++i)
|
|
||||||
AddIndexes( i );
|
|
||||||
|
|
||||||
log << log2 << "DirCont: indexes rebuilt, table.size: " << table.size() << ", table_id.size: " << table_id.size() << ", table_parent.size: " << table_parent.size() << logend;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
DirContainer::ParentIterator DirContainer::ParentBegin()
|
DirContainer::ParentIterator DirContainer::ParentBegin()
|
||||||
{
|
{
|
||||||
return table_parent.begin();
|
return table_parent.begin();
|
||||||
|
@ -184,3 +152,56 @@ DirContainer::ParentIterator DirContainer::NextParent(ParentIterator i)
|
||||||
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bool DirContainer::DelById(long id)
|
||||||
|
{
|
||||||
|
TableId::iterator i = table_id.find(id);
|
||||||
|
|
||||||
|
if( i == table_id.end() )
|
||||||
|
{
|
||||||
|
log << log1 << "DirCont: delete: there is no directory with id: " << id << logend;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
long parent_id = i->second->parent_id;
|
||||||
|
TableParent::iterator z = table_parent.lower_bound(parent_id);
|
||||||
|
bool found = false;
|
||||||
|
|
||||||
|
for( ; z != table_parent.end() && z->first == parent_id ; ++z )
|
||||||
|
{
|
||||||
|
if( z->second == i->second )
|
||||||
|
{
|
||||||
|
log << log2 << "DirCont: deleted directory id: " << id << ", url: " << i->second->url;
|
||||||
|
|
||||||
|
if( i->second->parent_id == -1 )
|
||||||
|
{
|
||||||
|
log << log2 << " (root directory)";
|
||||||
|
is_root = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
log << log2 << logend;
|
||||||
|
|
||||||
|
table.erase(i->second);
|
||||||
|
|
||||||
|
log << log3 << "DirCont: deleted indexes into directory id: " << id << logend;
|
||||||
|
table_id.erase(i);
|
||||||
|
table_parent.erase(z);
|
||||||
|
|
||||||
|
found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !found )
|
||||||
|
{
|
||||||
|
log << log1 << "DirCont: can't find an index_parent into directory id: " << id << ", url: " << i->second->url << " (deleting skipped)" << logend;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
#ifndef headerfiledircontainer
|
#ifndef headerfiledircontainer
|
||||||
#define headerfiledircontainer
|
#define headerfiledircontainer
|
||||||
|
|
||||||
#include <vector>
|
#include <list>
|
||||||
#include <map>
|
#include <map>
|
||||||
#include "item.h"
|
#include "item.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
@ -20,7 +20,7 @@ class DirContainer
|
||||||
{
|
{
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef std::vector<Item> Table;
|
typedef std::list<Item> Table;
|
||||||
typedef Table::iterator Iterator;
|
typedef Table::iterator Iterator;
|
||||||
typedef Table::size_type SizeType;
|
typedef Table::size_type SizeType;
|
||||||
|
|
||||||
|
@ -43,6 +43,8 @@ public:
|
||||||
|
|
||||||
Iterator FindId(long id);
|
Iterator FindId(long id);
|
||||||
|
|
||||||
|
bool DelById(long id);
|
||||||
|
|
||||||
ParentIterator ParentBegin();
|
ParentIterator ParentBegin();
|
||||||
ParentIterator ParentEnd();
|
ParentIterator ParentEnd();
|
||||||
ParentSizeType ParentSize();
|
ParentSizeType ParentSize();
|
||||||
|
@ -53,17 +55,14 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void AddIndexes(Iterator item);
|
|
||||||
void RebuildIndexes();
|
|
||||||
|
|
||||||
// main table with dirs
|
// main table with dirs
|
||||||
Table table;
|
Table table;
|
||||||
|
|
||||||
// true if there is a root dir in the table
|
// true if there is a root dir in the table
|
||||||
bool is_root;
|
bool is_root;
|
||||||
|
|
||||||
// root dir
|
// root
|
||||||
SizeType root_index;
|
Iterator root_iter;
|
||||||
|
|
||||||
// indexes
|
// indexes
|
||||||
TableId table_id;
|
TableId table_id;
|
||||||
|
|
|
@ -19,23 +19,27 @@ void Dirs::Clear()
|
||||||
|
|
||||||
void Dirs::CheckRootDir()
|
void Dirs::CheckRootDir()
|
||||||
{
|
{
|
||||||
DirContainer::ParentIterator i;
|
DirContainer::Iterator i = dir_table.GetRoot();
|
||||||
long roots = 0;
|
|
||||||
|
|
||||||
|
if( i != dir_table.End() )
|
||||||
|
return;
|
||||||
|
|
||||||
for( i=dir_table.FindFirstParent(-1) ; i!=dir_table.ParentEnd() ; i=dir_table.NextParent(i) )
|
log << log1 << "Dirs: there is no a root dir in the database (creating one)" << logend;
|
||||||
++roots;
|
|
||||||
|
|
||||||
if( roots == 0 )
|
Item root;
|
||||||
|
|
||||||
|
root.type = Item::dir;
|
||||||
|
root.parent_id = -1;
|
||||||
|
root.user_id = -1;
|
||||||
|
root.group_id = -1;
|
||||||
|
root.privileges = 0755;
|
||||||
|
root.default_item = -1;
|
||||||
|
|
||||||
|
// !! upewnic sie ze baza nie zmieni url (gdyby wczesniej juz byl w bazie pusty url)
|
||||||
|
// !! zrobic jakis wyjatek do wprowadzania roota?
|
||||||
|
if( db.AddItem(root) == Error::ok )
|
||||||
{
|
{
|
||||||
log << log1 << "Dirs: there is no a root dir in the database" << logend;
|
dir_table.PushBack(root);
|
||||||
Clear();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if( roots > 1 )
|
|
||||||
{
|
|
||||||
log << log1 << "Dirs: there are more than one root dir in the database" << logend;
|
|
||||||
Clear();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -372,3 +376,30 @@ void Dirs::SplitPath(const std::string & path, std::string & dir, std::string &
|
||||||
if( i < path.size() - 1 )
|
if( i < path.size() - 1 )
|
||||||
file.assign(path, i+1, path.size() - i - 1);
|
file.assign(path, i+1, path.size() - i - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void Dirs::DeleteDir(long id)
|
||||||
|
{
|
||||||
|
DirContainer::ParentIterator pnext, p = dir_table.FindFirstParent(id);
|
||||||
|
|
||||||
|
for( ; p != dir_table.ParentEnd() ; p = pnext )
|
||||||
|
{
|
||||||
|
// this iterator p will be deleted by the next DeleteDir(p->second->id)
|
||||||
|
// (the next iterator we must calculate beforehand)
|
||||||
|
pnext = dir_table.NextParent(p);
|
||||||
|
|
||||||
|
DeleteDir(p->second->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
if( db.DelDirById(id) == Error::ok )
|
||||||
|
dir_table.DelById(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
27
core/dirs.h
27
core/dirs.h
|
@ -24,19 +24,6 @@
|
||||||
|
|
||||||
class Dirs
|
class Dirs
|
||||||
{
|
{
|
||||||
|
|
||||||
private:
|
|
||||||
public: // !! temporarily
|
|
||||||
|
|
||||||
|
|
||||||
DirContainer dir_table;
|
|
||||||
|
|
||||||
bool ExtractName(const char * & s, std::string & name);
|
|
||||||
void CheckRootDir();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
void Clear();
|
void Clear();
|
||||||
|
@ -86,6 +73,20 @@ public:
|
||||||
|
|
||||||
static void SplitPath(const std::string & path, std::string & dir, std::string & file);
|
static void SplitPath(const std::string & path, std::string & dir, std::string & file);
|
||||||
|
|
||||||
|
|
||||||
|
void DeleteDir(long id);
|
||||||
|
|
||||||
|
|
||||||
|
void CheckRootDir();
|
||||||
|
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
DirContainer dir_table;
|
||||||
|
|
||||||
|
bool ExtractName(const char * & s, std::string & name);
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -23,6 +23,7 @@ public:
|
||||||
added_item,
|
added_item,
|
||||||
edited_item,
|
edited_item,
|
||||||
deleted_item,
|
deleted_item,
|
||||||
|
deleted_dir,
|
||||||
privileged_item,
|
privileged_item,
|
||||||
added_dir,
|
added_dir,
|
||||||
defaulted_dir,
|
defaulted_dir,
|
||||||
|
|
|
@ -43,7 +43,7 @@ public:
|
||||||
no_function, // !! zamienic na no_function
|
no_function, // !! zamienic na no_function
|
||||||
|
|
||||||
item_required, // !! zamienic na no_item (i usunac db_no_item)
|
item_required, // !! zamienic na no_item (i usunac db_no_item)
|
||||||
|
unknown_param,
|
||||||
unknown = 1000
|
unknown = 1000
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,7 @@ void FunctionParser::ParseDirectories()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
while( true )
|
while( true )
|
||||||
{
|
{
|
||||||
request.dir_table.push_back( pdir );
|
request.dir_table.push_back( pdir );
|
||||||
|
|
|
@ -31,6 +31,8 @@ void Session::Clear()
|
||||||
done_status = Error::ok;
|
done_status = Error::ok;
|
||||||
item.Clear();
|
item.Clear();
|
||||||
done_timer = 0;
|
done_timer = 0;
|
||||||
|
|
||||||
|
dir_old.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -72,5 +74,8 @@ void Session::CheckTimers()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Session::IncrementTimersIfExist()
|
||||||
|
{
|
||||||
|
if( done_timer != 0 )
|
||||||
|
++done_timer;
|
||||||
|
}
|
||||||
|
|
|
@ -49,6 +49,8 @@ struct Session
|
||||||
Item item;
|
Item item;
|
||||||
|
|
||||||
|
|
||||||
|
std::string dir_old;
|
||||||
|
|
||||||
// -------------------
|
// -------------------
|
||||||
|
|
||||||
Session();
|
Session();
|
||||||
|
@ -57,6 +59,7 @@ struct Session
|
||||||
bool operator<(const Session & s) const;
|
bool operator<(const Session & s) const;
|
||||||
bool DecTimer(int & timer);
|
bool DecTimer(int & timer);
|
||||||
void CheckTimers();
|
void CheckTimers();
|
||||||
|
void IncrementTimersIfExist();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -169,6 +169,11 @@ void dir_last_default_item_url(Info & i)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void dir_old(Info & i)
|
||||||
|
{
|
||||||
|
HtmlEscape(i.out, request.session->dir_old);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -79,6 +79,11 @@ void done_added_dir(Info & i)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void done_deleted_dir(Info & i)
|
||||||
|
{
|
||||||
|
i.result = request.session->done == Done::deleted_dir;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void done_defaulted_dir(Info & i)
|
void done_defaulted_dir(Info & i)
|
||||||
|
|
|
@ -131,6 +131,7 @@ Ezc::Pattern * p = 0;
|
||||||
|
|
||||||
case Error::db_no_item:
|
case Error::db_no_item:
|
||||||
case Error::no_function:
|
case Error::no_function:
|
||||||
|
case Error::unknown_param:
|
||||||
p = &pat_err_404;
|
p = &pat_err_404;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -241,6 +242,8 @@ void Templates::CreateFunctions()
|
||||||
functions.Insert("dir_last_default_item_dir", dir_last_default_item_dir);
|
functions.Insert("dir_last_default_item_dir", dir_last_default_item_dir);
|
||||||
functions.Insert("dir_last_default_item_url", dir_last_default_item_url);
|
functions.Insert("dir_last_default_item_url", dir_last_default_item_url);
|
||||||
|
|
||||||
|
functions.Insert("dir_old", dir_old);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
user
|
user
|
||||||
*/
|
*/
|
||||||
|
@ -274,6 +277,7 @@ void Templates::CreateFunctions()
|
||||||
functions.Insert("done_privileged_item", done_privileged_item);
|
functions.Insert("done_privileged_item", done_privileged_item);
|
||||||
functions.Insert("done_loggedout", done_loggedout);
|
functions.Insert("done_loggedout", done_loggedout);
|
||||||
functions.Insert("done_added_dir", done_added_dir);
|
functions.Insert("done_added_dir", done_added_dir);
|
||||||
|
functions.Insert("done_deleted_dir", done_deleted_dir);
|
||||||
functions.Insert("done_defaulted_dir", done_defaulted_dir);
|
functions.Insert("done_defaulted_dir", done_defaulted_dir);
|
||||||
|
|
||||||
|
|
||||||
|
@ -347,7 +351,7 @@ void Templates::Read()
|
||||||
pat_err_others.ParseFile("err_others.html");
|
pat_err_others.ParseFile("err_others.html");
|
||||||
|
|
||||||
pat_fun_who.Directory(data.templates);
|
pat_fun_who.Directory(data.templates);
|
||||||
pat_fun_who.ParseFile("who.html");
|
pat_fun_who.ParseFile("fun_who.html");
|
||||||
|
|
||||||
CreateFunctions();
|
CreateFunctions();
|
||||||
|
|
||||||
|
|
|
@ -114,6 +114,9 @@ namespace TemplatesFunctions
|
||||||
void dir_last_default_item_dir(Info &);
|
void dir_last_default_item_dir(Info &);
|
||||||
void dir_last_default_item_url(Info & i);
|
void dir_last_default_item_url(Info & i);
|
||||||
|
|
||||||
|
void dir_old(Info & i);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
user
|
user
|
||||||
*/
|
*/
|
||||||
|
@ -149,6 +152,7 @@ namespace TemplatesFunctions
|
||||||
void done_privileged_item(Info & i);
|
void done_privileged_item(Info & i);
|
||||||
|
|
||||||
void done_added_dir(Info & i);
|
void done_added_dir(Info & i);
|
||||||
|
void done_deleted_dir(Info & i);
|
||||||
void done_defaulted_dir(Info & i);
|
void done_defaulted_dir(Info & i);
|
||||||
|
|
||||||
void done_loggedout(Info & i);
|
void done_loggedout(Info & i);
|
||||||
|
|
Loading…
Reference in New Issue