X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ffrontends%2Fcontrollers%2Fhelper_funcs.C;h=34ac0f1207a9a156061d489d7cd1f5c9a26cc61d;hb=120c89f24fae05379fbdc8539d3cfae574c2aecd;hp=06a7f772a73a32af9079df9ff74bb9761ef61c22;hpb=c265d16ed06149b478c2d2c9b9b8e69cdb1bcf3d;p=lyx.git diff --git a/src/frontends/controllers/helper_funcs.C b/src/frontends/controllers/helper_funcs.C index 06a7f772a7..34ac0f1207 100644 --- a/src/frontends/controllers/helper_funcs.C +++ b/src/frontends/controllers/helper_funcs.C @@ -1,21 +1,15 @@ -/* This file is part of - * ====================================================== - * - * LyX, The Document Processor - * - * Copyright 2001 The LyX Team. +/** + * \file helper_funcs.C + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. * - * ====================================================== + * \author Angus Leeming * - * \file helper_funcs.C - * \author Angus Leeming + * Full author contact details are available in file CREDITS */ #include -#ifdef __GNUG__ -#pragma implementation -#endif #include #include "LString.h" @@ -31,22 +25,29 @@ using std::pair; using std::vector; using std::make_pair; -string const browseFile(LyXView * lv, string const & filename, + +string const browseFile(string const & filename, string const & title, string const & pattern, + bool save, pair const & dir1, pair const & dir2) { - string lastPath = "."; + string lastPath("."); if (!filename.empty()) lastPath = OnlyPath(filename); - FileDialog fileDlg(lv, title, LFUN_SELECT_FILE_SYNC, dir1, dir2); + FileDialog fileDlg(title, LFUN_SELECT_FILE_SYNC, dir1, dir2); FileDialog::Result result; - while (1) { - result = fileDlg.Select(lastPath, pattern, OnlyFilename(filename)); + while (true) { + if (save) + result = fileDlg.save(lastPath, pattern, + OnlyFilename(filename)); + else + result = fileDlg.open(lastPath, pattern, + OnlyFilename(filename)); if (result.second.empty()) return result.second; @@ -65,16 +66,17 @@ string const browseFile(LyXView * lv, string const & filename, } -string const browseRelFile(LyXView * lv, string const & filename, +string const browseRelFile(string const & filename, string const & refpath, string const & title, string const & pattern, + bool save, pair const & dir1, pair const & dir2) { string const fname = MakeAbsPath(filename, refpath); - string const outname = browseFile(lv, fname, title, pattern, + string const outname = browseFile(fname, title, pattern, save, dir1, dir2); string const reloutname = MakeRelPath(outname, refpath); if (prefixIs(reloutname, "../")) @@ -84,14 +86,48 @@ string const browseRelFile(LyXView * lv, string const & filename, } +string const browseDir(string const & pathname, + string const & title, + pair const & dir1, + pair const & dir2) +{ + string lastPath("."); + if (!pathname.empty()) + lastPath = OnlyPath(pathname); + + FileDialog fileDlg(title, LFUN_SELECT_FILE_SYNC, dir1, dir2); + + FileDialog::Result result; + + while (true) { + result = fileDlg.opendir(lastPath, + OnlyFilename(pathname)); + + if (result.second.empty()) + return result.second; + + lastPath = OnlyPath(result.second); + + if (result.second.find_first_of("#~$% ") == string::npos) + break; + + Alert::alert(_("directory name can't contain any " + "of these characters:"), + _("space, '#', '~', '$' or '%'.")); + } + + return result.second; +} + + // sorry this is just a temporary hack we should include vspace.h! (Jug) extern const char * stringFromUnit(int); vector const getLatexUnits() { vector units; - const char * str; - for(int i=0; (str = stringFromUnit(i)); ++i) + char const * str; + for (int i = 0; (str = stringFromUnit(i)); ++i) units.push_back(str); return units;