// Filename: pathReplace.h // Created by: drose (07Feb03) // //////////////////////////////////////////////////////////////////// // // PANDA 3D SOFTWARE // Copyright (c) Carnegie Mellon University. All rights reserved. // // All use of this software is subject to the terms of the revised BSD // license. You should have received a copy of this license along // with this source code in a file named "LICENSE." // //////////////////////////////////////////////////////////////////// #ifndef PATHREPLACE_H #define PATHREPLACE_H #include "pandatoolbase.h" #include "pathStore.h" #include "referenceCount.h" #include "globPattern.h" #include "filename.h" #include "dSearchPath.h" #include "pvector.h" #include "pmap.h" //////////////////////////////////////////////////////////////////// // Class : PathReplace // Description : This encapsulates the user's command-line request to // replace existing, incorrect pathnames to models and // textures from a file with correct pathnames. It // corresponds to a sequence of -pr command-line // options, as well as the -pp option. // // This can also go the next step, which is to convert a // known file into a suitable form for storing in a // model file. In this capacity, it corresponds to the // -ps and -pd options. //////////////////////////////////////////////////////////////////// class PathReplace : public ReferenceCount { public: PathReplace(); ~PathReplace(); INLINE void clear_error(); INLINE bool had_error() const; INLINE void clear(); INLINE void add_pattern(const string &orig_prefix, const string &replacement_prefix); INLINE int get_num_patterns() const; INLINE const string &get_orig_prefix(int n) const; INLINE const string &get_replacement_prefix(int n) const; INLINE bool is_empty() const; Filename match_path(const Filename &orig_filename, const DSearchPath &additional_path = DSearchPath()); Filename store_path(const Filename &orig_filename); INLINE Filename convert_path(const Filename &orig_filename, const DSearchPath &additional_path = DSearchPath()); void full_convert_path(const Filename &orig_filename, const DSearchPath &additional_path, Filename &resolved_path, Filename &output_path); void write(ostream &out, int indent_level = 0) const; public: // This is used (along with _entries) to support match_path(). DSearchPath _path; // These are used to support store_path(). PathStore _path_store; Filename _path_directory; bool _copy_files; Filename _copy_into_directory; // If this is this true, then the error flag is set (see had_error() // and clear_error()) if any Filename passed to match_path() or // convert_path(), and unmatched by one of the prefixes, happens to // be an absolute pathname. bool _noabs; // If this is true, then the error flag is set if any Filename // passed to match_path() or convert_path() cannot be found. bool _exists; private: bool copy_this_file(Filename &filename); class Component { public: INLINE Component(const string &component); INLINE Component(const Component ©); INLINE void operator = (const Component ©); GlobPattern _orig_prefix; bool _double_star; }; typedef pvector Components; class Entry { public: Entry(const string &orig_prefix, const string &replacement_prefix); INLINE Entry(const Entry ©); INLINE void operator = (const Entry ©); bool try_match(const Filename &filename, Filename &new_filename) const; size_t r_try_match(const vector_string &components, size_t oi, size_t ci) const; string _orig_prefix; Components _orig_components; bool _is_local; string _replacement_prefix; }; typedef pvector Entries; Entries _entries; bool _error_flag; typedef pmap Copied; Copied _orig_to_target; Copied _target_to_orig; }; #include "pathReplace.I" #endif