⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 netbyte.cpp

📁 linux下的一款播放器
💻 CPP
字号:
/* ***** BEGIN LICENSE BLOCK ***** * Source last modified: $Id: netbyte.cpp,v 1.6.28.3 2004/07/09 01:48:16 hubbe Exp $ *  * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved. *  * The contents of this file, and the files included with this file, * are subject to the current version of the RealNetworks Public * Source License (the "RPSL") available at * http://www.helixcommunity.org/content/rpsl unless you have licensed * the file under the current version of the RealNetworks Community * Source License (the "RCSL") available at * http://www.helixcommunity.org/content/rcsl, in which case the RCSL * will apply. You may also obtain the license terms directly from * RealNetworks.  You may not use this file except in compliance with * the RPSL or, if you have a valid RCSL with RealNetworks applicable * to this file, the RCSL.  Please see the applicable RPSL or RCSL for * the rights, obligations and limitations governing use of the * contents of the file. *  * Alternatively, the contents of this file may be used under the * terms of the GNU General Public License Version 2 or later (the * "GPL") in which case the provisions of the GPL are applicable * instead of those above. If you wish to allow use of your version of * this file only under the terms of the GPL, and not to allow others * to use your version of this file under the terms of either the RPSL * or RCSL, indicate your decision by deleting the provisions above * and replace them with the notice and other provisions required by * the GPL. If you do not delete the provisions above, a recipient may * use your version of this file under the terms of any one of the * RPSL, the RCSL or the GPL. *  * This file is part of the Helix DNA Technology. RealNetworks is the * developer of the Original Code and owns the copyrights in the * portions it created. *  * This file, and the files included with this file, is distributed * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET * ENJOYMENT OR NON-INFRINGEMENT. *  * Technology Compatibility Kit Test Suite(s) Location: *    http://www.helixcommunity.org/content/tck *  * Contributor(s): *  * ***** END LICENSE BLOCK ***** */#include "hxcom.h"#include "hlxclib/ctype.h"#include "safestring.h"#include "netbyte.h"#include "hxtypes.h"#include "ihxpckts.h"#include "hxbuffer.h"#ifdef _MACINTOSH#include "hxstrutl.h" // for isascii definition#endif#include "hxheap.h"#ifdef _DEBUG#undef HX_THIS_FILE		static const char HX_THIS_FILE[] = __FILE__;#endif#ifndef INADDR_NONE#define INADDR_NONE -1#endif#if defined(HELIX_CONFIG_NOSTATICS)# include "globals/hxglobals.h"#endif#if defined(HELIX_CONFIG_NOSTATICS)# define STATIC_CHAR_ARRAY(name, length) \    static const char _##name = '\0'; \    char*& str = (char*&)HXGlobalCharArray::Get(&_##name, length, "" );#else    # define STATIC_CHAR_ARRAY(name, length) static char name[length];#endif /* HELIX_CONFIG_NOSTATICS */#ifndef NET_ENDIANNetWord WToNet(HostWord wHost) {		/* Hopefully, a portable implementation		** (although it's unnecessary labor on a		** non-swapped machine) 		*/		NetWord wNet;		unsigned char *uc = (unsigned char *)&wNet;		*uc++ = (unsigned char) ((wHost & 0xFF00) >> 8);		*uc++ = (unsigned char) (wHost & 0x00FF);		return wNet;} 	HostWord WToHost(NetWord wNet) {		HostWord wHost;		unsigned char *uc = (unsigned char *)&wNet;		wHost = (*uc++) << 8;		wHost += (*uc++);		return wHost;}NetDWord DwToNet(HostDWord dwHost) {		NetDWord dwNet;		unsigned char *uc = (unsigned char *)&dwNet;		*uc++ = (unsigned char) ((dwHost & 0xFF000000L) >> 24);		*uc++ = (unsigned char) ((dwHost & 0x00FF0000L) >> 16);		*uc++ = (unsigned char) ((dwHost & 0x0000FF00L) >> 8);		*uc++ = (unsigned char) (dwHost & 0x000000FFL);		return dwNet;} 	HostDWord DwToHost(NetDWord dwNet) {		HostDWord dwHost;		unsigned char *uc = (unsigned char *)&dwNet;		dwHost = ((unsigned long)(*uc++)) << 24;		dwHost += ((unsigned long)(*uc++)) << 16;		dwHost += ((unsigned long)(*uc++)) << 8;		dwHost += (unsigned long)(*uc++);		return dwHost;}#endifint TestBigEndian(void){    unsigned long test = 0x000000FF;    char *temp = (char *)&test;    /* on big endian machines, the first byte should be 0x00, on little endian 0xFF.*/    return (temp[0] == 0);}/*  Converts 2 byte ints from big endian to little endian or vice versa */void SwapWordBytes(HostWord *data, int numInts){    INT32     i;    INT16  temp;    char    *temp1, *temp2;    /* temp2 points to our temporary int that will hold the swapped bytes */    temp2 = (char *) &temp;    for(i = 0; i < numInts; i++)    {	temp1 = (char *) &data[i];        temp2[0] = temp1[1];	temp2[1] = temp1[0];	data[i] = temp;    }}/*  Converts 4 byte ints from big endian to little endian or vice versa */void SwapDWordBytes(HostDWord *data, int numInts){    INT32     i,temp;    char    *temp1, *temp2;    /* temp2 points to our temporary int that will hold the swapped bytes */    temp2 = (char *) &temp;    for(i = 0; i < numInts; i++)    {	temp1 = (char *) &data[i];        temp2[0] = temp1[3];        temp2[1] = temp1[2];        temp2[2] = temp1[1];	temp2[3] = temp1[0];	data[i] = temp;    }}/* * IP domain addresses will NOT be recignized as valid addresses * even if they are specified as "99.99.234" or "99.234" */intIsNumericAddr(const char* addrStr, UINT32 size){    // check the params    if (NULL == addrStr || 0 == size)    {	return 0;    }        const char* ptr = (addrStr && size) ? addrStr+size-1 : 0;    int len = (int)size;    int numericAddr = 0;    int dotCount = 0;    if (isdigit(*ptr))        numericAddr = 1;    while (--len)    {        if (*ptr == '.')            dotCount++;        else if (isalpha(*ptr))            numericAddr = 0;        --ptr;    }    return (dotCount == 3) ? numericAddr : 0;}voidNetLongToAscii(UINT32 addr, IHXBuffer* pAddrBuf){    char str[16]; /* Flawfinder: ignore */  // max addr string length + NULL -- "255.255.255.255"    char* ptr = (char *)str;    char* prevStrEnd = 0;    SafeSprintf(ptr, sizeof(str), "%lu", ((addr&0xff000000) >> 24));    ptr = (char *)memchr(str, 0, 16);    prevStrEnd = ptr;    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%lu", ((addr&0x00ff0000) >> 16));    ptr = (char *)memchr(prevStrEnd, 0, 16);    prevStrEnd = ptr;    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%lu", ((addr&0x0000ff00) >> 8));    ptr = (char *)memchr(prevStrEnd, 0, 16);    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%lu", (addr&0x000000ff));    pAddrBuf->Set((BYTE *)str, strlen(str)+1);}// takes the addr in HOST-byte order!!!// its too late in the cycle to make this fundamental a change// so we r keeping it the samechar*HXInetNtoa(UINT32 addr){    STATIC_CHAR_ARRAY(str, 16); /* Flawfinder: ignore */ // max addr string length + NULL -- "255.255.255.255"    char* ptr = (char *)str;    char* prevStrEnd = 0;    SafeSprintf(ptr, sizeof(str), "%lu", ((addr&0xff000000) >> 24));    ptr = (char *)memchr(str, 0, 16);    prevStrEnd = ptr;    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%lu", ((addr&0x00ff0000) >> 16));    ptr = (char *)memchr(prevStrEnd, 0, 16);    prevStrEnd = ptr;    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%lu", ((addr&0x0000ff00) >> 8));    ptr = (char *)memchr(prevStrEnd, 0, 16);    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%lu", (addr&0x000000ff));    return str;}/** ++Copyright++ 1983, 1990, 1993* -* Copyright (c) 1983, 1990, 1993*    The Regents of the University of California.  All rights reserved.* * Redistribution and use in source and binary forms, with or without* modification, are permitted provided that the following conditions* are met:* 1. Redistributions of source code must retain the above copyright*    notice, this list of conditions and the following disclaimer.* 2. Redistributions in binary form must reproduce the above copyright*    notice, this list of conditions and the following disclaimer in the*    documentation and/or other materials provided with the distribution.* 3. All advertising materials mentioning features or use of this software*    must display the following acknowledgement:* This product includes software developed by the University of* California, Berkeley and its contributors.* 4. Neither the name of the University nor the names of its contributors*    may be used to endorse or promote products derived from this software*    without specific prior written permission.* * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE* ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF* SUCH DAMAGE.* -* Portions Copyright (c) 1993 by Digital Equipment Corporation.* * Permission to use, copy, modify, and distribute this software for any* purpose with or without fee is hereby granted, provided that the above* copyright notice and this permission notice appear in all copies, and that* the name of Digital Equipment Corporation not be used in advertising or* publicity pertaining to distribution of the document or software without* specific, written prior permission.* * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL* WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES* OF MERCHANTABILITY AND FITNESS.   IN NO EVENT SHALL DIGITAL EQUIPMENT* CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR* PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS* ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS* SOFTWARE.* -* --Copyright--*//** Ascii internet address interpretation routine.* The value returned is in network order.* Check whether "cp" is a valid ascii representation* of an Internet address and convert to a binary address.* Returns 1 if the address is valid, 0 if not.* This replaces inet_addr, the return value from which* cannot distinguish between failure and a local broadcast address.*/UINT32HXinet_addr(const char* cp){    UINT32 val = 0;    int base = 0, n = 0;    char c;    UINT parts[4];    UINT *pp = parts;    c = *cp;    for (;;)     {	/*	* Collect number up to ``.''.	* Values are specified as for C:	* 0x=hex, 0=octal, isdigit=decimal.	*/	if (!isdigit(c))	    return (INADDR_NONE);	val = 0; base = 10;	if (c == '0') 	{	    c = *++cp;	    if (c == 'x' || c == 'X')	    {		base = 16, c = *++cp;	    }	    else	    {		base = 8;	    }	}		for (;;) 	{	    if (isascii(c) && isdigit(c)) 	    {		val = (val * base) + (c - '0');		c = *++cp;	    } 	    else if (base == 16 && isascii(c) && isxdigit(c)) 	    {		val = (val << 4) | (c + 10 - (islower(c) ? 'a' : 'A'));		c = *++cp;	    } 	    else	    {		break;	    }	}	if (c == '.') 	{	    /*	    * Internet format:	    * a.b.c.d	    * a.b.c (with c treated as 16 bits)	    * a.b (with b treated as 24 bits)	    */	    if (pp >= parts + 3)	    {		return (INADDR_NONE);	    }	    *pp++ = val;	    c = *++cp;	} 	else	{	    break;	}    }    /*    * Check for trailing characters.    */    if (c != '\0' && (!isascii(c) || !isspace(c)))    {	return (INADDR_NONE);    }    /*    * Concoct the address according to    * the number of parts specified.    */    n = pp - parts + 1;    switch (n)     {	case 0:	    return (INADDR_NONE); /* initial nondigit */	case 1: /* a -- 32 bits */	    break;	case 2: /* a.b -- 8.24 bits */	    if (val > 0xffffff)		return (INADDR_NONE);	    val |= parts[0] << 24;	    break;	case 3: /* a.b.c -- 8.8.16 bits */	    if (val > 0xffff)		return (INADDR_NONE);	    val |= (parts[0] << 24) | (parts[1] << 16);	    break;	case 4: /* a.b.c.d -- 8.8.8.8 bits */	    if (val > 0xff)		return (INADDR_NONE);	    val |= (parts[0] << 24) | (parts[1] << 16) | (parts[2] << 8);	    break;    }    return DwToNet(val);}// to store actual netbyte order of bytes in a string// on a little endian machine basically swap the byteschar*NetLongAddrToDecimalStr(ULONG32 ulAddr){    STATIC_CHAR_ARRAY(str, 11);/* Flawfinder: ignore */ // max decimal digits (4 Gig) for a 4-byte number    unsigned long test = 0x000000FF;    char *temp = (char *)&test;    if (temp[0] != 0x0) // big-endian    {	ULONG32 addr = 0;	char* temp1 = (char *)&addr;	temp = (char *)&ulAddr;	temp1[0] = temp[3];	temp1[1] = temp[2];	temp1[2] = temp[1];	temp1[3] = temp[0];	SafeSprintf(str, sizeof(str), "%lu", (unsigned long)addr);    }    else    {	SafeSprintf(str, sizeof(str), "%lu", (unsigned long)ulAddr);    }    return str;}char*NetLongToAsciiStr(UINT32 addr){    STATIC_CHAR_ARRAY(str, 16);/* Flawfinder: ignore */ // max addr string length + NULL -- "255.255.255.255"    UCHAR* tmp = (UCHAR *)&addr;    char* ptr = (char *)str;    char* prevStrEnd = 0;    SafeSprintf(ptr, sizeof(str), "%u", tmp[0]);    ptr = (char *)memchr(str, 0, 16);    prevStrEnd = ptr;    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%u", tmp[1]);    ptr = (char *)memchr(str, 0, 16);    prevStrEnd = ptr;    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%u", tmp[2]);    ptr = (char *)memchr(str, 0, 16);    prevStrEnd = ptr;    SafeSprintf(ptr, sizeof(str)-(ptr-str), ".%u", tmp[3]);    return str;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -