aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorStefan Saraev <stefan@saraev.ca>2015-03-22 22:58:17 +0200
committerStefan Saraev <stefan@saraev.ca>2015-04-01 19:35:42 +0300
commit35288b96af7513c677a7a2a55d4cab47ea1c0e6f (patch)
tree987e1a5f5c1a042fa7b88ce9c7623a900fa92bf6 /lib
parentf4ad529a6a7b59eff19ca1932d283a79ac4868ff (diff)
[replaytv] remove replaytv support
Diffstat (limited to 'lib')
-rw-r--r--lib/libRTV/GuideParser.cpp1588
-rw-r--r--lib/libRTV/GuideParser.h7
-rw-r--r--lib/libRTV/Makefile.in9
-rw-r--r--lib/libRTV/crypt.c216
-rw-r--r--lib/libRTV/crypt.h29
-rw-r--r--lib/libRTV/guideclient.c128
-rw-r--r--lib/libRTV/guideclient.h27
-rw-r--r--lib/libRTV/httpclient.c494
-rw-r--r--lib/libRTV/httpclient.h95
-rw-r--r--lib/libRTV/httpfsclient.c401
-rw-r--r--lib/libRTV/httpfsclient.h79
-rw-r--r--lib/libRTV/interface.c363
-rw-r--r--lib/libRTV/interface.h33
-rwxr-xr-xlib/libRTV/libRTV.libbin62010 -> 0 bytes
-rw-r--r--lib/libRTV/libRTV.sln30
-rw-r--r--lib/libRTV/libRTV.vcxproj98
-rw-r--r--lib/libRTV/libRTV.vcxproj.filters77
-rwxr-xr-xlib/libRTV/libRTVd.libbin152314 -> 0 bytes
-rw-r--r--lib/libRTV/md5.c337
-rw-r--r--lib/libRTV/md5.h24
-rw-r--r--lib/libRTV/netclient.c316
-rw-r--r--lib/libRTV/netclient.h29
-rw-r--r--lib/libRTV/rtv.c222
-rw-r--r--lib/libRTV/rtv.h85
-rw-r--r--lib/libRTV/sleep.c44
-rw-r--r--lib/libRTV/sleep.h22
26 files changed, 0 insertions, 4753 deletions
diff --git a/lib/libRTV/GuideParser.cpp b/lib/libRTV/GuideParser.cpp
deleted file mode 100644
index b70c45e1e6..0000000000
--- a/lib/libRTV/GuideParser.cpp
+++ /dev/null
@@ -1,1588 +0,0 @@
-
-/*
-** ReplayTV 5000
-** Guide Parser
-** by Lee Thompson <thompsonl@logh.net> Dan Frumin <rtv@frumin.com>, Todd Larason <jtl@molehill.org>
-**
-** This program is distributed in the hope that it will be useful,
-** but WITHOUT ANY WARRANTY; without even the implied warranty of
-** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-**
-** If you distribute a modified version of this program, the program MUST tell the user
-** in the usage summary how the program has been modified, and who performed the modification.
-** Modified source code MUST be distributed with the modified program.
-**
-** For additional detail on the Replay 4000/4500/5000 internals, protocols and structures I highly recommend
-** visiting Todd's site: http://www.molehill.org/twiki/bin/view/Replay/WebHome
-**
-***************************************************************************************************************
-**
-** IMPORTANT NOTE: This is the last version of GuideParser with this codebase.
-**
-** GuideParser was originally just a research project to learn the Guide Snapshot format. This research
-** phase is pretty much at a close and this code is very ugly.
-**
-** Others wishing to continue development of GuideParser with this code are welcome to do so under the above
-** limitations.
-**
-***************************************************************************************************************
-**
-** Revision History:
-**
-** 1.02 - LT Updated for 5.0 Software
-** 1.01 - LT ReplayTV 5000
-** 1.0 - LT Final version with this codebase.
-** Organized the structures a bit better.
-** Fixed some annoying bugs.
-** Added -combined option which does a mini replayChannel lookup, best used with -ls
-** .11 - LT Whoops! ReplayChannel had the wrong number for szThemeInfo, should've been 64 not 60! (Thanks Clem!)
-** Todd corrected a mis-assigned bitmask for TV rating "TV-G"
-** Todd's been knocking himself out with research... as a result no more unknowns in tagProgramInfo!
-** Added Genre lookups
-** .10 - LT Works on FreeBSD now (thanks Andy!)
-** Fixed a minor display bug.
-** Supports MPAA "G" ratings.
-** Added -d option for dumping unknowns as numbers.
-** Added -x (Xtra) option for displaying TMSIDs and so forth.
-** Added -nowrap to supress word wrap.
-** Added STDIN support!
-** Added Input Source lookup.
-** Better organized sub-structures.
-** Channel/Show Output now uses the word wrapper for everything.
-** Some minor tweaks.
-** Less unknowns. (Thanks in large part to Todd)
-** Released on Mar 10th 2002
-** .09 - LT Wrote an int64 Big->Small Endian converter.
-** UNIX/WIN32 stuff sorted out.
-** Cleaned up some code.
-** Dependency on stdafx.h removed.
-** Improved Word Wrapper.
-** Fixed some bugs.
-** Less unknowns.
-** Released on Jan 13th 2002
-** .08 - LT More fixes!
-** Better wordwrapping!
-** Less unknowns!
-** Released on Jan 10th 2002
-** .07 - LT Categories :)
-** Dan added the extraction command line switches and code.
-** Released on Jan 8th 2002
-** .06 - LT Timezone fixes
-** Released on Jan 5th 2002
-** .05 - LT Checking to see if guide file is damaged (some versions of ReplayPC have a problem in this area)
-** Found a case where GuideHeader.replayshows is not accurate!
-** Lots of other fixes.
-** Released on Jan 4th 2002
-** .04 - LT Day of Week implemented.
-** Categories are loaded but lookup isn't working.
-** .03 - LT Private build.
-** .02 - LT Private build.
-** .01 - LT Private build.
-** Initial Version
-** 01/03/2002
-**
-**
-***************************************************************************************************************
-**
-** TO DO:
-**
-** 1. Rewrite!
-**
-**
-** BUGS
-** Piping from replaypc to guideparser gets a few replaychannels in and somehow loses it's alignment -- looks
-** like the 'file' is being truncated.
-**
-***************************************************************************************************************
-** FreeBSD fixes by Andrew Tulloch <andrew@biliskner.demon.co.uk>
-***************************************************************************************************************
-*/
-
-#ifdef _XBOX
-#include <Xtl.h>
-#pragma pack(1) // don't use byte alignments on the structs
-#endif
-
-#ifdef _WIN32
-#if !defined(AFX_STDAFX_H__11AD8D81_EA54_4CD0_9A74_44F7170DE43F__INCLUDED_)
-#define AFX_STDAFX_H__11AD8D81_EA54_4CD0_9A74_44F7170DE43F__INCLUDED_
-#endif
-
-#if _MSC_VER > 1000
-#pragma once
-#endif // _MSC_VER > 1000
-
-#pragma pack(1) // don't use byte alignments on the structs
-
-#define WIN32_LEAN_AND_MEAN
-
-#if defined (_WIN32) && !defined(_XBOX)
-#include <winsock2.h>
-#endif
-
-#include <winnt.h>
-#include <winbase.h>
-#endif
-
-#if (defined(__unix__) || defined(__APPLE__))
-#include <netinet/in.h>
-#endif
-
-#include <string.h>
-#include <memory.h>
-#include <math.h>
-#include <stdio.h>
-#include <time.h>
-#include <fcntl.h>
-
-#if defined (_WIN32) && !defined(_XBOX)
-#pragma comment(lib, "ws2_32.lib") // load winsock2 (we only use it for endian conversion)
-#define FILEPOS fpos_t
-#endif
-
-#ifdef __APPLE__
-#include <AvailabilityMacros.h>
-#endif
-
-#if defined(__unix__) || defined(__APPLE__)
-typedef unsigned char BYTE;
-typedef unsigned long long DWORD64;
-typedef unsigned long DWORD;
-typedef unsigned short WORD;
-#define FILEPOS unsigned long
-#define _tzset() tzset()
-#define _tzname tzname
-#define _timezone timezone
-#define MoveMemory(dst,src,len) memmove(dst,src,len)
-#define HIWORD(x) (WORD)(x >> 16)
-#endif
-
-extern int _daylight;
-#if defined(__APPLE__) && (MAC_OS_X_VERSION_MAX_ALLOWED > 1040)
-extern long _timezone;
-#endif
-#ifndef _WIN32
-extern char *_tzname[2];
-#endif
-
-#define SHOWSTRUCTURESIZES 1 // this is for debugging...
-#undef SHOWSTRUCTURESIZES // ...uncomment this line for structure sizes to be shown
-
-// 5.0
-#define REPLAYSHOW 512 // needed size of replayshow structure
-#define GUIDEHEADER 840 // needed size of guideheader structure
-#define PROGRAMINFO 272 // needed size of programinfo structure
-#define CHANNELINFO 80 // needed size of channelinfo structure
-
-// 4.5
-#define GUIDEHEADER45 808 // needed size of guideheader structure
-
-// 4.3
-#define GUIDEHEADER43 808 // needed size of guideheader structure
-#define REPLAYSHOW43 444 // needed size of replayshow structure
-
-#define MAXCHANNELS 99
-
-#define lpszTitle "ReplayTV 5000 (Alpha) GuideParser v1.02 (Build 17)"
-#define lpszCopyright "(C) 2002 Lee Thompson, Dan Frumin, Todd Larason, and Andrew Tulloch"
-#define lpszComment ""
-
-//-------------------------------------------------------------------------
-// Data Structures
-//-------------------------------------------------------------------------
-
-//-------------------------------------------------------------------------
-//******************** COMMENTS *******************************************
-//-------------------------------------------------------------------------
-/*
-** General ReplayTV Notes
-**
-** The RTV4K/5K platforms are capable of supporting NTSC, PAL and SECAM so
-** in theory there may be one or more bytes always set a certain way as they
-** reflect NTSC.
-**
-** On the subject of recorded time: The ReplayTV units appear to
-** automatically pad shows by 3 seconds. e.g. If you schedule a show that
-** airs at 6:00 PM, the recording will actually begin at 5:59:57 PM.
-** Because of this, even an unpadded show will have a 3 second discrepency
-** between ReplayShow.recorded and ReplayShow.eventtime.
-**
-**
-** Categories
-**
-** There appears to be an *internal* maximum of 32 but the units appear
-** to only use 17 total.
-**
-** Secondary Offset (GuideHeader)
-**
-** If you jump to this absolute location this repeats the first 12 bytes of
-** this header, null terminates and then 4 unknown DWORDs.
-**
-** You will then be at the first byte of the first ReplayChannel record.
-**
-**
-** Genre Codes
-** Todd Larason's been slowly figuring these out, you can see the list at
-** http://www.molehill.org/twiki/bin/view/Replay/RnsGetCG2
-**
-*/
-
-/**************************************************************************
-**
-** GUIDE HEADER
-**
-**
-** Most of the unknowns in the GuideHeader are garbage/junk. Why
-** these aren't initialized to null I have no idea.
-**
-** They may also be a memory structure that has no meaning on a 'remote unit'.
-**
-**************************************************************************/
-
-// 5000 OS Version 5.0
-typedef struct tagGuideSnapshotHeader {
- WORD osversion; // OS Version (5 for 4.5, 3 for 4.3, 0 on 5.0)
- WORD snapshotversion; // Snapshot Version (1) (2 on 5.0) This might be better termed as snapshot version
- DWORD structuresize; // Should always be 64
- DWORD unknown1; // 0x00000002
- DWORD unknown2; // 0x00000005
- DWORD channelcount; // Number of Replay Channels
- DWORD channelcountcheck; // Should always be equal to channelcount, it's incremented as the snapshot is built.
- DWORD unknown3; // 0x00000000
- DWORD groupdataoffset; // Offset of Group Data
- DWORD channeloffset; // Offset of First Replay Channel (If you don't care about categories, jump to this)
- DWORD showoffset; // Offset of First Replay Show (If you don't care about ReplayChannels, jump to this)
- DWORD snapshotsize; // Total Size of the Snapshot
- DWORD unknown4; // 0x00000001
- DWORD unknown5; // 0x00000004
- DWORD flags; // Careful, this is uninitialized, ignore invalid bits
- DWORD unknown6; // 0x00000002
- DWORD unknown7; // 0x00000000
-} GuideSnapshotHeader;
-
-typedef struct tagGroupData {
- DWORD structuresize; // Should always be 776
- DWORD categories; // Number of Categories (MAX: 32 [ 0 - 31 ] )
- DWORD category[32]; // category lookup 2 ^ number, position order = text
- DWORD categoryoffset[32]; // Offsets for the GuideHeader.catbuffer
- char catbuffer[512]; // GuideHeader.categoryoffset contains the starting position of each category.
-} GroupData;
-
-typedef struct tagGuideHeader {
- struct tagGuideSnapshotHeader GuideSnapshotHeader;
- struct tagGroupData GroupData;
-} GuideHeader;
-
-// 4000 OS Version 4.3 / 5000 OS Version 4.5
-typedef struct tagGuideSnapshotHeader45 {
- WORD osversion; // Major Revision (5 for Replay5000s, 3 for Replay 4000/4500s)
- WORD snapshotversion; // Minor Revision (1)
- DWORD structuresize; // Should always be 32
- DWORD channelcount; // Number of Replay Channels
- DWORD channelcountcheck; // Number of Replay Channels (Copy 2; should always match)
- DWORD groupdataoffset; // Offset of Group Data
- DWORD channeloffset; // Offset of First Replay Channel (If you don't care about categories, jump to this)
- DWORD showoffset; // Offset of First Replay Show (If you don't care about ReplayChannels, jump to this)
- DWORD flags; // Careful, this is uninitialized, ignore invalid bits
-} GuideSnapshotHeader45;
-
-// GroupData structure is the same for 4.3/4.5 and 5.0
-
-typedef struct tagGuideHeader45 {
- struct tagGuideSnapshotHeader45 GuideSnapshotHeader;
- struct tagGroupData GroupData;
-} GuideHeader45;
-
-/*******************************************************************************
-**
-** SUB-STRUCTURES
-**
-*******************************************************************************/
-
-//-------------------------------------------------------------------------
-// Movie Extended Info Structure
-
-typedef struct tagMovieInfo {
- WORD mpaa; // MPAA Rating
- WORD stars; // Star Rating * 10 (i.e. value of 20 = 2 stars)
- WORD year; // Release Year
- WORD runtime; // Strange HH:MM format
-} MovieInfo;
-
-
-//-------------------------------------------------------------------------
-// Has Parts Info Structure
-
-typedef struct tagPartsInfo {
- WORD partnumber; // Part X [Of Y]
- WORD maxparts; // [Part X] Of Y
-} PartsInfo;
-
-
-//--------------------------------------------------------------------------
-// Program Info Structure
-
-typedef struct tagProgramInfo {
- DWORD structuresize; // Should always be 272 (0x0110)
- DWORD autorecord; // If non-zero it is an automatic recording, otherwise it is a manual recording.
- DWORD isvalid; // Not sure what it actually means! (should always be 1 in exported guide)
- DWORD tuning; // Tuning (Channel Number) for the Program
- DWORD flags; // Program Flags
- DWORD eventtime; // Scheduled Time of the Show
- DWORD tmsID; // Tribune Media Services ID (inherited from ChannelInfo)
- WORD minutes; // Minutes (add with show padding for total)
- BYTE genre1; // Genre Code 1
- BYTE genre2; // Genre Code 2
- BYTE genre3; // Genre Code 3
- BYTE genre4; // Genre Code 4
- WORD recLen; // Record Length of Description Block
- BYTE titleLen; // Length of Title
- BYTE episodeLen; // Length of Episode
- BYTE descriptionLen; // Length of Description
- BYTE actorLen; // Length of Actors
- BYTE guestLen; // Length of Guest
- BYTE suzukiLen; // Length of Suzuki String (Newer genre tags)
- BYTE producerLen; // Length of Producer
- BYTE directorLen; // Length of Director
- char szDescription[228]; // This can have parts/movie sub-structure
-} ProgramInfo;
-
-
-//--------------------------------------------------------------------------
-// Channel Info Structure
-
-typedef struct tagChannelInfo {
- DWORD structuresize; // Should always be 80 (0x50)
- DWORD usetuner; // If non-zero the tuner is used, otherwise it's a direct input.
- DWORD isvalid; // Record valid if non-zero
- DWORD tmsID; // Tribune Media Services ID
- WORD channel; // Channel Number
- BYTE device; // Device
- BYTE tier; // Cable/Satellite Service Tier
- char szChannelName[16]; // Channel Name
- char szChannelLabel[32]; // Channel Description
- char cablesystem[8]; // Cable system ID
- DWORD channelindex; // Channel Index (USUALLY tagChannelinfo.channel repeated)
-} ChannelInfo;
-
-
-/*******************************************************************************
-**
-** REPLAY SHOW
-**
-*******************************************************************************/
-
-typedef struct tagReplayShow {
- DWORD created; // ReplayChannel ID (tagReplayChannel.created)
- DWORD recorded; // Filename/Time of Recording (aka ShowID)
- DWORD inputsource; // Replay Input Source
- DWORD quality; // Recording Quality Level
- DWORD guaranteed; // (0xFFFFFFFF if guaranteed)
- DWORD playbackflags; // Not well understood yet.
- struct tagChannelInfo ChannelInfo;
- struct tagProgramInfo ProgramInfo;
- DWORD ivsstatus; // Always 1 in a snapshot outside of a tagReplayChannel
- DWORD guideid; // The show_id on the original ReplayTV for IVS shows. Otherwise 0
- DWORD downloadid; // Valid only during actual transfer of index or mpeg file; format/meaning still unknown
- DWORD timessent; // Times sent using IVS
- DWORD seconds; // Show Duration in Seconds (this is the exact actual length of the recording)
- DWORD GOP_count; // MPEG Group of Picture Count
- DWORD GOP_highest; // Highest GOP number seen, 0 on a snapshot.
- DWORD GOP_last; // Last GOP number seen, 0 on a snapshot.
- DWORD checkpointed; // 0 in possibly-out-of-date in-memory copies; always -1 in snapshots
- DWORD intact; // 0xffffffff in a snapshot; 0 means a deleted show
- DWORD upgradeflag; // Always 0 in a snapshot
- DWORD instance; // Episode Instance Counter (0 offset)
- WORD unused; // Not preserved when padding values are set, presumably not used
- BYTE beforepadding; // Before Show Padding
- BYTE afterpadding; // After Show Padding
- DWORD64 indexsize; // Size of NDX file (IVS Shows Only)
- DWORD64 mpegsize; // Size of MPG file (IVS Shows Only)
- char szReserved[68]; // Show Label (NOT PRESENT in 4k 4.3 version, work around it)
-} ReplayShow;
-
-
-//-------------------------------------------------------------------------
-// WIN32 Functions
-//-------------------------------------------------------------------------
-
-#ifdef _WIN32
-
-//-------------------------------------------------------------------------
-void UnixTimeToFileTime(time_t t, LPFILETIME pft)
-{
- LONGLONG ll;
-
- ll = Int32x32To64(t, 10000000) + 116444736000000000;
- pft->dwLowDateTime = (DWORD)ll;
- pft->dwHighDateTime = (DWORD)(ll >> 32);
-}
-
-
-//-------------------------------------------------------------------------
-void UnixTimeToSystemTime(time_t t, LPSYSTEMTIME pst)
-{
- FILETIME ft;
-
- UnixTimeToFileTime(t, &ft);
- FileTimeToSystemTime(&ft, pst);
-}
-
-//-------------------------------------------------------------------------
-char * UnixTimeToString(time_t t)
-{
- static char sbuf[17];
- char szTimeZone[32];
- SYSTEMTIME st;
- int tzbias;
-
- _tzset();
-
- memset(szTimeZone,0,sizeof(szTimeZone));
-
- MoveMemory(szTimeZone,_tzname[0],1);
- strcat(szTimeZone,"T");
-
-#if (MAC_OS_X_VERSION_MAX_ALLOWED <= 1040) && !defined(_WIN32)
- struct timezone tz;
- gettimeofday(NULL, &tz);
- tzbias = tz.tz_minuteswest;
-#else
- tzbias = _timezone;
-#endif
-
- UnixTimeToSystemTime(t - tzbias, &st);
- sprintf(sbuf, "%d-%.2d-%.2d %.2d:%.2d:%.2d",
- st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond);
- return sbuf;
-}
-
-
-#endif
-
-//-------------------------------------------------------------------------
-// UNIX Functions
-//-------------------------------------------------------------------------
-
-#if defined(__unix__) || defined(__APPLE__)
-char * UnixTimeToString(time_t t)
-{
- static char sbuf[17];
- struct tm * tm;
-
- tm = localtime(&t);
- strftime(sbuf, sizeof(sbuf), "%Y-%m-%d %H:%M:%S", tm);
- return sbuf;
-}
-#endif
-
-
-//-------------------------------------------------------------------------
-// Common Functions
-//-------------------------------------------------------------------------
-
-
-//-------------------------------------------------------------------------
-// Lookup Tables
-//-------------------------------------------------------------------------
-
-//-------------------------------------------------------------------------
-void DisplayQuality(int quality, char *szQuality)
-{
- switch( quality )
- {
- case 0:
- strcpy( szQuality, "High" );
- break;
- case 1:
- strcpy( szQuality, "Medium" );
- break;
- case 2:
- strcpy( szQuality, "Standard" );
- break;
- default:
- strcpy( szQuality, "" );
- break;
- }
-}
-
-//-------------------------------------------------------------------------
-void DisplayExtendedTVRating(int tvrating, char *szRating, bool append)
-{
-
- if (append == false)
- {
- strcpy( szRating, "");
- }
-
- if (tvrating & 0x00020000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
-
- strcat( szRating, "S" ); // Sex
- }
-
- if (tvrating & 0x00040000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
-
- strcat( szRating, "V" ); // Violence
- }
-
- if (tvrating & 0x00080000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
-
- strcat( szRating, "L" ); // Language
- }
-
- if (tvrating & 0x00100000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
-
- strcat( szRating, "D" ); // Drug Use
- }
-
- if (tvrating & 0x00200000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
-
- strcat( szRating, "F" ); // Fantasy Violence
- }
-
-}
-
-//-------------------------------------------------------------------------
-void DisplayTVRating(int tvrating, char *szRating)
-{
- strcpy( szRating, "");
-
- if (tvrating & 0x00008000)
- {
- strcpy( szRating, "TV-Y" );
- }
-
- if (tvrating & 0x00010000)
- {
- strcpy( szRating, "TV-Y7" );
- }
-
- if (tvrating & 0x00001000)
- {
- strcpy( szRating, "TV-G" );
- }
-
- if (tvrating & 0x00004000)
- {
- strcpy( szRating, "TV-PG" );
- }
-
- if (tvrating & 0x00002000)
- {
- strcpy( szRating, "TV-MA" );
- }
-
- if (tvrating & 0x00000800)
- {
- strcpy( szRating, "TV-14" );
- }
-
-}
-
-//-------------------------------------------------------------------------
-void DisplayExtendedMPAARating(int mpaarating, char *szRating, bool append)
-{
- if (append == false)
- {
- strcpy( szRating, "");
- }
-
- if (mpaarating & 0x00400000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "AC" ); // Adult Content
- }
-
- if (mpaarating & 0x00800000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "BN" ); // Brief Nudity
- }
-
- if (mpaarating & 0x01000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "GL" ); // Graphic Language
- }
-
- if (mpaarating & 0x02000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "GV" ); // Graphic Violence
- }
-
- if (mpaarating & 0x04000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "AL" ); // Adult Language
- }
-
- if (mpaarating & 0x08000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "MV" ); // Mild Violence
- }
-
- if (mpaarating & 0x10000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "N" ); // Nudity
- }
-
- if (mpaarating & 0x20000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "RP" ); // Rape
- }
-
- if (mpaarating & 0x40000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "SC " ); // Sexual Content
- }
-
- if (mpaarating & 0x80000000)
- {
- if (strlen(szRating) > 0)
- {
- strcat( szRating, " ");
- }
-
- strcat( szRating, "V" ); // Violence
- }
-
-}
-
-
-//-------------------------------------------------------------------------
-void DisplayMPAARating(int mpaarating, char *szRating)
-{
- strcpy( szRating, "");
-
- if (mpaarating & 0x00000001)
- {
- strcat( szRating, "AO" ); // unverified
- }
-
- if (mpaarating & 0x00000002)
- {
- strcat( szRating, "G" );
- }
-
- if (mpaarating & 0x00000004)
- {
- strcat( szRating, "NC-17" );
- }
-
- if (mpaarating & 0x00000008)
- {
- strcat( szRating, "NR" );
- }
-
- if (mpaarating & 0x00000010)
- {
- strcat( szRating, "PG" );
- }
-
- if (mpaarating & 0x00000020)
- {
- strcat( szRating, "PG-13" );
- }
-
- if (mpaarating & 0x00000040)
- {
- strcat( szRating, "R" );
- }
-
-}
-
-//-------------------------------------------------------------------------
-// Data Presentation Functions
-//-------------------------------------------------------------------------
-
-//-------------------------------------------------------------------------
-void ConvertCodepage(char *szString)
-{
- unsigned int i = 0;
- char ch;
-
- if (szString[0] == 0)
- {
- return;
- }
-
- for( i = 0; i < strlen(szString); ++i )
- {
- ch = szString[i];
-
- // Windows Codepage Translation to DOS/UNIX etc
-
- if (ch == (char)146)
- {
- szString[i] = '\'';
- }
-
- if (ch == (char)147)
- {
- szString[i] = '\"';
- }
-
- if (ch == (char)148)
- {
- szString[i] = '\"';
- }
-
-
-#ifdef _WIN32
- // Windows (Console) specific translations
-#endif
-
-#if defined(__unix__) || defined(__APPLE__)
- // UNIX specific translations
-#endif
-
- }
-
- return;
-
-}
-
-//-------------------------------------------------------------------------
-// Misc. Functions
-//-------------------------------------------------------------------------
-
-//-------------------------------------------------------------------------
-int CalculateMinutes( int seconds )
-{
- int retval = 0;
- double result1 = 0.0;
- double result2 = 0.0;
-
- if (seconds < 1)
- {
- return 0;
- }
-
- result1 = seconds / 60;
- result2 = seconds % 60;
-
- if (result2 > .0) // this will round up if there's any remainder,
- // could also make this .5 etc
- {
- retval = (int)result1 + 1;
- }
- else
- {
- retval = (int)result1;
- }
-
- return retval;
-
-}
-
-//-------------------------------------------------------------------------
-// ENDIAN CONVERSION FUNCTIONS
-//-------------------------------------------------------------------------
-
-//-------------------------------------------------------------------------
-// LONGLONG/INT64 Endian Conversion
-//-------------------------------------------------------------------------
-
-//-------------------------------------------------------------------------
-#if _WIN32_WINNT < 0x0602 && !defined(ntohll)
-DWORD64 ntohll(DWORD64 llValue)
-{
- DWORD64 retval = 0;
-
- // This is really cheesy but it works so that's all that matters
- // If someone out there wants to replace this with something cooler,
- // please feel free to do so!
-
- char szBuffer[17];
- char szInt64[17];
-
- memset(szBuffer,0,sizeof(szBuffer));
- memset(szInt64,0,sizeof(szInt64));
-
- MoveMemory(szBuffer,&llValue,sizeof(llValue));
-
- size_t cc = sizeof(llValue) - 1;
- size_t i = 0;
-
- for( i = 0; i < sizeof(llValue); ++i )
- {
- szInt64[i] = szBuffer[cc];
- --cc;
- }
-
- MoveMemory(&retval,szInt64,sizeof(retval));
-
- return retval;
-}
-#endif // _MSC_VER < 1700
-//-------------------------------------------------------------------------
-void ConvertProgramInfoEndian(struct tagProgramInfo * strProgramInfo)
-{
-
- strProgramInfo->autorecord = ntohl(strProgramInfo->autorecord);
- strProgramInfo->eventtime = ntohl(strProgramInfo->eventtime);
- strProgramInfo->flags = ntohl(strProgramInfo->flags);
- strProgramInfo->isvalid = ntohl(strProgramInfo->isvalid);
- strProgramInfo->minutes = ntohs(strProgramInfo->minutes);
- strProgramInfo->recLen = ntohs(strProgramInfo->recLen);
- strProgramInfo->structuresize = ntohl(strProgramInfo->structuresize);
- strProgramInfo->tuning = ntohl(strProgramInfo->tuning);
- strProgramInfo->tmsID = ntohl(strProgramInfo->tmsID);
-
- return;
-}
-
-//-------------------------------------------------------------------------
-void ConvertMovieInfoEndian(struct tagMovieInfo * strMovieInfo)
-{
- strMovieInfo->mpaa = ntohs(strMovieInfo->mpaa);
- strMovieInfo->runtime = ntohs(strMovieInfo->runtime);
- strMovieInfo->stars = ntohs(strMovieInfo->stars);
- strMovieInfo->year = ntohs(strMovieInfo->year);
-
- return;
-}
-
-//-------------------------------------------------------------------------
-void ConvertPartsInfoEndian(struct tagPartsInfo * strPartsInfo)
-{
- strPartsInfo->maxparts = ntohs(strPartsInfo->maxparts);
- strPartsInfo->partnumber = ntohs(strPartsInfo->partnumber);
-
- return;
-}
-//-------------------------------------------------------------------------
-void ConvertReplayShowEndian(struct tagReplayShow * strReplayShow)
-{
- strReplayShow->checkpointed = ntohl(strReplayShow->checkpointed);
- strReplayShow->created = ntohl(strReplayShow->created);
- strReplayShow->downloadid = ntohl(strReplayShow->downloadid);
- strReplayShow->GOP_count = ntohl(strReplayShow->GOP_count);
- strReplayShow->GOP_highest = ntohl(strReplayShow->GOP_highest);
- strReplayShow->GOP_last = ntohl(strReplayShow->GOP_last);
- strReplayShow->guaranteed = ntohl(strReplayShow->guaranteed);
- strReplayShow->guideid = ntohl(strReplayShow->guideid);
- strReplayShow->indexsize = ntohll(strReplayShow->indexsize);
- strReplayShow->inputsource = ntohl(strReplayShow->inputsource);
- strReplayShow->instance = ntohl(strReplayShow->instance);
- strReplayShow->intact = ntohl(strReplayShow->intact);
- strReplayShow->ivsstatus = ntohl(strReplayShow->ivsstatus);
- strReplayShow->mpegsize = ntohll(strReplayShow->mpegsize);
- strReplayShow->playbackflags = ntohl(strReplayShow->playbackflags);
- strReplayShow->quality = ntohl(strReplayShow->quality);
- strReplayShow->recorded = ntohl(strReplayShow->recorded);
- strReplayShow->seconds = ntohl(strReplayShow->seconds);
- strReplayShow->timessent = ntohl(strReplayShow->timessent);
- strReplayShow->upgradeflag = ntohl(strReplayShow->upgradeflag);
- strReplayShow->unused = ntohs(strReplayShow->unused);
-
- return;
-}
-
-//-------------------------------------------------------------------------
-void ConvertReplayGuideEndian(struct tagGuideHeader * strGuideHeader)
-{
-
- strGuideHeader->GroupData.categories = ntohl(strGuideHeader->GroupData.categories);
- strGuideHeader->GroupData.structuresize = ntohl(strGuideHeader->GroupData.structuresize);
-
- strGuideHeader->GuideSnapshotHeader.snapshotsize = ntohl(strGuideHeader->GuideSnapshotHeader.snapshotsize);
- strGuideHeader->GuideSnapshotHeader.channeloffset = ntohl(strGuideHeader->GuideSnapshotHeader.channeloffset);
- strGuideHeader->GuideSnapshotHeader.flags = ntohl(strGuideHeader->GuideSnapshotHeader.flags);
- strGuideHeader->GuideSnapshotHeader.groupdataoffset = ntohl(strGuideHeader->GuideSnapshotHeader.groupdataoffset);
- strGuideHeader->GuideSnapshotHeader.osversion = ntohs(strGuideHeader->GuideSnapshotHeader.osversion);
- strGuideHeader->GuideSnapshotHeader.snapshotversion = ntohs(strGuideHeader->GuideSnapshotHeader.snapshotversion);
- strGuideHeader->GuideSnapshotHeader.channelcount = ntohl(strGuideHeader->GuideSnapshotHeader.channelcount);
- strGuideHeader->GuideSnapshotHeader.channelcountcheck = ntohl(strGuideHeader->GuideSnapshotHeader.channelcountcheck);
- strGuideHeader->GuideSnapshotHeader.showoffset = ntohl(strGuideHeader->GuideSnapshotHeader.showoffset);
-
- strGuideHeader->GuideSnapshotHeader.unknown1 = ntohl(strGuideHeader->GuideSnapshotHeader.unknown1);
- strGuideHeader->GuideSnapshotHeader.unknown2 = ntohl(strGuideHeader->GuideSnapshotHeader.unknown2);
- strGuideHeader->GuideSnapshotHeader.unknown3 = ntohl(strGuideHeader->GuideSnapshotHeader.unknown3);
- strGuideHeader->GuideSnapshotHeader.unknown4 = ntohl(strGuideHeader->GuideSnapshotHeader.unknown4);
- strGuideHeader->GuideSnapshotHeader.unknown5 = ntohl(strGuideHeader->GuideSnapshotHeader.unknown5);
- strGuideHeader->GuideSnapshotHeader.unknown6 = ntohl(strGuideHeader->GuideSnapshotHeader.unknown6);
- strGuideHeader->GuideSnapshotHeader.unknown7 = ntohl(strGuideHeader->GuideSnapshotHeader.unknown7);
-
- for( unsigned int cc = 0; cc < strGuideHeader->GroupData.categories; ++cc )
- {
- strGuideHeader->GroupData.category[cc] = ntohl(strGuideHeader->GroupData.category[cc]);
- strGuideHeader->GroupData.categoryoffset[cc] = ntohl(strGuideHeader->GroupData.categoryoffset[cc]);
- }
-
-
- {
- strGuideHeader->GuideSnapshotHeader.structuresize = ntohl(strGuideHeader->GuideSnapshotHeader.structuresize);
- }
-
- return;
-}
-
-//-------------------------------------------------------------------------
-void ConvertReplayGuide45To50Endian(struct tagGuideHeader45 * strGuideHeader45, struct tagGuideHeader * strGuideHeader)
-{
-
- strGuideHeader->GroupData.categories = ntohl(strGuideHeader45->GroupData.categories);
- strGuideHeader->GroupData.structuresize = ntohl(strGuideHeader45->GroupData.structuresize);
-
- strGuideHeader->GuideSnapshotHeader.snapshotsize = 0;
- strGuideHeader->GuideSnapshotHeader.channeloffset = ntohl(strGuideHeader45->GuideSnapshotHeader.channeloffset);
- strGuideHeader->GuideSnapshotHeader.flags = ntohl(strGuideHeader45->GuideSnapshotHeader.flags);
- strGuideHeader->GuideSnapshotHeader.groupdataoffset = ntohl(strGuideHeader45->GuideSnapshotHeader.groupdataoffset);
- strGuideHeader->GuideSnapshotHeader.osversion = ntohs(strGuideHeader45->GuideSnapshotHeader.osversion);
- strGuideHeader->GuideSnapshotHeader.snapshotversion = ntohs(strGuideHeader45->GuideSnapshotHeader.snapshotversion);
- strGuideHeader->GuideSnapshotHeader.channelcount = ntohl(strGuideHeader45->GuideSnapshotHeader.channelcount);
- strGuideHeader->GuideSnapshotHeader.channelcountcheck = ntohl(strGuideHeader45->GuideSnapshotHeader.channelcountcheck);
- strGuideHeader->GuideSnapshotHeader.showoffset = ntohl(strGuideHeader45->GuideSnapshotHeader.showoffset);
-
- strGuideHeader->GuideSnapshotHeader.unknown1 = 0;
- strGuideHeader->GuideSnapshotHeader.unknown2 = 0;
- strGuideHeader->GuideSnapshotHeader.unknown3 = 0;
- strGuideHeader->GuideSnapshotHeader.unknown4 = 0;
- strGuideHeader->GuideSnapshotHeader.unknown5 = 0;
- strGuideHeader->GuideSnapshotHeader.unknown6 = 0;
- strGuideHeader->GuideSnapshotHeader.unknown7 = 0;
-
- for( unsigned int cc = 0; cc < strGuideHeader->GroupData.categories; ++cc )
- {
- strGuideHeader->GroupData.category[cc] = ntohl(strGuideHeader45->GroupData.category[cc]);
- strGuideHeader->GroupData.categoryoffset[cc] = ntohl(strGuideHeader45->GroupData.categoryoffset[cc]);
- }
-
-
- {
- strGuideHeader->GuideSnapshotHeader.structuresize = ntohl(strGuideHeader45->GuideSnapshotHeader.structuresize);
- }
-
- return;
-}
-
-//-------------------------------------------------------------------------
-// GuideParser
-//-------------------------------------------------------------------------
-
-extern "C" {
-int GuideParser(char * szOutputBuffer, const char * szInput, const size_t InputSize)
-{
- const char * fptr, * junkptr;
- bool moreshows, receivedshow;
- bool isguaranteed, isrepeat, isletterbox, ismovie, hasparts, iscc, isppv, isstereo, issap;
- char szBuffer[1024], szQuality[16];
- char szEpisodeTitle[128];
- char szStarRating[6], szMPAARating[10], szOriginalDescriptionBuffer[226];
- char szTVRating[32];
- char szShowTitle[128];
- char szExtTV[64];
- char szExtMPAA[64];
- int i, curshow, cc;
- size_t readsize;
- ReplayShow strReplayShow;
- GuideHeader strGuideHeader;
- GuideHeader45 strGuideHeader45;
- MovieInfo strMovieInfo;
- PartsInfo strPartsInfo;
-
- // Initialize
-
- memset(szBuffer,0,sizeof(szBuffer));
- memset(szQuality,0,sizeof(szQuality));
- memset(szEpisodeTitle,0,sizeof(szEpisodeTitle));
- memset(szOriginalDescriptionBuffer,0,sizeof(szOriginalDescriptionBuffer));
- memset(szStarRating,0,sizeof(szStarRating));
- memset(szMPAARating,0,sizeof(szMPAARating));
- memset(szExtTV,0,sizeof(szExtTV));
- memset(szExtMPAA,0,sizeof(szExtMPAA));
- sprintf(szOutputBuffer,"%s", "");
-
- // Display Initial Header
-
- //printf("%s\n",lpszTitle);
- //printf("%s\n\n",lpszCopyright);
- //printf("%s\n",lpszComment);
-
- // Structure Sizes
-
-#ifdef SHOWSTRUCTURESIZES
-
- //printf("struct strGuideHeader is %d bytes\n",sizeof(tagGuideHeader));
- //printf("struct strMovieInfo is %d bytes\n",sizeof(tagMovieInfo));
- //printf("struct strPartsInfo is %d bytes\n",sizeof(tagPartsInfo));
- //printf("struct strProgramInfo is %d bytes\n",sizeof(tagProgramInfo));
- //printf("struct strChannelInfo is %d bytes\n",sizeof(tagChannelInfo));
- //printf("struct strReplayShow is %d bytes\n",sizeof(tagReplayShow));
- //printf("\n");
-#endif
-
-#ifdef _DEBUG
- // Check to make sure structures are required sizes, this is mostly for those of you tinkering with this
- // and - of course - me :).
-
- if (sizeof(ProgramInfo) != PROGRAMINFO)
- {
- //printf("Error in ProgramInfo structure, needs to be %u instead of %u\n",PROGRAMINFO,sizeof(ProgramInfo));
- }
-
- if (sizeof(ChannelInfo) != CHANNELINFO)
- {
- //printf("Error in ChannelInfo structure, needs to be %u instead of %u\n",CHANNELINFO,sizeof(ChannelInfo));
- }
-
-
- if (sizeof(ReplayShow) != REPLAYSHOW)
- {
- //printf("Error in ReplayShow structure, needs to be %u instead of %u\n",REPLAYSHOW,sizeof(ReplayShow));
- }
-
- if (sizeof(GuideHeader) != GUIDEHEADER)
- {
- //printf("Error in GuideHeader structure, needs to be %u instead of %u\n",GUIDEHEADER,sizeof(GuideHeader));
- }
-
- // 4.5
- if (sizeof(GuideHeader45) != GUIDEHEADER45)
- {
- //printf("Error in GuideHeader45 structure, needs to be %u instead of %u\n",GUIDEHEADER45,sizeof(GuideHeader45));
- }
-#endif
-
- curshow = 0;
- i = 0;
- junkptr = szInput;
- fptr = szInput;
-
- DWORD ver;
-
- memcpy(&ver, fptr, sizeof(ver));
- ver = ntohl(ver);
- //printf("V %d.%d!\n", HIWORD(ver), LOWORD(ver));
-
- //-------------------------------------------------------------------------
- // Replay Header
- //-------------------------------------------------------------------------
-
- //printf("Reading ReplayTV Guide Header\n");
-
- switch(HIWORD(ver))
- {
- case 0: // 5k 5.0
- memcpy( &strGuideHeader, fptr, sizeof(strGuideHeader) );
- ConvertReplayGuideEndian(&strGuideHeader);
- break;
- case 3: // 4k 4.3
- case 5: // 5k 4.5
- memcpy( &strGuideHeader45, fptr, sizeof(strGuideHeader45) );
- ConvertReplayGuide45To50Endian(&strGuideHeader45, &strGuideHeader);
- break;
- default: // Unknown: try 5k 5.0
- //printf("Unknown ReplayTV version: %d.%d!\n", HIWORD(ver), LOWORD(ver));
- memcpy( &strGuideHeader, fptr, sizeof(strGuideHeader) );
- ConvertReplayGuideEndian(&strGuideHeader);
- break;
- }
-
- if (strGuideHeader.GuideSnapshotHeader.channelcount != strGuideHeader.GuideSnapshotHeader.channelcountcheck)
- {
- //printf("Guide Snapshot might be damaged. (%u/%u)\n",strGuideHeader.GuideSnapshotHeader.channelcount,strGuideHeader.GuideSnapshotHeader.channelcountcheck);
- }
-
- // jump to the first show record
-
- // fptr = (long)strGuideHeader.GuideSnapshotHeader.showoffset + junkptr;
- fptr = (long)strGuideHeader.GuideSnapshotHeader.showoffset + junkptr;
-
- //-------------------------------------------------------------------------
- // ReplayShows
- //-------------------------------------------------------------------------
-
-
- //printf("\n\nReading ReplayShows\n\n");
-
- moreshows = true;
- curshow = 0;
-
- strcat(szOutputBuffer, "<REPLAYGUIDE>\n");
- do
- {
- readsize = sizeof(strReplayShow);
- // 4k 4.3 doesn't have the extra bytes for szReserved at the end of the struct
- if ( HIWORD( ver ) == 3 ) readsize -= sizeof(strReplayShow.szReserved);
-
- // Need to check if ptr is at, beyond or near end of input (i.e. within sizeof(strReplayshow))
- if ( (InputSize - (fptr - szInput) ) < readsize)
- {
- moreshows = false;
- }
- else
- {
- memcpy( &strReplayShow, fptr, readsize);
-
- curshow++;
-
- memset(szTVRating,0,sizeof(szTVRating));
- memset(szBuffer,0,sizeof(szBuffer));
- memset(szEpisodeTitle,0,sizeof(szEpisodeTitle));
- memset(szShowTitle,0,sizeof(szShowTitle));
- memset(szMPAARating,0,sizeof(szMPAARating));
- memset(szOriginalDescriptionBuffer,0,sizeof(szOriginalDescriptionBuffer));
- strcpy(szStarRating,"*****");
- memset(szExtTV,0,sizeof(szExtTV));
- memset(szExtMPAA,0,sizeof(szExtMPAA));
-
- // Convert Endian
-
- ConvertReplayShowEndian(&strReplayShow);
- ConvertProgramInfoEndian(&strReplayShow.ProgramInfo);
-
- /*
- // this is for this hack, this seems to be no longer used so copy it from eventtime
-
- if (strReplayShow.recorded == 0) {
- strReplayShow.recorded = strReplayShow.ProgramInfo.eventtime;
- }
- */
-
- // Process ProgramInfo
-
- MoveMemory(szOriginalDescriptionBuffer,strReplayShow.ProgramInfo.szDescription,sizeof(szOriginalDescriptionBuffer));
-
- // Process Flags
-
- iscc = false;
- issap = false;
- isstereo = false;
- ismovie = false;
- isppv = false;
- hasparts = false;
- isletterbox = false;
- isrepeat = false;
- receivedshow = false;
- isguaranteed = false;
- cc = 0; // Offset for Extended Data
-
- if (strReplayShow.guaranteed == 0xFFFFFFFF)
- {
- isguaranteed = true;
- }
-
- if (strReplayShow.guideid != 0)
- {
- receivedshow = true;
- }
-
-
- if (strReplayShow.ProgramInfo.flags & 0x00000001)
- {
- iscc = true;
- }
-
- if (strReplayShow.ProgramInfo.flags & 0x00000002)
- {
- isstereo = true;
- }
-
- if (strReplayShow.ProgramInfo.flags & 0x00000004)
- {
- isrepeat = true;
- }
-
- if (strReplayShow.ProgramInfo.flags & 0x00000008)
- {
- issap = true;
- }
-
- if (strReplayShow.ProgramInfo.flags & 0x00000010)
- {
- isletterbox = true;
- }
-
- if (strReplayShow.ProgramInfo.flags & 0x00000020)
- {
- // Movie, load extra 8 bytes into MovieInfo structure.
-
- ismovie = true;
- MoveMemory(&strMovieInfo,szOriginalDescriptionBuffer + cc,sizeof(strMovieInfo));
- ConvertMovieInfoEndian(&strMovieInfo);
-
- memset(szBuffer,0,sizeof(szBuffer));
- cc = cc + sizeof(strMovieInfo);
- MoveMemory(szBuffer,szOriginalDescriptionBuffer + cc,sizeof(szOriginalDescriptionBuffer) - cc);
-
- // this won't do the half stars, it's too cheesy for that!
-
- i = strMovieInfo.stars / 10;
- szStarRating[i] = 0;
-
- // MPAA Rating
-
- DisplayMPAARating(strMovieInfo.mpaa,szMPAARating);
- DisplayExtendedMPAARating(strMovieInfo.mpaa,szExtMPAA,false);
-
- if (strlen(szMPAARating) > 0)
- {
- if (strlen(szExtMPAA) > 0)
- {
- strcat( szMPAARating, " (" );
- strcat( szMPAARating, szExtMPAA );
- strcat( szMPAARating, ")" );
- }
- }
- }
-
-
- if (strReplayShow.ProgramInfo.flags & 0x00000040)
- {
-
- // Multiple Parts
-
- hasparts = true;
- MoveMemory(&strPartsInfo,szOriginalDescriptionBuffer + cc,sizeof(strPartsInfo));
- ConvertPartsInfoEndian(&strPartsInfo);
-
- memset(szBuffer,0,sizeof(szBuffer));
-
- cc = cc + sizeof(strPartsInfo);
- MoveMemory(szBuffer,szOriginalDescriptionBuffer + cc,sizeof(szOriginalDescriptionBuffer) - cc);
- }
-
- if (strReplayShow.ProgramInfo.flags & 0x00000080)
- {
- isppv = true;
- }
-
- if (!ismovie)
- {
- /*
- **
- ** NOTE:
- ** This is what the Replay does. However, the TMS data does support a mix
- ** so, if you want, you can remove "if (!ismovie)".
- */
-
- DisplayTVRating(strReplayShow.ProgramInfo.flags,szTVRating);
- DisplayExtendedTVRating(strReplayShow.ProgramInfo.flags,szExtTV,false);
- }
-
- if (strlen(szTVRating) > 0)
- {
- if (strlen(szExtTV) > 0)
- {
- strcat( szTVRating, " (" );
- strcat( szTVRating, szExtTV );
- strcat( szTVRating, ")" );
- }
- }
-
-
-
- i = cc; // set offset (needed if it's been mangled by HasParts or IsMovie)
-
- strncpy(szShowTitle,strReplayShow.ProgramInfo.szDescription + i,strReplayShow.ProgramInfo.titleLen);
- i = i + strReplayShow.ProgramInfo.titleLen;
-
- strncpy(szEpisodeTitle,strReplayShow.ProgramInfo.szDescription + i,strReplayShow.ProgramInfo.episodeLen);
- i = i + strReplayShow.ProgramInfo.episodeLen;
-
- // Convert Codepages
-
- ConvertCodepage(strReplayShow.ProgramInfo.szDescription);
- ConvertCodepage(szShowTitle);
- ConvertCodepage(szEpisodeTitle);
-
- // Build Strings
-
- DisplayQuality(strReplayShow.quality,szQuality);
-
- // Display Record
-
- strcat(szOutputBuffer, "<ITEM>\n");
- strcat(szOutputBuffer,"\t<DISPLAYNAME>");
-
- if (szEpisodeTitle[0] > 31)
- {
- sprintf(szBuffer,"%s \"%s\"",szShowTitle,szEpisodeTitle);
- strcat(szOutputBuffer, szBuffer);
- }
- else
- {
- if (ismovie)
- {
-
- if (szStarRating[0] != 0)
- {
- if (strMovieInfo.stars % 10)
- {
- sprintf(szBuffer,"%s (%s1/2, %s, %d",szShowTitle,szStarRating,szMPAARating,strMovieInfo.year);
- strcat(szOutputBuffer, szBuffer);
- }
- else
- {
- sprintf(szBuffer,"%s (%s, %s, %d",szShowTitle,szStarRating,szMPAARating,strMovieInfo.year);
- strcat(szOutputBuffer, szBuffer);
- }
- }
- else
- {
- sprintf(szBuffer,"%s (%s, %d",szShowTitle,szMPAARating,strMovieInfo.year);
- strcat(szOutputBuffer, szBuffer);
- }
- }
- else
- {
- strcat(szOutputBuffer, szShowTitle);
- }
- }
-
- // display flags
-
- cc = 0;
- i = 0;
-
- if (iscc)
- {
- cc++;
- }
- if (isstereo)
- {
- cc++;
- }
- if (isrepeat)
- {
- cc++;
- }
- if (issap)
- {
- cc++;
- }
- if (isppv)
- {
- cc++;
- }
-
- if (szTVRating[0] > 31)
- {
- cc++;
- }
-
- if (isletterbox)
- {
- cc++;
- }
-
- if (cc > 0)
- {
- if (ismovie)
- {
- strcat(szOutputBuffer,", ");
- }
- else
- {
- strcat(szOutputBuffer," (");
- }
- i = 1;
- }
- else
- {
- if (ismovie)
- {
- strcat(szOutputBuffer,")");
- }
- }
-
- if (szTVRating[0] > 31)
- {
- strcat(szOutputBuffer,szTVRating);
- cc--;
- if (cc)
- {
- strcat(szOutputBuffer,", ");
- }
- }
-
- if (iscc)
- {
- strcat(szOutputBuffer,"CC");
- cc--;
- if (cc)
- {
- strcat(szOutputBuffer,", ");
- }
- }
-
- if (isstereo)
- {
- strcat(szOutputBuffer,"Stereo");
- cc--;
- if (cc)
- {
- strcat(szOutputBuffer,", ");
- }
- }
-
- if (isrepeat)
- {
- strcat(szOutputBuffer,"Repeat");
- cc--;
- if (cc)
- {
- strcat(szOutputBuffer,", ");
- }
- }
-
- if (issap)
- {
- strcat(szOutputBuffer,"SAP");
- cc--;
- if (cc)
- {
- strcat(szOutputBuffer,", ");
- }
- }
-
- if (isppv)
- {
- strcat(szOutputBuffer,"PPV");
- cc--;
- if (cc)
- {
- strcat(szOutputBuffer,", ");
- }
- }
-
- if (isletterbox)
- {
- strcat(szOutputBuffer,"Letterboxed");
- cc--;
- if (cc)
- {
- strcat(szOutputBuffer,", ");
- }
- }
-
- if (i > 0)
- {
- strcat(szOutputBuffer,")");
- }
-
- if (hasparts)
- {
- sprintf(szBuffer,"Part %d of %d",strPartsInfo.partnumber,strPartsInfo.maxparts);
- strcat(szOutputBuffer, szBuffer);
- }
-
- strcat(szOutputBuffer,"</DISPLAYNAME>\n");
-
- sprintf(szBuffer,"\t<QUALITY>%s</QUALITY>\n",szQuality);
- strcat(szOutputBuffer, szBuffer);
-
- sprintf(szBuffer,"\t<RECORDED>%s</RECORDED>\n",UnixTimeToString(strReplayShow.recorded));
- strcat(szOutputBuffer, szBuffer);
-
- sprintf(szBuffer,"\t<PATH>Video/%ld.mpg</PATH>\n",strReplayShow.recorded);
- strcat(szOutputBuffer, szBuffer);
-
- strcat(szOutputBuffer,"\t<DURATION>");
- i = strReplayShow.ProgramInfo.minutes + strReplayShow.afterpadding + strReplayShow.beforepadding;
- cc = CalculateMinutes(strReplayShow.seconds);
- if (cc != i)
- {
- // This can happen if the cable goes out during recording or if you hit STOP etc.
- sprintf(szBuffer,"%d minutes ( %d scheduled )",cc,i);
- }
- else
- {
- sprintf(szBuffer,"%d minutes",cc);
- }
- strcat(szOutputBuffer, szBuffer);
- strcat(szOutputBuffer,"</DURATION>\n");
-
- sprintf(szBuffer,"\t<SIZE>%d</SIZE>\n",cc);
- strcat(szOutputBuffer, szBuffer);
-
- strcat(szOutputBuffer,"</ITEM>\n");
-
- fptr += readsize;
- }
- }
- while ( moreshows == true );
- strcat(szOutputBuffer, "</REPLAYGUIDE>\n");
-
- // Done, shut it down
-
- //printf("Done! %u ReplayShows parsed!\n", curshow);
-
- return 0;
-
-}
-}
-
diff --git a/lib/libRTV/GuideParser.h b/lib/libRTV/GuideParser.h
deleted file mode 100644
index 16f990c5ea..0000000000
--- a/lib/libRTV/GuideParser.h
+++ /dev/null
@@ -1,7 +0,0 @@
-#ifndef GUIDEPARSER_H
-#define GUIDEPARSER_H
-
-extern int GuideParser(char * szOutputBuffer, const char * szInput, const size_t InputSize);
-
-#endif
-
diff --git a/lib/libRTV/Makefile.in b/lib/libRTV/Makefile.in
deleted file mode 100644
index ebd7448758..0000000000
--- a/lib/libRTV/Makefile.in
+++ /dev/null
@@ -1,9 +0,0 @@
-SRCS=crypt.c guideclient.c GuideParser.c httpclient.c httpfsclient.c interface.c md5.c netclient.c rtv.c sleep.c
-
-CFLAGS += -D_LINUX
-CXXFLAGS += -D_LINUX
-
-LIB= librtv.a
-
-include ../../Makefile.include
-
diff --git a/lib/libRTV/crypt.c b/lib/libRTV/crypt.c
deleted file mode 100644
index df4d682d6b..0000000000
--- a/lib/libRTV/crypt.c
+++ /dev/null
@@ -1,216 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "crypt.h"
-#include "md5.h"
-#include <stdio.h>
-#include <string.h>
-#include <stdlib.h>
-#include <time.h>
-
-static void checksum(unsigned char * dest, unsigned const char * src, u32 len,
- int checksum_num)
-{
-
- static unsigned char extradata[][64] = {{
- 0x41,0x47,0xc8,0x09, 0xba,0x3c,0x99,0x6a,
- 0xda,0x09,0x9a,0x0f, 0xc0,0xd3,0x47,0xca,
- 0xd1,0x95,0x81,0x19, 0xab,0x17,0xc6,0x5f,
- 0xad,0xea,0xe5,0x75, 0x9c,0x49,0x18,0xa5,
- 0xdf,0x35,0x46,0x5b, 0x78,0x0e,0xcb,0xc7,
- 0x8c,0x3e,0xf4,0x90, 0xa2,0xb7,0x8e,0x00,
- 0x53,0x8d,0x4c,0xab, 0x13,0xa5,0x16,0x00,
- 0xff,0xb8,0x4b,0x20, 0x29,0x22,0x9d,0xee,
- }, {
- 0xda,0x76,0x5c,0xd4, 0x34,0xc3,0xd7,0x2c,
- 0xac,0x40,0xb8,0xd8, 0x59,0xbc,0x59,0x34,
- 0xaa,0xbf,0x89,0xbd, 0x85,0xe8,0x40,0x27,
- 0x78,0x2b,0x18,0x6e, 0xa6,0x6e,0x5a,0xc6,
- 0xda,0xe3,0x86,0x84, 0x40,0x14,0x2a,0x23,
- 0x4f,0x5d,0x38,0x5e, 0x7f,0xd9,0x73,0x7d,
- 0xe4,0x80,0x3d,0x21, 0x28,0x41,0xf1,0xb2,
- 0x96,0x43,0x2b,0xcc, 0x0c,0x9d,0x26,0xb9,
- }};
-
- rtv_md5_context c;
- rtv_md5_starts(&c);
- rtv_md5_update(&c, src, len);
- rtv_md5_update(&c, extradata[checksum_num], sizeof extradata[checksum_num]);
- rtv_md5_finish(&c, dest);
-
-}
-
-static u32 cryptblock(u32 k, char * buf, u32 size)
-{
- u32 i;
-
- for (i = 0; i < size; i++) {
- k = k * 0xb8f7 + 0x15bb9;
- buf[i] ^= k;
- }
- return k;
-}
-
-/* cyphertext bytes:
- *
- * 2, 4, 1, 7 -- key material block 1
- * 0, 3, 5, 6 -- unknown/unused
- * 8..23 -- checksum(24..end)
- * 24..27 -- crypt(0x42ffdfa9)
- * 28..31 -- crypt(time_t)
- * 32..end -- crypt(text)
- *
- * it looks like you should be able to decrypt 24..end in one step, after
- * getting the key material, if you don't want to do the sanity check first
- * and don't mind it all in one buffer
- */
-
-int rtv_decrypt(const char * cyphertext, u32 cyphertext_len,
- char * plainbuf, u32 plainbuf_len,
- u32 * p_time, u32 * p_plain_len,
- int checksum_num)
-{
- unsigned char key_buf[4];
- unsigned char sanity_buf[4];
- unsigned char time_buf[4];
- unsigned char csum_buf[16];
- unsigned char * p;
- u32 key;
- u32 sanity;
-#if VERBOSE_OBFUSC
- unsigned char obfusc_buf[4];
- u32 obfusc;
-#endif
-
- if (plainbuf_len < cyphertext_len - 32)
- return -1;
-
- /* unshuffle the key and unxor it */
- key_buf[0] = cyphertext[2];
- key_buf[1] = cyphertext[4];
- key_buf[2] = cyphertext[1];
- key_buf[3] = cyphertext[7];
- p = key_buf;
- key = rtv_to_u32(&p) ^ 0xcb0baf47;
-
-#if VERBOSE_OBFUSC
- obfusc_buf[0] = cyphertext[0];
- obfusc_buf[1] = cyphertext[3];
- obfusc_buf[2] = cyphertext[5];
- obfusc_buf[3] = cyphertext[6];
- p = key_buf;
- obfusc = rtv_to_u32(&p);
- //fprintf(stderr, "Key: %ld (0x%lx)\n", (unsigned long)key, (unsigned long)key);
- //fprintf(stderr, "Obfusc: %ld (0x%lx)\n", (unsigned long)obfusc, (unsigned long)obfusc);
-#endif
-
- /* check the sanity field */
- memcpy(sanity_buf, cyphertext + 24, 4);
- key = cryptblock(key, (char*)sanity_buf, 4);
- p = sanity_buf;
- sanity = rtv_to_u32(&p);
- if (sanity != 0x42ffdfa9)
- return -1;
-
- /* decrypt the time field */
- memcpy(time_buf, cyphertext + 28, 4);
- key = cryptblock(key, (char*)time_buf, 4);
-
- /* decrypt the actual text */
- memcpy(plainbuf, cyphertext + 32, cyphertext_len - 32);
- cryptblock(key, (char*)plainbuf, cyphertext_len - 32);
-
- /* check the checksum */
- checksum(csum_buf, (unsigned const char*)(cyphertext + 24), cyphertext_len - 24, checksum_num);
- if (memcmp(csum_buf, cyphertext + 8, 16) != 0)
- return -2;
-
- if (p_plain_len) {
- *p_plain_len = cyphertext_len - 32;
- }
- if (p_time) {
- p = time_buf;
- *p_time = rtv_to_u32(&p);
-#if VERBOSE_OBFUSC
-// fprintf(stderr, "Time: %ld (0x%lx)\n", (unsigned long)*p_time, (unsigned long)*p_time);
-#endif
- }
- return 0;
-}
-
-int rtv_encrypt(const char * plaintext, u32 plaintext_len,
- char * cyphertext, u32 buffer_len, u32 * cyphertext_len,
- int checksum_num)
-{
- u32 key;
- u32 t;
- u32 obfusc;
- unsigned char key_buf[4];
- unsigned char obfusc_buf[4];
- unsigned char * p;
-
- if (buffer_len < plaintext_len + 32)
- return -1;
-
- /* make up a key and obfuscatory material; get the time */
- key = rand();
- obfusc = rand();
- t = (u32)time(NULL);
-
- p = NULL;//getenv("TIMEOFF");
- if (p)
- t += atoi((char*)p);
-
- /* encrypt the key */
- p = key_buf;
- rtv_from_u32(&p, key ^ 0xcb0baf47);
-
- p = obfusc_buf;
- rtv_from_u32(&p, obfusc);
-
- /* scramble the key and obfusc material */
- cyphertext[0] = obfusc_buf[3];
- cyphertext[1] = key_buf[2];
- cyphertext[2] = key_buf[0];
- cyphertext[3] = obfusc_buf[2];
- cyphertext[4] = key_buf[1];
- cyphertext[5] = obfusc_buf[1];
- cyphertext[6] = obfusc_buf[0];
- cyphertext[7] = key_buf[3];
-
- /* store the sanity check & time */
- p = (unsigned char*)(cyphertext + 24);
- rtv_from_u32(&p, 0x42ffdfa9);
- rtv_from_u32(&p, t);
-
- /* copy the plaintext */
- memcpy(p, plaintext, plaintext_len);
-
- /* encrypt the whole thing */
- cryptblock(key, cyphertext+24, plaintext_len+8);
-
- /* fill in the checksum */
- checksum((unsigned char*)(cyphertext + 8), (unsigned const char*)(cyphertext + 24), plaintext_len + 8, checksum_num);
-
- /* and we're done */
- *cyphertext_len = plaintext_len + 32;
- return 0;
-}
diff --git a/lib/libRTV/crypt.h b/lib/libRTV/crypt.h
deleted file mode 100644
index 497d180881..0000000000
--- a/lib/libRTV/crypt.h
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#ifndef CRYPT_H
-#define CRYPT_H
-
-#include "rtv.h"
-
-int rtv_decrypt(const char * cyphertext, u32 cypherlength,
- char * plainbuf, u32 plainbuflength,
- u32 * time, u32 * plainlen,
- int checksum_num);
-int rtv_encrypt(const char * plaintext, u32 plaintext_len,
- char * cyphertext, u32 buffer_len, u32 * cyphertext_len,
- int checksum_num);
-#endif
-
-
diff --git a/lib/libRTV/guideclient.c b/lib/libRTV/guideclient.c
deleted file mode 100644
index e21cdd8789..0000000000
--- a/lib/libRTV/guideclient.c
+++ /dev/null
@@ -1,128 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "rtv.h"
-#include "guideclient.h"
-#include "httpclient.h"
-
-#include <string.h>
-#include <stdio.h>
-
-#define MIN(x,y) ((x)<(y)?(x):(y))
-
-struct snapshot_data
-{
- int firsttime;
- int filesize;
- int bytes_read;
- char * timestamp;
- char * buf;
- u32 status;
-};
-
-static void get_snapshot_callback(unsigned char * buf, size_t len, void * vd)
-{
- struct snapshot_data * data = vd;
- unsigned char * buf_data_start;
- unsigned long bytes_to_read;
-
- if (data->firsttime) {
- unsigned char * end, * equal, * cur;
-
- data->firsttime = 0;
-
- /* First line: error code */
- cur = buf;
- end = (unsigned char*)strchr((char*)cur, '\n');
- if (end) *end = '\0';
- data->status = strtoul((char*)cur, NULL, 16);
- if (!end) return;
- do {
- cur = end + 1;
- if (*cur == '#') {
- end = (unsigned char*)strchr((char*)cur, '\0');
- len -= (end - buf);
- buf_data_start = end;
- break;
- }
- end = (unsigned char*)strchr((char*)cur, '\n');
- if (!end) return;
- *end = '\0';
- equal = (unsigned char*)strchr((char*)cur, '=');
- if (!equal) return;
- if (strncmp((char*)cur, "guide_file_name=", (int)(equal-cur+1)) == 0) {
- data->timestamp = malloc(strlen((const char*)(equal+1))+1);
- strcpy((char*)data->timestamp, (const char*)(equal+1));
- } else if (strncmp((char*)cur, "FileLength=", (int)(equal-cur+1)) == 0) {
- data->filesize = strtoul((char*)equal+1, NULL, 0);
- data->buf = malloc(data->filesize);
- } /* also "RemoteFileName", but we don't expose it */
- } while (1);
- } else {
- buf_data_start = buf;
- }
-
- bytes_to_read = MIN(len, (unsigned)(data->filesize - data->bytes_read));
- memcpy(data->buf + data->bytes_read, buf_data_start, bytes_to_read);
- data->bytes_read += bytes_to_read;
-
- free(buf);
-}
-
-unsigned long guide_client_get_snapshot(unsigned char ** presult,
- unsigned char ** ptimestamp,
- unsigned long * psize,
- const char * address,
- const char * cur_timestamp)
-{
- struct snapshot_data data;
- char url[512];
- struct hc * hc;
-
- memset(&data, 0, sizeof data);
- data.firsttime = 1;
- data.status = -1;
-
- sprintf(url, "http://%s/http_replay_guide-get_snapshot?"
- "guide_file_name=%s&serial_no=RTV4080K0000000000",
- address,
- cur_timestamp);
-
- hc = hc_start_request(url);
- if (!hc) {
- perror("Error: guide_client_get_snapshot(): hc_start_request()");
- goto exit;
- }
-
-
- hc_send_request(hc);
- hc_read_pieces(hc, get_snapshot_callback, &data);
-
- hc_free(hc);
-
- *ptimestamp = (unsigned char*)data.timestamp;
- *presult = (unsigned char*)data.buf;
- *psize = data.filesize;
-
-exit:
- return data.status;
-}
-
diff --git a/lib/libRTV/guideclient.h b/lib/libRTV/guideclient.h
deleted file mode 100644
index b448783376..0000000000
--- a/lib/libRTV/guideclient.h
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#ifndef GUIDECLIENT_H
-#define GUIDECLIENT_H
-
-#include "httpclient.h"
-
-unsigned long guide_client_get_snapshot(unsigned char ** presult,
- unsigned char ** ptimestamp,
- unsigned long * psize,
- const char * address,
- const char * cur_timestamp);
-
-/* XXX should also have is_show_in_use and delete_show */
-#endif
diff --git a/lib/libRTV/httpclient.c b/lib/libRTV/httpclient.c
deleted file mode 100644
index 26a4946faf..0000000000
--- a/lib/libRTV/httpclient.c
+++ /dev/null
@@ -1,494 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "httpclient.h"
-
-#include <ctype.h>
-#include <stdio.h>
-#include <string.h>
-
-#define MAX_CHUNK 32768
-
-struct hc_headers
-{
- char * tag;
- char * value;
- struct hc_headers * next;
-};
-
-struct hc
-{
- struct nc * nc;
- char * hostname;
- short port;
- char * localpart;
- char * status;
- struct hc_headers * req_headers;
- struct hc_headers * rsp_headers;
- size_t curr_chunk_len;
-};
-
-static void hc_h_free(struct hc_headers * hh)
-{
- free(hh->tag);
- free(hh->value);
- free(hh);
-}
-
-static struct hc_headers * hc_h_make(const char * tag, const char * value)
-{
- struct hc_headers * h;
-
- h = malloc(sizeof *h);
- if (!h)
- goto error;
- memset(h, 0, sizeof *h);
-
- h->tag = strdup(tag);
- if (!h->tag)
- goto error;
-
- h->value = strdup(value);
- if (!h->value)
- goto error;
-
- return h;
-error:
- if (h)
- hc_h_free(h);
- return NULL;
-}
-
-void hc_free(struct hc * hc)
-{
- struct hc_headers * n;
-
- if (hc) {
- free(hc->hostname);
- free(hc->localpart);
- free(hc->status);
- while (hc->req_headers) {
- n = hc->req_headers->next;
- hc_h_free(hc->req_headers);
- hc->req_headers = n;
- }
- while (hc->rsp_headers) {
- n = hc->rsp_headers->next;
- hc_h_free(hc->rsp_headers);
- hc->rsp_headers = n;
- }
- if (hc->nc)
- nc_close(hc->nc);
- free(hc);
- }
-}
-
-int hc_add_req_header(struct hc * hc, const char * tag, const char * value)
-{
- struct hc_headers * h;
-
- h = hc_h_make(tag, value);
- if (!h)
- goto error;
- h->next = hc->req_headers;
- hc->req_headers = h;
- return 0;
-error:
- return -1;
-}
-
-struct hc * hc_start_request(char * url)
-{
- struct hc * hc;
- char * e;
-
- hc = malloc(sizeof *hc);
- memset(hc, 0, sizeof *hc);
-
- if (strncmp(url, "http://", 7) != 0) {
- goto error;
- }
- url += 7;
- e = strchr(url, '/');
- if (!e) {
- hc->hostname = strdup(url);
- hc->localpart = strdup("/");
- } else {
- hc->hostname = malloc(e - url + 1);
- if (!hc->hostname) goto error;
- memcpy(hc->hostname, url, e - url);
- hc->hostname[e-url] = '\0';
- hc->localpart = strdup(e);
- if (!hc->localpart) goto error;
- }
-
- if (hc_add_req_header(hc, "Host", hc->hostname) < 0)
- goto error;
-
- e = strchr(hc->hostname, ':');
- if (e) {
- *e = '\0';
- hc->port = (short)strtoul(e+1, NULL, 10);
- } else {
- hc->port = 80;
- }
-
- hc->nc = nc_open(hc->hostname, hc->port);
- if (!hc->nc)
- goto error;
-
- return hc;
-error:
- if (hc)
- hc_free(hc);
- return NULL;
-}
-
-int hc_send_request(struct hc * hc)
-{
- char buffer[1024];
- size_t l;
- struct hc_headers * h;
-
- l = strlen(hc->localpart) + strlen("GET HTTP/1.1\r\n");
- for (h = hc->req_headers; h; h = h->next)
- l += strlen(h->tag) + strlen(h->value) + 4;
- l += 3;
- if (l > sizeof buffer) {
- //fprintf(stderr, "ERROR: hc_send_request: buffer too small; need %lu\n",(unsigned long)l);
- return -1;
- }
-
- l = sprintf(buffer, "GET %s HTTP/1.1\r\n", hc->localpart);
- for (h = hc->req_headers; h; h = h->next)
- l += sprintf(buffer+l, "%s: %s\r\n", h->tag, h->value);
- l += sprintf(buffer+l, "\r\n");
- nc_write(hc->nc, (unsigned char*)buffer, l);
-
- if (nc_read_line(hc->nc, (unsigned char*)buffer, sizeof buffer) <= 0) {
- perror("ERROR: hc_send_request nc_read_line");
- return -1;
- }
-
- hc->status = strdup(buffer);
- while (nc_read_line(hc->nc, (unsigned char*)buffer, sizeof buffer) > 0) {
- char * e;
- e = strchr(buffer, ':');
- if (e) {
- *e = '\0';
- e++;
- while (isspace(*e))
- e++;
- h = hc_h_make(buffer, e);
- h->next = hc->rsp_headers;
- hc->rsp_headers = h;
- } else {
- //fprintf(stderr, "ERROR: hc_send_request got invalid header line :%s:\n", buffer);
- }
- }
-
- return 0;
-}
-
-int hc_post_request(struct hc * hc,
- int (*callback)(unsigned char *, size_t, void *),
- void * v)
-{
- char buffer[1024];
- size_t l;
- struct hc_headers * h;
-
- l = strlen(hc->localpart) + strlen("POST HTTP/1.0\r\n");
- for (h = hc->req_headers; h; h = h->next)
- l += strlen(h->tag) + strlen(h->value) + 4;
- l += 3;
- if (l > sizeof buffer) {
- //fprintf(stderr, "ERROR: hc_post_request: buffer too small; need %lu\n",(unsigned long)l);
- return -1;
- }
-
- l = sprintf(buffer, "POST %s HTTP/1.0\r\n", hc->localpart);
- for (h = hc->req_headers; h; h = h->next)
- l += sprintf(buffer+l, "%s: %s\r\n", h->tag, h->value);
- l += sprintf(buffer+l, "\r\n");
- nc_write(hc->nc, (unsigned char*)buffer, l);
-
- while ((l = callback((unsigned char*)buffer, sizeof buffer, v)) != 0) {
- int r;
- r = nc_write(hc->nc, (unsigned char*)buffer, l);
-// fprintf(stderr, "%d\n", r);
-
- }
-
- if (nc_read_line(hc->nc, (unsigned char*)buffer, sizeof buffer) <= 0) {
- perror("ERROR: hc_post_request nc_read_line");
- return -1;
- }
- hc->status = strdup(buffer);
- while (nc_read_line(hc->nc, (unsigned char*)buffer, sizeof buffer) > 0) {
- char * e;
- e = strchr(buffer, ':');
- if (e) {
- *e = '\0';
- e++;
- while (isspace(*e))
- e++;
- h = hc_h_make(buffer, e);
- h->next = hc->rsp_headers;
- hc->rsp_headers = h;
- } else {
- //fprintf(stderr, "ERROR: hc_post_request got invalid header line :%s:\n", buffer);
- }
- }
-
- return 0;
-}
-
-int hc_get_status(struct hc * hc)
-{
- return strtoul(hc->status + 9, NULL, 10);
-}
-
-char * hc_lookup_rsp_header(struct hc * hc, const char * tag)
-{
- struct hc_headers * h;
-
- for (h = hc->rsp_headers; h; h = h->next)
- if (strcasecmp(tag, h->tag) == 0)
- return h->value;
- return NULL;
-}
-
-extern int hc_read_pieces(struct hc * hc,
- void (*callback)(unsigned char *, size_t, void *),
- void * v)
-{
- char * te;
- int chunked = 0;
- int done = 0;
- char * buf;
- size_t len, len_read, octets_to_go;
- char * cl;
-
- cl = hc_lookup_rsp_header(hc, "Content-Length");
- if (cl) {
- octets_to_go = strtoul(cl, NULL, 10);
- } else {
- octets_to_go = 0;
- }
-
- te = hc_lookup_rsp_header(hc, "Transfer-Encoding");
- if (te && strcmp(te, "chunked") == 0) {
- chunked = 1;
- }
- while (!done) {
- if (chunked) {
- char lenstr[32];
-
- nc_read_line(hc->nc, (unsigned char*)lenstr, sizeof lenstr);
- len = strtoul(lenstr, NULL, 16);
- } else {
- if (cl) {
- len = octets_to_go;
- if (len > MAX_CHUNK)
- len = MAX_CHUNK;
- } else {
- len = MAX_CHUNK;
- }
- }
- if (len) {
- buf = malloc(len+1);
- len_read = nc_read(hc->nc, (unsigned char*)buf, len);
- if (len_read < len)
- done = 1;
- buf[len_read] = '\0';
- callback((unsigned char*)buf, len_read, v);
- if (cl) {
- octets_to_go -= len_read;
- if (octets_to_go == 0 && !chunked) {
- done = 1;
- }
- }
- } else {
- done = 1;
- }
- if (chunked) {
- char linebuf[80];
- /* if done, then any non-blank lines read here are
- supposed to be treated as HTTP header lines, but since
- we didn't say we could accept trailers, the server's
- only allowed to send them if it's happy with us
- discarding them. (2616 3.7b). The Replay doesn't use
- trailers anyway */
- while (nc_read_line(hc->nc, (unsigned char*)linebuf, sizeof linebuf) > 0)
- ;
- }
- }
- return 0;
-}
-
-struct chunk
-{
- char * buf;
- size_t len;
- struct chunk * next;
-};
-
-struct read_all_data
-{
- struct chunk * start;
- struct chunk * end;
- size_t total;
-};
-
-static void read_all_callback(unsigned char * buf, size_t len, void * vd)
-{
- struct read_all_data * data = vd;
- struct chunk * chunk;
-
- chunk = malloc(sizeof *chunk);
- chunk->buf = (char*)buf;
- chunk->len = len;
- chunk->next = NULL;
-
- if (data->end) {
- data->end->next = chunk;
- data->end = chunk;
- } else {
- data->start = data->end = chunk;
- }
-
- data->total += len;
-}
-
-unsigned char * hc_read_all_len(struct hc * hc, size_t * plen)
-{
- struct read_all_data data;
- struct chunk * chunk, * next;
- size_t cur;
- unsigned char * r;
-
- data.start = data.end = NULL;
- data.total = 0;
-
- hc_read_pieces(hc, read_all_callback, &data);
-
- r = malloc(data.total + 1);
- cur = 0;
- for (chunk = data.start; chunk; chunk = next) {
- memcpy(r+cur, chunk->buf, chunk->len);
- cur += chunk->len;
- free(chunk->buf);
- next = chunk->next;
- free(chunk);
- }
-
- r[data.total] = '\0';
- if (plen)
- *plen = data.total;
-
- return r;
-}
-
-unsigned char * hc_read_all(struct hc * hc)
-{
- return hc_read_all_len(hc, NULL);
-}
-
-
-extern int hc_read_pieces_len(struct hc * hc,
- void (*callback)(unsigned char *, size_t, void *),
- void * v, size_t len_to_read)
-{
- char * te;
- int chunked = 0;
- int done = 0;
- char * buf;
- size_t len, len_read, octets_to_go;
- char * cl;
-
- // NOTE: len_to_read is not currently implemented for non-chunked content.
- // The ReplayTV only sends chunked content so this doesn't matter here.
- cl = hc_lookup_rsp_header(hc, "Content-Length");
- if (cl) {
- octets_to_go = strtoul(cl, NULL, 10);
- } else {
- octets_to_go = 0;
- }
-
- te = hc_lookup_rsp_header(hc, "Transfer-Encoding");
- if (te && strcmp(te, "chunked") == 0) {
- chunked = 1;
- }
- while (!done) {
- if (chunked) {
- char lenstr[32];
-
- if (!hc->curr_chunk_len) {
- nc_read_line(hc->nc, (unsigned char*)lenstr, sizeof lenstr);
- hc->curr_chunk_len = strtoul(lenstr, NULL, 16);
- }
- if (len_to_read > hc->curr_chunk_len) {
- len = hc->curr_chunk_len;
- } else {
- len = len_to_read;
- }
- } else {
- if (cl) {
- len = octets_to_go;
- if (len > MAX_CHUNK)
- len = MAX_CHUNK;
- } else {
- len = MAX_CHUNK;
- }
- }
- if (len) {
- buf = malloc(len+1);
- len_read = nc_read(hc->nc, (unsigned char*)buf, len);
- if (len_read <= len)
- done = 1;
- buf[len_read] = '\0';
- callback((unsigned char*)buf, len_read, v);
- if (cl) {
- octets_to_go -= len_read;
- if (octets_to_go == 0 && !chunked) {
- done = 1;
- }
- }
- hc->curr_chunk_len -= len_read;
- } else {
- done = 1;
- }
- if (chunked && !hc->curr_chunk_len) {
- char linebuf[80];
- /* if done, then any non-blank lines read here are
- supposed to be treated as HTTP header lines, but since
- we didn't say we could accept trailers, the server's
- only allowed to send them if it's happy with us
- discarding them. (2616 3.7b). The Replay doesn't use
- trailers anyway */
- while (nc_read_line(hc->nc, (unsigned char*)linebuf, sizeof linebuf) > 0)
- ;
- }
- }
- return 0;
-}
-
diff --git a/lib/libRTV/httpclient.h b/lib/libRTV/httpclient.h
deleted file mode 100644
index 7f2da0e585..0000000000
--- a/lib/libRTV/httpclient.h
+++ /dev/null
@@ -1,95 +0,0 @@
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-/*
- * Overview of an HTTP request:
- *
- * 1. call hc_start_request() with an URL
- *
- * hc = hc_start_request("http://192.168.117.3/index.html");
- * if (!hc) {error}
- *
- * Right now the address in the URL must be given as an IP address, not
- * a hostname. That's a bug, not a feature.
- *
- * 2. add any necessary headers with hc_add_req_header; the Host header is
- * created automatically; any others, including User-Agent, must be
- * explicitely set
- *
- * if (!hc_add_req_header(hc, "User-Agent", "Mozilla/4.0 (Isn't everything?)") != 0) {error}
- *
- * 3. send the request; hc_send_request() uses GET, hc_post_request() uses
- * POST, with the callback function called repeatedly for the data. It
- * should return the number of bytes filled in, and signal end of data by
- * returning 0.
- *
- * if (!hc_send_request(hc)) {error}
- *
- * 4. check the returned status; 200 is the normal success code, any 2.. code
- * is a success of some sort. 3.. codes are redirects, 4.. are errors; see
- * the HTTP specs for more information
- *
- * if (hc_get_status(hc)/100 != 2) {exception of some sort}
- *
- * 5. Check any response headers you're interested in.
- *
- * last_modified = hc_lookup_rsp_header(hc, "Last-Modified");
- * if (!last_modified) {header wasn't supplied}
- *
- * 6. read the data; if the item is known to be short, you have the memory for
- * it (2x the data length; half of that as a contiguous block), and don't
- * mind waiting for all of it, get it all with hc_read_all(). If one of
- * conditions doesn't hold, call hc_read_pieces(). The callback function
- * is given a buffer to a chunk of data, the amount of data there, and
- * a pointer you supply, usually to a structure where it can store state,
- * get parameters from the original caller and return information to the
- * original caller
- *
- * if (!(data = hc_read_all(hc))) {error}
- *
- * Either way, you own the data chunk -- free() it when you're done with it
- *
- * 7. Clean up
- *
- * hc_free(hc);
- */
-#ifndef HTTPCLIENT_H
-#define HTTPCLIENT_H
-
-#include "netclient.h"
-
-#ifdef _WIN32
-# define strcasecmp(a, b) strcmp(a, b)
-#endif
-
-struct hc;
-
-extern struct hc * hc_start_request(char * url);
-extern int hc_add_req_header(struct hc * hc, const char * tag, const char * value);
-extern int hc_send_request(struct hc * hc);
-extern int hc_post_request(struct hc * hc,
- int (*callback)(unsigned char *, size_t, void *),
- void * v);
-extern int hc_get_status(struct hc * hc);
-extern char * hc_lookup_rsp_header(struct hc * hc, const char * tag);
-extern unsigned char * hc_read_all_len(struct hc * hc, size_t * plen);
-extern unsigned char * hc_read_all(struct hc * hc);
-extern int hc_read_pieces(struct hc * hc,
- void (*)(unsigned char *, size_t, void *),
- void *);
-extern int hc_read_pieces_len(struct hc * hc,
- void (*)(unsigned char *, size_t, void *),
- void *, size_t);
-extern void hc_free(struct hc * hc);
-#endif
diff --git a/lib/libRTV/httpfsclient.c b/lib/libRTV/httpfsclient.c
deleted file mode 100644
index c53ad6a9b1..0000000000
--- a/lib/libRTV/httpfsclient.c
+++ /dev/null
@@ -1,401 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * Parts based on ReplayPC 0.3 by Matthew T. Linehan and others
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "httpfsclient.h"
-#include "sleep.h"
-#include "crypt.h"
-
-#include <stdarg.h>
-#include <stdio.h>
-#include <string.h>
-#include <errno.h>
-
-int hfs_output_errors = 1;
-
-#define ARGBUFSIZE 2048
-static int make_httpfs_url(char * dst, size_t size,
- const char * address, const char * command,
- va_list args)
-{
- char * d, * tag, * value, *argp;
- int argno = 0;
- size_t l, argl;
- char argbuf[ARGBUFSIZE]; /* XXX bad, should fix this */
-
- (void) size;
-
- l = strlen(address) + strlen(command) + strlen("http:///httpfs-?");
- if (l >= size) {
- //if (hfs_output_errors)
- //fprintf(stderr, "Error: make_httpfs_url: address + command too long for buffer\n");
- return -1;
- }
-
- d = dst;
- d += sprintf(d, "http://%s/httpfs-%s?", address, command);
-
- argp = argbuf;
- argl = 0;
- while ((tag = va_arg(args, char *)) != NULL) {
- value = va_arg(args, char *);
- if (value == NULL) {
- continue;
- }
- if (argno)
- argl++;
- argl += strlen(tag)+1+strlen(value);
- if (argl >= sizeof(argbuf)) {
- //if (hfs_output_errors)
- //fprintf(stderr, "Error: make_httpfs_url: with arg %s, argbuf too small\n", tag);
- return -1;
- }
- if (argno)
- *argp++ = '&';
- argp += sprintf(argp, "%s=%s", tag, value);
- argno++;
- }
-
- if (replaytv_version.major >= 5 ||
- (replaytv_version.major == 4 && replaytv_version.minor >= 3)) {
- unsigned char ctext[ARGBUFSIZE+32] ;
- u32 ctextlen;
- unsigned int i;
-
- if (l + strlen("__Q_=") + 2*argl + 32 >= size) {
- //if (hfs_output_errors)
- // fprintf(stderr, "Error: make_httpfs_url: encrypted args too large for buffer\n");
- return -1;
- }
-
- strcpy(d, "__Q_=");
- d += strlen(d);
- rtv_encrypt(argbuf, argl, (char*)ctext, sizeof ctext, &ctextlen, 1);
- for (i = 0; i < ctextlen; i++)
- d += sprintf(d, "%02x", ctext[i]);
- } else {
- if (l + argl >= size) {
- //if (hfs_output_errors)
- //fprintf(stderr, "Error: make_httpfs_url: args too large for buffer\n");
- return -1;
- }
- strcpy(d, argbuf);
- }
-
- return 0;
-}
-
-static int add_httpfs_headers(struct hc * hc)
-{
- hc_add_req_header(hc, "Authorization", "Basic Uk5TQmFzaWM6QTd4KjgtUXQ=" );
- hc_add_req_header(hc, "User-Agent", "Replay-HTTPFS/1");
- hc_add_req_header(hc, "Accept-Encoding", "text/plain");
-
- return 0;
-}
-
-static struct hc * make_request(const char * address, const char * command,
- va_list ap)
-{
- struct hc * hc = NULL;
- char url[URLSIZE];
- int http_status;
-
- if (make_httpfs_url(url, sizeof url, address, command, ap) < 0)
- goto exit;
-
- hc = hc_start_request(url);
- if (!hc) {
- if (hfs_output_errors)
- perror("Error: make_request(): hc_start_request()");
- if (errno == 0) {
-// fprintf(stderr, "Check your clock.\n"
- // "The system clock must be within 40 seconds of the Replay's.");
- }
- goto exit;
- }
-
- if (add_httpfs_headers(hc)) {
- goto exit;
- }
-
- hc_send_request(hc);
-
- http_status = hc_get_status(hc);
- if (http_status/100 != 2) {
- //if (hfs_output_errors)
- //fprintf(stderr, "Error: http status %d\n", http_status);
- goto exit;
- }
-
- return hc;
-
-exit:
- if (hc)
- hc_free(hc);
- return NULL;
-}
-
-
-unsigned long hfs_do_simple(char ** presult, const char * address,
- const char * command, ...)
-{
- va_list ap;
- struct hc * hc;
- char * tmp, * e;
- int http_status;
- unsigned long rtv_status;
-
- va_start(ap, command);
- hc = make_request(address, command, ap);
- va_end(ap);
-
- if (!hc)
- return -1;
-
- http_status = hc_get_status(hc);
- if (http_status/100 != 2) {
- //if (hfs_output_errors)
- // fprintf(stderr, "Error: http status %d\n", http_status);
- hc_free(hc);
- return http_status;
- }
-
- tmp = (char*)hc_read_all(hc);
- hc_free(hc);
-
- e = strchr(tmp, '\n');
- if (e) {
- *presult = strdup(e+1);
- rtv_status = strtoul(tmp, NULL, 10);
- free(tmp);
- return rtv_status;
- } else if (http_status == 204) {
- *presult = NULL;
- free(tmp);
- return 0;
- } else {
- //if (hfs_output_errors)
- // fprintf(stderr, "Error: end of httpfs status line not found\n");
- return -1;
- }
-}
-
-struct hfs_data
-{
- void (*fn)(unsigned char *, size_t, void *);
- void * v;
- unsigned long status;
- u16 msec_delay;
- u8 firsttime;
- char * buffer;
- size_t bufLen;
-};
-
-/* XXX should this free the buf, or make a new one on the first block
- * and let our caller free them if it wants? */
-static void hfs_callback(unsigned char * buf, size_t len, void * vd)
-{
- struct hfs_data * data = vd;
- unsigned char * buf_data_start;
-
- if (data->firsttime) {
- unsigned char * e;
-
- data->firsttime = 0;
-
- /* First line: error code */
- e = (unsigned char*)strchr((char*)buf, '\n');
- if (e)
- *e = '\0';
- data->status = strtoul((char*)buf, NULL, 16);
-
- e++;
- len -= (e - buf);
- buf_data_start = e;
- } else {
- buf_data_start = buf;
- }
-
- data->fn(buf_data_start, len, data->v);
- free(buf);
-
- if (data->msec_delay)
- rtv_sleep(data->msec_delay);
-}
-
-unsigned long hfs_do_chunked(void (*fn)(unsigned char *, size_t, void *),
- void *v,
- const char * address,
- u16 msec_delay,
- const char * command,
- ...)
-{
- struct hfs_data data;
- struct hc * hc;
- va_list ap;
-
- va_start(ap, command);
- hc = make_request(address, command, ap);
- va_end(ap);
-
- if (!hc)
- return -1;
-
- memset(&data, 0, sizeof data);
- data.fn = fn;
- data.v = v;
- data.firsttime = 1;
- data.msec_delay = msec_delay;
-
- hc_read_pieces(hc, hfs_callback, &data);
- hc_free(hc);
-
- return data.status;
-}
-
-unsigned long hfs_do_post_simple(char ** presult, const char * address,
- int (*fn)(unsigned char *, size_t, void *),
- void *v,
- unsigned long size,
- const char * command, ...)
-{
- char buf[URLSIZE];
- va_list ap;
- struct hc * hc;
- char * tmp, * e;
- int http_status;
- unsigned long rtv_status;
-
- va_start(ap, command);
- if (make_httpfs_url(buf, sizeof buf, address, command, ap) < 0)
- return -1;
- va_end(ap);
-
- errno = 0;
- hc = hc_start_request(buf);
- if (!hc) {
- if (hfs_output_errors)
- perror("Error: hfs_do_simple(): hc_start_request()");
- if (errno == 0) {
- //fprintf(stderr, "Check your clock.\n"
- // "The system clock must be within 40 seconds of the Replay's.");
- }
- return -1;
- }
- sprintf(buf, "%lu", size);
- if (add_httpfs_headers(hc) != 0)
- return -1;
-
- hc_add_req_header(hc, "Content-Length", buf);
-
- hc_post_request(hc, fn, v);
-
- http_status = hc_get_status(hc);
- if (http_status/100 != 2) {
- //if (hfs_output_errors)
- // fprintf(stderr, "Error: http status %d\n", http_status);
- hc_free(hc);
- return http_status;
- }
-
- tmp = (char*)hc_read_all(hc);
- hc_free(hc);
-
- e = strchr(tmp, '\n');
- if (e) {
- *presult = strdup(e+1);
- rtv_status = strtoul(tmp, NULL, 10);
- free(tmp);
- return rtv_status;
- } else if (http_status == 204) {
- *presult = NULL;
- free(tmp);
- return 0;
- } else {
- //if (hfs_output_errors)
- //fprintf(stderr, "Error: end of httpfs status line not found\n");
- return -1;
- }
-}
-
-
-static void hfs_callback2(unsigned char * buf, size_t len, void * vd)
-{
- struct hfs_data * data = vd;
- unsigned char * buf_data_start;
-
- if (data->firsttime) {
- unsigned char * e;
-
- data->firsttime = 0;
-
- /* First line: error code */
- e = (unsigned char*)strchr((char*)buf, '\n');
- if (e)
- *e = '\0';
- data->status = strtoul((char*)buf, NULL, 16);
-
- e++;
- len -= (e - buf);
- buf_data_start = e;
- } else {
- buf_data_start = buf;
- }
-
- /* append to buffer, this may be called multiple times */
- memcpy(data->buffer+data->bufLen, buf_data_start, len);
- data->bufLen += len;
- free(buf);
-}
-
-struct hc * hfs_do_chunked_open(const char * address, const char * command, ...)
-{
- struct hc * hc;
- va_list ap;
-
- va_start(ap, command);
- hc = make_request(address, command, ap);
- va_end(ap);
-
- return hc;
-}
-
-size_t hfs_do_chunked_read(struct hc * hc, char * buf, size_t pos, size_t len)
-{
- struct hfs_data data;
-
- memset(&data, 0, sizeof data);
- data.buffer = buf;
- if (!pos)
- data.firsttime = 1;
-
- hc_read_pieces_len(hc, hfs_callback2, &data, len);
-
- return data.bufLen;
-}
-
-void hfs_do_chunked_close(struct hc * hc)
-{
- hc_free(hc);
-}
-
diff --git a/lib/libRTV/httpfsclient.h b/lib/libRTV/httpfsclient.h
deleted file mode 100644
index a949b86158..0000000000
--- a/lib/libRTV/httpfsclient.h
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * Parts based on ReplayPC 0.3 by Matthew T. Linehan and others
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-/*
- * These all return:
- * 0 for complete success
- * -1 for a miscellaneous client error
- * an HTTP error code if the server returned one (300-499 range)
- * an httpfs error code if the httpfs provider returned one (8082xxxx range,
- * it seems)
- *
- * hfs_do_simple: makes a request, collects all the data, gives it back
- * hfs_do_chunked: makes a request, gives it to a callback function in chunks
- * the callback does *not* own the data, and must not free it
- * or keep a pointer to it; copy it if you want to keep it.
- * This difference from the httpclient layer is ugly and may
- * change at some point, even though that will cause a memory
- * leak in all existing clients
- * hfs_do_post_simple: POSTs a request, using a callback function to get chunks
- * of data. The size must be known beforehand, an apparent
- * unfortunate limitation of the ReplayTV httpfs server.
- * writefile is the only (current/known) httpfs command that
- * needs POST
- *
- * command: the httpfs command, one of: ls fstat volinfo cp mv rm create
- * mkdir readfile writefile
- * arguments are passed as tag/value pairs, NULL terminated.
- * args for cp: src dest
- * arg for create, fstat, ls, mkdir, rm, volinfo: name
- * args for mv: old new
- * args for readfile, writefile: name pos size
- */
-
-#ifndef HTTPFSCLIENT_H
-#define HTTPFSCLIENT_H
-
-#include "httpclient.h"
-#include "rtv.h"
-
-#define URLSIZE 512
-
-extern int hfs_output_errors;
-
-extern unsigned long hfs_do_simple(char ** presult,
- const char * address, const char * command,
- ...);
-extern unsigned long hfs_do_chunked(void (*)(unsigned char *, size_t, void *),
- void *,
- const char * address, u16 msec_delay,
- const char * command,
- ...);
-extern unsigned long hfs_do_post_simple(char ** presult, const char * address,
- int (*fn)(unsigned char *, size_t, void *),
- void *v,
- unsigned long size,
- const char * command,
- ...);
-extern struct hc * hfs_do_chunked_open(const char * address, const char * command, ...);
-extern size_t hfs_do_chunked_read(struct hc * hc, char * buf, size_t pos, size_t len);
-extern void hfs_do_chunked_close(struct hc * hc);
-
-
-#define RTV_ENOFILE 80820005
-#define RTV_EEXIST 80820018
-#define RTV_EPERM 80820024
-#endif
diff --git a/lib/libRTV/interface.c b/lib/libRTV/interface.c
deleted file mode 100644
index 0aa0e54013..0000000000
--- a/lib/libRTV/interface.c
+++ /dev/null
@@ -1,363 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * libRTV
- * by rtvguy
- * A library encapsulating most of the functionality of John Todd Larason's
- * ReplayPC project and Lee Thompson's GuideParser project.
- *
- * libRTV includes much of the original source code by the authors of the
- * ReplayPC and GuideParser projects. GuideParser was modified under the
- * terms of its license to remove support for parsing ReplayChannels and
- * add support for parsing all current versions of ReplayGuide data. ReplayPC
- * was modified under the terms of its license to improve efficiency of the
- * network code for the purposes of streaming video to a calling program, as
- * well as to remove reliance on the OpenSSL library for MD5 functions.
- *
- * ReplayPC Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- * GuideParser Copyright (C) 2002-2003 Lee Thompson <thompsonl@logh.net>,
- * Dan Frumin <rtv@frumin.com>, Todd Larason <jtl@molehill.org>
- * libRTV Copyright (C) 2003-2004 rtvguy
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include <string.h>
-#include <stdio.h>
-
-#include "httpfsclient.h"
-#include "guideclient.h"
-#include "GuideParser.h"
-#include "interface.h"
-
-#ifdef _XBOX
-#include <Xtl.h>
-typedef SOCKET socket_fd;
-#elif defined _WIN32
-#include <WS2tcpip.h>
-typedef SOCKET socket_fd;
-#else
-#include <unistd.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <arpa/inet.h>
-#include <sys/select.h>
-#include <stdlib.h>
-#define closesocket(fd) close(fd)
-typedef int socket_fd;
-typedef socket_fd SOCKET;
-#define INVALID_SOCKET (-1)
-#endif
-
-//*********************************************************************************************
-u64 rtv_get_filesize(const char* strHostName, const char* strFileName)
-{
- char * data = NULL;
- char ** lines;
- int num_lines;
- int i;
- u64 size;
- unsigned long status;
-
- status = hfs_do_simple(&data, strHostName,
- "fstat",
- "name", strFileName,
- NULL);
- if (status != 0) {
- //fprintf(stderr, "Error fstat %ld\n", status);
- free(data);
- return 0;
- }
-
- num_lines = rtv_split_lines(data, &lines);
- for (i = 0; i < num_lines; i++) {
- if (strncmp(lines[i], "size=", 5) == 0) {
- sscanf(lines[i]+5, "%llu", &size);
- break;
- }
- }
-
- rtv_free_lines(num_lines, lines);
- free(data);
- return size;
-}
-//*********************************************************************************************
-unsigned long rtv_get_guide(unsigned char ** result, const char * address)
-{
- char * orig_timestamp = "0";
- unsigned char * timestamp = NULL;
- unsigned long size;
- unsigned long status;
-
- status = guide_client_get_snapshot(result, &timestamp, &size,
- address, orig_timestamp);
- if (timestamp)
- free(timestamp);
- if (status != 0) {
- //fprintf(stderr, "Error get_snapshot %ld\n", status);
- return 0;
- }
-
- return size;
-}
-//*********************************************************************************************
-int rtv_parse_guide(char * szOutputBuffer, const char * szInput, const size_t InputSize)
-{
- return(GuideParser(szOutputBuffer, szInput, InputSize));
-}
-//*********************************************************************************************
-int rtv_get_guide_xml(unsigned char ** result, const char * address)
-{
- unsigned long gsize;
- unsigned char * lresult = NULL;
-
- gsize = rtv_get_guide(&lresult, address);
- if (!gsize)
- {
- if (lresult)
- free (lresult);
- return 0;
- }
-
- *result = malloc(gsize * 1.5);
- if (!*result)
- {
- if (lresult)
- free (lresult);
- return 0;
- }
-
- rtv_parse_guide((char*)*result, (char*)lresult, gsize);
-
- if (lresult)
- free (lresult);
- return 1;
-}
-//*********************************************************************************************
-int rtv_list_files(unsigned char ** result, const char * address, const char * path)
-{
- unsigned long status;
-
- status = hfs_do_simple((char **)result, address,
- "ls",
- "name", path,
- NULL);
- if (status != 0) {
- //fprintf(stderr, "Error %ld\n", status);
- if (result)
- free(result);
- return 0;
- }
-
- return 1;
-}
-//*********************************************************************************************
-RTVD rtv_open_file(const char * address, const char * strFileName, u64 filePos)
-{
- RTVD rtvd;
- char szOffset[32];
-
- rtvd = malloc(sizeof *rtvd);
-
- rtvd->firstReadDone = 0;
-#ifdef _LINUX
- sprintf(szOffset,"%llu",filePos);
-#else
- _i64toa(filePos,szOffset,10);
-#endif
-
- rtvd->hc = hfs_do_chunked_open( address,
- "readfile",
- "pos", szOffset,
- "name", strFileName,
- NULL);
- return rtvd;
-}
-//*********************************************************************************************
-size_t rtv_read_file(RTVD rtvd, char * lpBuf, size_t uiBufSize)
-{
- size_t lenread;
-
- lenread = hfs_do_chunked_read(rtvd->hc, (char *) lpBuf, rtvd->firstReadDone, uiBufSize);
- rtvd->firstReadDone = 1;
-
- return lenread;
-}
-//*********************************************************************************************
-void rtv_close_file(RTVD rtvd)
-{
- hfs_do_chunked_close(rtvd->hc);
- free(rtvd);
-}
-//*********************************************************************************************
-int rtv_discovery(struct RTV ** result, unsigned long msTimeout)
-{
- const char upnpQuery[] = "M-SEARCH * HTTP/1.1\r\nHOST: 239.255.255.250:1900\r\nMAN: \"ssdp:discover\"\r\nST: urn:replaytv-com:device:ReplayDevice:1\r\nMX: 3\r\n\r\n";
- const char httpQuery[] = "GET /%s HTTP/1.1\r\nHost: %s\r\n\r\n";
- char sendBuf[128];
- char upnpFile[32];
- char * p1, * p2;
- char msg[2048];
- int opt;
- int r, len, numRTV;
- SOCKET s1, s2;
- struct timeval tv;
- struct RTV * rtv = NULL;
- fd_set fds1, fds2;
- struct sockaddr_in sin; /* send address structure */
- struct sockaddr_in sin2; /* receive address structure */
-
- // Need to initialize Winsock on Win32
-#if defined(_WIN32) && !defined(_XBOX)
- WSADATA wd;
- if (WSAStartup(MAKEWORD(2,2), &wd) == -1)
- {
- goto error;
- }
-#endif
- s1 = 0;
- s2 = 0;
-
- // Set up the information for the UPNP port connection
- sin.sin_family = AF_INET;
- sin.sin_port = htons(1900);
-
- // For some reason, the UPNP address doesn't work on Xbox; so we
- // use the broadcast address, which seems to work.
-#if defined(_XBOX) || defined(_WIN32)
- sin.sin_addr.S_un.S_addr = htonl(INADDR_BROADCAST);
-#else
- inet_aton("239.255.255.250",(struct in_addr*)&sin.sin_addr.s_addr);
-#endif
-
- if ((s1 = socket(AF_INET, SOCK_DGRAM, 0)) < 0)
- {
- //fprintf(stderr,"error: socket(): %d\n", errno);
- goto error;
- }
-
- opt = 1;
- if ((setsockopt(s1, SOL_SOCKET, SO_BROADCAST, (const void*)&opt, sizeof(opt))) < 0) {
- goto error;
- }
-
- // Send the UPNP query
- r = sendto(s1, upnpQuery, (int) strlen(upnpQuery), 0, (struct sockaddr *)&sin, sizeof(sin));
-
- // Initialize variables in preparation to receive responses from the ReplayTV(s)
- numRTV = 0;
- rtv = calloc(1, sizeof(struct RTV));
- if (!rtv) goto error;
- //memset(rtv,0,sizeof(struct RTV));
- tv.tv_sec = msTimeout / 1000;
- tv.tv_usec = (msTimeout % 1000) * 1000;
- FD_ZERO(&fds1);
- FD_SET(s1, &fds1);
-
- // Read the response from a ReplayTV, loop while there are more responses waiting
- while (select((int) s1 + 1, &fds1, NULL, NULL, &tv))
- {
- len = sizeof(struct sockaddr);
- r = recvfrom(s1, msg, sizeof(msg), 0, (struct sockaddr *)&sin2, (socklen_t*)&len);
- if (r < 0)
- {
- //fprintf(stderr, "recvfrom error: %d\n", errno);
- } else {
- numRTV++;
-
- // Reallocate memory to accomodate the additional ReplayTVs found
- if (numRTV > 1)
- {
- rtv = realloc(rtv, sizeof(struct RTV) * numRTV);
- if (!rtv) goto error;
- }
- //printf("ip: %s\n", inet_ntoa(sin2.sin_addr));
-
- // Extract IP part and copy to hostname
- p1 = strstr(msg, "LOCATION: http://") + 17;
- p2 = strchr(p1, '/');
- *p2 = '\0';
- strcpy(rtv[numRTV-1].hostname, p1);
-
- // Extract UPNP device description file part and copy to upnpFile
- p1 = p2 + 1;
- p2 = strchr(p1, '\r');
- *p2 = '\0';
- strcpy(upnpFile, p1);
-
- strcpy(rtv[numRTV-1].friendlyName, rtv[numRTV-1].hostname);
-
- // Open socket for connecting to ReplayTV to get its friendlyName
- if ((s2 = socket(AF_INET, SOCK_STREAM, 0)) >= 0) {
- // Connect to ReplayTV
- sin2.sin_port = htons(80);
- r = connect(s2, (struct sockaddr *)&sin2, sizeof(sin2));
- sprintf(sendBuf, httpQuery, upnpFile, rtv[numRTV-1].hostname);
- r = send(s2, sendBuf, (int) strlen(sendBuf), 0);
- FD_ZERO(&fds2);
- FD_SET(s2, &fds2);
- // Read response if there is one
- if (select((int) s2 + 1, &fds2, NULL, NULL, &tv)) {
- p1 = msg;
- p2 = p1 + sizeof(msg);
- r = 0;
- do {
- p1+=r;
- r = recv(s2, p1, p2-p1, 0);
- } while(r>0 && (p2-p1) > 0);
- msg[sizeof(msg)-1] = 0;
-
- p1 = strstr(msg, "<friendlyName>");
- if(p1) {
- p1 += 14;
- p2 = strchr(p1, '<');
- if(p2)
- {
- *p2 = '\0';
- strcpy(rtv[numRTV-1].friendlyName, p1);
- }
- }
- }
-
- r = closesocket(s2);
- s2 = 0;
- }
- }
- }
- r = closesocket(s1);
- s1 = 0;
-
- //Need to clean up the Winsock on Win32
-#if defined(_WIN32) && !defined(_XBOX)
- WSACleanup();
-#endif
-
- // Pass back the pointer to the array of rtv and return number of ReplayTV(s) found
- *result = rtv;
- return numRTV;
-
- // Clean up and return error
-error:
- if (rtv) free(rtv);
- if (s1) closesocket(s1);
- if (s2) closesocket(s2);
-#if defined(_WIN32) && !defined(_XBOX)
- WSACleanup();
-#endif
- return -1;
-}
-//*********************************************************************************************
-
diff --git a/lib/libRTV/interface.h b/lib/libRTV/interface.h
deleted file mode 100644
index 501f7b6959..0000000000
--- a/lib/libRTV/interface.h
+++ /dev/null
@@ -1,33 +0,0 @@
-
-
-#ifndef RTVINTERFACE_H
-#define RTVINTERFACE_H
-
-#include "rtv.h"
-
-struct rtv_data
-{
- struct hc * hc;
- short firstReadDone;
-};
-
-struct RTV
-{
- char hostname[16];
- char friendlyName[32];
-};
-
-typedef struct rtv_data * RTVD;
-
-extern u64 rtv_get_filesize(const char* strHostName, const char* strFileName);
-extern unsigned long rtv_get_guide(unsigned char ** result, const char * address);
-extern int rtv_parse_guide(char * szOutputBuffer, const char * szInput, const size_t InputSize);
-extern int rtv_get_guide_xml(unsigned char ** result, const char * address);
-extern int rtv_list_files(unsigned char ** result, const char * address, const char * path);
-extern RTVD rtv_open_file(const char * address, const char * strFileName, u64 filePos);
-extern size_t rtv_read_file(RTVD rtvd, char * lpBuf, size_t uiBufSize);
-extern void rtv_close_file(RTVD rtvd);
-extern int rtv_discovery(struct RTV ** result, unsigned long msTimeout);
-
-#endif
-
diff --git a/lib/libRTV/libRTV.lib b/lib/libRTV/libRTV.lib
deleted file mode 100755
index 08637e9a72..0000000000
--- a/lib/libRTV/libRTV.lib
+++ /dev/null
Binary files differ
diff --git a/lib/libRTV/libRTV.sln b/lib/libRTV/libRTV.sln
deleted file mode 100644
index 0713f1c274..0000000000
--- a/lib/libRTV/libRTV.sln
+++ /dev/null
@@ -1,30 +0,0 @@
-Microsoft Visual Studio Solution File, Format Version 8.00
-Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libRTV", "libRTV.vcproj", "{DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}"
- ProjectSection(ProjectDependencies) = postProject
- EndProjectSection
-EndProject
-Global
- GlobalSection(SolutionConfiguration) = preSolution
- Debug = Debug
- Profile = Profile
- Profile_FastCap = Profile_FastCap
- Release = Release
- Release_LTCG = Release_LTCG
- EndGlobalSection
- GlobalSection(ProjectConfiguration) = postSolution
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Debug.ActiveCfg = Debug|Win32
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Debug.Build.0 = Debug|Win32
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Profile.ActiveCfg = Profile|Xbox
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Profile.Build.0 = Profile|Xbox
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Profile_FastCap.ActiveCfg = Profile_FastCap|Xbox
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Profile_FastCap.Build.0 = Profile_FastCap|Xbox
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Release.ActiveCfg = Release|Win32
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Release.Build.0 = Release|Win32
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Release_LTCG.ActiveCfg = Release_LTCG|Xbox
- {DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}.Release_LTCG.Build.0 = Release_LTCG|Xbox
- EndGlobalSection
- GlobalSection(ExtensibilityGlobals) = postSolution
- EndGlobalSection
- GlobalSection(ExtensibilityAddIns) = postSolution
- EndGlobalSection
-EndGlobal
diff --git a/lib/libRTV/libRTV.vcxproj b/lib/libRTV/libRTV.vcxproj
deleted file mode 100644
index c13b8f7d29..0000000000
--- a/lib/libRTV/libRTV.vcxproj
+++ /dev/null
@@ -1,98 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
- <ItemGroup Label="ProjectConfigurations">
- <ProjectConfiguration Include="Debug|Win32">
- <Configuration>Debug</Configuration>
- <Platform>Win32</Platform>
- </ProjectConfiguration>
- <ProjectConfiguration Include="Release|Win32">
- <Configuration>Release</Configuration>
- <Platform>Win32</Platform>
- </ProjectConfiguration>
- </ItemGroup>
- <PropertyGroup Label="Globals">
- <ProjectGuid>{DD4818AE-7E35-40B7-A6A0-0FF83AA1C916}</ProjectGuid>
- <Keyword>XboxProj</Keyword>
- </PropertyGroup>
- <Import Project="$(SolutionDir)\XBMC.core-defaults.props" />
- <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
- <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
- <ConfigurationType>StaticLibrary</ConfigurationType>
- <UseDebugLibraries>false</UseDebugLibraries>
- <CharacterSet>MultiByte</CharacterSet>
- </PropertyGroup>
- <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
- <ConfigurationType>StaticLibrary</ConfigurationType>
- <UseDebugLibraries>true</UseDebugLibraries>
- <CharacterSet>MultiByte</CharacterSet>
- </PropertyGroup>
- <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
- <ImportGroup Label="ExtensionSettings">
- </ImportGroup>
- <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets">
- <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
- <Import Project="$(SolutionDir)\XBMC.defaults.props" />
- </ImportGroup>
- <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets">
- <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
- <Import Project="$(SolutionDir)\XBMC.defaults.props" />
- </ImportGroup>
- <PropertyGroup Label="UserMacros" />
- <PropertyGroup>
- <_ProjectFileVersion>10.0.30319.1</_ProjectFileVersion>
- <OutDir Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">$(SolutionDir)libs\$(TargetName)\$(Configuration)\</OutDir>
- <IntDir Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">$(SolutionDir)objs\$(TargetName)\$(Configuration)\</IntDir>
- <OutDir Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">$(SolutionDir)libs\$(TargetName)\$(Configuration)\</OutDir>
- <IntDir Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">$(SolutionDir)objs\$(TargetName)\$(Configuration)\</IntDir>
- <TargetName Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">$(ProjectName)_win32</TargetName>
- <TargetName Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">$(ProjectName)_win32</TargetName>
- </PropertyGroup>
- <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
- <ClCompile>
- <PreprocessorDefinitions>_LIB;_CRT_SECURE_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;_SECURE_SCL=0;%(PreprocessorDefinitions)</PreprocessorDefinitions>
- <PrecompiledHeader>
- </PrecompiledHeader>
- <SmallerTypeCheck>true</SmallerTypeCheck>
- </ClCompile>
- </ItemDefinitionGroup>
- <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
- <ClCompile>
- <PreprocessorDefinitions>_LIB;_CRT_SECURE_NO_WARNINGS;_CRT_NONSTDC_NO_DEPRECATE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
- <PrecompiledHeader>
- </PrecompiledHeader>
- <RuntimeTypeInfo>true</RuntimeTypeInfo>
- </ClCompile>
- <Lib>
- <OutputFile>$(OutDir)$(TargetName)$(TargetExt)</OutputFile>
- </Lib>
- </ItemDefinitionGroup>
- <ItemGroup>
- <ClCompile Include="crypt.c" />
- <ClCompile Include="guideclient.c" />
- <ClCompile Include="GuideParser.cpp">
- <CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
- </ClCompile>
- <ClCompile Include="httpclient.c" />
- <ClCompile Include="httpfsclient.c" />
- <ClCompile Include="interface.c" />
- <ClCompile Include="md5.c" />
- <ClCompile Include="netclient.c" />
- <ClCompile Include="rtv.c" />
- <ClCompile Include="sleep.c" />
- </ItemGroup>
- <ItemGroup>
- <ClInclude Include="crypt.h" />
- <ClInclude Include="guideclient.h" />
- <ClInclude Include="GuideParser.h" />
- <ClInclude Include="httpclient.h" />
- <ClInclude Include="httpfsclient.h" />
- <ClInclude Include="interface.h" />
- <ClInclude Include="md5.h" />
- <ClInclude Include="netclient.h" />
- <ClInclude Include="rtv.h" />
- <ClInclude Include="sleep.h" />
- </ItemGroup>
- <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
- <ImportGroup Label="ExtensionTargets">
- </ImportGroup>
-</Project> \ No newline at end of file
diff --git a/lib/libRTV/libRTV.vcxproj.filters b/lib/libRTV/libRTV.vcxproj.filters
deleted file mode 100644
index 86d51f781e..0000000000
--- a/lib/libRTV/libRTV.vcxproj.filters
+++ /dev/null
@@ -1,77 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
- <ItemGroup>
- <Filter Include="Source Files">
- <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>
- <Extensions>cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>
- </Filter>
- <Filter Include="Header Files">
- <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>
- <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>
- </Filter>
- </ItemGroup>
- <ItemGroup>
- <ClCompile Include="crypt.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="guideclient.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="GuideParser.cpp">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="httpclient.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="httpfsclient.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="interface.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="md5.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="netclient.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="rtv.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- <ClCompile Include="sleep.c">
- <Filter>Source Files</Filter>
- </ClCompile>
- </ItemGroup>
- <ItemGroup>
- <ClInclude Include="crypt.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="guideclient.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="GuideParser.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="httpclient.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="httpfsclient.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="interface.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="md5.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="netclient.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="rtv.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- <ClInclude Include="sleep.h">
- <Filter>Header Files</Filter>
- </ClInclude>
- </ItemGroup>
-</Project> \ No newline at end of file
diff --git a/lib/libRTV/libRTVd.lib b/lib/libRTV/libRTVd.lib
deleted file mode 100755
index 61b4c8d77b..0000000000
--- a/lib/libRTV/libRTVd.lib
+++ /dev/null
Binary files differ
diff --git a/lib/libRTV/md5.c b/lib/libRTV/md5.c
deleted file mode 100644
index 73dbb1d780..0000000000
--- a/lib/libRTV/md5.c
+++ /dev/null
@@ -1,337 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * RFC 1321 compliant MD5 implementation,
- * by Christophe Devine <devine(at)cr0.net>
- * this program is licensed under the GPL.
- */
-
-#include <string.h>
-
-#include "md5.h"
-
-#define GET_UINT32(n,b,i) \
-{ \
- (n) = ( (uint32) (b)[(i) ] ) \
- | ( (uint32) (b)[(i) + 1] << 8 ) \
- | ( (uint32) (b)[(i) + 2] << 16 ) \
- | ( (uint32) (b)[(i) + 3] << 24 ); \
-}
-
-#define PUT_UINT32(n,b,i) \
-{ \
- (b)[(i) ] = (uint8) ( (n) ); \
- (b)[(i) + 1] = (uint8) ( (n) >> 8 ); \
- (b)[(i) + 2] = (uint8) ( (n) >> 16 ); \
- (b)[(i) + 3] = (uint8) ( (n) >> 24 ); \
-}
-
-void rtv_md5_starts( rtv_md5_context *ctx )
-{
- ctx->total[0] = 0;
- ctx->total[1] = 0;
-
- ctx->state[0] = 0x67452301;
- ctx->state[1] = 0xEFCDAB89;
- ctx->state[2] = 0x98BADCFE;
- ctx->state[3] = 0x10325476;
-}
-
-void rtv_md5_process( rtv_md5_context *ctx, const uint8 data[64] )
-{
- uint32 X[16], A, B, C, D;
-
- GET_UINT32( X[0], data, 0 );
- GET_UINT32( X[1], data, 4 );
- GET_UINT32( X[2], data, 8 );
- GET_UINT32( X[3], data, 12 );
- GET_UINT32( X[4], data, 16 );
- GET_UINT32( X[5], data, 20 );
- GET_UINT32( X[6], data, 24 );
- GET_UINT32( X[7], data, 28 );
- GET_UINT32( X[8], data, 32 );
- GET_UINT32( X[9], data, 36 );
- GET_UINT32( X[10], data, 40 );
- GET_UINT32( X[11], data, 44 );
- GET_UINT32( X[12], data, 48 );
- GET_UINT32( X[13], data, 52 );
- GET_UINT32( X[14], data, 56 );
- GET_UINT32( X[15], data, 60 );
-
-#define S(x,n) ((x << n) | ((x & 0xFFFFFFFF) >> (32 - n)))
-
-#define P(a,b,c,d,k,s,t) \
-{ \
- a += F(b,c,d) + X[k] + t; a = S(a,s) + b; \
-}
-
- A = ctx->state[0];
- B = ctx->state[1];
- C = ctx->state[2];
- D = ctx->state[3];
-
-#define F(x,y,z) (z ^ (x & (y ^ z)))
-
- P( A, B, C, D, 0, 7, 0xD76AA478 );
- P( D, A, B, C, 1, 12, 0xE8C7B756 );
- P( C, D, A, B, 2, 17, 0x242070DB );
- P( B, C, D, A, 3, 22, 0xC1BDCEEE );
- P( A, B, C, D, 4, 7, 0xF57C0FAF );
- P( D, A, B, C, 5, 12, 0x4787C62A );
- P( C, D, A, B, 6, 17, 0xA8304613 );
- P( B, C, D, A, 7, 22, 0xFD469501 );
- P( A, B, C, D, 8, 7, 0x698098D8 );
- P( D, A, B, C, 9, 12, 0x8B44F7AF );
- P( C, D, A, B, 10, 17, 0xFFFF5BB1 );
- P( B, C, D, A, 11, 22, 0x895CD7BE );
- P( A, B, C, D, 12, 7, 0x6B901122 );
- P( D, A, B, C, 13, 12, 0xFD987193 );
- P( C, D, A, B, 14, 17, 0xA679438E );
- P( B, C, D, A, 15, 22, 0x49B40821 );
-
-#undef F
-
-#define F(x,y,z) (y ^ (z & (x ^ y)))
-
- P( A, B, C, D, 1, 5, 0xF61E2562 );
- P( D, A, B, C, 6, 9, 0xC040B340 );
- P( C, D, A, B, 11, 14, 0x265E5A51 );
- P( B, C, D, A, 0, 20, 0xE9B6C7AA );
- P( A, B, C, D, 5, 5, 0xD62F105D );
- P( D, A, B, C, 10, 9, 0x02441453 );
- P( C, D, A, B, 15, 14, 0xD8A1E681 );
- P( B, C, D, A, 4, 20, 0xE7D3FBC8 );
- P( A, B, C, D, 9, 5, 0x21E1CDE6 );
- P( D, A, B, C, 14, 9, 0xC33707D6 );
- P( C, D, A, B, 3, 14, 0xF4D50D87 );
- P( B, C, D, A, 8, 20, 0x455A14ED );
- P( A, B, C, D, 13, 5, 0xA9E3E905 );
- P( D, A, B, C, 2, 9, 0xFCEFA3F8 );
- P( C, D, A, B, 7, 14, 0x676F02D9 );
- P( B, C, D, A, 12, 20, 0x8D2A4C8A );
-
-#undef F
-
-#define F(x,y,z) (x ^ y ^ z)
-
- P( A, B, C, D, 5, 4, 0xFFFA3942 );
- P( D, A, B, C, 8, 11, 0x8771F681 );
- P( C, D, A, B, 11, 16, 0x6D9D6122 );
- P( B, C, D, A, 14, 23, 0xFDE5380C );
- P( A, B, C, D, 1, 4, 0xA4BEEA44 );
- P( D, A, B, C, 4, 11, 0x4BDECFA9 );
- P( C, D, A, B, 7, 16, 0xF6BB4B60 );
- P( B, C, D, A, 10, 23, 0xBEBFBC70 );
- P( A, B, C, D, 13, 4, 0x289B7EC6 );
- P( D, A, B, C, 0, 11, 0xEAA127FA );
- P( C, D, A, B, 3, 16, 0xD4EF3085 );
- P( B, C, D, A, 6, 23, 0x04881D05 );
- P( A, B, C, D, 9, 4, 0xD9D4D039 );
- P( D, A, B, C, 12, 11, 0xE6DB99E5 );
- P( C, D, A, B, 15, 16, 0x1FA27CF8 );
- P( B, C, D, A, 2, 23, 0xC4AC5665 );
-
-#undef F
-
-#define F(x,y,z) (y ^ (x | ~z))
-
- P( A, B, C, D, 0, 6, 0xF4292244 );
- P( D, A, B, C, 7, 10, 0x432AFF97 );
- P( C, D, A, B, 14, 15, 0xAB9423A7 );
- P( B, C, D, A, 5, 21, 0xFC93A039 );
- P( A, B, C, D, 12, 6, 0x655B59C3 );
- P( D, A, B, C, 3, 10, 0x8F0CCC92 );
- P( C, D, A, B, 10, 15, 0xFFEFF47D );
- P( B, C, D, A, 1, 21, 0x85845DD1 );
- P( A, B, C, D, 8, 6, 0x6FA87E4F );
- P( D, A, B, C, 15, 10, 0xFE2CE6E0 );
- P( C, D, A, B, 6, 15, 0xA3014314 );
- P( B, C, D, A, 13, 21, 0x4E0811A1 );
- P( A, B, C, D, 4, 6, 0xF7537E82 );
- P( D, A, B, C, 11, 10, 0xBD3AF235 );
- P( C, D, A, B, 2, 15, 0x2AD7D2BB );
- P( B, C, D, A, 9, 21, 0xEB86D391 );
-
-#undef F
-
- ctx->state[0] += A;
- ctx->state[1] += B;
- ctx->state[2] += C;
- ctx->state[3] += D;
-}
-
-void rtv_md5_update( rtv_md5_context *ctx, const uint8 *input, uint32 length )
-{
- uint32 left, fill;
-
- if( ! length ) return;
-
- left = ctx->total[0] & 0x3F;
- fill = 64 - left;
-
- ctx->total[0] += length;
- ctx->total[0] &= 0xFFFFFFFF;
-
- if( ctx->total[0] < length )
- ctx->total[1]++;
-
- if( left && length >= fill )
- {
- memcpy( (void *) (ctx->buffer + left),
- (void *) input, fill );
- rtv_md5_process( ctx, ctx->buffer );
- length -= fill;
- input += fill;
- left = 0;
- }
-
- while( length >= 64 )
- {
- rtv_md5_process( ctx, input );
- length -= 64;
- input += 64;
- }
-
- if( length )
- {
- memcpy( (void *) (ctx->buffer + left),
- (void *) input, length );
- }
-}
-
-static uint8 rtv_md5_padding[64] =
-{
- 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
-};
-
-void rtv_md5_finish( rtv_md5_context *ctx, uint8 digest[16] )
-{
- uint32 last, padn;
- uint32 high, low;
- uint8 msglen[8];
-
- high = ( ctx->total[0] >> 29 )
- | ( ctx->total[1] << 3 );
- low = ( ctx->total[0] << 3 );
-
- PUT_UINT32( low, msglen, 0 );
- PUT_UINT32( high, msglen, 4 );
-
- last = ctx->total[0] & 0x3F;
- padn = ( last < 56 ) ? ( 56 - last ) : ( 120 - last );
-
- rtv_md5_update( ctx, rtv_md5_padding, padn );
- rtv_md5_update( ctx, msglen, 8 );
-
- PUT_UINT32( ctx->state[0], digest, 0 );
- PUT_UINT32( ctx->state[1], digest, 4 );
- PUT_UINT32( ctx->state[2], digest, 8 );
- PUT_UINT32( ctx->state[3], digest, 12 );
-}
-
-#ifdef TEST
-
-#include <stdlib.h>
-#include <stdio.h>
-
-/*
- * those are the standard RFC 1321 test vectors
- */
-
-static char *msg[] =
-{
- "",
- "a",
- "abc",
- "message digest",
- "abcdefghijklmnopqrstuvwxyz",
- "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",
- "12345678901234567890123456789012345678901234567890123456789012" \
- "345678901234567890"
-};
-
-static char *val[] =
-{
- "d41d8cd98f00b204e9800998ecf8427e",
- "0cc175b9c0f1b6a831c399e269772661",
- "900150983cd24fb0d6963f7d28e17f72",
- "f96b697d7cb7938d525a2f31aaf161d0",
- "c3fcd3d76192e4007dfb496cca67e13b",
- "d174ab98d277d9f5a5611c2c9f419d9f",
- "57edf4a22be3c955ac49da2e2107b67a"
-};
-
-int main( int argc, char *argv[] )
-{
- FILE *f;
- int i, j;
- char output[33];
- rtv_md5_context ctx;
- unsigned char buf[1000];
- unsigned char md5sum[16];
-
- if( argc < 2 )
- {
- //printf( "\n MD5 Validation Tests:\n\n" );
-
- for( i = 0; i < 7; i++ )
- {
- //printf( " Test %d ", i + 1 );
-
- rtv_md5_starts( &ctx );
- rtv_md5_update( &ctx, (uint8 *) msg[i], strlen( msg[i] ) );
- rtv_md5_finish( &ctx, md5sum );
-
- for( j = 0; j < 16; j++ )
- {
- sprintf( output + j * 2, "%02x", md5sum[j] );
- }
-
- if( memcmp( output, val[i], 32 ) )
- {
- //printf( "failed!\n" );
- return( 1 );
- }
-
- //printf( "passed.\n" );
- }
-
- //printf( "\n" );
- }
- else
- {
- if( ! ( f = fopen( argv[1], "rb" ) ) )
- {
- perror( "fopen" );
- return( 1 );
- }
-
- rtv_md5_starts( &ctx );
-
- while( ( i = fread( buf, 1, sizeof( buf ), f ) ) > 0 )
- {
- rtv_md5_update( &ctx, buf, i );
- }
-
- rtv_md5_finish( &ctx, md5sum );
-
- for( j = 0; j < 16; j++ )
- {
- //printf( "%02x", md5sum[j] );
- }
-
- //printf( " %s\n", argv[1] );
- }
-
- return( 0 );
-}
-
-#endif
diff --git a/lib/libRTV/md5.h b/lib/libRTV/md5.h
deleted file mode 100644
index bde04de12b..0000000000
--- a/lib/libRTV/md5.h
+++ /dev/null
@@ -1,24 +0,0 @@
-#ifndef _MD5_H
-#define _MD5_H
-
-#ifndef uint8
-#define uint8 unsigned char
-#endif
-
-#ifndef uint32
-#define uint32 unsigned long int
-#endif
-
-typedef struct
-{
- uint32 total[2];
- uint32 state[4];
- uint8 buffer[64];
-}
-rtv_md5_context;
-
-void rtv_md5_starts( rtv_md5_context *ctx );
-void rtv_md5_update( rtv_md5_context *ctx, const uint8 *input, uint32 length );
-void rtv_md5_finish( rtv_md5_context *ctx, uint8 digest[16] );
-
-#endif /* md5.h */
diff --git a/lib/libRTV/netclient.c b/lib/libRTV/netclient.c
deleted file mode 100644
index 1a9c4de175..0000000000
--- a/lib/libRTV/netclient.c
+++ /dev/null
@@ -1,316 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * Parts based on ReplayPC 0.3 by Matthew T. Linehan and others
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "netclient.h"
-#include "rtv.h"
-
-#include <stdio.h>
-#include <string.h>
-#include <errno.h>
-//#include <netdb.h>
-
-#ifdef _XBOX
-# include <Xtl.h>
-
- typedef SOCKET socket_fd;
-
- struct hostent {
- char * h_name; /* official name of host */
- char * * h_aliases; /* alias list */
- short h_addrtype; /* host address type */
- short h_length; /* length of address */
- char * * h_addr_list; /* list of addresses */
- #define h_addr h_addr_list[0] /* address, for backward compat */
- };
-
- struct hostent * gethostbyname(const char * name);
-#elif defined _WIN32
-# include <winsock2.h>
-# pragma comment(lib, "ws2_32.lib")
- typedef SOCKET socket_fd;
-#else
-# include <unistd.h>
-# include <sys/socket.h>
-# include <netinet/in.h>
-# include <arpa/inet.h>
-# define closesocket(fd) close(fd)
- typedef int socket_fd;
-# define INVALID_SOCKET (-1)
-#include <netdb.h>
-#endif
-
-#ifndef MIN
-#define MIN(x,y) ((x)<(y) ? (x) : (y))
-#endif
-
-static int nc_do_dump = 0;
-static int nc_initted = 0;
-
-struct nc
-{
- u8 rcv_buf[32768];
- size_t low, high;
- socket_fd fd;
-};
-
-static void nc_fini(void)
-{
- nc_initted = 0;
-
-#ifdef _WIN32
- WSACleanup();
-#endif
-}
-
-static void nc_dump(char * tag, unsigned char * buf, size_t sz)
-{
-#if 0
- unsigned int rows, row, col, i, c;
- if (!nc_do_dump)
- return;
- //fprintf(stderr, "NC DUMP: %s %lu\n", tag, (unsigned long)sz);
- if (buf == NULL)
- return;
- rows = (sz + 15)/16;
- for (row = 0; row < rows; row++) {
- //fprintf(stderr, "| ");
- for (col = 0; col < 16; col++) {
- i = row * 16 + col;
- //if (i < sz)
- // fprintf(stderr, "%02x", buf[i]);
- //else
- // fprintf(stderr, " ");
- //if ((i & 3) == 3)
- // fprintf(stderr, " ");
- }
- fprintf(stderr, " | ");
- for (col = 0; col < 16; col++) {
- i = row * 16 + col;
- if (i < sz) {
- c = buf[i];
- fprintf(stderr, "%c", (c >= ' ' && c <= '~') ? c : '.');
- } else {
- fprintf(stderr, " ");
- }
- if ((i & 3) == 3)
- fprintf(stderr, " ");
- }
- fprintf(stderr, " |\n");
- }
-#endif
-}
-
-void nc_error(char * where)
-{
-#ifdef _WIN32
- //fprintf(stderr, "NC error:%s:%d/%d\n", where, errno, WSAGetLastError());
-#else
- //fprintf(stderr, "NC error:%s:%d:%s\n", where, errno, strerror(errno));
-#endif
-}
-
-static int nc_init(void)
-{
-#ifdef _WIN32
- WSADATA wd;
-
- nc_dump("initting", NULL, 0);
-
- if (WSAStartup(MAKEWORD(2,2), &wd) == -1) {
- nc_error("WSAStartup");
- return -1;
- }
-#endif
- nc_initted = 1;
-
- //if (getenv("NC_DUMP"))
- // nc_do_dump = 1;
-
- atexit(nc_fini);
- return 0;
-}
-
-static unsigned long parse_addr(const char *address_str)
-{
- unsigned long addr;
- struct hostent *hent;
-
- addr = inet_addr(address_str);
- if (addr != INADDR_NONE)
- return addr;
-
- nc_dump("looking up address", NULL, 0);
-
- hent = gethostbyname(address_str);
- if (!hent) {
- //herror(address_str);
- return INADDR_NONE;
- }
-
- if (hent->h_addrtype == AF_INET && hent->h_addr_list[0] != NULL) {
- memcpy(&addr, hent->h_addr_list[0], sizeof(addr));
- return addr;
- }
-
- //fprintf(stderr, "No IPv4 address for %s\n", address_str);
- return INADDR_NONE;
-}
-
-struct nc * nc_open(char * address_str, short port)
-{
- struct nc * nc;
- struct sockaddr_in address;
-
- if (!nc_initted) {
- if (nc_init()) {
- //fprintf(stderr, "Couldn't initialize netclient library\n");
- return NULL;
- }
- }
-
- nc = malloc(sizeof *nc);
- if (!nc) {
- //fprintf(stderr, "Couldn't allocate memory for struct nc\n");
- return NULL;
- }
- memset(nc, 0, sizeof *nc);
- nc->fd = -1;
-
- memset(&address, 0, sizeof address);
- address.sin_family = AF_INET;
- address.sin_port = htons(port);
- address.sin_addr.s_addr = parse_addr(address_str);
-
- if (address.sin_addr.s_addr == INADDR_NONE) {
- //fprintf(stderr, "Couldn't determine address for \"%s\"\n", address_str);
- return NULL;
- }
-
- nc_dump("creating socket", NULL, 0);
- nc->fd = socket(AF_INET, SOCK_STREAM, 0);
- if (nc->fd == INVALID_SOCKET) {
- nc_error("open_nc socket");
- return NULL;
- }
- nc_dump("created", NULL, 0);
-
- nc_dump("connecting", NULL, 0);
- if (connect(nc->fd, (struct sockaddr *)&address, sizeof(address)) == -1) {
- nc_error("open_nc connect");
- return NULL;
- }
- nc_dump("connected", NULL, 0);
-
- return nc;
-}
-
-int nc_close(struct nc * nc)
-{
- int r = 0;
-
- if (nc->fd >= 0) {
- nc_dump("closing", NULL, 0);
- r = closesocket(nc->fd);
- nc_dump("closed", NULL, 0);
- }
- free(nc);
-
- return r;
-}
-
-static void fill_rcv_buf(struct nc * nc)
-{
- int r;
-
- nc_dump("receiving...", NULL, 0);
- r = recv(nc->fd, nc->rcv_buf, sizeof(nc->rcv_buf), 0);
- nc->low = 0;
- if (r <= 0) {
- if (r < 0)
- nc_error("fill_rcv_buf recv");
- /* XXX -- error or closed, return whatever we got*/
- nc->high = 0;
- } else {
- nc->high = r;
- }
- nc_dump("received", nc->rcv_buf, nc->high);
-}
-
-int nc_read(struct nc * nc, unsigned char * buf, size_t len)
-{
- size_t l;
- int r = 0;
-
- nc_dump("Reading", NULL, len);
- while (len) {
- if (nc->high == nc->low) {
- fill_rcv_buf(nc);
- }
- if (nc->high == 0) {
- nc_dump("Read", buf, r);
- return r;
- }
- l = MIN(len, nc->high - nc->low);
- memcpy(buf + r, nc->rcv_buf + nc->low, l);
- len -= l;
- r += l;
- nc->low += l;
- }
- nc_dump("Read", buf, r);
- return r;
-}
-
-int nc_read_line(struct nc * nc, unsigned char * buf, size_t maxlen)
-{
- size_t r = 0;
-
- nc_dump("Reading line", NULL, maxlen);
- while (r < maxlen) {
- if (nc_read(nc, buf + r, 1) <= 0) {
- return r;
- }
- if (buf[r] == '\012') {
- buf[r] = '\0';
- if (r > 0 && buf[r-1] == '\015') {
- r--;
- buf[r] = '\0';
- }
- nc_dump("Read line", buf, r);
- return r;
- }
- r++;
- }
- nc_dump("Read line", buf, r);
- return r;
-}
-
-int nc_write(struct nc * nc, unsigned char * buf, size_t len)
-{
- int r;
- nc_dump("sending...", buf, len);
- r = send(nc->fd, buf, len, 0);
- if (r < 0)
- nc_error("nc_write");
- nc_dump("sent", NULL, 0);
- return r;
-}
diff --git a/lib/libRTV/netclient.h b/lib/libRTV/netclient.h
deleted file mode 100644
index dbba53f8ec..0000000000
--- a/lib/libRTV/netclient.h
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#ifndef NETCLIENT_H
-#define NETCLIENT_H
-
-#include <stdlib.h>
-
-struct nc;
-
-extern void nc_error(char * where);
-extern struct nc * nc_open(char * address, short port);
-extern int nc_close(struct nc * nc);
-extern int nc_read(struct nc * nc, unsigned char * buf, size_t len);
-extern int nc_read_line(struct nc * nc, unsigned char * buf, size_t maxlen);
-extern int nc_write(struct nc * nc, unsigned char * buf, size_t len);
-
-#endif
diff --git a/lib/libRTV/rtv.c b/lib/libRTV/rtv.c
deleted file mode 100644
index 4064a05d63..0000000000
--- a/lib/libRTV/rtv.c
+++ /dev/null
@@ -1,222 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "rtv.h"
-
-#include <string.h>
-#include <stdlib.h>
-
-struct replaytv_version replaytv_version = {4, 3, 0, 280};
-
-u8 rtv_to_u8(unsigned char ** pp)
-{
- unsigned char * p;
- u8 r;
-
- p = *pp;
- r = *p++;
- *pp = p;
-
- return r;
-}
-
-u16 rtv_to_u16(unsigned char ** pp)
-{
- u16 r;
- r = rtv_to_u8(pp) << 8;
- r |= rtv_to_u8(pp);
- return r;
-}
-
-u32 rtv_to_u32(unsigned char ** pp)
-{
- u32 r;
- r = rtv_to_u16(pp) << 16;
- r |= rtv_to_u16(pp);
- return r;
-}
-
-u64 rtv_to_u64(unsigned char ** pp)
-{
- u64 r;
-
- r = (u64)(rtv_to_u32(pp)) << 32;
- r |= (u64)(rtv_to_u32(pp));
- return r;
-}
-
-void rtv_to_buf_len(unsigned char ** pp, unsigned char * b, size_t l)
-{
- unsigned char * p;
- p = *pp;
- memcpy(b, p, l);
- p += l;
- *pp = p;
-}
-
-void rtv_from_u8(unsigned char ** pp, u8 v)
-{
- unsigned char * p;
-
- p = *pp;
- *p++ = v;
- *pp = p;
-}
-
-void rtv_from_u16(unsigned char ** pp, u16 v)
-{
- rtv_from_u8(pp, (u8)((v & 0xff00) >> 8));
- rtv_from_u8(pp, (u8)((v & 0x00ff) ));
-}
-
-void rtv_from_u32(unsigned char ** pp, u32 v)
-{
- rtv_from_u16(pp, (u16)((v & 0xffff0000) >> 16));
- rtv_from_u16(pp, (u16)((v & 0x0000ffff) ));
-}
-
-void rtv_from_u64(unsigned char ** pp, u64 v)
-{
- rtv_from_u32(pp, (u32)((v & 0xffffffff00000000LL) >> 32));
- rtv_from_u32(pp, (u32)((v & 0x00000000ffffffffLL) ));
-}
-
-void rtv_from_buf_len(unsigned char ** pp, unsigned char * b, size_t l)
-{
- unsigned char * p;
- p = *pp;
- memcpy(p, b, l);
- p += l;
- *pp = p;
-}
-
-/* supports formats:
- * 520411140
- * 4.1
- * 4.1(140)
- * 4.1 (140)
- * 4.1.1
- * 4.1.1.140
- * 4.1.1(140)
- * 4.1.1 (140)
- */
-extern int rtv_set_replaytv_version(char * version)
-{
- if (strncmp(version, "520", 3) == 0 &&
- strlen(version) == 9) {
- replaytv_version.major = version[3] - '0';
- replaytv_version.minor = version[4] - '0';
- replaytv_version.patch = version[5] - '0';
- replaytv_version.build = atoi(version+6);
- return 0;
- }
- replaytv_version.major = strtoul(version, &version, 10);
- if (version == NULL || *version != '.')
- return -1; /* need at least major&minor */
- version++;
- replaytv_version.minor = strtoul(version, &version, 10);
- switch (*version) {
- case '\0': /* '4.1' style */
- replaytv_version.patch = 0;
- replaytv_version.build = 0;
- return 0;
- case '.': /* '4.1.1'... style */
- version++;
- replaytv_version.patch = strtoul(version, &version, 10);
- break;
- case ' ': /* '4.1 (140)' */
- case '(': /* '4.1(140)' */
- replaytv_version.patch = 0;
- break;
- default:
- return -1;
- }
- if (*version == '\0') { /* '4.1.1' */
- replaytv_version.build = 0;
- return 0;
- }
- switch (*version) {
- case '.': /* '4.1.1.140' */
- version++;
- break;
- case ' ': /* '4.1 (140)' or '4.1.1 (140)' */
- version++;
- if (*version != '(')
- return -1;
- version++;
- break;
- case '(': /* '4.1(140)' or '4.1.1(140)' */
- version++;
- break;
- default:
- return -1;
- }
- replaytv_version.build = strtoul(version, &version, 10);
- if (*version == '\0')
- return 0;
- if (*version == ')')
- return 0;
- return -1;
-}
-
-int rtv_split_lines(char * src, char *** pdst)
-{
- int num_lines, i;
- char * p;
- char ** dst;
-
- num_lines = 0;
- p = src;
- while (p) {
- p = strchr(p, '\n');
- if (p) {
- p++;
- num_lines++;
- }
- }
-
- dst = calloc(num_lines, sizeof(char *));
- dst[0] = src;
- p = src;
- i = 1;
- while (p) {
- p = strchr(p, '\n');
- if (p) {
- *p = '\0';
- p++;
- if (*p) {
- dst[i] = p;
- i++;
- }
- }
- }
-
- *pdst = dst;
-
- return num_lines;
-}
-
-void rtv_free_lines(int num_lines, char ** lines)
-{
- (void)num_lines; /* not used with the above implementation */
-
- free(lines);
-}
diff --git a/lib/libRTV/rtv.h b/lib/libRTV/rtv.h
deleted file mode 100644
index 8edaf9966d..0000000000
--- a/lib/libRTV/rtv.h
+++ /dev/null
@@ -1,85 +0,0 @@
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#ifndef RTV_H
-#define RTV_H
-
-#include <stdlib.h>
-
-#if 0
-#define _LARGEFILE64_SOURCE
-typedef unsigned char u8;
-typedef unsigned short u16;
-typedef unsigned long u32;
-typedef unsigned long long u64;
-typedef long long s64;
-#ifdef __APPLE__
-#define U64F "q"
-#else
-#define U64F "ll"
-#endif
-#else
-
-typedef unsigned char u8;
-typedef unsigned short u16;
-typedef unsigned long u32;
-#ifdef _WIN32
-typedef unsigned __int64 u64;
-typedef __int64 s64;
-#define U64F "I64"
-#endif
-#ifndef _WIN32
-typedef unsigned long long u64;
-typedef signed long long s64;
-#define U64F "l"
-#endif
-#endif
-
-#ifndef EXPECT_CAN_EXIT
-#define EXPECT_CAN_EXIT 0
-#endif
-
-#define RTV_DELAY_SECONDS 40 // 795KB/SEC (+/- 64KB/SEC)
-
-struct replaytv_version {
- int major, minor, patch, build;
-};
-
-extern struct replaytv_version replaytv_version;
-
-extern u8 rtv_to_u8(unsigned char ** pp);
-extern u16 rtv_to_u16(unsigned char ** pp);
-extern u32 rtv_to_u32(unsigned char ** pp);
-extern u64 rtv_to_u64(unsigned char ** pp);
-extern void rtv_to_buf_len(unsigned char ** pp, unsigned char * b, size_t l);
-#define rtv_to_buf(pp, buf) rtv_to_buf_len(pp, buf, sizeof buf)
-extern void rtv_from_u8(unsigned char ** p, u8 v);
-extern void rtv_from_u16(unsigned char ** pp, u16 v);
-extern void rtv_from_u32(unsigned char ** pp, u32 v);
-extern void rtv_from_u64(unsigned char ** pp, u64 v);
-extern void rtv_from_buf_len(unsigned char ** pp, unsigned char * b, size_t l);
-#define rtv_from_buf(pp, buf) rtv_to_buf_len(pp, buf, sizeof buf)
-
-extern int rtv_set_replaytv_version(char * version);
-
-extern int rtv_split_lines(char * src, char *** dst);
-extern void rtv_free_lines(int num, char ** lines);
-
-#define expect(x) do { \
- if (!(x)) { \
- if (EXPECT_CAN_EXIT) (exit(-1)); \
- } \
-} while(0)
-
-#endif
diff --git a/lib/libRTV/sleep.c b/lib/libRTV/sleep.c
deleted file mode 100644
index 4d59cbc22b..0000000000
--- a/lib/libRTV/sleep.c
+++ /dev/null
@@ -1,44 +0,0 @@
-#ifndef __GNUC__
-#pragma code_seg( "RTV_TEXT" )
-#pragma data_seg( "RTV_DATA" )
-#pragma bss_seg( "RTV_BSS" )
-#pragma const_seg( "RTV_RD" )
-#endif
-
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#include "sleep.h"
-
-#ifdef _WIN32
-#include "windows.h"
-
-void rtv_sleep(u16 msec)
-{
- Sleep(msec);
-}
-#elif defined _XBOX
-#include "Xtl.h"
-
-void rtv_sleep(u16 msec)
-{
- Sleep(msec);
-}
-#else
-#include <unistd.h>
-void rtv_sleep(u16 msec)
-{
- usleep(msec * 1000);
-}
-#endif
diff --git a/lib/libRTV/sleep.h b/lib/libRTV/sleep.h
deleted file mode 100644
index 6a46036ff4..0000000000
--- a/lib/libRTV/sleep.h
+++ /dev/null
@@ -1,22 +0,0 @@
-/*
- * Copyright (C) 2002 John Todd Larason <jtl@molehill.org>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- */
-
-#ifndef SLEEP_H
-#define SLEEP_H
-
-#include "rtv.h"
-
-void rtv_sleep(u16 msec);
-
-#endif