Mercurial > octave
diff liboctave/system/file-stat.h @ 31607:aac27ad79be6 stable
maint: Re-indent code after switch to using namespace macros.
* build-env.h, build-env.in.cc, Cell.h, __betainc__.cc, __eigs__.cc,
__ftp__.cc, __ichol__.cc, __ilu__.cc, __isprimelarge__.cc, __magick_read__.cc,
__pchip_deriv__.cc, amd.cc, base-text-renderer.cc, base-text-renderer.h,
besselj.cc, bitfcns.cc, bsxfun.cc, c-file-ptr-stream.h, call-stack.cc,
call-stack.h, ccolamd.cc, cellfun.cc, chol.cc, colamd.cc, dasrt.cc, data.cc,
debug.cc, defaults.cc, defaults.h, det.cc, display.cc, display.h, dlmread.cc,
dynamic-ld.cc, dynamic-ld.h, ellipj.cc, environment.cc, environment.h,
error.cc, error.h, errwarn.h, event-manager.cc, event-manager.h,
event-queue.cc, event-queue.h, fcn-info.cc, fcn-info.h, fft.cc, fft2.cc,
file-io.cc, filter.cc, find.cc, ft-text-renderer.cc, ft-text-renderer.h,
gcd.cc, gl-render.cc, gl-render.h, gl2ps-print.cc, gl2ps-print.h,
graphics-toolkit.cc, graphics-toolkit.h, graphics.cc, gsvd.cc, gtk-manager.cc,
gtk-manager.h, help.cc, help.h, hook-fcn.cc, hook-fcn.h, input.cc, input.h,
interpreter-private.cc, interpreter-private.h, interpreter.cc, interpreter.h,
inv.cc, jsondecode.cc, jsonencode.cc, latex-text-renderer.cc,
latex-text-renderer.h, load-path.cc, load-path.h, load-save.cc, load-save.h,
lookup.cc, ls-hdf5.cc, ls-mat4.cc, ls-mat5.cc, lsode.cc, lu.cc, mappers.cc,
matrix_type.cc, max.cc, mex.cc, mexproto.h, mxarray.h, mxtypes.in.h,
oct-errno.in.cc, oct-hdf5-types.cc, oct-hist.cc, oct-hist.h, oct-map.cc,
oct-map.h, oct-opengl.h, oct-prcstrm.h, oct-process.cc, oct-process.h,
oct-stdstrm.h, oct-stream.cc, oct-stream.h, oct-strstrm.h,
octave-default-image.h, ordqz.cc, ordschur.cc, pager.cc, pager.h, pinv.cc,
pow2.cc, pr-output.cc, psi.cc, qr.cc, quadcc.cc, rand.cc, regexp.cc,
settings.cc, settings.h, sighandlers.cc, sighandlers.h, sparse-xpow.cc,
sqrtm.cc, stack-frame.cc, stack-frame.h, stream-euler.cc, strfns.cc, svd.cc,
syminfo.cc, syminfo.h, symrcm.cc, symrec.cc, symrec.h, symscope.cc, symscope.h,
symtab.cc, symtab.h, sysdep.cc, sysdep.h, text-engine.cc, text-engine.h,
text-renderer.cc, text-renderer.h, time.cc, toplev.cc, typecast.cc,
url-handle-manager.cc, url-handle-manager.h, urlwrite.cc, utils.cc, utils.h,
variables.cc, variables.h, xdiv.cc, __delaunayn__.cc, __init_fltk__.cc,
__init_gnuplot__.cc, __ode15__.cc, __voronoi__.cc, audioread.cc, convhulln.cc,
gzip.cc, cdef-class.cc, cdef-class.h, cdef-fwd.h, cdef-manager.cc,
cdef-manager.h, cdef-method.cc, cdef-method.h, cdef-object.cc, cdef-object.h,
cdef-package.cc, cdef-package.h, cdef-property.cc, cdef-property.h,
cdef-utils.cc, cdef-utils.h, ov-base-diag.cc, ov-base-int.cc, ov-base-mat.cc,
ov-base-mat.h, ov-base-scalar.cc, ov-base.cc, ov-base.h, ov-bool-mat.cc,
ov-bool-mat.h, ov-bool-sparse.cc, ov-bool.cc, ov-builtin.h, ov-cell.cc,
ov-ch-mat.cc, ov-class.cc, ov-class.h, ov-classdef.cc, ov-classdef.h,
ov-complex.cc, ov-cx-diag.cc, ov-cx-mat.cc, ov-cx-sparse.cc, ov-dld-fcn.cc,
ov-dld-fcn.h, ov-fcn-handle.cc, ov-fcn-handle.h, ov-fcn.h, ov-float.cc,
ov-flt-complex.cc, ov-flt-cx-diag.cc, ov-flt-cx-mat.cc, ov-flt-re-diag.cc,
ov-flt-re-mat.cc, ov-flt-re-mat.h, ov-intx.h, ov-java.cc, ov-lazy-idx.cc,
ov-legacy-range.cc, ov-magic-int.cc, ov-mex-fcn.cc, ov-mex-fcn.h,
ov-null-mat.cc, ov-perm.cc, ov-range.cc, ov-re-diag.cc, ov-re-mat.cc,
ov-re-mat.h, ov-re-sparse.cc, ov-scalar.cc, ov-str-mat.cc, ov-struct.cc,
ov-typeinfo.cc, ov-typeinfo.h, ov-usr-fcn.cc, ov-usr-fcn.h, ov.cc, ov.h, ovl.h,
octave.cc, octave.h, op-b-sbm.cc, op-bm-sbm.cc, op-cs-scm.cc, op-fm-fcm.cc,
op-fs-fcm.cc, op-s-scm.cc, op-scm-cs.cc, op-scm-s.cc, op-sm-cs.cc, ops.h,
anon-fcn-validator.cc, anon-fcn-validator.h, bp-table.cc, bp-table.h,
comment-list.cc, comment-list.h, filepos.h, lex.h, oct-lvalue.cc, oct-lvalue.h,
parse.h, profiler.cc, profiler.h, pt-anon-scopes.cc, pt-anon-scopes.h,
pt-arg-list.cc, pt-arg-list.h, pt-args-block.cc, pt-args-block.h,
pt-array-list.cc, pt-array-list.h, pt-assign.cc, pt-assign.h, pt-binop.cc,
pt-binop.h, pt-bp.cc, pt-bp.h, pt-cbinop.cc, pt-cbinop.h, pt-cell.cc,
pt-cell.h, pt-check.cc, pt-check.h, pt-classdef.cc, pt-classdef.h, pt-cmd.h,
pt-colon.cc, pt-colon.h, pt-const.cc, pt-const.h, pt-decl.cc, pt-decl.h,
pt-eval.cc, pt-eval.h, pt-except.cc, pt-except.h, pt-exp.cc, pt-exp.h,
pt-fcn-handle.cc, pt-fcn-handle.h, pt-id.cc, pt-id.h, pt-idx.cc, pt-idx.h,
pt-jump.h, pt-loop.cc, pt-loop.h, pt-mat.cc, pt-mat.h, pt-misc.cc, pt-misc.h,
pt-pr-code.cc, pt-pr-code.h, pt-select.cc, pt-select.h, pt-spmd.cc, pt-spmd.h,
pt-stmt.cc, pt-stmt.h, pt-tm-const.cc, pt-tm-const.h, pt-unop.cc, pt-unop.h,
pt-walk.cc, pt-walk.h, pt.cc, pt.h, token.cc, token.h, Range.cc, Range.h,
idx-vector.cc, idx-vector.h, range-fwd.h, CollocWt.cc, CollocWt.h,
aepbalance.cc, aepbalance.h, chol.cc, chol.h, gepbalance.cc, gepbalance.h,
gsvd.cc, gsvd.h, hess.cc, hess.h, lo-mappers.cc, lo-mappers.h, lo-specfun.cc,
lo-specfun.h, lu.cc, lu.h, oct-convn.cc, oct-convn.h, oct-fftw.cc, oct-fftw.h,
oct-norm.cc, oct-norm.h, oct-rand.cc, oct-rand.h, oct-spparms.cc,
oct-spparms.h, qr.cc, qr.h, qrp.cc, qrp.h, randgamma.cc, randgamma.h,
randmtzig.cc, randmtzig.h, randpoisson.cc, randpoisson.h, schur.cc, schur.h,
sparse-chol.cc, sparse-chol.h, sparse-lu.cc, sparse-lu.h, sparse-qr.cc,
sparse-qr.h, svd.cc, svd.h, child-list.cc, child-list.h, dir-ops.cc, dir-ops.h,
file-ops.cc, file-ops.h, file-stat.cc, file-stat.h, lo-sysdep.cc, lo-sysdep.h,
lo-sysinfo.cc, lo-sysinfo.h, mach-info.cc, mach-info.h, oct-env.cc, oct-env.h,
oct-group.cc, oct-group.h, oct-password.cc, oct-password.h, oct-syscalls.cc,
oct-syscalls.h, oct-time.cc, oct-time.h, oct-uname.cc, oct-uname.h,
action-container.cc, action-container.h, base-list.h, cmd-edit.cc, cmd-edit.h,
cmd-hist.cc, cmd-hist.h, f77-fcn.h, file-info.cc, file-info.h,
lo-array-errwarn.cc, lo-array-errwarn.h, lo-hash.cc, lo-hash.h, lo-ieee.h,
lo-regexp.cc, lo-regexp.h, lo-utils.cc, lo-utils.h, oct-base64.cc,
oct-base64.h, oct-glob.cc, oct-glob.h, oct-inttypes.h, oct-mutex.cc,
oct-mutex.h, oct-refcount.h, oct-shlib.cc, oct-shlib.h, oct-sparse.cc,
oct-sparse.h, oct-string.h, octave-preserve-stream-state.h, pathsearch.cc,
pathsearch.h, quit.cc, quit.h, unwind-prot.cc, unwind-prot.h, url-transfer.cc,
url-transfer.h:
Re-indent code after switch to using namespace macros.
author | Rik <rik@octave.org> |
---|---|
date | Thu, 01 Dec 2022 18:02:15 -0800 |
parents | e88a07dec498 |
children | 597f3ee61a48 |
line wrap: on
line diff
--- a/liboctave/system/file-stat.h Thu Dec 01 14:23:45 2022 -0800 +++ b/liboctave/system/file-stat.h Thu Dec 01 18:02:15 2022 -0800 @@ -38,290 +38,290 @@ OCTAVE_BEGIN_NAMESPACE(sys) - class - OCTAVE_API - base_file_stat - { - public: +class +OCTAVE_API +base_file_stat +{ +public: + + base_file_stat (void) + : m_initialized (false), m_fail (false), m_errmsg (), m_mode (), + m_ino (), m_dev (), m_nlink (), m_uid (), m_gid (), + m_size (), m_atime (), m_mtime (), m_ctime (), m_rdev (), + m_blksize (), m_blocks () { } - base_file_stat (void) - : m_initialized (false), m_fail (false), m_errmsg (), m_mode (), - m_ino (), m_dev (), m_nlink (), m_uid (), m_gid (), - m_size (), m_atime (), m_mtime (), m_ctime (), m_rdev (), - m_blksize (), m_blocks () { } + base_file_stat (const base_file_stat& fs) + : m_initialized (fs.m_initialized), m_fail (fs.m_fail), + m_errmsg (fs.m_errmsg), m_mode (fs.m_mode), m_ino (fs.m_ino), + m_dev (fs.m_dev), m_nlink (fs.m_nlink), m_uid (fs.m_uid), + m_gid (fs.m_gid), m_size (fs.m_size), m_atime (fs.m_atime), + m_mtime (fs.m_mtime), m_ctime (fs.m_ctime), m_rdev (fs.m_rdev), + m_blksize (fs.m_blksize), m_blocks (fs.m_blocks) { } - base_file_stat (const base_file_stat& fs) - : m_initialized (fs.m_initialized), m_fail (fs.m_fail), - m_errmsg (fs.m_errmsg), m_mode (fs.m_mode), m_ino (fs.m_ino), - m_dev (fs.m_dev), m_nlink (fs.m_nlink), m_uid (fs.m_uid), - m_gid (fs.m_gid), m_size (fs.m_size), m_atime (fs.m_atime), - m_mtime (fs.m_mtime), m_ctime (fs.m_ctime), m_rdev (fs.m_rdev), - m_blksize (fs.m_blksize), m_blocks (fs.m_blocks) { } - - base_file_stat& operator = (const base_file_stat& fs) + base_file_stat& operator = (const base_file_stat& fs) + { + if (this != &fs) { - if (this != &fs) - { - m_initialized = fs.m_initialized; - m_fail = fs.m_fail; - m_errmsg = fs.m_errmsg; - m_mode = fs.m_mode; - m_ino = fs.m_ino; - m_dev = fs.m_dev; - m_nlink = fs.m_nlink; - m_uid = fs.m_uid; - m_gid = fs.m_gid; - m_size = fs.m_size; - m_atime = fs.m_atime; - m_mtime = fs.m_mtime; - m_ctime = fs.m_ctime; - m_rdev = fs.m_rdev; - m_blksize = fs.m_blksize; - m_blocks = fs.m_blocks; - } - - return *this; - } - - // The minimum difference in file time stamp values. - // FIXME: This value should come from the filesystem itself. - // How can we get that info? - sys::time time_resolution (void) const - { - static sys::time resolution (1.0); - return resolution; + m_initialized = fs.m_initialized; + m_fail = fs.m_fail; + m_errmsg = fs.m_errmsg; + m_mode = fs.m_mode; + m_ino = fs.m_ino; + m_dev = fs.m_dev; + m_nlink = fs.m_nlink; + m_uid = fs.m_uid; + m_gid = fs.m_gid; + m_size = fs.m_size; + m_atime = fs.m_atime; + m_mtime = fs.m_mtime; + m_ctime = fs.m_ctime; + m_rdev = fs.m_rdev; + m_blksize = fs.m_blksize; + m_blocks = fs.m_blocks; } - // File status and info. The is_XXX functions will return false for - // file_stat objects that are not properly initialized. The others - // should all return 0 (or the equivalent, for the given object) - // which is likely not meaningful. + return *this; + } - bool is_blk (void) const; - bool is_chr (void) const; - bool is_dir (void) const; - bool is_fifo (void) const; - bool is_lnk (void) const; - bool is_reg (void) const; - bool is_sock (void) const; + // The minimum difference in file time stamp values. + // FIXME: This value should come from the filesystem itself. + // How can we get that info? + sys::time time_resolution (void) const + { + static sys::time resolution (1.0); + return resolution; + } + + // File status and info. The is_XXX functions will return false for + // file_stat objects that are not properly initialized. The others + // should all return 0 (or the equivalent, for the given object) + // which is likely not meaningful. - static bool is_blk (mode_t mode); - static bool is_chr (mode_t mode); - static bool is_dir (mode_t mode); - static bool is_fifo (mode_t mode); - static bool is_lnk (mode_t mode); - static bool is_reg (mode_t mode); - static bool is_sock (mode_t mode); + bool is_blk (void) const; + bool is_chr (void) const; + bool is_dir (void) const; + bool is_fifo (void) const; + bool is_lnk (void) const; + bool is_reg (void) const; + bool is_sock (void) const; - static bool have_struct_stat_st_rdev (void); - static bool have_struct_stat_st_blksize (void); - static bool have_struct_stat_st_blocks (void); - - ino_t ino (void) const { return m_ino; } - dev_t dev (void) const { return m_dev; } + static bool is_blk (mode_t mode); + static bool is_chr (mode_t mode); + static bool is_dir (mode_t mode); + static bool is_fifo (mode_t mode); + static bool is_lnk (mode_t mode); + static bool is_reg (mode_t mode); + static bool is_sock (mode_t mode); - nlink_t nlink (void) const { return m_nlink; } - - uid_t uid (void) const { return m_uid; } - gid_t gid (void) const { return m_gid; } - - off_t size (void) const { return m_size; } + static bool have_struct_stat_st_rdev (void); + static bool have_struct_stat_st_blksize (void); + static bool have_struct_stat_st_blocks (void); - sys::time atime (void) const { return m_atime; } - sys::time mtime (void) const { return m_mtime; } - sys::time ctime (void) const { return m_ctime; } + ino_t ino (void) const { return m_ino; } + dev_t dev (void) const { return m_dev; } - dev_t rdev (void) const { return m_rdev; } + nlink_t nlink (void) const { return m_nlink; } + + uid_t uid (void) const { return m_uid; } + gid_t gid (void) const { return m_gid; } - long blksize (void) const { return m_blksize; } - long blocks (void) const { return m_blocks; } - - mode_t mode (void) const { return m_mode; } + off_t size (void) const { return m_size; } - std::string mode_as_string (void) const; + sys::time atime (void) const { return m_atime; } + sys::time mtime (void) const { return m_mtime; } + sys::time ctime (void) const { return m_ctime; } - bool ok (void) const { return m_initialized && ! m_fail; } + dev_t rdev (void) const { return m_rdev; } - operator bool () const { return ok (); } + long blksize (void) const { return m_blksize; } + long blocks (void) const { return m_blocks; } - bool exists (void) const { return ok (); } + mode_t mode (void) const { return m_mode; } + + std::string mode_as_string (void) const; - std::string error (void) const { return ok () ? "" : m_errmsg; } + bool ok (void) const { return m_initialized && ! m_fail; } - // Has the file referenced by this object been modified since TIME? - bool is_newer (const sys::time& time) const { return m_mtime > time; } + operator bool () const { return ok (); } - // It's nice to be able to hide the file_stat object if we don't - // really care about it. - static int is_newer (const std::string&, const sys::time&); + bool exists (void) const { return ok (); } + + std::string error (void) const { return ok () ? "" : m_errmsg; } - protected: + // Has the file referenced by this object been modified since TIME? + bool is_newer (const sys::time& time) const { return m_mtime > time; } - virtual ~base_file_stat (void) = default; - - // TRUE means we have already called stat. - bool m_initialized; + // It's nice to be able to hide the file_stat object if we don't + // really care about it. + static int is_newer (const std::string&, const sys::time&); - // TRUE means the stat for this file failed. - bool m_fail; +protected: - // If a failure occurs, this contains the system error text. - std::string m_errmsg; + virtual ~base_file_stat (void) = default; - // file type and permissions - mode_t m_mode; + // TRUE means we have already called stat. + bool m_initialized; - // serial number - ino_t m_ino; + // TRUE means the stat for this file failed. + bool m_fail; - // device number - dev_t m_dev; + // If a failure occurs, this contains the system error text. + std::string m_errmsg; - // number of links - nlink_t m_nlink; + // file type and permissions + mode_t m_mode; - // user ID of owner - uid_t m_uid; + // serial number + ino_t m_ino; - // group ID of owner - gid_t m_gid; + // device number + dev_t m_dev; - // size in bytes, for regular files - off_t m_size; + // number of links + nlink_t m_nlink; - // time of last access - sys::time m_atime; + // user ID of owner + uid_t m_uid; + + // group ID of owner + gid_t m_gid; - // time of last modification - sys::time m_mtime; + // size in bytes, for regular files + off_t m_size; - // time of last file status change - sys::time m_ctime; + // time of last access + sys::time m_atime; - // device number for special files - dev_t m_rdev; + // time of last modification + sys::time m_mtime; - // best I/O block size - long m_blksize; + // time of last file status change + sys::time m_ctime; - // number of 512-byte blocks allocated - long m_blocks; - }; + // device number for special files + dev_t m_rdev; - class - OCTAVE_API - file_stat : public base_file_stat - { - public: + // best I/O block size + long m_blksize; + + // number of 512-byte blocks allocated + long m_blocks; +}; - // This constructor must remain defined in the cpp file rather than in - // the header file (bug #50234). - file_stat (const std::string& n = "", bool fl = true); +class +OCTAVE_API +file_stat : public base_file_stat +{ +public: - file_stat (const file_stat& fs) - : base_file_stat (fs), m_file_name (fs.m_file_name), - m_follow_links (fs.m_follow_links) { } + // This constructor must remain defined in the cpp file rather than in + // the header file (bug #50234). + file_stat (const std::string& n = "", bool fl = true); - file_stat& operator = (const file_stat& fs) + file_stat (const file_stat& fs) + : base_file_stat (fs), m_file_name (fs.m_file_name), + m_follow_links (fs.m_follow_links) { } + + file_stat& operator = (const file_stat& fs) + { + if (this != &fs) { - if (this != &fs) - { - base_file_stat::operator = (fs); + base_file_stat::operator = (fs); - m_file_name = fs.m_file_name; - m_follow_links = fs.m_follow_links; - } - - return *this; + m_file_name = fs.m_file_name; + m_follow_links = fs.m_follow_links; } - // This destructor must remain as an empty destructor defined in the - // cpp file rather than in the header file (bug #50234). - ~file_stat (void); + return *this; + } + + // This destructor must remain as an empty destructor defined in the + // cpp file rather than in the header file (bug #50234). + ~file_stat (void); + + void get_stats (bool force = false) + { + if (! m_initialized || force) + update_internal (force); + } - void get_stats (bool force = false) + void get_stats (const std::string& n, bool force = false) + { + if (n != m_file_name || ! m_initialized || force) { - if (! m_initialized || force) - update_internal (force); + m_initialized = false; + + m_file_name = n; + + update_internal (force); } + } + +private: - void get_stats (const std::string& n, bool force = false) + // Name of the file. + std::string m_file_name; + + // TRUE means follow symbolic links to the ultimate file (stat). + // FALSE means get information about the link itself (lstat). + bool m_follow_links; + + void update_internal (bool force = false); +}; + +class +OCTAVE_API +file_fstat : public base_file_stat +{ +public: + + file_fstat (int n) : base_file_stat (), m_fid (n) + { + update_internal (); + } + + file_fstat (const file_fstat& fs) + : base_file_stat (fs), m_fid (fs.m_fid) { } + + file_fstat& operator = (const file_fstat& fs) + { + if (this != &fs) { - if (n != m_file_name || ! m_initialized || force) - { - m_initialized = false; + base_file_stat::operator = (fs); - m_file_name = n; - - update_internal (force); - } + m_fid = fs.m_fid; } - private: - - // Name of the file. - std::string m_file_name; + return *this; + } - // TRUE means follow symbolic links to the ultimate file (stat). - // FALSE means get information about the link itself (lstat). - bool m_follow_links; - - void update_internal (bool force = false); - }; + ~file_fstat (void) = default; - class - OCTAVE_API - file_fstat : public base_file_stat - { - public: - - file_fstat (int n) : base_file_stat (), m_fid (n) - { - update_internal (); - } - - file_fstat (const file_fstat& fs) - : base_file_stat (fs), m_fid (fs.m_fid) { } - - file_fstat& operator = (const file_fstat& fs) - { - if (this != &fs) - { - base_file_stat::operator = (fs); + void get_stats (bool force = false) + { + if (! m_initialized || force) + update_internal (force); + } - m_fid = fs.m_fid; - } - - return *this; - } - - ~file_fstat (void) = default; - - void get_stats (bool force = false) - { - if (! m_initialized || force) - update_internal (force); - } - - void get_stats (int n, bool force = false) + void get_stats (int n, bool force = false) + { + if (n != m_fid || ! m_initialized || force) { - if (n != m_fid || ! m_initialized || force) - { - m_initialized = false; + m_initialized = false; - m_fid = n; + m_fid = n; - update_internal (force); - } + update_internal (force); } + } - private: +private: - // Open file descriptor. - int m_fid; + // Open file descriptor. + int m_fid; - void update_internal (bool force = false); - }; + void update_internal (bool force = false); +}; OCTAVE_END_NAMESPACE(sys) OCTAVE_END_NAMESPACE(octave)