Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
M
mongoose
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
mongoose
Commits
f42c5dea
Commit
f42c5dea
authored
Aug 30, 2010
by
valenok
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fixes in options handling
parent
97f21552
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
30 deletions
+18
-30
main.c
main.c
+18
-30
No files found.
main.c
View file @
f42c5dea
...
@@ -122,7 +122,7 @@ static void verify_document_root(const char *root) {
...
@@ -122,7 +122,7 @@ static void verify_document_root(const char *root) {
path
=
buf
;
path
=
buf
;
}
}
if
(
stat
(
path
,
&
st
)
!=
0
)
{
if
(
stat
(
path
,
&
st
)
!=
0
||
!
S_ISDIR
(
st
.
st_mode
)
)
{
fprintf
(
stderr
,
"Invalid root directory:
\"
%s
\"\n
"
,
root
);
fprintf
(
stderr
,
"Invalid root directory:
\"
%s
\"\n
"
,
root
);
exit
(
EXIT_FAILURE
);
exit
(
EXIT_FAILURE
);
}
}
...
@@ -139,7 +139,7 @@ static char *sdup(const char *str) {
...
@@ -139,7 +139,7 @@ static char *sdup(const char *str) {
static
void
set_option
(
char
**
options
,
const
char
*
name
,
const
char
*
value
)
{
static
void
set_option
(
char
**
options
,
const
char
*
name
,
const
char
*
value
)
{
int
i
;
int
i
;
if
(
!
strcmp
(
name
,
"document_root"
))
{
if
(
!
strcmp
(
name
,
"document_root"
)
||
!
(
strcmp
(
name
,
"r"
))
)
{
verify_document_root
(
value
);
verify_document_root
(
value
);
}
}
...
@@ -159,46 +159,30 @@ static void set_option(char **options, const char *name, const char *value) {
...
@@ -159,46 +159,30 @@ static void set_option(char **options, const char *name, const char *value) {
}
}
static
void
process_command_line_arguments
(
char
*
argv
[],
char
**
options
)
{
static
void
process_command_line_arguments
(
char
*
argv
[],
char
**
options
)
{
const
char
*
config_file
=
CONFIG_FILE
;
const
char
*
config_file
=
NULL
;
char
line
[
512
],
opt
[
512
],
*
vals
[
100
],
val
[
512
],
path
[
FILENAME
_MAX
],
*
p
;
char
line
[
512
],
opt
[
512
],
val
[
512
],
path
[
PATH
_MAX
],
*
p
;
FILE
*
fp
;
FILE
*
fp
=
NULL
;
size_t
i
,
line_no
=
0
;
size_t
i
,
line_no
=
0
;
/* First find out, which config file to open */
/* Should we use a config file ? */
for
(
i
=
1
;
argv
[
i
]
!=
NULL
&&
argv
[
i
][
0
]
==
'-'
;
i
+=
2
)
if
(
argv
[
1
]
!=
NULL
&&
argv
[
2
]
==
NULL
)
{
if
(
argv
[
i
+
1
]
==
NULL
)
config_file
=
argv
[
1
];
show_usage_and_exit
();
}
else
if
(
argv
[
1
]
==
NULL
)
{
/* No command line flags specified. Look where binary lives */
if
(
argv
[
i
]
!=
NULL
&&
argv
[
i
+
1
]
!=
NULL
)
{
/* More than one non-option arguments are given */
show_usage_and_exit
();
}
else
if
(
argv
[
i
]
!=
NULL
)
{
/* Just one non-option argument is given, this is config file */
config_file
=
argv
[
i
];
}
else
{
/* No config file specified. Look for one where binary lives */
if
((
p
=
strrchr
(
argv
[
0
],
DIRSEP
))
!=
0
)
{
if
((
p
=
strrchr
(
argv
[
0
],
DIRSEP
))
!=
0
)
{
snprintf
(
path
,
sizeof
(
path
),
"%.*s%s"
,
snprintf
(
path
,
sizeof
(
path
),
"%.*s%s"
,
(
int
)
(
p
-
argv
[
0
])
+
1
,
argv
[
0
],
config_file
);
(
int
)
(
p
-
argv
[
0
])
+
1
,
argv
[
0
],
CONFIG_FILE
);
config_file
=
path
;
}
}
}
}
fp
=
fopen
(
config_file
,
"r"
);
/* If config file was set in command line and open failed, exit */
/* If config file was set in command line and open failed, exit */
if
(
fp
==
NULL
&&
argv
[
i
]
!
=
NULL
)
{
if
(
config_file
!=
NULL
&&
(
fp
=
fopen
(
config_file
,
"r"
))
=
=
NULL
)
{
fprintf
(
stderr
,
"cannot open config file %s: %s
\n
"
,
fprintf
(
stderr
,
"cannot open config file %s: %s
\n
"
,
config_file
,
strerror
(
errno
));
config_file
,
strerror
(
errno
));
exit
(
EXIT_FAILURE
);
exit
(
EXIT_FAILURE
);
}
}
/* Reset temporary value holders */
(
void
)
memset
(
vals
,
0
,
sizeof
(
vals
));
if
(
fp
!=
NULL
)
{
if
(
fp
!=
NULL
)
{
printf
(
"Loading config file %s, ignoring command line arguments
\n
"
,
fprintf
(
stderr
,
"Loading config file %s
\n
"
,
config_file
);
config_file
);
/* Loop over the lines in config file */
/* Loop over the lines in config file */
while
(
fgets
(
line
,
sizeof
(
line
),
fp
)
!=
NULL
)
{
while
(
fgets
(
line
,
sizeof
(
line
),
fp
)
!=
NULL
)
{
...
@@ -219,8 +203,12 @@ static void process_command_line_arguments(char *argv[], char **options) {
...
@@ -219,8 +203,12 @@ static void process_command_line_arguments(char *argv[], char **options) {
(
void
)
fclose
(
fp
);
(
void
)
fclose
(
fp
);
}
else
{
}
else
{
for
(
i
=
1
;
argv
[
i
]
!=
NULL
&&
argv
[
i
][
0
]
==
'-'
;
i
+=
2
)
for
(
i
=
1
;
argv
[
i
]
!=
NULL
;
i
+=
2
)
{
if
(
argv
[
i
][
0
]
!=
'-'
||
argv
[
i
+
1
]
==
NULL
||
argv
[
i
+
1
][
0
]
==
'-'
)
{
show_usage_and_exit
();
}
set_option
(
options
,
&
argv
[
i
][
1
],
argv
[
i
+
1
]);
set_option
(
options
,
&
argv
[
i
][
1
],
argv
[
i
+
1
]);
}
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment