added QSE_GLOB_TOLERANT
enhanced check for __int128_t added qse_getnwifcfg() added qse_skad_t, qse_skadtonwad(), qse_nwadtoskad() added more checks to configure.ac
This commit is contained in:
		@ -25,6 +25,8 @@ bin_PROGRAMS = \
 | 
			
		||||
	mbwc01 \
 | 
			
		||||
	mbwc02 \
 | 
			
		||||
	nwad01 \
 | 
			
		||||
	nwif01 \
 | 
			
		||||
	nwif02 \
 | 
			
		||||
	oht \
 | 
			
		||||
	path01 \
 | 
			
		||||
	pio \
 | 
			
		||||
 | 
			
		||||
@ -38,11 +38,12 @@ bin_PROGRAMS = chr01$(EXEEXT) env$(EXEEXT) dll$(EXEEXT) fio01$(EXEEXT) \
 | 
			
		||||
	fio02$(EXEEXT) fma$(EXEEXT) fmt01$(EXEEXT) fmt02$(EXEEXT) \
 | 
			
		||||
	fs01$(EXEEXT) htb$(EXEEXT) glob01$(EXEEXT) ipad01$(EXEEXT) \
 | 
			
		||||
	lda$(EXEEXT) main01$(EXEEXT) main02$(EXEEXT) mbwc01$(EXEEXT) \
 | 
			
		||||
	mbwc02$(EXEEXT) nwad01$(EXEEXT) oht$(EXEEXT) path01$(EXEEXT) \
 | 
			
		||||
	pio$(EXEEXT) pma$(EXEEXT) rex01$(EXEEXT) rbt$(EXEEXT) \
 | 
			
		||||
	sio01$(EXEEXT) sio02$(EXEEXT) sio03$(EXEEXT) sll$(EXEEXT) \
 | 
			
		||||
	slmb01$(EXEEXT) str01$(EXEEXT) task01$(EXEEXT) time$(EXEEXT) \
 | 
			
		||||
	tre01$(EXEEXT) uri01$(EXEEXT) xma$(EXEEXT)
 | 
			
		||||
	mbwc02$(EXEEXT) nwad01$(EXEEXT) nwif01$(EXEEXT) \
 | 
			
		||||
	nwif02$(EXEEXT) oht$(EXEEXT) path01$(EXEEXT) pio$(EXEEXT) \
 | 
			
		||||
	pma$(EXEEXT) rex01$(EXEEXT) rbt$(EXEEXT) sio01$(EXEEXT) \
 | 
			
		||||
	sio02$(EXEEXT) sio03$(EXEEXT) sll$(EXEEXT) slmb01$(EXEEXT) \
 | 
			
		||||
	str01$(EXEEXT) task01$(EXEEXT) time$(EXEEXT) tre01$(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
 | 
			
		||||
@ -135,6 +136,14 @@ am_nwad01_OBJECTS = nwad01.$(OBJEXT)
 | 
			
		||||
nwad01_OBJECTS = $(am_nwad01_OBJECTS)
 | 
			
		||||
nwad01_LDADD = $(LDADD)
 | 
			
		||||
nwad01_DEPENDENCIES = $(am__DEPENDENCIES_2)
 | 
			
		||||
nwif01_SOURCES = nwif01.c
 | 
			
		||||
nwif01_OBJECTS = nwif01.$(OBJEXT)
 | 
			
		||||
nwif01_LDADD = $(LDADD)
 | 
			
		||||
nwif01_DEPENDENCIES = $(am__DEPENDENCIES_2)
 | 
			
		||||
nwif02_SOURCES = nwif02.c
 | 
			
		||||
nwif02_OBJECTS = nwif02.$(OBJEXT)
 | 
			
		||||
nwif02_LDADD = $(LDADD)
 | 
			
		||||
nwif02_DEPENDENCIES = $(am__DEPENDENCIES_2)
 | 
			
		||||
am_oht_OBJECTS = oht.$(OBJEXT)
 | 
			
		||||
oht_OBJECTS = $(am_oht_OBJECTS)
 | 
			
		||||
oht_LDADD = $(LDADD)
 | 
			
		||||
@ -221,23 +230,23 @@ SOURCES = $(chr01_SOURCES) $(dll_SOURCES) $(env_SOURCES) \
 | 
			
		||||
	$(fmt01_SOURCES) $(fmt02_SOURCES) $(fs01_SOURCES) \
 | 
			
		||||
	$(glob01_SOURCES) $(htb_SOURCES) $(ipad01_SOURCES) \
 | 
			
		||||
	$(lda_SOURCES) $(main01_SOURCES) $(main02_SOURCES) \
 | 
			
		||||
	$(mbwc01_SOURCES) $(mbwc02_SOURCES) $(nwad01_SOURCES) \
 | 
			
		||||
	$(oht_SOURCES) $(path01_SOURCES) $(pio_SOURCES) $(pma_SOURCES) \
 | 
			
		||||
	$(rbt_SOURCES) $(rex01_SOURCES) $(sio01_SOURCES) \
 | 
			
		||||
	$(sio02_SOURCES) $(sio03_SOURCES) $(sll_SOURCES) \
 | 
			
		||||
	$(slmb01_SOURCES) $(str01_SOURCES) task01.c $(time_SOURCES) \
 | 
			
		||||
	$(tre01_SOURCES) uri01.c $(xma_SOURCES)
 | 
			
		||||
	$(mbwc01_SOURCES) $(mbwc02_SOURCES) $(nwad01_SOURCES) nwif01.c \
 | 
			
		||||
	nwif02.c $(oht_SOURCES) $(path01_SOURCES) $(pio_SOURCES) \
 | 
			
		||||
	$(pma_SOURCES) $(rbt_SOURCES) $(rex01_SOURCES) \
 | 
			
		||||
	$(sio01_SOURCES) $(sio02_SOURCES) $(sio03_SOURCES) \
 | 
			
		||||
	$(sll_SOURCES) $(slmb01_SOURCES) $(str01_SOURCES) task01.c \
 | 
			
		||||
	$(time_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) \
 | 
			
		||||
	$(glob01_SOURCES) $(htb_SOURCES) $(ipad01_SOURCES) \
 | 
			
		||||
	$(lda_SOURCES) $(main01_SOURCES) $(main02_SOURCES) \
 | 
			
		||||
	$(mbwc01_SOURCES) $(mbwc02_SOURCES) $(nwad01_SOURCES) \
 | 
			
		||||
	$(oht_SOURCES) $(path01_SOURCES) $(pio_SOURCES) $(pma_SOURCES) \
 | 
			
		||||
	$(rbt_SOURCES) $(rex01_SOURCES) $(sio01_SOURCES) \
 | 
			
		||||
	$(sio02_SOURCES) $(sio03_SOURCES) $(sll_SOURCES) \
 | 
			
		||||
	$(slmb01_SOURCES) $(str01_SOURCES) task01.c $(time_SOURCES) \
 | 
			
		||||
	$(tre01_SOURCES) uri01.c $(xma_SOURCES)
 | 
			
		||||
	$(mbwc01_SOURCES) $(mbwc02_SOURCES) $(nwad01_SOURCES) nwif01.c \
 | 
			
		||||
	nwif02.c $(oht_SOURCES) $(path01_SOURCES) $(pio_SOURCES) \
 | 
			
		||||
	$(pma_SOURCES) $(rbt_SOURCES) $(rex01_SOURCES) \
 | 
			
		||||
	$(sio01_SOURCES) $(sio02_SOURCES) $(sio03_SOURCES) \
 | 
			
		||||
	$(sll_SOURCES) $(slmb01_SOURCES) $(str01_SOURCES) task01.c \
 | 
			
		||||
	$(time_SOURCES) $(tre01_SOURCES) uri01.c $(xma_SOURCES)
 | 
			
		||||
ETAGS = etags
 | 
			
		||||
CTAGS = ctags
 | 
			
		||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
 | 
			
		||||
@ -583,6 +592,12 @@ mbwc02$(EXEEXT): $(mbwc02_OBJECTS) $(mbwc02_DEPENDENCIES) $(EXTRA_mbwc02_DEPENDE
 | 
			
		||||
nwad01$(EXEEXT): $(nwad01_OBJECTS) $(nwad01_DEPENDENCIES) $(EXTRA_nwad01_DEPENDENCIES) 
 | 
			
		||||
	@rm -f nwad01$(EXEEXT)
 | 
			
		||||
	$(LINK) $(nwad01_OBJECTS) $(nwad01_LDADD) $(LIBS)
 | 
			
		||||
nwif01$(EXEEXT): $(nwif01_OBJECTS) $(nwif01_DEPENDENCIES) $(EXTRA_nwif01_DEPENDENCIES) 
 | 
			
		||||
	@rm -f nwif01$(EXEEXT)
 | 
			
		||||
	$(LINK) $(nwif01_OBJECTS) $(nwif01_LDADD) $(LIBS)
 | 
			
		||||
nwif02$(EXEEXT): $(nwif02_OBJECTS) $(nwif02_DEPENDENCIES) $(EXTRA_nwif02_DEPENDENCIES) 
 | 
			
		||||
	@rm -f nwif02$(EXEEXT)
 | 
			
		||||
	$(LINK) $(nwif02_OBJECTS) $(nwif02_LDADD) $(LIBS)
 | 
			
		||||
oht$(EXEEXT): $(oht_OBJECTS) $(oht_DEPENDENCIES) $(EXTRA_oht_DEPENDENCIES) 
 | 
			
		||||
	@rm -f oht$(EXEEXT)
 | 
			
		||||
	$(LINK) $(oht_OBJECTS) $(oht_LDADD) $(LIBS)
 | 
			
		||||
@ -659,6 +674,8 @@ distclean-compile:
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mbwc01.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/mbwc02.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/nwad01.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/nwif01.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/nwif02.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/oht.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/path01.Po@am__quote@
 | 
			
		||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pio.Po@am__quote@
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										90
									
								
								qse/samples/cmn/nwif01.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								qse/samples/cmn/nwif01.c
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,90 @@
 | 
			
		||||
#include <qse/cmn/nwif.h>
 | 
			
		||||
#include <qse/cmn/mbwc.h>
 | 
			
		||||
#include <qse/cmn/main.h>
 | 
			
		||||
#include <qse/cmn/stdio.h>
 | 
			
		||||
#include <qse/cmn/mem.h>
 | 
			
		||||
#include <qse/cmn/str.h>
 | 
			
		||||
 | 
			
		||||
#include <locale.h>
 | 
			
		||||
#if defined(_WIN32)
 | 
			
		||||
#	include <windows.h>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
static void print_nwifcfg (qse_nwifcfg_t* ptr)
 | 
			
		||||
{
 | 
			
		||||
	qse_char_t tmp[128];
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("[%s] ifindex=[%u] "), ptr->name, ptr->index);
 | 
			
		||||
		
 | 
			
		||||
	qse_nwadtostr (&ptr->addr, tmp, QSE_COUNTOF(tmp), QSE_NWADTOSTR_ALL);
 | 
			
		||||
	qse_printf (QSE_T("addr=[%s] "), tmp);
 | 
			
		||||
	qse_nwadtostr (&ptr->mask, tmp, QSE_COUNTOF(tmp), QSE_NWADTOSTR_ALL);
 | 
			
		||||
	qse_printf (QSE_T("mask=[%s] "), tmp);
 | 
			
		||||
 | 
			
		||||
	if (ptr->flags & QSE_NWIFCFG_BCAST)
 | 
			
		||||
	{
 | 
			
		||||
		qse_nwadtostr (&ptr->bcast, tmp, QSE_COUNTOF(tmp), QSE_NWADTOSTR_ALL);
 | 
			
		||||
		qse_printf (QSE_T("bcast=[%s] "), tmp);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("mtu=[%d] "), (int)ptr->mtu);
 | 
			
		||||
	qse_printf (QSE_T("\n"));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int test_main (int argc, qse_char_t* argv[])
 | 
			
		||||
{
 | 
			
		||||
	qse_char_t name[100];
 | 
			
		||||
	unsigned int index;
 | 
			
		||||
	int i;
 | 
			
		||||
 | 
			
		||||
	for (i = 1; ;i++)
 | 
			
		||||
	{
 | 
			
		||||
		if (qse_nwifindextostr (i, name, QSE_COUNTOF(name)) <= -1) 
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("ifindex %d failed\n"), i);
 | 
			
		||||
			break;
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		index = qse_nwifstrtoindex (name);
 | 
			
		||||
		if (index == 0)
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("ifname %s failed\n"), name);
 | 
			
		||||
			break;
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		if (i != index)
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("index mismatch %d %d %s\n"), i, index, name);
 | 
			
		||||
			break;
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		qse_printf (QSE_T("OK %d %s\n"), index, name);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("================================================\n"));
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int qse_main (int argc, qse_achar_t* argv[])
 | 
			
		||||
{
 | 
			
		||||
#if defined(_WIN32)
 | 
			
		||||
	char locale[100];
 | 
			
		||||
	UINT codepage = GetConsoleOutputCP();	
 | 
			
		||||
	if (codepage == CP_UTF8)
 | 
			
		||||
	{
 | 
			
		||||
		/*SetConsoleOutputCP (CP_UTF8);*/
 | 
			
		||||
		qse_setdflcmgrbyid (QSE_CMGR_UTF8);
 | 
			
		||||
	}
 | 
			
		||||
	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_runmain (argc, argv, test_main);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										92
									
								
								qse/samples/cmn/nwif02.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								qse/samples/cmn/nwif02.c
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,92 @@
 | 
			
		||||
#include <qse/cmn/nwif.h>
 | 
			
		||||
#include <qse/cmn/mbwc.h>
 | 
			
		||||
#include <qse/cmn/main.h>
 | 
			
		||||
#include <qse/cmn/stdio.h>
 | 
			
		||||
#include <qse/cmn/mem.h>
 | 
			
		||||
#include <qse/cmn/str.h>
 | 
			
		||||
 | 
			
		||||
#include <locale.h>
 | 
			
		||||
#if defined(_WIN32)
 | 
			
		||||
#	include <windows.h>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
static void print_nwifcfg (qse_nwifcfg_t* ptr)
 | 
			
		||||
{
 | 
			
		||||
	qse_char_t tmp[128];
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("[%s] ifindex=[%u] "), ptr->name, ptr->index);
 | 
			
		||||
		
 | 
			
		||||
	qse_nwadtostr (&ptr->addr, tmp, QSE_COUNTOF(tmp), QSE_NWADTOSTR_ALL);
 | 
			
		||||
	qse_printf (QSE_T("addr=[%s] "), tmp);
 | 
			
		||||
	qse_nwadtostr (&ptr->mask, tmp, QSE_COUNTOF(tmp), QSE_NWADTOSTR_ALL);
 | 
			
		||||
	qse_printf (QSE_T("mask=[%s] "), tmp);
 | 
			
		||||
 | 
			
		||||
	if (ptr->flags & QSE_NWIFCFG_BCAST)
 | 
			
		||||
	{
 | 
			
		||||
		qse_nwadtostr (&ptr->bcast, tmp, QSE_COUNTOF(tmp), QSE_NWADTOSTR_ALL);
 | 
			
		||||
		qse_printf (QSE_T("bcast=[%s] "), tmp);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	qse_printf (QSE_T("mtu=[%d] "), (int)ptr->mtu);
 | 
			
		||||
	qse_printf (QSE_T("\n"));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int test_main (int argc, qse_char_t* argv[])
 | 
			
		||||
{
 | 
			
		||||
	qse_nwifcfg_t cfg;
 | 
			
		||||
	int i;
 | 
			
		||||
 | 
			
		||||
	for (i = 1; ;i++)
 | 
			
		||||
	{
 | 
			
		||||
		if (qse_nwifindextostr (i, cfg.name, QSE_COUNTOF(cfg.name)) <= -1) 
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("ifindex %d failed for IN4\n"), i);
 | 
			
		||||
			break;
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		cfg.type = QSE_NWIFCFG_IN4;
 | 
			
		||||
		if (qse_getnwifcfg (&cfg) <= -1)
 | 
			
		||||
			qse_printf (QSE_T("Cannot get v4 configuration - %s\n"), cfg.name);
 | 
			
		||||
		else print_nwifcfg (&cfg);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	for (i = 1; ;i++)
 | 
			
		||||
	{
 | 
			
		||||
		if (qse_nwifindextostr (i, cfg.name, QSE_COUNTOF(cfg.name)) <= -1) 
 | 
			
		||||
		{
 | 
			
		||||
			qse_printf (QSE_T("ifindex %d failed for IN6\n"), i);
 | 
			
		||||
			break;
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		cfg.type = QSE_NWIFCFG_IN6;
 | 
			
		||||
		if (qse_getnwifcfg (&cfg) <= -1)
 | 
			
		||||
			qse_printf (QSE_T("Cannot get v6 configuration - %s\n"), cfg.name);
 | 
			
		||||
		else print_nwifcfg (&cfg);
 | 
			
		||||
	}
 | 
			
		||||
	qse_printf (QSE_T("================================================\n"));
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int qse_main (int argc, qse_achar_t* argv[])
 | 
			
		||||
{
 | 
			
		||||
#if defined(_WIN32)
 | 
			
		||||
	char locale[100];
 | 
			
		||||
	UINT codepage = GetConsoleOutputCP();	
 | 
			
		||||
	if (codepage == CP_UTF8)
 | 
			
		||||
	{
 | 
			
		||||
		/*SetConsoleOutputCP (CP_UTF8);*/
 | 
			
		||||
		qse_setdflcmgrbyid (QSE_CMGR_UTF8);
 | 
			
		||||
	}
 | 
			
		||||
	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_runmain (argc, argv, test_main);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user