File: env_set_intermediate_dir_mode.html

package info (click to toggle)
db4.7 4.7.25-9
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 65,844 kB
  • ctags: 43,162
  • sloc: ansic: 155,831; java: 62,154; tcl: 53,808; sh: 14,078; perl: 13,476; cpp: 10,662; cs: 2,660; makefile: 2,629; awk: 1,749; xml: 197; python: 26; php: 22; asm: 14; sed: 9
file content (118 lines) | stat: -rw-r--r-- 5,918 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
<!--$Id: env_set_intermediate_dir_mode.so,v 1.1 2008/01/15 15:35:22 bostic Exp $-->
<!--Copyright (c) 1997,2008 Oracle.  All rights reserved.-->
<!--See the file LICENSE for redistribution information.-->
<html>
<head>
<title>Berkeley DB: DbEnv::set_intermediate_dir_mode</title>
<meta name="description" content="Berkeley DB: An embedded database programmatic toolkit.">
<meta name="keywords" content="embedded,database,programmatic,toolkit,btree,hash,hashing,transaction,transactions,locking,logging,access method,access methods,Java,C,C++">
</head>
<body bgcolor=white>
<table width="100%"><tr valign=top>
<td>
<b>DbEnv::set_intermediate_dir_mode</b>
</td>
<td align=right>
<a href="../api_cxx/api_core.html"><img src="../images/api.gif" alt="API"></a>
<a href="../ref/toc.html"><img src="../images/ref.gif" alt="Ref"></a></td>
</tr></table>
<hr size=1 noshade>
<tt>
<b><pre>
#include &lt;db_cxx.h&gt;
<p>
int
DbEnv::set_intermediate_dir_mode(u_int32_t mode);
<p>
int
DbEnv::get_intermediate_dir_mode(u_int32_t *modep);
</pre></b>
<hr size=1 noshade>
<b>Description: DbEnv::set_intermediate_dir_mode</b>
<p>By default, Berkeley DB does not create intermediate directories needed for
recovery, that is, if the file <b>/a/b/c/mydatabase</b> is being
recovered, and the directory path <b>b/c</b> does not exist, recovery
will fail.   This default behavior is because Berkeley DB does not know what
permissions are appropriate for intermediate directory creation, and
creating the directory might result in a security problem.</p>
<p>The DbEnv::set_intermediate_dir_mode method causes Berkeley DB to create any
intermediate directories needed during recovery, using the specified
permissions.</p>
<p>On UNIX systems or in IEEE/ANSI Std 1003.1 (POSIX) environments, created directories
are owned by the process owner; the group ownership of created
directories is based on the system and directory defaults, and is not
further specified by Berkeley DB.</p>
<p>The database environment's intermediate directory permissions may also be configured using the
environment's <a href="../ref/env/db_config.html#DB_CONFIG">DB_CONFIG</a> file.  The syntax of the entry in that
file is a single line with the string "set_intermediate_dir_mode", one or more whitespace
characters, and the directory permissions.
Because the <a href="../ref/env/db_config.html#DB_CONFIG">DB_CONFIG</a> file is read when the database environment
is opened, it will silently overrule configuration done before that
time.</p>
<p>The DbEnv::set_intermediate_dir_mode method configures operations performed using the specified
<a href="../api_cxx/env_class.html">DbEnv</a> handle, not all operations performed on the underlying
database environment.</p>
<p>The DbEnv::set_intermediate_dir_mode method may not be called after the <a href="../api_cxx/env_open.html">DbEnv::open</a> method is
called.
</p>
<p>The DbEnv::set_intermediate_dir_mode method
either returns a non-zero error value
or throws an exception that encapsulates a non-zero error value on
failure, and returns 0 on success.
</p>
<b>Parameters</b> <br>
 <b>mode</b><ul compact><li>The <b>mode</b> parameter specifies the directory permissions.
<p>Directory permissions are interpreted as a string of nine characters,
using the character set <b>r</b> (read), <b>w</b> (write), <b>x</b>
(execute or search), and <b>-</b> (none).  The first character is the
read permissions for the directory owner (set to either <b>r</b> or
<b>-</b>). The second character is the write permissions for the
directory owner (set to either <b>w</b> or <b>-</b>). The third
character is the execute permissions for the directory owner (set to
either <b>x</b> or <b>-</b>).</p>
<p>Similarly, the second set of three characters are the read, write and
execute/search permissions for the directory group, and the third set
of three characters are the read, write and execute/search permissions
for all others.  For example, the string <b>rwx------</b> would
configure read, write and execute/search access for the owner only.  The
string <b>rwxrwx---</b> would configure read, write and execute/search
access for both the owner and the group.  The string <b>rwxr-----</b>
would configure read, write and execute/search access for the directory
owner and read-only access for the directory group.</p></ul>
<br>
<br><b>Errors</b>
<p>The DbEnv::set_intermediate_dir_mode method
may fail and throw
<a href="../api_cxx/except_class.html">DbException</a>,
encapsulating one of the following non-zero errors, or return one of
the following non-zero errors:</p>
<br>
<b>EINVAL</b><ul compact><li>If the method was called after <a href="../api_cxx/env_open.html">DbEnv::open</a> was called; or if an
invalid flag value or parameter was specified.</ul>
<br>
<hr size=1 noshade>
<b>Description: DbEnv::get_intermediate_dir_mode</b>
<p>The DbEnv::get_intermediate_dir_mode method returns the intermediate directory permissions.</p>
<p>The DbEnv::get_intermediate_dir_mode method may be called at any time during the life of the
application.</p>
<p>The DbEnv::get_intermediate_dir_mode method
either returns a non-zero error value
or throws an exception that encapsulates a non-zero error value on
failure, and returns 0 on success.
</p>
<b>Parameters</b> <br>
 <b>modep</b><ul compact><li>The DbEnv::get_intermediate_dir_mode method returns a reference to the
intermediate directory permissions in <b>modep</b>.</ul>
<br>
<hr size=1 noshade>
<br><b>Class</b>
<a href="../api_cxx/env_class.html">DbEnv</a>
<br><b>See Also</b>
<a href="../api_cxx/env_list.html">Database Environments and Related Methods</a>
</tt>
<table width="100%"><tr><td><br></td><td align=right>
<a href="../api_cxx/api_core.html"><img src="../images/api.gif" alt="API"></a><a href="../ref/toc.html"><img src="../images/ref.gif" alt="Ref"></a>
</td></tr></table>
<p><font size=1>Copyright (c) 1996,2008 Oracle.  All rights reserved.</font>
</body>
</html>