added qse_mbstouri()/qse_wcstouri()/qse_strtouri().
added qse_enbase64()/qse_debase64(). enhanced basic authorization to httpd-std
This commit is contained in:
@ -39,6 +39,7 @@ bin_PROGRAMS = \
|
||||
str01 \
|
||||
time \
|
||||
tre01 \
|
||||
uri01 \
|
||||
xma
|
||||
|
||||
LDFLAGS = -L../../lib/cmn
|
||||
|
@ -42,7 +42,7 @@ bin_PROGRAMS = chr01$(EXEEXT) env$(EXEEXT) dll$(EXEEXT) fio01$(EXEEXT) \
|
||||
pio$(EXEEXT) pma$(EXEEXT) rex01$(EXEEXT) rbt$(EXEEXT) \
|
||||
sio01$(EXEEXT) sio02$(EXEEXT) sio03$(EXEEXT) sll$(EXEEXT) \
|
||||
slmb01$(EXEEXT) str01$(EXEEXT) time$(EXEEXT) tre01$(EXEEXT) \
|
||||
xma$(EXEEXT)
|
||||
uri01$(EXEEXT) xma$(EXEEXT)
|
||||
@WCHAR_TRUE@@WIN32_TRUE@am__append_1 = $(UNICOWS_LIBS)
|
||||
subdir = samples/cmn
|
||||
DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in
|
||||
@ -190,6 +190,10 @@ am_tre01_OBJECTS = tre01.$(OBJEXT)
|
||||
tre01_OBJECTS = $(am_tre01_OBJECTS)
|
||||
tre01_LDADD = $(LDADD)
|
||||
tre01_DEPENDENCIES = $(am__DEPENDENCIES_2)
|
||||
uri01_SOURCES = uri01.c
|
||||
uri01_OBJECTS = uri01.$(OBJEXT)
|
||||
uri01_LDADD = $(LDADD)
|
||||
uri01_DEPENDENCIES = $(am__DEPENDENCIES_2)
|
||||
am_xma_OBJECTS = xma.$(OBJEXT)
|
||||
xma_OBJECTS = $(am_xma_OBJECTS)
|
||||
xma_LDADD = $(LDADD)
|
||||
@ -217,7 +221,7 @@ SOURCES = $(chr01_SOURCES) $(dll_SOURCES) $(env_SOURCES) \
|
||||
$(rbt_SOURCES) $(rex01_SOURCES) $(sio01_SOURCES) \
|
||||
$(sio02_SOURCES) $(sio03_SOURCES) $(sll_SOURCES) \
|
||||
$(slmb01_SOURCES) $(str01_SOURCES) $(time_SOURCES) \
|
||||
$(tre01_SOURCES) $(xma_SOURCES)
|
||||
$(tre01_SOURCES) uri01.c $(xma_SOURCES)
|
||||
DIST_SOURCES = $(chr01_SOURCES) $(dll_SOURCES) $(env_SOURCES) \
|
||||
$(fio01_SOURCES) $(fio02_SOURCES) $(fma_SOURCES) \
|
||||
$(fmt01_SOURCES) $(fmt02_SOURCES) $(fs01_SOURCES) \
|
||||
@ -228,7 +232,7 @@ DIST_SOURCES = $(chr01_SOURCES) $(dll_SOURCES) $(env_SOURCES) \
|
||||
$(rbt_SOURCES) $(rex01_SOURCES) $(sio01_SOURCES) \
|
||||
$(sio02_SOURCES) $(sio03_SOURCES) $(sll_SOURCES) \
|
||||
$(slmb01_SOURCES) $(str01_SOURCES) $(time_SOURCES) \
|
||||
$(tre01_SOURCES) $(xma_SOURCES)
|
||||
$(tre01_SOURCES) uri01.c $(xma_SOURCES)
|
||||
ETAGS = etags
|
||||
CTAGS = ctags
|
||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
||||
@ -598,6 +602,9 @@ time$(EXEEXT): $(time_OBJECTS) $(time_DEPENDENCIES) $(EXTRA_time_DEPENDENCIES)
|
||||
tre01$(EXEEXT): $(tre01_OBJECTS) $(tre01_DEPENDENCIES) $(EXTRA_tre01_DEPENDENCIES)
|
||||
@rm -f tre01$(EXEEXT)
|
||||
$(LINK) $(tre01_OBJECTS) $(tre01_LDADD) $(LIBS)
|
||||
uri01$(EXEEXT): $(uri01_OBJECTS) $(uri01_DEPENDENCIES) $(EXTRA_uri01_DEPENDENCIES)
|
||||
@rm -f uri01$(EXEEXT)
|
||||
$(LINK) $(uri01_OBJECTS) $(uri01_LDADD) $(LIBS)
|
||||
xma$(EXEEXT): $(xma_OBJECTS) $(xma_DEPENDENCIES) $(EXTRA_xma_DEPENDENCIES)
|
||||
@rm -f xma$(EXEEXT)
|
||||
$(LINK) $(xma_OBJECTS) $(xma_LDADD) $(LIBS)
|
||||
@ -640,6 +647,7 @@ distclean-compile:
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/str01.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/time.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tre01.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/uri01.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/xma.Po@am__quote@
|
||||
|
||||
.c.o:
|
||||
|
139
qse/samples/cmn/uri01.c
Normal file
139
qse/samples/cmn/uri01.c
Normal file
@ -0,0 +1,139 @@
|
||||
#include <qse/cmn/uri.h>
|
||||
#include <qse/cmn/main.h>
|
||||
#include <qse/cmn/mbwc.h>
|
||||
#include <qse/cmn/stdio.h>
|
||||
|
||||
#include <locale.h>
|
||||
#if defined(_WIN32)
|
||||
# include <windows.h>
|
||||
#endif
|
||||
|
||||
static void xxx (const qse_wchar_t* ptr, qse_size_t len)
|
||||
{
|
||||
if (ptr)
|
||||
{
|
||||
qse_size_t i;
|
||||
qse_printf (QSE_T(" ["));
|
||||
for (i = 0; i < len; i++)
|
||||
qse_printf (QSE_T("%hc"), ptr[i]);
|
||||
qse_printf (QSE_T("] "));
|
||||
}
|
||||
else
|
||||
{
|
||||
qse_printf (QSE_T(" (null) "));
|
||||
}
|
||||
}
|
||||
|
||||
static int test_main (int argc, qse_char_t* argv[], qse_char_t* envp[])
|
||||
{
|
||||
static const qse_wchar_t* wcs[] =
|
||||
{
|
||||
QSE_WT("http://www.google.com"),
|
||||
QSE_WT("http://www.google.com:80"),
|
||||
QSE_WT("http://abc@www.google.com:80"),
|
||||
QSE_WT("http://abc:def@www.google.com:80"),
|
||||
QSE_WT("http://abc:def@www.google.com:80/"),
|
||||
QSE_WT("http://abc:def@www.google.com:80/?#"),
|
||||
QSE_WT("http://abc:def@www.google.com:80/abcdef/ghi?kkk=23#fragment"),
|
||||
QSE_WT("http://abc:def@www.google.com:80/abcdef/ghi#fragment#fragment"),
|
||||
QSE_WT("http://abc:def@www@.google.com:80/abcdef/ghi#fragment#fragment"),
|
||||
QSE_WT("http://@@@@@abc:def@www@.google.com:80/abcdef/ghi#fragment#fragment")
|
||||
};
|
||||
|
||||
qse_size_t i;
|
||||
qse_uri_t uri;
|
||||
|
||||
for (i = 0; i < QSE_COUNTOF(wcs); i++)
|
||||
{
|
||||
qse_printf (QSE_T("[%ls] => "), wcs[i]);
|
||||
if (qse_wcstouri (wcs[i], &uri, 0) <= -1)
|
||||
{
|
||||
qse_printf (QSE_T("[ERROR]"));
|
||||
}
|
||||
else
|
||||
{
|
||||
xxx (uri.scheme.ptr, uri.scheme.len);
|
||||
xxx (uri.auth.user.ptr, uri.auth.user.len);
|
||||
xxx (uri.auth.pass.ptr, uri.auth.pass.len);
|
||||
xxx (uri.host.ptr, uri.host.len);
|
||||
xxx (uri.port.ptr, uri.port.len);
|
||||
xxx (uri.path.ptr, uri.path.len);
|
||||
xxx (uri.query.ptr, uri.query.len);
|
||||
xxx (uri.frag.ptr, uri.frag.len);
|
||||
}
|
||||
qse_printf (QSE_T("\n"));
|
||||
}
|
||||
|
||||
qse_printf (QSE_T("================================================\n"));
|
||||
|
||||
for (i = 0; i < QSE_COUNTOF(wcs); i++)
|
||||
{
|
||||
qse_printf (QSE_T("[%ls] => "), wcs[i]);
|
||||
if (qse_wcstouri (wcs[i], &uri, QSE_WCSTOURI_NOQUERY | QSE_WCSTOURI_NOAUTH) <= -1)
|
||||
{
|
||||
qse_printf (QSE_T("[ERROR]"));
|
||||
}
|
||||
else
|
||||
{
|
||||
xxx (uri.scheme.ptr, uri.scheme.len);
|
||||
xxx (uri.auth.user.ptr, uri.auth.user.len);
|
||||
xxx (uri.auth.pass.ptr, uri.auth.pass.len);
|
||||
xxx (uri.host.ptr, uri.host.len);
|
||||
xxx (uri.port.ptr, uri.port.len);
|
||||
xxx (uri.path.ptr, uri.path.len);
|
||||
xxx (uri.query.ptr, uri.query.len);
|
||||
xxx (uri.frag.ptr, uri.frag.len);
|
||||
}
|
||||
qse_printf (QSE_T("\n"));
|
||||
}
|
||||
|
||||
qse_printf (QSE_T("================================================\n"));
|
||||
|
||||
for (i = 0; i < QSE_COUNTOF(wcs); i++)
|
||||
{
|
||||
qse_printf (QSE_T("[%ls] => "), wcs[i]);
|
||||
if (qse_wcstouri (wcs[i], &uri, QSE_WCSTOURI_NOQUERY | QSE_WCSTOURI_NOAUTH | QSE_WCSTOURI_NOFRAG) <= -1)
|
||||
{
|
||||
qse_printf (QSE_T("[ERROR]"));
|
||||
}
|
||||
else
|
||||
{
|
||||
xxx (uri.scheme.ptr, uri.scheme.len);
|
||||
xxx (uri.auth.user.ptr, uri.auth.user.len);
|
||||
xxx (uri.auth.pass.ptr, uri.auth.pass.len);
|
||||
xxx (uri.host.ptr, uri.host.len);
|
||||
xxx (uri.port.ptr, uri.port.len);
|
||||
xxx (uri.path.ptr, uri.path.len);
|
||||
xxx (uri.query.ptr, uri.query.len);
|
||||
xxx (uri.frag.ptr, uri.frag.len);
|
||||
}
|
||||
qse_printf (QSE_T("\n"));
|
||||
}
|
||||
|
||||
qse_printf (QSE_T("================================================\n"));
|
||||
return 0;
|
||||
}
|
||||
|
||||
int qse_main (int argc, qse_achar_t* argv[], qse_achar_t* envp[])
|
||||
{
|
||||
#if defined(_WIN32)
|
||||
char locale[100];
|
||||
UINT codepage = GetConsoleOutputCP();
|
||||
if (codepage == CP_UTF8)
|
||||
{
|
||||
/*SetConsoleOUtputCP (CP_UTF8);*/
|
||||
qse_setdflcmgr (qse_utf8cmgr);
|
||||
}
|
||||
else
|
||||
{
|
||||
sprintf (locale, ".%u", (unsigned int)codepage);
|
||||
setlocale (LC_ALL, locale);
|
||||
qse_setdflcmgrbyid (QSE_CMGR_SLMB);
|
||||
}
|
||||
#else
|
||||
setlocale (LC_ALL, "");
|
||||
qse_setdflcmgrbyid (QSE_CMGR_SLMB);
|
||||
#endif
|
||||
return qse_runmainwithenv (argc, argv, envp, test_main);
|
||||
}
|
||||
|
@ -55,6 +55,7 @@ static void sigint (int sig)
|
||||
}
|
||||
|
||||
/* --------------------------------------------------------------------- */
|
||||
#if 0
|
||||
static qse_httpd_server_t* attach_server (qse_httpd_t* httpd, const qse_char_t* uri)
|
||||
{
|
||||
qse_httpd_server_t server, * xserver;
|
||||
@ -93,6 +94,7 @@ static qse_httpd_server_t* attach_server (qse_httpd_t* httpd, const qse_char_t*
|
||||
|
||||
return xserver;
|
||||
}
|
||||
#endif
|
||||
|
||||
/* --------------------------------------------------------------------- */
|
||||
static int httpd_main (int argc, qse_char_t* argv[])
|
||||
@ -116,7 +118,7 @@ static int httpd_main (int argc, qse_char_t* argv[])
|
||||
|
||||
for (i = 1; i < argc; i++)
|
||||
{
|
||||
if (attach_server (httpd, argv[i]) == QSE_NULL)
|
||||
if (qse_httpd_attachserverstd (httpd, argv[i], 0) == QSE_NULL)
|
||||
{
|
||||
qse_fprintf (QSE_STDERR,
|
||||
QSE_T("Failed to add httpd listener - %s\n"), argv[i]);
|
||||
|
Reference in New Issue
Block a user