[Libreoffice-commits] .: 2 commits - sal/osl
Stephan Bergmann
sbergmann at kemper.freedesktop.org
Mon Dec 19 07:47:41 PST 2011
sal/osl/unx/file_stat.cxx | 65 +++++++---------------------------------------
1 file changed, 11 insertions(+), 54 deletions(-)
New commits:
commit fb2078addcbd96662283b2481206eee7ce3d50b6
Author: Stephan Bergmann <sbergman at redhat.com>
Date: Mon Dec 19 16:47:13 2011 +0100
Clean up previous commit.
diff --git a/sal/osl/unx/file_stat.cxx b/sal/osl/unx/file_stat.cxx
index 6b2407a..949121f 100644
--- a/sal/osl/unx/file_stat.cxx
+++ b/sal/osl/unx/file_stat.cxx
@@ -101,73 +101,14 @@ namespace /* private */
pStat->uValidFields |= osl_FileStatus_Mask_Attributes;
}
- inline void set_file_access_rights(const struct stat& file_stat, int S_IR, int S_IW, int S_IX, oslFileStatus* pStat)
- {
- /* we cannot really map osl_File_Attribute_ReadOnly to
- the Unix access rights, it's a Windows only flag
- that's why the following hack. We set osl_FileStatus_Mask_Attributes
- but if there is no read access for a file we clear the flag
- again to signal to the caller that there are no file attributes
- to read because that's better than to give them incorrect one.
- */
- pStat->uValidFields |= osl_FileStatus_Mask_Attributes;
-
- if ((0 == (S_IW & file_stat.st_mode)) && (S_IR & file_stat.st_mode))
- pStat->uAttributes |= osl_File_Attribute_ReadOnly;
-
- if (S_IX & file_stat.st_mode)
- pStat->uAttributes |= osl_File_Attribute_Executable;
- }
-
- /* a process may belong to up to NGROUPS_MAX groups, so when
- checking group access rights, we have to check all belonging
- groups */
- inline bool is_in_process_grouplist(const gid_t file_group)
- {
- // check primary process group
-
- if (getgid() == file_group)
- return true;
-
- // check supplementary process groups
-
- gid_t grplist[NGROUPS_MAX];
- int grp_number = getgroups(NGROUPS_MAX, grplist);
-
- for (int i = 0; i < grp_number; i++)
- {
- if (grplist[i] == file_group)
- return true;
- }
- return false;
- }
-
- /* Currently we are determining the file access right based
- on the real user ID not the effective user ID!
- We don't use access(...) because access follows links which
- may cause performance problems see #97133.
+ /* This code used not to use access(...) because access follows links which
+ may cause performance problems see #97133. (That apparently references a
+ no-longer accessible Hamburg-internal bug-tracking system.)
+ However, contrary to what is stated above the use of access calls is
+ required on network file systems not using unix semantics (AFS, see
+ fdo#43095).
*/
- inline void set_file_access_rights(const struct stat& file_stat, oslFileStatus* pStat)
- {
- if (getuid() == file_stat.st_uid)
- {
- set_file_access_rights(file_stat, S_IRUSR, S_IWUSR, S_IXUSR, pStat);
- }
- else if (is_in_process_grouplist(file_stat.st_gid))
- {
- set_file_access_rights(file_stat, S_IRGRP, S_IWGRP, S_IXGRP, pStat);
- }
- else
- {
- set_file_access_rights(file_stat, S_IROTH, S_IWOTH, S_IXOTH, pStat);
- }
- }
-
- /* contrary to what is stated above the use of access calls
- is required on network file systems not using unix semantics
- (AFS)
- */
- inline void set_file_access_real_rights(const rtl::OUString& file_path, oslFileStatus* pStat)
+ inline void set_file_access_rights(const rtl::OUString& file_path, oslFileStatus* pStat)
{
pStat->uValidFields |= osl_FileStatus_Mask_Attributes;
@@ -193,15 +134,10 @@ namespace /* private */
set_file_hidden_status(file_path, pStat);
set_file_access_mask(file_stat, pStat);
-#ifdef FAKE_ACCESS_RIGHTS
// we set the file access rights only on demand
// because it's potentially expensive
if (uFieldMask & osl_FileStatus_Mask_Attributes)
- set_file_access_rights(file_stat, pStat);
-#else
- if (uFieldMask & osl_FileStatus_Mask_Attributes)
- set_file_access_real_rights(file_path, pStat);
-#endif
+ set_file_access_rights(file_path, pStat);
}
inline void set_file_access_time(const struct stat& file_stat, oslFileStatus* pStat)
commit 32a6a0891fb5f2d893cca656cd44afd0bcbe3272
Author: Moritz Bechler <mbechler at eenterphace.org>
Date: Mon Dec 19 16:36:31 2011 +0100
fdo#43095: allow the use of real access() calls
diff --git a/sal/osl/unx/file_stat.cxx b/sal/osl/unx/file_stat.cxx
index 674e603..6b2407a 100644
--- a/sal/osl/unx/file_stat.cxx
+++ b/sal/osl/unx/file_stat.cxx
@@ -163,6 +163,22 @@ namespace /* private */
}
}
+ /* contrary to what is stated above the use of access calls
+ is required on network file systems not using unix semantics
+ (AFS)
+ */
+ inline void set_file_access_real_rights(const rtl::OUString& file_path, oslFileStatus* pStat)
+ {
+ pStat->uValidFields |= osl_FileStatus_Mask_Attributes;
+
+ if (access_u(file_path.pData, W_OK) < 0)
+ pStat->uAttributes |= osl_File_Attribute_ReadOnly;
+
+ if (access_u(file_path.pData, X_OK) == 0)
+ pStat->uAttributes |= osl_File_Attribute_Executable;
+ }
+
+
inline void set_file_hidden_status(const rtl::OUString& file_path, oslFileStatus* pStat)
{
pStat->uAttributes = osl::systemPathIsHiddenFileOrDirectoryEntry(file_path) ? osl_File_Attribute_Hidden : 0;
@@ -177,10 +193,15 @@ namespace /* private */
set_file_hidden_status(file_path, pStat);
set_file_access_mask(file_stat, pStat);
+#ifdef FAKE_ACCESS_RIGHTS
// we set the file access rights only on demand
// because it's potentially expensive
if (uFieldMask & osl_FileStatus_Mask_Attributes)
set_file_access_rights(file_stat, pStat);
+#else
+ if (uFieldMask & osl_FileStatus_Mask_Attributes)
+ set_file_access_real_rights(file_path, pStat);
+#endif
}
inline void set_file_access_time(const struct stat& file_stat, oslFileStatus* pStat)
More information about the Libreoffice-commits
mailing list