parserp.cpp
上传用户:zhongxx05
上传日期:2007-06-06
资源大小:33641k
文件大小:6k
源码类别:

Symbian

开发平台:

C/C++

  1. /* ***** BEGIN LICENSE BLOCK ***** 
  2.  * Version: RCSL 1.0/RPSL 1.0 
  3.  *  
  4.  * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved. 
  5.  *      
  6.  * The contents of this file, and the files included with this file, are 
  7.  * subject to the current version of the RealNetworks Public Source License 
  8.  * Version 1.0 (the "RPSL") available at 
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed 
  10.  * the file under the RealNetworks Community Source License Version 1.0 
  11.  * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl, 
  12.  * in which case the RCSL will apply. You may also obtain the license terms 
  13.  * directly from RealNetworks.  You may not use this file except in 
  14.  * compliance with the RPSL or, if you have a valid RCSL with RealNetworks 
  15.  * applicable to this file, the RCSL.  Please see the applicable RPSL or 
  16.  * RCSL for the rights, obligations and limitations governing use of the 
  17.  * contents of the file.  
  18.  *  
  19.  * This file is part of the Helix DNA Technology. RealNetworks is the 
  20.  * developer of the Original Code and owns the copyrights in the portions 
  21.  * it created. 
  22.  *  
  23.  * This file, and the files included with this file, is distributed and made 
  24.  * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
  25.  * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
  26.  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS 
  27.  * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
  28.  * 
  29.  * Technology Compatibility Kit Test Suite(s) Location: 
  30.  *    http://www.helixcommunity.org/content/tck 
  31.  * 
  32.  * Contributor(s): 
  33.  *  
  34.  * ***** END LICENSE BLOCK ***** */ 
  35. #define INITGUID
  36. // include
  37. #include "hxtypes.h"
  38. #include "hxcom.h"
  39. #include "hxcomm.h"
  40. #include "ihxpckts.h"
  41. #include "hxxml.h"
  42. #include "hxxrsmg.h"
  43. #include "hxerror.h"
  44. // hxmisc
  45. #include "baseobj.h"
  46. #include "unkimp.h"
  47. // hxcont
  48. #include "hxstring.h"
  49. #include "hxmap.h"
  50. #include "hxslist.h"
  51. #include "hxbuffer.h"
  52. // pxcomlib
  53. #include "pxslist.h"
  54. #include "pxmap.h"
  55. #include "pxcolor.h"
  56. #include "pxrect.h"
  57. #include "pxeffect.h"
  58. #include "rpfile.h"
  59. #include "rpparser.h"
  60. #include "pxcontxt.h"
  61. void main(int argc, char** argv)
  62. {
  63.     // Check args
  64.     if (argc < 2 || argc > 3)
  65.     {
  66.         fprintf(stdout, "Usage: parserp foo.rp [strictness]n");
  67.         exit(0);
  68.     }
  69.     // Open the file
  70.     FILE *fp = fopen(argv[1], "rb");
  71.     if (!fp)
  72.     {
  73.         fprintf(stdout, "Cannot open %s.n", argv[1]);
  74.         exit(0);
  75.     }
  76.     UINT32 ulStrictLevel = REALPIX_STRICTNESS_HIGH;
  77.     if (argc == 3)
  78.     {
  79. ulStrictLevel = (UINT32) atoi(argv[2]);
  80.     }
  81.     // Get the size of the file
  82.     fseek(fp, 0, SEEK_END);
  83.     UINT32 ulSize = (UINT32) ftell(fp);
  84.     fseek(fp, 0, SEEK_SET);
  85.     // Create the test context
  86.     PXTestContext* pContext = NULL;
  87.     HX_RESULT      retVal   = PXTestContext::CreateObject(&pContext);
  88.     if (SUCCEEDED(retVal))
  89.     {
  90.         // Get an IUnknown interface from the context
  91.         IUnknown* pUnknown = NULL;
  92.         retVal             = pContext->QueryInterface(IID_IUnknown,
  93.                                                       (void**) &pUnknown);
  94.         if (SUCCEEDED(retVal))
  95.         {
  96.             // Get an IHXBuffer object to hold the file
  97.             IHXBuffer* pBuffer = NULL;
  98.             retVal              = pContext->CreateInstance(CLSID_IHXBuffer,
  99.                                                            (void**) &pBuffer);
  100.             if (SUCCEEDED(retVal))
  101.             {
  102.                 // Set the size of the buffer
  103.                 retVal = pBuffer->SetSize(ulSize);
  104.                 if (SUCCEEDED(retVal))
  105.                 {
  106.                     // Read the file into the buffer
  107.                     fread(pBuffer->GetBuffer(), 1, ulSize, fp);
  108.                     // Create a PXRealPixFile object
  109.                     PXRealPixFile* pRealPixFile = NULL;
  110.                     retVal = PXRealPixFile::CreateObject(&pRealPixFile);
  111.                     if (SUCCEEDED(retVal))
  112.                     {
  113.                         // AddRef the object
  114.                         pRealPixFile->AddRef();
  115.                         // Create a PXRealPixParser object
  116.                         PXRealPixParser* pRealPixParser = NULL;
  117.                         retVal = PXRealPixParser::CreateObject(&pRealPixParser);
  118.                         if (SUCCEEDED(retVal))
  119.                         {
  120.                             // AddRef the object
  121.                             pRealPixParser->AddRef();
  122.                             // Init the parser
  123.                             retVal = pRealPixParser->Init(pUnknown, pRealPixFile, ulStrictLevel);
  124.                             if (SUCCEEDED(retVal))
  125.                             {
  126.                                 // Parse the file
  127.                                 IHXBuffer* pError = NULL;
  128.                                 retVal             = pRealPixParser->Parse(pBuffer,   // the .rp file
  129.                                                                            TRUE,      // bIsFinal == TRUE
  130.                                                                            pError);   // output error string
  131.                                 if (SUCCEEDED(retVal))
  132.                                 {
  133.                                     fprintf(stdout, "%s parsed successfully.n", argv[1]);
  134.                                 }
  135.                                 else
  136.                                 {
  137.                                     fprintf(stdout, "Error parsing %s: %sn", argv[1], (const char*) pError->GetBuffer());
  138.                                 }
  139.                             }
  140.                         }
  141.                         HX_RELEASE(pRealPixParser);
  142.                     }
  143.                     HX_RELEASE(pRealPixFile);
  144.                 }
  145.             }
  146.             HX_RELEASE(pBuffer);
  147.         }
  148.         HX_RELEASE(pUnknown);
  149.     }
  150.     // Close the file
  151.     fclose(fp);
  152. }