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
64771986
Commit
64771986
authored
Sep 14, 2010
by
valenok
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
honoring command line flags when using config file, command line flags take preference
parent
d475188a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
80 additions
and
22 deletions
+80
-22
main.c
main.c
+78
-20
test.pl
test/test.pl
+2
-2
No files found.
main.c
View file @
64771986
...
@@ -56,10 +56,9 @@
...
@@ -56,10 +56,9 @@
#define MAX_OPTIONS 40
#define MAX_OPTIONS 40
static
int
exit_flag
;
static
int
exit_flag
;
static
char
*
options
[
MAX_OPTIONS
];
static
char
server_name
[
40
];
// Set by init_server_name()
static
char
server_name
[
40
];
static
char
*
config_file
;
// Set by process_command_line_arguments()
static
char
*
config_file
;
static
struct
mg_context
*
ctx
;
// Set by start_mongoose()
static
struct
mg_context
*
ctx
;
#if !defined(CONFIG_FILE)
#if !defined(CONFIG_FILE)
#define CONFIG_FILE "mongoose.conf"
#define CONFIG_FILE "mongoose.conf"
...
@@ -183,7 +182,9 @@ static void process_command_line_arguments(char *argv[], char **options) {
...
@@ -183,7 +182,9 @@ static void process_command_line_arguments(char *argv[], char **options) {
FILE
*
fp
=
NULL
;
FILE
*
fp
=
NULL
;
size_t
i
,
line_no
=
0
;
size_t
i
,
line_no
=
0
;
/* Should we use a config file ? */
options
[
0
]
=
NULL
;
// Should we use a config file ?
if
(
argv
[
1
]
!=
NULL
&&
argv
[
2
]
==
NULL
)
{
if
(
argv
[
1
]
!=
NULL
&&
argv
[
2
]
==
NULL
)
{
config_file
=
argv
[
1
];
config_file
=
argv
[
1
];
}
else
if
((
p
=
strrchr
(
argv
[
0
],
DIRSEP
))
==
NULL
)
{
}
else
if
((
p
=
strrchr
(
argv
[
0
],
DIRSEP
))
==
NULL
)
{
...
@@ -197,20 +198,21 @@ static void process_command_line_arguments(char *argv[], char **options) {
...
@@ -197,20 +198,21 @@ static void process_command_line_arguments(char *argv[], char **options) {
fp
=
fopen
(
config_file
,
"r"
);
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
(
argv
[
1
]
!=
NULL
&&
argv
[
2
]
==
NULL
&&
fp
==
NULL
)
{
if
(
argv
[
1
]
!=
NULL
&&
argv
[
2
]
==
NULL
&&
fp
==
NULL
)
{
die
(
"Cannot open config file %s: %s"
,
config_file
,
strerror
(
errno
));
die
(
"Cannot open config file %s: %s"
,
config_file
,
strerror
(
errno
));
}
}
// Load config file settings first
if
(
fp
!=
NULL
)
{
if
(
fp
!=
NULL
)
{
fprintf
(
stderr
,
"Loading config file %s
\n
"
,
config_file
);
fprintf
(
stderr
,
"Loading config file %s
\n
"
,
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
)
{
line_no
++
;
line_no
++
;
/
* Ignore empty lines and comments */
/
/ Ignore empty lines and comments
if
(
line
[
0
]
==
'#'
||
line
[
0
]
==
'\n'
)
if
(
line
[
0
]
==
'#'
||
line
[
0
]
==
'\n'
)
continue
;
continue
;
...
@@ -221,13 +223,14 @@ static void process_command_line_arguments(char *argv[], char **options) {
...
@@ -221,13 +223,14 @@ static void process_command_line_arguments(char *argv[], char **options) {
}
}
(
void
)
fclose
(
fp
);
(
void
)
fclose
(
fp
);
}
else
{
}
for
(
i
=
1
;
argv
[
i
]
!=
NULL
;
i
+=
2
)
{
if
(
argv
[
i
][
0
]
!=
'-'
||
argv
[
i
+
1
]
==
NULL
)
{
// Now handle command line flags. They override config file settings.
show_usage_and_exit
();
for
(
i
=
1
;
argv
[
i
]
!=
NULL
;
i
+=
2
)
{
}
if
(
argv
[
i
][
0
]
!=
'-'
||
argv
[
i
+
1
]
==
NULL
)
{
s
et_option
(
options
,
&
argv
[
i
][
1
],
argv
[
i
+
1
]
);
s
how_usage_and_exit
(
);
}
}
set_option
(
options
,
&
argv
[
i
][
1
],
argv
[
i
+
1
]);
}
}
}
}
...
@@ -237,6 +240,7 @@ static void init_server_name(void) {
...
@@ -237,6 +240,7 @@ static void init_server_name(void) {
}
}
static
void
start_mongoose
(
int
argc
,
char
*
argv
[])
{
static
void
start_mongoose
(
int
argc
,
char
*
argv
[])
{
char
*
options
[
MAX_OPTIONS
];
int
i
;
int
i
;
/* Edit passwords file if -A option is specified */
/* Edit passwords file if -A option is specified */
...
@@ -342,12 +346,60 @@ static void edit_config_file(void) {
...
@@ -342,12 +346,60 @@ static void edit_config_file(void) {
WinExec
(
cmd
,
SW_SHOW
);
WinExec
(
cmd
,
SW_SHOW
);
}
}
static
void
show_error
(
void
)
{
char
buf
[
256
];
FormatMessage
(
FORMAT_MESSAGE_FROM_SYSTEM
|
FORMAT_MESSAGE_IGNORE_INSERTS
,
NULL
,
GetLastError
(),
MAKELANGID
(
LANG_NEUTRAL
,
SUBLANG_DEFAULT
),
buf
,
sizeof
(
buf
),
NULL
);
MessageBox
(
NULL
,
buf
,
"Error"
,
MB_OK
);
}
static
int
manage_service
(
int
action
)
{
static
const
char
*
service_name
=
"Mongoose"
;
SC_HANDLE
hSCM
=
NULL
,
hService
=
NULL
;
char
path
[
PATH_MAX
];
int
success
=
1
;
if
((
hSCM
=
OpenSCManager
(
NULL
,
NULL
,
action
==
ID_INSTALL_SERVICE
?
GENERIC_WRITE
:
GENERIC_READ
))
==
NULL
)
{
success
=
0
;
show_error
();
}
else
if
(
action
==
ID_INSTALL_SERVICE
)
{
GetModuleFileName
(
NULL
,
path
,
sizeof
(
path
));
hService
=
CreateService
(
hSCM
,
service_name
,
service_name
,
SERVICE_ALL_ACCESS
,
SERVICE_WIN32_OWN_PROCESS
,
SERVICE_AUTO_START
,
SERVICE_ERROR_NORMAL
,
path
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
);
if
(
hService
)
{
ChangeServiceConfig2
(
hService
,
SERVICE_CONFIG_DESCRIPTION
,
server_name
);
}
else
{
show_error
();
}
}
else
if
(
action
==
ID_REMOVE_SERVICE
)
{
if
((
hService
=
OpenService
(
hSCM
,
service_name
,
DELETE
))
==
NULL
||
!
DeleteService
(
hService
))
{
show_error
();
}
}
else
if
((
hService
=
OpenService
(
hSCM
,
service_name
,
SERVICE_QUERY_STATUS
))
==
NULL
)
{
success
=
0
;
}
//CloseServiceHandle(hService);
//CloseServiceHandle(hSCM);
return
success
;
}
static
LRESULT
CALLBACK
WindowProc
(
HWND
hWnd
,
UINT
msg
,
WPARAM
wParam
,
static
LRESULT
CALLBACK
WindowProc
(
HWND
hWnd
,
UINT
msg
,
WPARAM
wParam
,
LPARAM
lParam
)
{
LPARAM
lParam
)
{
static
SERVICE_TABLE_ENTRY
service_table
[]
=
{
static
SERVICE_TABLE_ENTRY
service_table
[]
=
{
{
server_name
,
(
LPSERVICE_MAIN_FUNCTION
)
ServiceMain
},
{
server_name
,
(
LPSERVICE_MAIN_FUNCTION
)
ServiceMain
},
{
NULL
,
NULL
}
{
NULL
,
NULL
}
};
};
int
service_installed
;
char
buf
[
200
];
POINT
pt
;
POINT
pt
;
HMENU
hMenu
;
HMENU
hMenu
;
...
@@ -370,6 +422,10 @@ static LRESULT CALLBACK WindowProc(HWND hWnd, UINT msg, WPARAM wParam,
...
@@ -370,6 +422,10 @@ static LRESULT CALLBACK WindowProc(HWND hWnd, UINT msg, WPARAM wParam,
case
ID_EDIT_CONFIG
:
case
ID_EDIT_CONFIG
:
edit_config_file
();
edit_config_file
();
break
;
break
;
case
ID_INSTALL_SERVICE
:
case
ID_REMOVE_SERVICE
:
manage_service
(
LOWORD
(
wParam
));
break
;
}
}
break
;
break
;
case
WM_USER
:
case
WM_USER
:
...
@@ -380,13 +436,15 @@ static LRESULT CALLBACK WindowProc(HWND hWnd, UINT msg, WPARAM wParam,
...
@@ -380,13 +436,15 @@ static LRESULT CALLBACK WindowProc(HWND hWnd, UINT msg, WPARAM wParam,
hMenu
=
CreatePopupMenu
();
hMenu
=
CreatePopupMenu
();
AppendMenu
(
hMenu
,
MF_STRING
|
MF_GRAYED
,
ID_SEPARATOR
,
server_name
);
AppendMenu
(
hMenu
,
MF_STRING
|
MF_GRAYED
,
ID_SEPARATOR
,
server_name
);
AppendMenu
(
hMenu
,
MF_SEPARATOR
,
ID_SEPARATOR
,
""
);
AppendMenu
(
hMenu
,
MF_SEPARATOR
,
ID_SEPARATOR
,
""
);
#if 0
service_installed
=
manage_service
(
0
);
AppendMenu(hMenu, MF_STRING | MF_GRAYED, ID_SEPARATOR,
snprintf
(
buf
,
sizeof
(
buf
),
"NT service: %s installed"
,
"NT service: not installed");
service_installed
?
""
:
"not"
);
AppendMenu(hMenu, MF_STRING, ID_INSTALL_SERVICE, "Install");
AppendMenu
(
hMenu
,
MF_STRING
|
MF_GRAYED
,
ID_SEPARATOR
,
buf
);
AppendMenu(hMenu, MF_STRING, ID_REMOVE_SERVICE, "Deinstall");
AppendMenu
(
hMenu
,
MF_STRING
|
(
service_installed
?
MF_GRAYED
:
0
),
ID_INSTALL_SERVICE
,
"Install"
);
AppendMenu
(
hMenu
,
MF_STRING
|
(
!
service_installed
?
MF_GRAYED
:
0
),
ID_REMOVE_SERVICE
,
"Deinstall"
);
AppendMenu
(
hMenu
,
MF_SEPARATOR
,
ID_SEPARATOR
,
""
);
AppendMenu
(
hMenu
,
MF_SEPARATOR
,
ID_SEPARATOR
,
""
);
#endif
AppendMenu
(
hMenu
,
MF_STRING
,
ID_EDIT_CONFIG
,
"Edit config file"
);
AppendMenu
(
hMenu
,
MF_STRING
,
ID_EDIT_CONFIG
,
"Edit config file"
);
AppendMenu
(
hMenu
,
MF_STRING
,
ID_QUIT
,
"Exit"
);
AppendMenu
(
hMenu
,
MF_STRING
,
ID_QUIT
,
"Exit"
);
GetCursorPos
(
&
pt
);
GetCursorPos
(
&
pt
);
...
...
test/test.pl
View file @
64771986
...
@@ -146,8 +146,8 @@ if (scalar(@ARGV) > 0 and $ARGV[0] eq 'embedded') {
...
@@ -146,8 +146,8 @@ if (scalar(@ARGV) > 0 and $ARGV[0] eq 'embedded') {
}
}
# Make sure we load config file if no options are given
# Make sure we load config file if no options are given
write_file
(
$config
,
"listening_ports 12345\n
access_log_file access.log\n
"
);
write_file
(
$config
,
"listening_ports 12345\n"
);
spawn
(
$exe
);
spawn
(
"$exe -a access.log"
);
my
$saved_port
=
$port
;
my
$saved_port
=
$port
;
$port
=
12345
;
$port
=
12345
;
o
(
"GET /test/hello.txt HTTP/1.0\n\n"
,
'HTTP/1.1 200 OK'
,
'Loading config file'
);
o
(
"GET /test/hello.txt HTTP/1.0\n\n"
,
'HTTP/1.1 200 OK'
,
'Loading config file'
);
...
...
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