fixed: a small problem in mountparser (it coused core dumped when there was a wrong mount point supplied)
fixed: 'default' funtion can take a directory now (there was an error early) git-svn-id: svn://ttmath.org/publicrep/cmslu/trunk@497 e52654a7-88a9-db11-a3e9-0013d4bc506e
This commit is contained in:
parent
e778903dab
commit
e94ccc86f8
|
@ -70,6 +70,7 @@ class Content
|
||||||
void PostFunEmacsEdit(bool with_url);
|
void PostFunEmacsEdit(bool with_url);
|
||||||
void PostFunEmacs();
|
void PostFunEmacs();
|
||||||
void PostFunMkdir(bool add_to_dir_table = false);
|
void PostFunMkdir(bool add_to_dir_table = false);
|
||||||
|
long PostFunDefaultParsePath();
|
||||||
void PostFunDefault();
|
void PostFunDefault();
|
||||||
void PostFunPriv();
|
void PostFunPriv();
|
||||||
void PostFunCreateThread();
|
void PostFunCreateThread();
|
||||||
|
|
|
@ -13,12 +13,56 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
long Content::PostFunDefaultParsePath()
|
||||||
|
{
|
||||||
|
Item * pdir, * pdir2;
|
||||||
|
long defaultid = -1;
|
||||||
|
|
||||||
|
std::string & path = request.PostVar("defaultitem");
|
||||||
|
|
||||||
|
|
||||||
|
if( !path.empty() )
|
||||||
|
{
|
||||||
|
std::string dir, file;
|
||||||
|
Dirs::SplitPath(path, dir, file);
|
||||||
|
|
||||||
|
pdir = data.dirs.GetDir(dir);
|
||||||
|
|
||||||
|
if( !pdir )
|
||||||
|
throw Error(Error::incorrect_dir);
|
||||||
|
|
||||||
|
if( file.empty() )
|
||||||
|
{
|
||||||
|
defaultid = pdir->id;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// checking whether the file is a directory too (the method SplitPath does not check it)
|
||||||
|
pdir2 = data.dirs.GetDir(file, pdir->id);
|
||||||
|
|
||||||
|
if( !pdir2 )
|
||||||
|
{
|
||||||
|
defaultid = db.GetFileId(pdir->id, file);
|
||||||
|
|
||||||
|
if( defaultid == -1 )
|
||||||
|
throw Error(Error::db_no_item);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// file is a directory
|
||||||
|
defaultid = pdir2->id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return defaultid;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void Content::PostFunDefault()
|
void Content::PostFunDefault()
|
||||||
{
|
{
|
||||||
Item * pdir;
|
|
||||||
long fileid = -1;
|
|
||||||
|
|
||||||
request.session->done = Done::defaulted_dir;
|
request.session->done = Done::defaulted_dir;
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,31 +71,15 @@ long fileid = -1;
|
||||||
request.status = Error::permision_denied;
|
request.status = Error::permision_denied;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
std::string & path = request.PostVar("defaultitem");
|
long defaultid = PostFunDefaultParsePath();
|
||||||
|
request.session->done_status = db.EditDefaultItem(request.dir_table.back()->id, defaultid);
|
||||||
if( !path.empty() )
|
|
||||||
{
|
|
||||||
std::string dir, file;
|
|
||||||
Dirs::SplitPath(path, dir, file);
|
|
||||||
|
|
||||||
pdir = data.dirs.GetDir(dir);
|
|
||||||
|
|
||||||
if( !pdir )
|
|
||||||
throw Error(Error::incorrect_dir);
|
|
||||||
|
|
||||||
fileid = db.GetFileId(pdir->id, file);
|
|
||||||
|
|
||||||
if( fileid == -1 )
|
|
||||||
throw Error(Error::db_no_item);
|
|
||||||
}
|
|
||||||
|
|
||||||
request.session->done_status = db.EditDefaultItem(request.dir_table.back()->id, fileid);
|
|
||||||
|
|
||||||
if( request.session->done_status == Error::ok )
|
if( request.session->done_status == Error::ok )
|
||||||
request.dir_table.back()->default_item = fileid;
|
request.dir_table.back()->default_item = defaultid;
|
||||||
}
|
}
|
||||||
catch(const Error & e)
|
catch(const Error & e)
|
||||||
{
|
{
|
||||||
|
|
|
@ -92,7 +92,7 @@ void MountParser::ReadMountPoint()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
err == Error::no_mountpoint;
|
err = Error::no_mountpoint;
|
||||||
log << log1 << "MP: there is no such a mount point: " << temp << logend;
|
log << log1 << "MP: there is no such a mount point: " << temp << logend;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ void Mounts::ReadMounts()
|
||||||
MountParser mp;
|
MountParser mp;
|
||||||
|
|
||||||
// !! tymczasowo - bedzie odczyt z bazy z /etc/fstab
|
// !! tymczasowo - bedzie odczyt z bazy z /etc/fstab
|
||||||
std::string temp = "thread /forum";
|
std::string temp = "thread /news";
|
||||||
|
|
||||||
Error err = mp.Parse(temp, mount_table);
|
Error err = mp.Parse(temp, mount_table);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue