--- parser3/src/classes/file.C 2001/03/29 20:53:02 1.13 +++ parser3/src/classes/file.C 2001/04/03 17:01:01 1.18 @@ -1,9 +1,11 @@ -/* - Parser +/** @file + Parser: @b file parser class. + Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) + Author: Alexander Petrosyan (http://design.ru/paf) - $Id: file.C,v 1.13 2001/03/29 20:53:02 paf Exp $ + $Id: file.C,v 1.18 2001/04/03 17:01:01 paf Exp $ */ #include "pa_request.h" @@ -21,13 +23,7 @@ VStateless_class *file_class; // methods -/// @test mkdirs static void _save(Request& r, const String& method_name, Array *params) { - if(r.self==file_class) - RTHROW(0, 0, - &method_name, - "method of 'file' is not static"); - Pool& pool=r.pool(); Value& vfile_name=*static_cast(params->get(0)); // forcing @@ -35,13 +31,8 @@ static void _save(Request& r, const Stri r.fail_if_junction_(true, vfile_name, method_name, "file name must not be junction"); - // forcing untaint language - String lfile_name(pool); - lfile_name.append(vfile_name.as_string(), - String::UL_FILE_NAME, true); - // save - static_cast(r.self)->save(r.absolute(lfile_name)); + static_cast(r.self)->save(r.absolute(vfile_name.as_string())); } static void _delete(Request& r, const String& method_name, Array *params) { @@ -52,13 +43,8 @@ static void _delete(Request& r, const St r.fail_if_junction_(true, vfile_name, method_name, "file name must not be junction"); - // forcing untaint language - String lfile_name(pool); - lfile_name.append(vfile_name.as_string(), - String::UL_FILE_NAME, true); - // unlink - file_delete(pool, r.absolute(lfile_name)); + file_delete(pool, r.absolute(vfile_name.as_string())); } static void _find(Request& r, const String& method_name, Array *params) { @@ -69,10 +55,7 @@ static void _find(Request& r, const Stri r.fail_if_junction_(true, vfile_name, method_name, "file name must not be junction"); - // forcing untaint language - String lfile_name(pool); - lfile_name.append(vfile_name.as_string(), - String::UL_FILE_NAME, true); + const String &lfile_name=vfile_name.as_string(); // passed file name simply exists in current dir if(file_readable(r.absolute(lfile_name))) { @@ -85,7 +68,7 @@ static void _find(Request& r, const Stri String test_name(pool); for(int j=0; j(params->get(0)); @@ -115,15 +93,12 @@ static void _load(Request& r, const Stri r.fail_if_junction_(true, vfile_name, method_name, "file name must not be junction"); - // forcing untaint language - String lfile_name(pool); - lfile_name.append(vfile_name.as_string(), - String::UL_FILE_NAME, true); + const String& lfile_name=vfile_name.as_string(); void *data; size_t size; file_read(pool, r.absolute(lfile_name), data, size, false/*binary*/); - char *user_file_name=params->size()==1?lfile_name.cstr() + char *user_file_name=params->size()==1?lfile_name.cstr(String::UL_FILE_NAME) :static_cast(params->get(1))->as_string().cstr(); const String *mime_type=0; @@ -153,17 +128,17 @@ static void _load(Request& r, const Stri void initialize_file_class(Pool& pool, VStateless_class& vclass) { // ^save[file-name] - vclass.add_native_method("save", _save, 1, 1); + vclass.add_native_method("save", Method::CT_DYNAMIC, _save, 1, 1); // ^delete[file-name] - vclass.add_native_method("delete", _delete, 1, 1); + vclass.add_native_method("delete", Method::CT_STATIC, _delete, 1, 1); // ^find[file-name] // ^find[file-name]{when-not-found} - vclass.add_native_method("find", _find, 1, 2); + vclass.add_native_method("find", Method::CT_STATIC, _find, 1, 2); // ^load[disk-name] // ^load[disk-name;user-name] // ^load[disk-name;user-name;mime-type] - vclass.add_native_method("load", _load, 1, 3); + vclass.add_native_method("load", Method::CT_DYNAMIC, _load, 1, 3); }