summaryrefslogtreecommitdiff
path: root/meta-extras/packages/helix/helix-libs
diff options
context:
space:
mode:
authorRichard Purdie <rpurdie@linux.intel.com>2010-08-27 15:14:24 +0100
committerRichard Purdie <rpurdie@linux.intel.com>2010-08-27 15:29:45 +0100
commit29d6678fd546377459ef75cf54abeef5b969b5cf (patch)
tree8edd65790e37a00d01c3f203f773fe4b5012db18 /meta-extras/packages/helix/helix-libs
parentda49de6885ee1bc424e70bc02f21f6ab920efb55 (diff)
downloadopenembedded-core-29d6678fd546377459ef75cf54abeef5b969b5cf.tar.gz
openembedded-core-29d6678fd546377459ef75cf54abeef5b969b5cf.tar.bz2
openembedded-core-29d6678fd546377459ef75cf54abeef5b969b5cf.zip
Major layout change to the packages directory
Having one monolithic packages directory makes it hard to find things and is generally overwhelming. This commit splits it into several logical sections roughly based on function, recipes.txt gives more information about the classifications used. The opportunity is also used to switch from "packages" to "recipes" as used in OpenEmbedded as the term "packages" can be confusing to people and has many different meanings. Not all recipes have been classified yet, this is just a first pass at separating things out. Some packages are moved to meta-extras as they're no longer actively used or maintained. Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
Diffstat (limited to 'meta-extras/packages/helix/helix-libs')
-rw-r--r--meta-extras/packages/helix/helix-libs/add-clutter.patch12668
-rw-r--r--meta-extras/packages/helix/helix-libs/helix-player.pc11
-rw-r--r--meta-extras/packages/helix/helix-libs/hxclient.pc11
3 files changed, 12690 insertions, 0 deletions
diff --git a/meta-extras/packages/helix/helix-libs/add-clutter.patch b/meta-extras/packages/helix/helix-libs/add-clutter.patch
new file mode 100644
index 0000000000..eb545ff73f
--- /dev/null
+++ b/meta-extras/packages/helix/helix-libs/add-clutter.patch
@@ -0,0 +1,12668 @@
+Index: helix-libs/clientapps/clutter/LICENSE.txt
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/LICENSE.txt 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,30 @@
++ Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++
++ The contents of this directory, and (except where otherwise
++ indicated) the directories included within this directory, are
++ subject to the current version of the RealNetworks Public Source
++ License (the "RPSL") available at RPSL.txt in this directory, unless
++ you have licensed the directory under the current version of the
++ RealNetworks Community Source License (the "RCSL") available at
++ RCSL.txt in this directory, in which case the RCSL will apply. You
++ may also obtain the license terms directly from RealNetworks. You
++ may not use the files in this directory except in compliance with the
++ RPSL or, if you have a valid RCSL with RealNetworks applicable to
++ this directory, the RCSL. Please see the applicable RPSL or RCSL for
++ the rights, obligations and limitations governing use of the contents
++ of the directory.
++
++ This directory is part of the Helix DNA Technology. RealNetworks is
++ the developer of the Original Code and owns the copyrights in the
++ portions it created.
++
++ This directory, and the directories included with this directory, are
++ distributed and made available on an 'AS IS' basis, WITHOUT WARRANTY
++ OF ANY KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY
++ DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY
++ WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
++ QUIET ENJOYMENT OR NON-INFRINGEMENT.
++
++ Technology Compatibility Kit Test Suite(s) Location:
++ http://www.helixcommunity.org/content/tck
++
+Index: helix-libs/clientapps/clutter/RCSL.txt
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/RCSL.txt 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,948 @@
++The RCSL is made up of a base agreement and a few Attachments.
++
++For Research and Development use, you agree to the terms of the
++RCSL R&D License (base RCSL and Attachments A, B, and C)
++
++For Commercial Use (either distribution or internal commercial
++deployment) of the Helix DNA with or without support for RealNetworks'
++RealAudio and RealVideo Add-on Technology, you agree to the
++terms of the same RCSL R&D license
++and execute one or more additional Commercial Use License attachments
++<see http://www.helixcommunity.org/content/rcsl-attachments>.
++
++------------------------------------------------------------------------
++
++
++ REALNETWORKS COMMUNITY SOURCE LICENSE
++
++Version 1.2 (Rev. Date: January 22, 2003).
++
++
++ RECITALS
++
++Original Contributor has developed Specifications, Source Code
++implementations and Executables of certain Technology; and
++
++Original Contributor desires to license the Technology to a large
++community to facilitate research, innovation and product development
++while maintaining compatibility of such products with the Technology as
++delivered by Original Contributor; and
++
++Original Contributor desires to license certain Trademarks for the
++purpose of branding products that are compatible with the relevant
++Technology delivered by Original Contributor; and
++
++You desire to license the Technology and possibly certain Trademarks
++from Original Contributor on the terms and conditions specified in this
++License.
++
++In consideration for the mutual covenants contained herein, You and
++Original Contributor agree as follows:
++
++
++ AGREEMENT
++
++*1. Introduction.*
++
++The RealNetworks Community Source License ("RCSL") and effective
++attachments ("License") may include five distinct licenses:
++
++i) Research Use license -- License plus Attachments A, B and C only.
++
++ii) Commercial Use and Trademark License, which may be for Internal
++Deployment Use or external distribution, or both -- License plus
++Attachments A, B, C, and D.
++
++iii) Technology Compatibility Kit (TCK) license -- Attachment C.
++
++iv) Add-On Technology License (Executable) Commercial Use License
++-Attachment F.
++
++v) Add-On Technology Source Code Porting and Optimization
++License-Attachment G.
++
++The Research Use license is effective when You click and accept this
++License. The TCK is effective when You click and accept this License,
++unless otherwise specified in the TCK attachments. The Commercial Use
++and Trademark, Add-On Technology License, and the Add-On Technology
++Source Code Porting and Optimization licenses must each be signed by You
++and Original Contributor to become effective. Once effective, these
++licenses and the associated requirements and responsibilities are
++cumulative. Capitalized terms used in this License are defined in the
++Glossary.
++
++*2. License Grants.*
++
++2.1 Original Contributor Grant.
++
++Subject to Your compliance with Sections 3, 8.10 and Attachment A of
++this License, Original Contributor grants to You a worldwide,
++royalty-free, non-exclusive license, to the extent of Original
++Contributor's Intellectual Property Rights covering the Original Code,
++Upgraded Code and Specifications, to do the following:
++
++(a) Research Use License:
++
++(i) use, reproduce and modify the Original Code, Upgraded Code and
++Specifications to create Modifications and Reformatted Specifications
++for Research Use by You;
++
++(ii) publish and display Original Code, Upgraded Code and Specifications
++with, or as part of Modifications, as permitted under Section 3.1(b) below;
++
++(iii) reproduce and distribute copies of Original Code and Upgraded Code
++to Licensees and students for Research Use by You;
++
++(iv) compile, reproduce and distribute Original Code and Upgraded Code
++in Executable form, and Reformatted Specifications to anyone for
++Research Use by You.
++
++(b) Other than the licenses expressly granted in this License, Original
++Contributor retains all right, title, and interest in Original Code and
++Upgraded Code and Specifications.
++
++2.2 Your Grants.
++
++(a) To Other Licensees. You hereby grant to each Licensee a license to
++Your Error Corrections and Shared Modifications, of the same scope and
++extent as Original Contributor's licenses under Section 2.1 a) above
++relative to Research Use and Attachment D relative to Commercial Use.
++
++(b) To Original Contributor. You hereby grant to Original Contributor a
++worldwide, royalty-free, non-exclusive, perpetual and irrevocable
++license, to the extent of Your Intellectual Property Rights covering
++Your Error Corrections, Shared Modifications and Reformatted
++Specifications, to use, reproduce, modify, display and distribute Your
++Error Corrections, Shared Modifications and Reformatted Specifications,
++in any form, including the right to sublicense such rights through
++multiple tiers of distribution.
++
++(c) Other than the licenses expressly granted in Sections 2.2(a) and (b)
++above, and the restrictions set forth in Section 3.1(d)(iv) below, You
++retain all right, title, and interest in Your Error Corrections, Shared
++Modifications and Reformatted Specifications.
++
++2.3 Contributor Modifications.
++
++You may use, reproduce, modify, display and distribute Contributor Error
++Corrections, Shared Modifications and Reformatted Specifications,
++obtained by You under this License, to the same scope and extent as with
++Original Code, Upgraded Code and Specifications.
++
++2.4 Subcontracting.
++
++You may deliver the Source Code of Covered Code to other Licensees
++having at least a Research Use license, for the sole purpose of
++furnishing development services to You in connection with Your rights
++granted in this License. All such Licensees must execute appropriate
++documents with respect to such work consistent with the terms of this
++License, and acknowledging their work-made-for-hire status or assigning
++exclusive right to the work product and associated Intellectual Property
++Rights to You.
++
++*3. Requirements and Responsibilities*.
++
++3.1 Research Use License.
++
++As a condition of exercising the rights granted under Section 2.1(a)
++above, You agree to comply with the following:
++
++(a) Your Contribution to the Community. All Error Corrections and Shared
++Modifications which You create or contribute to are automatically
++subject to the licenses granted under Section 2.2 above. You are
++encouraged to license all of Your other Modifications under Section 2.2
++as Shared Modifications, but are not required to do so. You agree to
++notify Original Contributor of any errors in the Specification.
++
++(b) Source Code Availability. You agree to provide all Your Error
++Corrections to Original Contributor as soon as reasonably practicable
++and, in any event, prior to Internal Deployment Use or Commercial Use,
++if applicable. Original Contributor may, at its discretion, post Source
++Code for Your Error Corrections and Shared Modifications on the
++Community Webserver. You may also post Error Corrections and Shared
++Modifications on a web-server of Your choice; provided, that You must
++take reasonable precautions to ensure that only Licensees have access to
++such Error Corrections and Shared Modifications. Such precautions shall
++include, without limitation, a password protection scheme limited to
++Licensees and a click-on, download certification of Licensee status
++required of those attempting to download from the server. An example of
++an acceptable certification is attached as Attachment A-2.
++
++(c) Notices. All Error Corrections and Shared Modifications You create
++or contribute to must include a file documenting the additions and
++changes You made and the date of such additions and changes. You must
++also include the notice set forth in Attachment A-1 in the file header.
++If it is not possible to put the notice in a particular Source Code file
++due to its structure, then You must include the notice in a location
++(such as a relevant directory file), where a recipient would be most
++likely to look for such a notice.
++
++(d) Redistribution.
++
++(i) Source. Covered Code may be distributed in Source Code form only to
++another Licensee (except for students as provided below). You may not
++offer or impose any terms on any Covered Code that alter the rights,
++requirements, or responsibilities of such Licensee. You may distribute
++Covered Code to students for use in connection with their course work
++and research projects undertaken at accredited educational institutions.
++Such students need not be Licensees, but must be given a copy of the
++notice set forth in Attachment A-3 and such notice must also be included
++in a file header or prominent location in the Source Code made available
++to such students.
++
++(ii) Executable. You may distribute Executable version(s) of Covered
++Code to Licensees and other third parties only for the purpose of
++evaluation and comment in connection with Research Use by You and under
++a license of Your choice, but which limits use of such Executable
++version(s) of Covered Code only to that purpose.
++
++(iii) Modified Class, Interface and Package Naming. In connection with
++Research Use by You only, You may use Original Contributor's class,
++Interface and package names only to accurately reference or invoke the
++Source Code files You modify. Original Contributor grants to You a
++limited license to the extent necessary for such purposes.
++
++(iv) You expressly agree that any distribution, in whole or in part, of
++Modifications developed by You shall only be done pursuant to the terms
++and conditions of this License.
++
++(e) Extensions.
++
++(i) Covered Code. You may not include any Source Code of Community Code
++in any Extensions. You may include the compiled Header Files of
++Community Code in an Extension provided that Your use of the Covered
++Code, including Heading Files, complies with the Commercial Use License,
++the TCK and all other terms of this License.
++
++(ii) Publication. No later than the date on which You first distribute
++such Extension for Commercial Use, You must publish to the industry, on
++a non-confidential basis and free of all copyright restrictions with
++respect to reproduction and use, an accurate and current specification
++for any Extension. In addition, You must make available an appropriate
++test suite, pursuant to the same rights as the specification,
++sufficiently detailed to allow any third party reasonably skilled in the
++technology to produce implementations of the Extension compatible with
++the specification. Such test suites must be made available as soon as
++reasonably practicable but, in no event, later than ninety (90) days
++after Your first Commercial Use of the Extension. You must use
++reasonable efforts to promptly clarify and correct the specification and
++the test suite upon written request by Original Contributor.
++
++(iii) Open. You agree to refrain from enforcing any Intellectual
++Property Rights You may have covering any interface(s) of Your
++Extension, which would prevent the implementation of such interface(s)
++by Original Contributor or any Licensee. This obligation does not
++prevent You from enforcing any Intellectual Property Right You have that
++would otherwise be infringed by an implementation of Your Extension.
++
++(iv) Interface Modifications and Naming. You may not modify or add to
++the GUID space * * "xxxxxxxx-0901-11d1-8B06-00A024406D59" or any other
++GUID space designated by Original Contributor. You may not modify any
++Interface prefix provided with the Covered Code or any other prefix
++designated by Original Contributor.* *
++
++* *
++
++(f) You agree that any Specifications provided to You by Original
++Contributor are confidential and proprietary information of Original
++Contributor. You must maintain the confidentiality of the Specifications
++and may not disclose them to any third party without Original
++Contributor's prior written consent. You may only use the Specifications
++under the terms of this License and only for the purpose of implementing
++the terms of this License with respect to Covered Code. You agree not
++use, copy or distribute any such Specifications except as provided in
++writing by Original Contributor.
++
++3.2 Commercial Use License.
++
++You may not make Commercial Use of any Covered Code unless You and
++Original Contributor have executed a copy of the Commercial Use and
++Trademark License attached as Attachment D.
++
++*4. Versions of the License.*
++
++4.1 License Versions.
++
++Original Contributor may publish revised versions of the License from
++time to time. Each version will be given a distinguishing version number.
++
++4.2 Effect.
++
++Once a particular version of Covered Code has been provided under a
++version of the License, You may always continue to use such Covered Code
++under the terms of that version of the License. You may also choose to
++use such Covered Code under the terms of any subsequent version of the
++License. No one other than Original Contributor has the right to
++promulgate License versions.
++
++4.3 Multiple-Licensed Code.
++
++Original Contributor may designate portions of the Covered Code as
++"Multiple-Licensed." "Multiple-Licensed" means that the Original
++Contributor permits You to utilize those designated portions of the
++Covered Code under Your choice of this License or the alternative
++license(s), if any, specified by the Original Contributor in an
++Attachment to this License.
++
++*5. Disclaimer of Warranty.*
++
++5.1 COVERED CODE PROVIDED AS IS.
++
++COVERED CODE IS PROVIDED UNDER THIS LICENSE "AS IS," WITHOUT WARRANTY OF
++ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION,
++WARRANTIES THAT THE COVERED CODE IS FREE OF DEFECTS, MERCHANTABLE, FIT
++FOR A PARTICULAR PURPOSE OR NON-INFRINGING. YOU AGREE TO BEAR THE ENTIRE
++RISK IN CONNECTION WITH YOUR USE AND DISTRIBUTION OF COVERED CODE UNDER
++THIS LICENSE. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART
++OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER
++EXCEPT SUBJECT TO THIS DISCLAIMER.
++
++5.2 Not Designed for High Risk Activities.
++
++You acknowledge that Original Code, Upgraded Code and Specifications are
++not designed or intended for use in high risk activities including, but
++not limited to: (i) on-line control of aircraft, air traffic, aircraft
++navigation or aircraft communications; or (ii) in the design,
++construction, operation or maintenance of any nuclear facility. Original
++Contributor disclaims any express or implied warranty of fitness for
++such uses.
++
++*6. Termination.*
++
++6.1 By You.
++
++You may terminate this Research Use license at anytime by providing
++written notice to Original Contributor.
++
++6.2 By Original Contributor.
++
++This License and the rights granted hereunder will terminate:
++
++(i) automatically if You fail to comply with the terms of this License
++and fail to cure such breach within 30 days of receipt of written notice
++of the breach;
++
++(ii) immediately in the event of circumstances specified in Sections 7.1
++and 8.4; or
++
++(iii) at Original Contributor's discretion upon any action initiated by
++You (including by cross-claim or counter claim) alleging that use or
++distribution by Original Contributor or any Licensee, of Original Code,
++Upgraded Code, Error Corrections, Shared Modifications or Specifications
++infringe a patent owned or controlled by You.
++
++6.3 Effective of Termination.
++
++Upon termination, You agree to discontinue use of and destroy all copies
++of Covered Code in Your possession. All sublicenses to the Covered Code
++which You have properly granted shall survive any termination of this
++License. Provisions that, by their nature, should remain in effect
++beyond the termination of this License shall survive including, without
++limitation, Sections 2.2, 3, 5, 7 and 8.
++
++6.4 No Compensation.
++
++Each party waives and releases the other from any claim to compensation
++or indemnity for permitted or lawful termination of the business
++relationship established by this License.
++
++*7. Liability.*
++
++7.1 Infringement. Should any of the Original Code, Upgraded Code, TCK or
++Specifications ("Materials") become the subject of a claim of
++infringement, Original Contributor may, at its sole option, (i) attempt
++to procure the rights necessary for You to continue using the Materials,
++(ii) modify the Materials so that they are no longer infringing, or
++(iii) terminate Your right to use the Materials, immediately upon
++written notice, and refund to You the amount, if any, having then
++actually been paid by You to Original Contributor for the Original Code,
++Upgraded Code and TCK, depreciated on a straight line, five year basis.
++
++7.2 LIMITATION OF LIABILITY. TO THE FULL EXTENT ALLOWED BY APPLICABLE
++LAW, ORIGINAL CONTRIBUTOR'S LIABILITY TO YOU FOR CLAIMS RELATING TO THIS
++LICENSE, WHETHER FOR BREACH OR IN TORT, SHALL BE LIMITED TO ONE HUNDRED
++PERCENT (100%) OF THE AMOUNT HAVING THEN ACTUALLY BEEN PAID BY YOU TO
++ORIGINAL CONTRIBUTOR FOR ALL COPIES LICENSED HEREUNDER OF THE PARTICULAR
++ITEMS GIVING RISE TO SUCH CLAIM, IF ANY, DURING THE TWELVE MONTHS
++PRECEDING THE CLAIMED BREACH. IN NO EVENT WILL YOU (RELATIVE TO YOUR
++SHARED MODIFICATIONS OR ERROR CORRECTIONS) OR ORIGINAL CONTRIBUTOR BE
++LIABLE FOR ANY INDIRECT, PUNITIVE, SPECIAL, INCIDENTAL OR CONSEQUENTIAL
++DAMAGES IN CONNECTION WITH OR RISING OUT OF THIS LICENSE (INCLUDING,
++WITHOUT LIMITATION, LOSS OF PROFITS, USE, DATA, OR OTHER ECONOMIC
++ADVANTAGE), HOWEVER IT ARISES AND ON ANY THEORY OF LIABILITY, WHETHER IN
++AN ACTION FOR CONTRACT, STRICT LIABILITY OR TORT (INCLUDING NEGLIGENCE)
++OR OTHERWISE, WHETHER OR NOT YOU OR ORIGINAL CONTRIBUTOR HAS BEEN
++ADVISED OF THE POSSIBILITY OF SUCH DAMAGE AND NOTWITHSTANDING THE
++FAILURE OF ESSENTIAL PURPOSE OF ANY REMEDY.
++
++*8. Miscellaneous.*
++
++8.1 Trademark.
++
++You shall not use any Trademark unless You and Original Contributor
++execute a copy of the Commercial Use and Trademark License Agreement
++attached hereto as Attachment D. Except as expressly provided in the
++License, You are granted no right, title or license to, or interest in,
++any Trademarks. Whether or not You and Original Contributor enter into
++the Trademark License, You agree not to (i) challenge Original
++Contributor's ownership or use of Trademarks; (ii) attempt to register
++any Trademarks, or any mark or logo substantially similar thereto; or
++(iii) incorporate any Trademarks into Your own trademarks, product
++names, service marks, company names, or domain names.
++
++8.2 Integration.
++
++This License represents the complete agreement concerning the subject
++matter hereof.
++
++8.3 Assignment.
++
++Original Contributor may assign this License, and its rights and
++obligations hereunder, in its sole discretion. You may assign the
++Research Use portions of this License and the TCK license to a third
++party upon prior written notice to Original Contributor (which may be
++provided electronically via the Community Web-Server). You may not
++assign the Commercial Use and Trademark license, the Add-On Technology
++License, or the Add-On Technology Source Code Porting License, including
++by way of merger (regardless of whether You are the surviving entity) or
++acquisition, without Original Contributor's prior written consent.
++
++8.4 Severability.
++
++If any provision of this License is held to be unenforceable, such
++provision shall be reformed only to the extent necessary to make it
++enforceable. Notwithstanding the foregoing, if You are prohibited by law
++from fully and specifically complying with Sections 2.2 or 3, this
++License will immediately terminate and You must immediately discontinue
++any use of Covered Code.
++
++8.5 Governing Law.
++
++This License shall be governed by the laws of the United States and the
++State of Washington, as applied to contracts entered into and to be
++performed in Washington between Washington residents. The application of
++the United Nations Convention on Contracts for the International Sale of
++Goods is expressly excluded. You agree that the state and federal courts
++located in Seattle, Washington have exclusive jurisdiction over any
++claim relating to the License, including contract and tort claims.
++
++8.6 Dispute Resolution.
++
++a) Arbitration. Any dispute arising out of or relating to this License
++shall be finally settled by arbitration as set out herein, except that
++either party may bring any action, in a court of competent jurisdiction
++(which jurisdiction shall be exclusive), with respect to any dispute
++relating to such party's Intellectual Property Rights or with respect to
++Your compliance with the TCK license. Arbitration shall be administered:
++(i) by the American Arbitration Association (AAA), (ii) in accordance
++with the rules of the United Nations Commission on International Trade
++Law (UNCITRAL) (the "Rules") in effect at the time of arbitration as
++modified herein; and (iii) the arbitrator will apply the substantive
++laws of Washington and the United States. Judgment upon the award
++rendered by the arbitrator may be entered in any court having
++jurisdiction to enforce such award.
++
++b) Arbitration language, venue and damages. All arbitration proceedings
++shall be conducted in English by a single arbitrator selected in
++accordance with the Rules, who must be fluent in English and be either a
++retired judge or practicing attorney having at least ten (10) years
++litigation experience and be reasonably familiar with the technology
++matters relative to the dispute. Unless otherwise agreed, arbitration
++venue shall be in Seattle, Washington. The arbitrator may award monetary
++damages only and nothing shall preclude either party from seeking
++provisional or emergency relief from a court of competent jurisdiction.
++The arbitrator shall have no authority to award damages in excess of
++those permitted in this License and any such award in excess is void.
++All awards will be payable in U.S. dollars and may include, for the
++prevailing party (i) pre-judgment award interest, (ii) reasonable
++attorneys' fees incurred in connection with the arbitration, and (iii)
++reasonable costs and expenses incurred in enforcing the award. The
++arbitrator will order each party to produce identified documents and
++respond to no more than twenty-five single question interrogatories.
++
++8.7 Construction.
++
++Any law or regulation, which provides that the language of a contract
++shall be construed against the drafter, shall not apply to this License.
++
++8.8 U.S. Government End Users.
++
++The Covered Code is a "commercial item," as that term is defined in 48
++C.F.R. 2.101 (Oct. 1995), consisting of "commercial computer software"
++and "commercial computer software documentation," as such terms are used
++in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48 C.F.R. 12.212 and
++48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995), all U.S. Government
++End Users acquire Covered Code with only those rights set forth herein.
++You agree to pass this notice to our licensees.
++
++8.9 Marketing Activities.
++
++Licensee hereby grants Original Contributor a non-exclusive,
++non-transferable, limited license to use the Licensee's company name and
++logo ("Licensee Marks") in any presentations, press releases, or
++marketing materials solely for the purpose of identifying Licensee as a
++member of the Helix Community. Licensee shall provide samples of
++Licensee Marks to Original Contributor upon request by Original
++Contributor. Original Contributor acknowledges that the Licensee Marks
++are the trademarks of Licensee. Original Contributor shall not use the
++Licensee Marks in a way that may imply that Original Contributor is an
++agency or branch of Licensee. Original Contributor understands and
++agrees that the use of any Licensee Marks in connection with this
++Agreement shall not create any right, title or interest, in, or to the
++Licensee Marks or any Licensee trademarks and that all such use and
++goodwill associated with any such trademarks will inure to the benefit
++of Licensee. Further the Original Contributor will stop usage of the
++Licensee Marks upon Licensee's request.
++
++8.10 Press Announcements.
++
++You may make press announcements or other public statements regarding
++this License without the prior written consent of the Original
++Contributor, if Your statement is limited to announcing the licensing of
++the Covered Code or the availability of Your Product and its
++compatibility with the Covered Code. All other public announcements
++regarding this license require the prior written consent of the Original
++Contributor. Consent requests are welcome at press@helixcommunity.org.
++
++8.11 International Use.
++
++a) Export/Import laws. Covered Code is subject to U.S. export control
++laws and may be subject to export or import regulations in other
++countries. Each party agrees to comply strictly with all such laws and
++regulations and acknowledges their responsibility to obtain such
++licenses to export, re-export, or import as may be required. You agree
++to pass these obligations to Your licensees.
++
++b) Intellectual Property Protection. Due to limited intellectual
++property protection and enforcement in certain countries, You agree not
++to redistribute the Original Code, Upgraded Code, TCK and Specifications
++to any country on the list of restricted countries on the Community Web
++Server.
++
++8.12 Language.
++
++This License is in the English language only, which language shall be
++controlling in all respects, and all versions of this License in any
++other language shall be for accommodation only and shall not be binding
++on the parties to this License. All communications and notices made or
++given pursuant to this License, and all documentation and support to be
++provided, unless otherwise noted, shall be in the English language.
++
++PLEASE READ THE TERMS OF THIS LICENSE CAREFULLY. BY CLICKING ON THE
++"ACCEPT" BUTTON BELOW YOU ARE ACCEPTING AND AGREEING TO THE TERMS AND
++CONDITIONS OF THIS LICENSE WITH REALNETWORKS, INC. IF YOU ARE AGREEING
++TO THIS LICENSE ON BEHALF OF A COMPANY, YOU REPRESENT THAT YOU ARE
++AUTHORIZED TO BIND THE COMPANY TO SUCH A LICENSE. WHETHER YOU ARE ACTING
++ON YOUR OWN BEHALF, OR REPRESENTING A COMPANY, YOU MUST BE OF MAJORITY
++AGE AND BE OTHERWISE COMPETENT TO ENTER INTO CONTRACTS. IF YOU DO NOT
++MEET THIS CRITERIA OR YOU DO NOT AGREE TO ANY OF THE TERMS AND
++CONDITIONS OF THIS LICENSE, CLICK ON THE REJECT BUTTON TO EXIT.
++
++
++ GLOSSARY
++
++1. *"Added Value"* means code which:
++
++(i) has a principal purpose which is substantially different from that
++of the stand-alone Technology;
++
++(ii) represents a significant functional and value enhancement to the
++Technology;
++
++(iii) operates in conjunction with the Technology; and
++
++(iv) is not marketed as a technology which replaces or substitutes for
++the Technology
++
++2. "*Applicable Patent Rights*" mean: (a) in the case where Original
++Contributor is the grantor of rights, claims of patents that (i) are now
++or hereafter acquired, owned by or assigned to Original Contributor and
++(ii) are necessarily infringed by using or making the Original Code or
++Upgraded Code, including Modifications provided by Original Contributor,
++alone and not in combination with other software or hardware; and (b) in
++the case where Licensee is the grantor of rights, claims of patents that
++(i) are now or hereafter acquired, owned by or assigned to Licensee and
++(ii) are infringed (directly or indirectly) by using or making
++Licensee's Modifications or Error Corrections, taken alone or in
++combination with Covered Code.
++
++3. "*Application Programming Interfaces (APIs)"* means the interfaces,
++associated header files, service provider interfaces, and protocols that
++enable a device, application, Operating System, or other program to
++obtain services from or make requests of (or provide services in
++response to requests from) other programs, and to use, benefit from, or
++rely on the resources, facilities, and capabilities of the relevant
++programs using the APIs. APIs includes the technical documentation
++describing the APIs, the Source Code constituting the API, and any
++Header Files used with the APIs.
++
++4. "*Commercial Use*" means any use (internal or external), copying,
++sublicensing or distribution (internal or external), directly or
++indirectly of Covered Code by You other than Your Research Use of
++Covered Code within Your business or organization or in conjunction with
++other Licensees with equivalent Research Use rights. Commercial Use
++includes any use of the Covered Code for direct or indirect commercial
++or strategic gain, advantage or other business purpose. Any Commercial
++Use requires execution of Attachment D by You and Original Contributor.
++
++5. "*Community Code*" means the Original Code, Upgraded Code, Error
++Corrections, Shared Modifications, or any combination thereof.
++
++6. "*Community Webserver(s)"* means the webservers designated by
++Original Contributor for access to the Original Code, Upgraded Code, TCK
++and Specifications and for posting Error Corrections and Shared
++Modifications.
++
++7. "*Compliant Covered Code*" means Covered Code that complies with the
++requirements of the TCK.
++
++8. "*Contributor*" means each Licensee that creates or contributes to
++the creation of any Error Correction or Shared Modification.
++
++9. "*Covered Code*" means the Original Code, Upgraded Code,
++Modifications, or any combination thereof.
++
++10. "*Error Correction*" means any change made to Community Code which
++conforms to the Specification and corrects the adverse effect of a
++failure of Community Code to perform any function set forth in or
++required by the Specifications.
++
++11. "*Executable*" means Covered Code that has been converted from
++Source Code to the preferred form for execution by a computer or digital
++processor (e.g. binary form).
++
++12. "*Extension(s)"* means any additional Interfaces developed by or for
++You which: (i) are designed for use with the Technology; (ii) constitute
++an API for a library of computing functions or services; and (iii) are
++disclosed or otherwise made available to third party software developers
++for the purpose of developing software which invokes such additional
++Interfaces. The foregoing shall not apply to software developed by Your
++subcontractors to be exclusively used by You.
++
++13. "*Header File(s)"* means that portion of the Source Code that
++provides the names and types of member functions, data members, class
++definitions, and interface definitions necessary to implement the APIs
++for the Covered Code. Header Files include, files specifically
++designated by Original Contributor as Header Files. Header Files do not
++include the code necessary to implement the functionality underlying the
++Interface.
++
++14. *"Helix DNA Server Technology"* means the program(s) that implement
++the Helix Universal Server streaming engine for the Technology as
++defined in the Specification.
++
++15. *"Helix DNA Client Technology"* means the Covered Code that
++implements the RealOne Player engine as defined in the Specification.
++
++16. *"Helix DNA Producer Technology"* means the Covered Code that
++implements the Helix Producer engine as defined in the Specification.
++
++17. *"Helix DNA Technology"* means the Helix DNA Server Technology, the
++Helix DNA Client Technology, the Helix DNA Producer Technology and other
++Helix technologies designated by Original Contributor.
++
++18. "*Intellectual Property Rights*" means worldwide statutory and
++common law rights associated solely with (i) Applicable Patent Rights;
++(ii) works of authorship including copyrights, copyright applications,
++copyright registrations and "moral rights"; (iii) the protection of
++trade and industrial secrets and confidential information; and (iv)
++divisions, continuations, renewals, and re-issuances of the foregoing
++now existing or acquired in the future.
++
++19. *"Interface*" means interfaces, functions, properties, class
++definitions, APIs, Header Files, GUIDs, V-Tables, and/or protocols
++allowing one piece of software, firmware or hardware to communicate or
++interoperate with another piece of software, firmware or hardware.
++
++20. "*Internal Deployment Use*" means use of Compliant Covered Code
++(excluding Research Use) within Your business or organization only by
++Your employees and/or agents on behalf of Your business or organization,
++but not to provide services, including content distribution, to third
++parties, subject to execution of Attachment D by You and Original
++Contributor, if required.
++
++21. "*Licensee*" means any party that has entered into and has in effect
++a version of this License with Original Contributor.
++
++22. "*MIME type*" means a description of what type of media or other
++content is in a file, including by way of example but not limited to
++'audio/x-pn-realaudio-plugin.'
++
++23. "*Modification(s)"* means (i) any addition to, deletion from and/or
++change to the substance and/or structure of the Covered Code, including
++Interfaces; (ii) the combination of any Covered Code and any previous
++Modifications; (iii) any new file or other representation of computer
++program statements that contains any portion of Covered Code; and/or
++(iv) any new Source Code implementing any portion of the Specifications.
++
++24. "*MP3 Patents*" means any patents necessary to make, use or sell
++technology implementing any portion of the specification developed by
++the Moving Picture Experts Group known as MPEG-1 Audio Layer-3 or MP3,
++including but not limited to all past and future versions, profiles,
++extensions, parts and amendments relating to the MP3 specification.
++
++25. "*MPEG-4 Patents*" means any patents necessary to make, use or sell
++technology implementing any portion of the specification developed by
++the Moving Pictures Experts Group known as MPEG-4, including but not
++limited to all past and future versions, profiles, extensions, parts and
++amendments relating to the MPEG-4 specification.
++
++26. "*Original Code*" means the initial Source Code for the Technology
++as described on the Community Web Server.
++
++27. "*Original Contributor*" means RealNetworks, Inc., its affiliates
++and its successors and assigns.
++
++28. "*Original Contributor MIME Type*" means the MIME registry, browser
++preferences, or local file/protocol associations invoking any Helix DNA
++Client-based application, including the RealOne Player, for playback of
++RealAudio, RealVideo, other RealMedia MIME types or datatypes (e.g.,
++.ram, .rnx, .rpm, .ra, .rm, .rp, .rt, .rf, .prx, .mpe, .rmp, .rmj, .rav,
++.rjs, .rmx, .rjt, .rms), and any other Original Contributor-specific or
++proprietary MIME types that Original Contributor may introduce in the
++future.
++
++29. "*Personal Use*" means use of Covered Code by an individual solely
++for his or her personal, private and non-commercial purposes. An
++individual's use of Covered Code in his or her capacity as an officer,
++employee, member, independent contractor or agent of a corporation,
++business or organization (commercial or non-commercial) does not qualify
++as Personal Use.
++
++30. "*RealMedia File Format*" means the file format designed and
++developed by RealNetworks for storing multimedia data and used to store
++RealAudio and RealVideo encoded streams. Valid RealMedia File Format
++extensions include: .rm, .rmj, .rmc, .rmvb, .rms.
++
++31. "*RCSL Webpage*" means the RealNetworks Community Source License
++webpage located at https://www.helixcommunity.org/content/rcsl or such
++other URL that Original Contributor may designate from time to time.
++
++32. "*Reformatted Specifications*" means any revision to the
++Specifications which translates or reformats the Specifications (as for
++example in connection with Your documentation) but which does not alter,
++subset or superset * *the functional or operational aspects of the
++Specifications.
++
++33. "*Research Use*" means use and distribution of Covered Code only for
++Your Personal Use, research or development use and expressly excludes
++Internal Deployment Use and Commercial Use. Research Use also includes
++use of Covered Code to teach individuals how to use Covered Code.
++
++34. "*Shared Modifications*" means Modifications that You distribute or
++use for a Commercial Use, in addition to any Modifications provided by
++You, at Your option, pursuant to Section 2.2, or received by You from a
++Contributor pursuant to Section 2.3.
++
++35. "*Source Code*" means the preferred form of the Covered Code for
++making modifications to it, including all modules it contains, plus any
++associated interface definition files, scripts used to control
++compilation and installation of an Executable, or source code
++differential comparisons against either the Original Code or another
++well known, available Covered Code of the Contributor's choice. The
++Source Code can be in a compressed or archival form, provided the
++appropriate decompression or de-archiving software is widely available
++for no charge.
++
++36. "*Specifications*" means the specifications for the Technology and
++other documentation, as designated on the Community Web Server, as may
++be revised by Original Contributor from time to time.
++
++37. "*Trademarks*" means Original Contributor's trademarks and logos,
++including, but not limited to, RealNetworks, RealAudio, RealVideo,
++RealOne, RealSystem, SureStream, Helix, Helix DNA and other trademarks
++whether now used or adopted in the future.
++
++38. "*Technology*" means the technology described in Attachment B, and
++Upgrades.
++
++39. "*Technology Compatibility Kit"* or *"TCK*" means the test programs,
++procedures, acceptance criteria and/or other requirements, designated by
++Original Contributor for use in verifying compliance of Covered Code
++with the Specifications, in conjunction with the Original Code and
++Upgraded Code. Original Contributor may, in its sole discretion and from
++time to time, revise a TCK to correct errors and/or omissions and in
++connection with Upgrades.
++
++40. "*Upgrade(s)"* means new versions of Technology designated
++exclusively by Original Contributor as an "Upgrade" and released by
++Original Contributor from time to time under the terms of the License.
++
++41. "*Upgraded Code*" means the Source Code and/or Executables for
++Upgrades, possibly including Modifications made by Contributors.
++
++42. *"User's Guide"* means the users guide for the TCK which Original
++Contributor makes available to You to provide direction in how to run
++the TCK and properly interpret the results, as may be revised by
++Original Contributor from time to time.
++
++43. "*You(r)*" means an individual, or a legal entity acting by and
++through an individual or individuals, exercising rights either under
++this License or under a future version of this License issued pursuant
++to Section 4.1. For legal entities, "You(r)" includes any entity that by
++majority voting interest controls, is controlled by, or is under common
++control with You.
++
++44. "*Your Products*" means any (i) hardware products You distribute
++integrating the Covered Code; (ii) any software products You distribute
++with the Covered Code that utilize the APIs of the Covered Code; or
++(iii) any services You provide using the Covered Code.
++
++
++ ATTACHMENT A
++
++REQUIRED NOTICES
++
++
++ ATTACHMENT A-1
++
++REQUIRED IN ALL CASES
++
++Notice to be included in header file of all Error Corrections and Shared
++Modifications:
++
++Portions Copyright 1994-2003 © RealNetworks, Inc. All rights reserved.
++
++The contents of this file, and the files included with this file, are
++subject to the current version of RealNetworks Community Source License
++Version 1.1 (the "License"). You may not use this file except in
++compliance with the License executed by both You and RealNetworks. You
++may obtain a copy of the License at *
++https://www.helixcommunity.org/content/rcsl.* You may also obtain a copy
++of the License by contacting RealNetworks directly. Please see the
++License for the rights, obligations and limitations governing use of the
++contents of the file.
++
++This file is part of the Helix DNA technology. RealNetworks, Inc., is
++the developer of the Original code and owns the copyrights in the
++portions it created.
++
++This file, and the files included with this file, are distributed on an
++'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED,
++AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
++LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
++PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++
++Contributor(s):
++
++_______________________________________________
++
++Technology Compatibility Kit Test Suite(s) Location:
++
++________________________________
++
++
++ ATTACHMENT A-2
++
++SAMPLE LICENSEE CERTIFICATION
++
++"By clicking the `Agree' button below, You certify that You are a
++Licensee in good standing under the RealNetworks Community Source
++License, ("License") and that Your access, use and distribution of code
++and information You may obtain at this site is subject to the License.
++If You are not a Licensee under the RealNetworks Community Source
++License You agree not to download, copy or use the Helix DNA technology.
++
++
++ ATTACHMENT A-3
++
++REQUIRED STUDENT NOTIFICATION
++
++"This software and related documentation has been obtained by Your
++educational institution subject to the RealNetworks Community Source
++License. You have been provided access to the software and related
++documentation for use only in connection with your course work and
++research activities as a matriculated student of Your educational
++institution. Any other use is expressly prohibited.
++
++THIS SOFTWARE AND RELATED DOCUMENTATION CONTAINS PROPRIETARY MATERIAL OF
++REALNETWORKS, INC, WHICH ARE PROTECTED BY VARIOUS INTELLECTUAL PROPERTY
++RIGHTS.
++
++You may not use this file except in compliance with the License. You may
++obtain a copy of the License on the web at
++https://www.helixcommunity.org/content/rcsl.
++
++*
++*
++
++
++ ATTACHMENT B
++
++Description of Technology
++
++Helix DNA, which consists of Helix DNA Client, Helix DNA Server and
++Helix DNA Producer.
++
++Description of "Technology"
++
++Helix DNA Technology v1.0 as described on the Community Web Server.
++
++
++ ATTACHMENT C
++
++TECHNOLOGY COMPATIBILITY KIT LICENSE
++
++The following license is effective for the *Helix DNA* Technology
++Compatibility Kit - as described on the Community Web Server. The
++Technology Compatibility Kit(s) for the Technology specified in
++Attachment B may be accessed at the Community Web Server.
++
++1. TCK License.
++
++1.1 Grants to use TCK
++
++Subject to the terms and restrictions set forth below and the
++RealNetworks Community Source License, and the Research Use license,
++Original Contributor grants to You a worldwide, non-exclusive,
++non-transferable license, to the extent of Original Contributor's
++Intellectual Property Rights in the TCK (without the right to
++sublicense), to use the TCK to develop and test Covered Code.
++
++1.2 TCK Use Restrictions.
++
++You are not authorized to create derivative works of the TCK or use the
++TCK to test any implementation of the Specification that is not Covered
++Code. You may not publish Your test results or make claims of
++comparative compatibility with respect to other implementations of the
++Specification. In consideration for the license grant in Section 1.1
++above You agree not to develop Your own tests that are intended to
++validate conformation with the Specification.
++
++2. Test Results.
++
++You agree to provide to Original Contributor or the third party test
++facility if applicable, Your test results that demonstrate that Covered
++Code is Compliant Covered Code and that Original Contributor may publish
++or otherwise distribute such test results.
++
++PLEASE READ THE TERMS OF THIS LICENSE CAREFULLY. BY CLICKING ON THE
++"ACCEPT" BUTTON BELOW YOU ARE ACCEPTING AND AGREEING TO THE TERMS AND
++CONDITIONS OF THIS LICENSE WITH THE ORIGINAL CONTRIBUTOR, REALNETWORKS,
++INC. IF YOU ARE AGREEING TO THIS LICENSE ON BEHALF OF A COMPANY, YOU
++REPRESENT THAT YOU ARE AUTHORIZED TO BIND THE COMPANY TO SUCH A LICENSE.
++WHETHER YOU ARE ACTING ON YOUR OWN BEHALF, OR REPRESENTING A COMPANY,
++YOU MUST BE OF MAJORITY AGE AND BE OTHERWISE COMPETENT TO ENTER INTO
++CONTRACTS. IF YOU DO NOT MEET THIS CRITERIA OR YOU DO NOT AGREE TO ANY
++OF THE TERMS AND CONDITIONS OF THIS LICENSE, CLICK ON THE REJECT BUTTON
++TO EXIT.
++
++*ACCEPT / REJECT
++*
++
++*
++*
++
++*To agree to the R&D/academic terms of this license, please register
++<https://www.helixcommunity.org/2002/intro/why-register> on the site --
++you will then be given a chance to agree to the clickwrap RCSL
++<https://reguseronly.helixcommunity.org/2002/clickwrap/rcsl-clickwrap>
++R&D License
++<https://reguseronly.helixcommunity.org/2002/clickwrap/rcsl-clickwrap>
++and gain access to the RCSL-licensed source code. To build or deploy
++commercial applications based on the RCSL, you will need to agree to the
++Commercial Use license attachments
++<https://www.helixcommunity.org/content/rcsl-attachments>*
++
++
++
+Index: helix-libs/clientapps/clutter/RPSL.txt
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/RPSL.txt 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,518 @@
++RealNetworks Public Source License Version 1.0
++(Rev. Date October 28, 2002)
++
++1. General Definitions. This License applies to any program or other work which
++RealNetworks, Inc., or any other entity that elects to use this license,
++("Licensor") makes publicly available and which contains a notice placed by
++Licensor identifying such program or work as "Original Code" and stating that it
++is subject to the terms of this RealNetworks Public Source License version 1.0
++(or subsequent version thereof) ("License"). You are not required to accept this
++License. However, nothing else grants You permission to use, copy, modify or
++distribute the software or its derivative works. These actions are prohibited by
++law if You do not accept this License. Therefore, by modifying, copying or
++distributing the software (or any work based on the software), You indicate your
++acceptance of this License to do so, and all its terms and conditions. In
++addition, you agree to the terms of this License by clicking the Accept button
++or downloading the software. As used in this License:
++
++1.1 "Applicable Patent Rights" mean: (a) in the case where Licensor is the
++grantor of rights, claims of patents that (i) are now or hereafter acquired,
++owned by or assigned to Licensor and (ii) are necessarily infringed by using or
++making the Original Code alone and not in combination with other software or
++hardware; and (b) in the case where You are the grantor of rights, claims of
++patents that (i) are now or hereafter acquired, owned by or assigned to You and
++(ii) are infringed (directly or indirectly) by using or making Your
++Modifications, taken alone or in combination with Original Code.
++
++1.2 "Compatible Source License" means any one of the licenses listed on Exhibit
++B or at https://www.helixcommunity.org/content/complicense or other licenses
++specifically identified by Licensor in writing. Notwithstanding any term to the
++contrary in any Compatible Source License, any code covered by any Compatible
++Source License that is used with Covered Code must be made readily available in
++Source Code format for royalty-free use under the terms of the Compatible Source
++License or this License.
++
++1.3 "Contributor" means any person or entity that creates or contributes to the
++creation of Modifications.
++
++1.4 "Covered Code" means the Original Code, Modifications, the combination of
++Original Code and any Modifications, and/or any respective portions thereof.
++
++1.5 "Deploy" means to use, sublicense or distribute Covered Code other than for
++Your internal research and development (R&D) and/or Personal Use, and includes
++without limitation, any and all internal use or distribution of Covered Code
++within Your business or organization except for R&D use and/or Personal Use, as
++well as direct or indirect sublicensing or distribution of Covered Code by You
++to any third party in any form or manner.
++
++1.6 "Derivative Work" means either the Covered Code or any derivative work under
++United States copyright law, and including any work containing or including any
++portion of the Covered Code or Modifications, either verbatim or with
++modifications and/or translated into another language. Derivative Work also
++includes any work which combines any portion of Covered Code or Modifications
++with code not otherwise governed by the terms of this License.
++
++1.7 "Externally Deploy" means to Deploy the Covered Code in any way that may be
++accessed or used by anyone other than You, used to provide any services to
++anyone other than You, or used in any way to deliver any content to anyone other
++than You, whether the Covered Code is distributed to those parties, made
++available as an application intended for use over a computer network, or used to
++provide services or otherwise deliver content to anyone other than You.
++
++1.8. "Interface" means interfaces, functions, properties, class definitions,
++APIs, header files, GUIDs, V-Tables, and/or protocols allowing one piece of
++software, firmware or hardware to communicate or interoperate with another piece
++of software, firmware or hardware.
++
++1.9 "Modifications" mean any addition to, deletion from, and/or change to, the
++substance and/or structure of the Original Code, any previous Modifications, the
++combination of Original Code and any previous Modifications, and/or any
++respective portions thereof. When code is released as a series of files, a
++Modification is: (a) any addition to or deletion from the contents of a file
++containing Covered Code; and/or (b) any new file or other representation of
++computer program statements that contains any part of Covered Code.
++
++1.10 "Original Code" means (a) the Source Code of a program or other work as
++originally made available by Licensor under this License, including the Source
++Code of any updates or upgrades to such programs or works made available by
++Licensor under this License, and that has been expressly identified by Licensor
++as such in the header file(s) of such work; and (b) the object code compiled
++from such Source Code and originally made available by Licensor under this
++License.
++
++1.11 "Personal Use" means use of Covered Code by an individual solely for his or
++her personal, private and non-commercial purposes. An individual's use of
++Covered Code in his or her capacity as an officer, employee, member, independent
++contractor or agent of a corporation, business or organization (commercial or
++non-commercial) does not qualify as Personal Use.
++
++1.12 "Source Code" means the human readable form of a program or other work that
++is suitable for making modifications to it, including all modules it contains,
++plus any associated interface definition files, scripts used to control
++compilation and installation of an executable (object code).
++
++1.13 "You" or "Your" means an individual or a legal entity exercising rights
++under this License. For legal entities, "You" or "Your" includes any entity
++which controls, is controlled by, or is under common control with, You, where
++"control" means (a) the power, direct or indirect, to cause the direction or
++management of such entity, whether by contract or otherwise, or (b) ownership of
++fifty percent (50%) or more of the outstanding shares or beneficial ownership of
++such entity.
++
++2. Permitted Uses; Conditions & Restrictions. Subject to the terms and
++conditions of this License, Licensor hereby grants You, effective on the date
++You accept this License (via downloading or using Covered Code or otherwise
++indicating your acceptance of this License), a worldwide, royalty-free,
++non-exclusive copyright license, to the extent of Licensor's copyrights cover
++the Original Code, to do the following:
++
++2.1 You may reproduce, display, perform, modify and Deploy Covered Code,
++provided that in each instance:
++
++(a) You must retain and reproduce in all copies of Original Code the copyright
++and other proprietary notices and disclaimers of Licensor as they appear in the
++Original Code, and keep intact all notices in the Original Code that refer to
++this License;
++
++(b) You must include a copy of this License with every copy of Source Code of
++Covered Code and documentation You distribute, and You may not offer or impose
++any terms on such Source Code that alter or restrict this License or the
++recipients' rights hereunder, except as permitted under Section 6;
++
++(c) You must duplicate, to the extent it does not already exist, the notice in
++Exhibit A in each file of the Source Code of all Your Modifications, and cause
++the modified files to carry prominent notices stating that You changed the files
++and the date of any change;
++
++(d) You must make Source Code of all Your Externally Deployed Modifications
++publicly available under the terms of this License, including the license grants
++set forth in Section 3 below, for as long as you Deploy the Covered Code or
++twelve (12) months from the date of initial Deployment, whichever is longer. You
++should preferably distribute the Source Code of Your Deployed Modifications
++electronically (e.g. download from a web site); and
++
++(e) if You Deploy Covered Code in object code, executable form only, You must
++include a prominent notice, in the code itself as well as in related
++documentation, stating that Source Code of the Covered Code is available under
++the terms of this License with information on how and where to obtain such
++Source Code. You must also include the Object Code Notice set forth in Exhibit A
++in the "about" box or other appropriate place where other copyright notices are
++placed, including any packaging materials.
++
++2.2 You expressly acknowledge and agree that although Licensor and each
++Contributor grants the licenses to their respective portions of the Covered Code
++set forth herein, no assurances are provided by Licensor or any Contributor that
++the Covered Code does not infringe the patent or other intellectual property
++rights of any other entity. Licensor and each Contributor disclaim any liability
++to You for claims brought by any other entity based on infringement of
++intellectual property rights or otherwise. As a condition to exercising the
++rights and licenses granted hereunder, You hereby assume sole responsibility to
++secure any other intellectual property rights needed, if any. For example, if a
++third party patent license is required to allow You to make, use, sell, import
++or offer for sale the Covered Code, it is Your responsibility to acquire such
++license(s).
++
++2.3 Subject to the terms and conditions of this License, Licensor hereby grants
++You, effective on the date You accept this License (via downloading or using
++Covered Code or otherwise indicating your acceptance of this License), a
++worldwide, royalty-free, perpetual, non-exclusive patent license under
++Licensor's Applicable Patent Rights to make, use, sell, offer for sale and
++import the Covered Code, provided that in each instance you comply with the
++terms of this License.
++
++3. Your Grants. In consideration of, and as a condition to, the licenses granted
++to You under this License:
++
++(a) You grant to Licensor and all third parties a non-exclusive, perpetual,
++irrevocable, royalty free license under Your Applicable Patent Rights and other
++intellectual property rights owned or controlled by You, to make, sell, offer
++for sale, use, import, reproduce, display, perform, modify, distribute and
++Deploy Your Modifications of the same scope and extent as Licensor's licenses
++under Sections 2.1 and 2.2; and
++
++(b) You grant to Licensor and its subsidiaries a non-exclusive, worldwide,
++royalty-free, perpetual and irrevocable license, under Your Applicable Patent
++Rights and other intellectual property rights owned or controlled by You, to
++make, use, sell, offer for sale, import, reproduce, display, perform,
++distribute, modify or have modified (for Licensor and/or its subsidiaries),
++sublicense and distribute Your Modifications, in any form and for any purpose,
++through multiple tiers of distribution.
++
++(c) You agree not use any information derived from Your use and review of the
++Covered Code, including but not limited to any algorithms or inventions that may
++be contained in the Covered Code, for the purpose of asserting any of Your
++patent rights, or assisting a third party to assert any of its patent rights,
++against Licensor or any Contributor.
++
++4. Derivative Works. You may create a Derivative Work by combining Covered Code
++with other code not otherwise governed by the terms of this License and
++distribute the Derivative Work as an integrated product. In each such instance,
++You must make sure the requirements of this License are fulfilled for the
++Covered Code or any portion thereof, including all Modifications.
++
++4.1 You must cause any Derivative Work that you distribute, publish or
++Externally Deploy, that in whole or in part contains or is derived from the
++Covered Code or any part thereof, to be licensed as a whole at no charge to all
++third parties under the terms of this License and no other license except as
++provided in Section 4.2. You also must make Source Code available for the
++Derivative Work under the same terms as Modifications, described in Sections 2
++and 3, above.
++
++4.2 Compatible Source Licenses. Software modules that have been independently
++developed without any use of Covered Code and which contain no portion of the
++Covered Code, Modifications or other Derivative Works, but are used or combined
++in any way wtih the Covered Code or any Derivative Work to form a larger
++Derivative Work, are exempt from the conditions described in Section 4.1 but
++only to the extent that: the software module, including any software that is
++linked to, integrated with, or part of the same applications as, the software
++module by any method must be wholly subject to one of the Compatible Source
++Licenses. Notwithstanding the foregoing, all Covered Code must be subject to the
++terms of this License. Thus, the entire Derivative Work must be licensed under a
++combination of the RPSL (for Covered Code) and a Compatible Source License for
++any independently developed software modules within the Derivative Work. The
++foregoing requirement applies even if the Compatible Source License would
++ordinarily allow the software module to link with, or form larger works with,
++other software that is not subject to the Compatible Source License. For
++example, although the Mozilla Public License v1.1 allows Mozilla code to be
++combined with proprietary software that is not subject to the MPL, if
++MPL-licensed code is used with Covered Code the MPL-licensed code could not be
++combined or linked with any code not governed by the MPL. The general intent of
++this section 4.2 is to enable use of Covered Code with applications that are
++wholly subject to an acceptable open source license. You are responsible for
++determining whether your use of software with Covered Code is allowed under Your
++license to such software.
++
++4.3 Mere aggregation of another work not based on the Covered Code with the
++Covered Code (or with a work based on the Covered Code) on a volume of a storage
++or distribution medium does not bring the other work under the scope of this
++License. If You deliver the Covered Code for combination and/or integration with
++an application previously provided by You (for example, via automatic updating
++technology), such combination and/or integration constitutes a Derivative Work
++subject to the terms of this License.
++
++5. Exclusions From License Grant. Nothing in this License shall be deemed to
++grant any rights to trademarks, copyrights, patents, trade secrets or any other
++intellectual property of Licensor or any Contributor except as expressly stated
++herein. No right is granted to the trademarks of Licensor or any Contributor
++even if such marks are included in the Covered Code. Nothing in this License
++shall be interpreted to prohibit Licensor from licensing under different terms
++from this License any code that Licensor otherwise would have a right to
++license. Modifications, Derivative Works and/or any use or combination of
++Covered Code with other technology provided by Licensor or third parties may
++require additional patent licenses from Licensor which Licensor may grant in its
++sole discretion. No patent license is granted separate from the Original Code or
++combinations of the Original Code with other software or hardware.
++
++5.1. Trademarks. This License does not grant any rights to use the trademarks or
++trade names owned by Licensor ("Licensor Marks" defined in Exhibit C) or to any
++trademark or trade name belonging to any Contributor. No Licensor Marks may be
++used to endorse or promote products derived from the Original Code other than as
++permitted by the Licensor Trademark Policy defined in Exhibit C.
++
++6. Additional Terms. You may choose to offer, and to charge a fee for, warranty,
++support, indemnity or liability obligations and/or other rights consistent with
++the scope of the license granted herein ("Additional Terms") to one or more
++recipients of Covered Code. However, You may do so only on Your own behalf and
++as Your sole responsibility, and not on behalf of Licensor or any Contributor.
++You must obtain the recipient's agreement that any such Additional Terms are
++offered by You alone, and You hereby agree to indemnify, defend and hold
++Licensor and every Contributor harmless for any liability incurred by or claims
++asserted against Licensor or such Contributor by reason of any such Additional
++Terms.
++
++7. Versions of the License. Licensor may publish revised and/or new versions of
++this License from time to time. Each version will be given a distinguishing
++version number. Once Original Code has been published under a particular version
++of this License, You may continue to use it under the terms of that version. You
++may also choose to use such Original Code under the terms of any subsequent
++version of this License published by Licensor. No one other than Licensor has
++the right to modify the terms applicable to Covered Code created under this
++License.
++
++8. NO WARRANTY OR SUPPORT. The Covered Code may contain in whole or in part
++pre-release, untested, or not fully tested works. The Covered Code may contain
++errors that could cause failures or loss of data, and may be incomplete or
++contain inaccuracies. You expressly acknowledge and agree that use of the
++Covered Code, or any portion thereof, is at Your sole and entire risk. THE
++COVERED CODE IS PROVIDED "AS IS" AND WITHOUT WARRANTY, UPGRADES OR SUPPORT OF
++ANY KIND AND LICENSOR AND LICENSOR'S LICENSOR(S) (COLLECTIVELY REFERRED TO AS
++"LICENSOR" FOR THE PURPOSES OF SECTIONS 8 AND 9) AND ALL CONTRIBUTORS EXPRESSLY
++DISCLAIM ALL WARRANTIES AND/OR CONDITIONS, EXPRESS OR IMPLIED, INCLUDING, BUT
++NOT LIMITED TO, THE IMPLIED WARRANTIES AND/OR CONDITIONS OF MERCHANTABILITY, OF
++SATISFACTORY QUALITY, OF FITNESS FOR A PARTICULAR PURPOSE, OF ACCURACY, OF QUIET
++ENJOYMENT, AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. LICENSOR AND EACH
++CONTRIBUTOR DOES NOT WARRANT AGAINST INTERFERENCE WITH YOUR ENJOYMENT OF THE
++COVERED CODE, THAT THE FUNCTIONS CONTAINED IN THE COVERED CODE WILL MEET YOUR
++REQUIREMENTS, THAT THE OPERATION OF THE COVERED CODE WILL BE UNINTERRUPTED OR
++ERROR-FREE, OR THAT DEFECTS IN THE COVERED CODE WILL BE CORRECTED. NO ORAL OR
++WRITTEN DOCUMENTATION, INFORMATION OR ADVICE GIVEN BY LICENSOR, A LICENSOR
++AUTHORIZED REPRESENTATIVE OR ANY CONTRIBUTOR SHALL CREATE A WARRANTY. You
++acknowledge that the Covered Code is not intended for use in high risk
++activities, including, but not limited to, the design, construction, operation
++or maintenance of nuclear facilities, aircraft navigation, aircraft
++communication systems, or air traffic control machines in which case the failure
++of the Covered Code could lead to death, personal injury, or severe physical or
++environmental damage. Licensor disclaims any express or implied warranty of
++fitness for such uses.
++
++9. LIMITATION OF LIABILITY. TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT
++SHALL LICENSOR OR ANY CONTRIBUTOR BE LIABLE FOR ANY INCIDENTAL, SPECIAL,
++INDIRECT OR CONSEQUENTIAL DAMAGES ARISING OUT OF OR RELATING TO THIS LICENSE OR
++YOUR USE OR INABILITY TO USE THE COVERED CODE, OR ANY PORTION THEREOF, WHETHER
++UNDER A THEORY OF CONTRACT, WARRANTY, TORT (INCLUDING NEGLIGENCE OR STRICT
++LIABILITY), PRODUCTS LIABILITY OR OTHERWISE, EVEN IF LICENSOR OR SUCH
++CONTRIBUTOR HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES AND
++NOTWITHSTANDING THE FAILURE OF ESSENTIAL PURPOSE OF ANY REMEDY. SOME
++JURISDICTIONS DO NOT ALLOW THE LIMITATION OF LIABILITY OF INCIDENTAL OR
++CONSEQUENTIAL DAMAGES, SO THIS LIMITATION MAY NOT APPLY TO YOU. In no event
++shall Licensor's total liability to You for all damages (other than as may be
++required by applicable law) under this License exceed the amount of ten dollars
++($10.00).
++
++10. Ownership. Subject to the licenses granted under this License, each
++Contributor retains all rights, title and interest in and to any Modifications
++made by such Contributor. Licensor retains all rights, title and interest in and
++to the Original Code and any Modifications made by or on behalf of Licensor
++("Licensor Modifications"), and such Licensor Modifications will not be
++automatically subject to this License. Licensor may, at its sole discretion,
++choose to license such Licensor Modifications under this License, or on
++different terms from those contained in this License or may choose not to
++license them at all.
++
++11. Termination.
++
++11.1 Term and Termination. The term of this License is perpetual unless
++terminated as provided below. This License and the rights granted hereunder will
++terminate:
++
++(a) automatically without notice from Licensor if You fail to comply with any
++term(s) of this License and fail to cure such breach within 30 days of becoming
++aware of such breach;
++
++(b) immediately in the event of the circumstances described in Section 12.5(b);
++or
++
++(c) automatically without notice from Licensor if You, at any time during the
++term of this License, commence an action for patent infringement against
++Licensor (including by cross-claim or counter claim in a lawsuit);
++
++(d) upon written notice from Licensor if You, at any time during the term of
++this License, commence an action for patent infringement against any third party
++alleging that the Covered Code itself (excluding combinations with other
++software or hardware) infringes any patent (including by cross-claim or counter
++claim in a lawsuit).
++
++11.2 Effect of Termination. Upon termination, You agree to immediately stop any
++further use, reproduction, modification, sublicensing and distribution of the
++Covered Code and to destroy all copies of the Covered Code that are in your
++possession or control. All sublicenses to the Covered Code which have been
++properly granted prior to termination shall survive any termination of this
++License. Provisions which, by their nature, should remain in effect beyond the
++termination of this License shall survive, including but not limited to Sections
++3, 5, 8, 9, 10, 11, 12.2 and 13. No party will be liable to any other for
++compensation, indemnity or damages of any sort solely as a result of terminating
++this License in accordance with its terms, and termination of this License will
++be without prejudice to any other right or remedy of any party.
++
++12. Miscellaneous.
++
++12.1 Government End Users. The Covered Code is a "commercial item" as defined in
++FAR 2.101. Government software and technical data rights in the Covered Code
++include only those rights customarily provided to the public as defined in this
++License. This customary commercial license in technical data and software is
++provided in accordance with FAR 12.211 (Technical Data) and 12.212 (Computer
++Software) and, for Department of Defense purchases, DFAR 252.227-7015 (Technical
++Data -- Commercial Items) and 227.7202-3 (Rights in Commercial Computer Software
++or Computer Software Documentation). Accordingly, all U.S. Government End Users
++acquire Covered Code with only those rights set forth herein.
++
++12.2 Relationship of Parties. This License will not be construed as creating an
++agency, partnership, joint venture or any other form of legal association
++between or among You, Licensor or any Contributor, and You will not represent to
++the contrary, whether expressly, by implication, appearance or otherwise.
++
++12.3 Independent Development. Nothing in this License will impair Licensor's
++right to acquire, license, develop, have others develop for it, market and/or
++distribute technology or products that perform the same or similar functions as,
++or otherwise compete with, Modifications, Derivative Works, technology or
++products that You may develop, produce, market or distribute.
++
++12.4 Waiver; Construction. Failure by Licensor or any Contributor to enforce any
++provision of this License will not be deemed a waiver of future enforcement of
++that or any other provision. Any law or regulation which provides that the
++language of a contract shall be construed against the drafter will not apply to
++this License.
++
++12.5 Severability. (a) If for any reason a court of competent jurisdiction finds
++any provision of this License, or portion thereof, to be unenforceable, that
++provision of the License will be enforced to the maximum extent permissible so
++as to effect the economic benefits and intent of the parties, and the remainder
++of this License will continue in full force and effect. (b) Notwithstanding the
++foregoing, if applicable law prohibits or restricts You from fully and/or
++specifically complying with Sections 2 and/or 3 or prevents the enforceability
++of either of those Sections, this License will immediately terminate and You
++must immediately discontinue any use of the Covered Code and destroy all copies
++of it that are in your possession or control.
++
++12.6 Dispute Resolution. Any litigation or other dispute resolution between You
++and Licensor relating to this License shall take place in the Seattle,
++Washington, and You and Licensor hereby consent to the personal jurisdiction of,
++and venue in, the state and federal courts within that District with respect to
++this License. The application of the United Nations Convention on Contracts for
++the International Sale of Goods is expressly excluded.
++
++12.7 Export/Import Laws. This software is subject to all export and import laws
++and restrictions and regulations of the country in which you receive the Covered
++Code and You are solely responsible for ensuring that You do not export,
++re-export or import the Covered Code or any direct product thereof in violation
++of any such restrictions, laws or regulations, or without all necessary
++authorizations.
++
++12.8 Entire Agreement; Governing Law. This License constitutes the entire
++agreement between the parties with respect to the subject matter hereof. This
++License shall be governed by the laws of the United States and the State of
++Washington.
++
++Where You are located in the province of Quebec, Canada, the following clause
++applies: The parties hereby confirm that they have requested that this License
++and all related documents be drafted in English. Les parties ont exig&eacute;
++que le pr&eacute;sent contrat et tous les documents connexes soient
++r&eacute;dig&eacute;s en anglais.
++
++ EXHIBIT A.
++
++"Copyright &copy; 1995-2002
++RealNetworks, Inc. and/or its licensors. All Rights Reserved.
++
++The contents of this file, and the files included with this file, are subject to
++the current version of the RealNetworks Public Source License Version 1.0 (the
++"RPSL") available at https://www.helixcommunity.org/content/rpsl unless you have
++licensed the file under the RealNetworks Community Source License Version 1.0
++(the "RCSL") available at https://www.helixcommunity.org/content/rcsl, in which
++case the RCSL will apply. You may also obtain the license terms directly from
++RealNetworks. You may not use this file except in compliance with the RPSL or,
++if you have a valid RCSL with RealNetworks applicable to this file, the RCSL.
++Please see the applicable RPSL or RCSL for the rights, obligations and
++limitations governing use of the contents of the file.
++
++This file is part of the Helix DNA Technology. RealNetworks is the developer of
++the Original code and owns the copyrights in the portions it created.
++
++This file, and the files included with this file, is distributed and made
++available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR
++IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING
++WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
++PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++
++Contributor(s): ____________________________________
++
++Technology Compatibility Kit Test
++Suite(s) Location (if licensed under the RCSL): ______________________________
++
++Object Code Notice: Helix DNA Client technology included. Copyright (c)
++RealNetworks, Inc., 1995-2002. All rights reserved.
++
++
++ EXHIBIT B
++
++Compatible Source Licenses for the RealNetworks Public Source License. The
++following list applies to the most recent version of the license as of October
++25, 2002, unless otherwise indicated.
++
++* Academic Free License
++* Apache Software License
++* Apple Public Source License
++* Artistic license
++* Attribution Assurance Licenses
++* BSD license
++* Common Public License (1)
++* Eiffel Forum License
++* GNU General Public License (GPL) (1)
++* GNU Library or "Lesser" General Public License (LGPL) (1)
++* IBM Public License
++* Intel Open Source License
++* Jabber Open Source License
++* MIT license
++* MITRE Collaborative Virtual Workspace License (CVW License)
++* Motosoto License
++* Mozilla Public License 1.0 (MPL)
++* Mozilla Public License 1.1 (MPL)
++* Nokia Open Source License
++* Open Group Test Suite License
++* Python Software Foundation License
++* Ricoh Source Code Public License
++* Sun Industry Standards Source License (SISSL)
++* Sun Public License
++* University of Illinois/NCSA Open Source License
++* Vovida Software License v. 1.0
++* W3C License
++* X.Net License
++* Zope Public License
++* zlib/libpng license
++
++(1) Note: because this license contains certain reciprocal licensing terms that
++purport to extend to independently developed code, You may be prohibited under
++the terms of this otherwise compatible license from using code licensed under
++its terms with Covered Code because Covered Code may only be licensed under the
++RealNetworks Public Source License. Any attempt to apply non RPSL license terms,
++including without limitation the GPL, to Covered Code is expressly forbidden.
++You are responsible for ensuring that Your use of Compatible Source Licensed
++code does not violate either the RPSL or the Compatible Source License.
++
++The latest version of this list can be found at:
++https://www.helixcommunity.org/content/complicense
++
++ EXHIBIT C
++
++RealNetworks' Trademark policy.
++
++RealNetworks defines the following trademarks collectively as "Licensor
++Trademarks": "RealNetworks", "RealPlayer", "RealJukebox", "RealSystem",
++"RealAudio", "RealVideo", "RealOne Player", "RealMedia", "Helix" or any other
++trademarks or trade names belonging to RealNetworks.
++
++RealNetworks "Licensor Trademark Policy" forbids any use of Licensor Trademarks
++except as permitted by and in strict compliance at all times with RealNetworks'
++third party trademark usage guidelines which are posted at
++http://www.realnetworks.com/info/helixlogo.html.
++
+Index: helix-libs/clientapps/clutter/Umakefil
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/Umakefil 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,325 @@
++#
++# ***** BEGIN LICENSE BLOCK *****
++# Version: RCSL 1.0/RPSL 1.0
++#
++# Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++#
++# The contents of this file, and the files included with this file, are
++# subject to the current version of the RealNetworks Public Source License
++# Version 1.0 (the "RPSL") available at
++# http://www.helixcommunity.org/content/rpsl unless you have licensed
++# the file under the RealNetworks Community Source License Version 1.0
++# (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++# in which case the RCSL will apply. You may also obtain the license terms
++# directly from RealNetworks. You may not use this file except in
++# compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++# applicable to this file, the RCSL. Please see the applicable RPSL or
++# RCSL for the rights, obligations and limitations governing use of the
++# contents of the file.
++#
++# This file is part of the Helix DNA Technology. RealNetworks is the
++# developer of the Original Code and owns the copyrights in the portions
++# it created.
++#
++# This file, and the files included with this file, is distributed and made
++# available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++# EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++# INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++# FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++#
++# Technology Compatibility Kit Test Suite(s) Location:
++# http://www.helixcommunity.org/content/tck
++#
++# Contributor(s):
++#
++# ***** END LICENSE BLOCK *****
++#
++
++UmakefileVersion(2,2)
++
++project.AddModuleIncludes("common/include",
++ "common/runtime/pub",
++ "client/include",
++ "client/common/system/pub",
++ "client/common/container/pub",
++ "client/audiosvc/pub",
++ "common/container/pub",
++ "video/sitelib/pub",
++ "video/colconverter/pub",
++ "video/sitelib/pub/platform/unix",
++ "video/sitelib",
++ "datatype/rm/include",
++ "client/core")
++
++project.AddSources("player.cpp",
++ "excontxt.cpp",
++ "exsite.cpp",
++ "exroot.cpp",
++ "exadvsnk.cpp",
++ "exerror.cpp",
++ "iids.cpp",
++ "exstateadvsnk.cpp",
++ "excallback.cpp",
++ "print.cpp")
++
++project.AddModuleLibraries(
++ "common/runtime[runtlib]",
++ "common/system[syslib]",
++ "common/container[contlib]",
++ "common/runtime[runtlib]",
++ "client/common/system[sysclntlib]",
++ "common/dbgtool[debuglib]",
++ "common/util[utillib]",
++ "video/sitelib[sitelib]",
++ "video/sitelib[sitecreatelib]",
++ "common/log/logutil[logutillib]",
++ "video/vidutil[vidutillib]"
++ )
++project.AddSystemLibraries('Xv', 'Xext')
++
++if project.IsDefined("HELIX_FEATURE_PREFERENCES"):
++ project.AddSources("preflist.cpp")
++
++if project.IsDefined("HELIX_FEATURE_AUTHENTICATION"):
++ project.AddSources("exaumgr.cpp")
++
++if project.IsDefined("HELIX_FEATURE_VIDEO"):
++ project.AddSources("exsitsup.cpp",
++ "fivemmap.cpp")
++ project.AddModuleIncludes('video/include')
++ if project.IsDefined("HELIX_FEATURE_PNG"):
++ project.AddModuleIncludes('datatype/image/png/common/pub')
++ project.AddModuleLibraries("common/import/zlib[zlib]",
++ "datatype/image/png/import/libpng[libpng]",
++ "datatype/image/png/common[pngcomlib]")
++
++if project.IsDefined("HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS"):
++ project.AddSources("exprdnld.cpp")
++
++if project.BuildOption("nodll"):
++ ## Client core
++ static_plugin_list = ["clntcore"]
++ project.AddModuleLibraries("common/runtime[runtlib]",
++ "common/fileio[fileiolib]",
++ "client/common/system[sysclntlib]",
++ "client/common/container[contclntlib]",
++ "client/core[clntcorelib]")
++ if not project.IsDefined("HELIX_FEATURE_LOGLEVEL_NONE"):
++ project.AddModuleLibraries("common/log/logutil[logutillib]")
++ if not project.IsDefined("HELIX_CONFIG_MINIMIZE_SIZE"):
++ project.AddModuleLibraries("client/common/util[utlclntlib]")
++ ## Client core libraries
++ if project.IsDefined("HELIX_FEATURE_AUDIO"):
++ project.AddModuleLibraries("audio/device[auddevlib]",
++ "client/audiosvc[audsvclib]")
++ if ('HELIX_FEATURE_VOLUME' in project.defines):
++ project.AddModuleLibraries("audio/gaintool[audgainlib]" )
++ if ('HELIX_FEATURE_VOLUME' in project.defines):
++ project.AddModuleLibraries("audio/crossfade[audxfadelib]")
++ if project.IsDefined("HELIX_FEATURE_MIXER"):
++ project.AddModuleLibraries("audio/mixer[audmixlib]")
++ if project.IsDefined("HELIX_FEATURE_RESAMPLER"):
++ project.AddModuleLibraries("audio/resampler[audresamplib]")
++ if project.IsDefined("HELIX_FEATURE_LIMITER"):
++ project.AddModuleLibraries("audio/limiter[audlimiter]")
++
++ if project.IsDefined("HELIX_FEATURE_VIDEO"):
++ project.AddModuleLibraries("client/videosvc[vidsvclib]",
++ "protocol/sdp[sdplib]")
++ if project.IsDefined("HELIX_FEATURE_PLAYBACK_NET"):
++ project.AddModuleLibraries("client/netwksvc[netsvclib]",
++ "common/netio[netiolib]",
++ "client/common/netio[netioclntlib]",
++ "protocol/transport/common/system[systranlib]",
++ "protocol/transport/rtp[rtptranlib]",
++ "protocol/common/util[protutillib]",
++ "protocol/rtsp[rtsplib]")
++ if project.IsDefined("HELIX_FEATURE_RDT"):
++ project.AddLibraries(GetSDKPath("prtclrdt_lib"))
++ project.AddModuleLibraries("protocol/transport/rdt[rdttranlib]")
++ if project.IsDefined("HELIX_FEATURE_PNA"):
++ project.AddLibraries(GetSDKPath("prtclpna_lib"))
++ if project.IsDefined("HELIX_FEATURE_XMLPARSER"):
++ project.AddModuleLibraries("common/lang/xml[xmllib]")
++ ## Add RAM file format and renderer
++ if project.IsDefined("HELIX_FEATURE_META"):
++ static_plugin_list[-1:-1] = ["ramfformat", "ramrender"]
++ project.AddModuleLibraries("datatype/ram/renderer[ramrendrlib]")
++ ## Add local file system
++ if project.IsDefined("HELIX_FEATURE_PLAYBACK_LOCAL"):
++ static_plugin_list[-1:-1] = ["smplfsys"]
++ project.AddModuleLibraries("common/fileio[fileiolib]")
++ ## Add http file system
++ if project.IsDefined("HELIX_FEATURE_PLAYBACK_NET"):
++ static_plugin_list[-1:-1] = ["hxsdp", "httpfsys"]
++ project.AddModuleLibraries("protocol/http[httplib]",
++ "protocol/common/util[protutillib]",
++ "protocol/sdp[sdplib]",
++ "filesystem/data[datafsys]",
++ "common/fileio[fileiolib]",
++ "common/import/zlib[zlib]")
++ ## Add realmedia file format
++ if project.IsDefined("HELIX_FEATURE_PLAYBACK_LOCAL") and \
++ (project.IsDefined("HELIX_FEATURE_AUDIO_REAL") or \
++ project.IsDefined("HELIX_FEATURE_VIDEO_REAL")):
++ static_plugin_list[-1:-1] = ["rmfformat"]
++ project.AddModuleLibraries("datatype/common/util[dtutillib]",
++ "datatype/common/container[dtcomcontlib]")
++ project.AddLibraries(GetSDKPath("rmcom_lib"),
++ GetSDKPath("rmacom_lib"),
++ GetSDKPath("rmff_lib"),
++ GetSDKPath("rmvidpyld_lib"))
++
++ ## Add realmedia renderer
++ if project.IsDefined("HELIX_FEATURE_AUDIO_REAL"):
++ static_plugin_list[-1:-1] = ["rarender"]
++ project.AddModuleLibraries("datatype/rm/audio/payload[rapayld]")
++ project.AddLibraries(GetSDKPath("rmarend_lib"),
++ GetSDKPath("rmacom_lib"))
++ ## Add mp3 file format and renderer
++ if project.IsDefined("HELIX_FEATURE_AUDIO_MPA_LAYER3") or \
++ project.IsDefined("HELIX_FEATURE_AUDIO_MPA_LAYER2") or \
++ project.IsDefined("HELIX_FEATURE_AUDIO_MPA_LAYER1"):
++ static_plugin_list[-1:-1] = ["mp3render"]
++ project.AddModuleLibraries("datatype/mp3/codec/fltpt[mp3codecfltpt]",
++ "datatype/mp3/common[mp3lib]",
++ "datatype/mp3/payload[mp3payld]",
++ "datatype/common/util[dtutillib]")
++ if project.IsDefined("HELIX_FEATURE_PLAYBACK_LOCAL"):
++ static_plugin_list[-1:-1] = ["mp3fformat"]
++ project.AddModuleLibraries("datatype/mp3/common[mp3lib]")
++ ## Add gecko realmedia codec
++ if project.IsDefined("HELIX_FEATURE_AUDIO_CODEC_GECKO"):
++ static_plugin_list[-1:-1] = ["cook"]
++ if not project.IsDefined("HELIX_CONFIG_FIXEDPOINT"):
++ project.AddLibraries(GetSDKPath("ra8lbrdec_flt_lib"))
++ else:
++ project.AddLibraries(GetSDKPath("ra8lbrdec_fix_lib"))
++ project.AddModuleLibraries("datatype/rm/audio/codec/common[racompat]")
++ ## Add RAAC codec
++ if project.IsDefined("HELIX_FEATURE_AUDIO_CODEC_RAAC"):
++ static_plugin_list[-1:-1] = ["raac"]
++ project.AddModuleLibraries("datatype/mp4/common[mp4comlib]",
++ "datatype/aac/codec/fixpt/decoder/hxwrap[aacdeclib]")
++ ## Add sipro realmedia codec
++ ## (Right now this only works for floating-point platforms)
++ if project.IsDefined("HELIX_FEATURE_AUDIO_CODEC_SIPRO"):
++ static_plugin_list[-1:-1] = ["sipr"]
++ project.AddLibraries(GetSDKPath("sipro_flt_backend_lib"))
++ ## Add tokyo realmedia codec
++ if project.IsDefined("HELIX_FEATURE_AUDIO_CODEC_TOKYO"):
++ static_plugin_list[-1:-1] = ["atrc"]
++ project.AddLibraries(GetSDKPath("ra8hbr_lib"))
++ ##
++ if project.IsDefined("HELIX_FEATURE_VIDEO"):
++ static_plugin_list[-1:-1] = ["vidsite"]
++ static_plugin_list[-1:-1] = ["hxltcolor"]
++ project.AddModuleLibraries("datatype/common/vidrend[vidrend]",
++ "video/sitelib[sitelib]",
++ "video/site[vidsite]",
++ "video/colconverter[hxltcolor]",
++ "datatype/rm/common[rmcomlib]",
++ "video/vidutil[vidutillib]")
++
++ if (project.IsDefined('HELIX_FEATURE_ALTERNATE_SITE_CREATE_LIB')):
++ project.AddLibraries(GetSDKPath("sitecreate_lib"))
++ else:
++ project.AddModuleLibraries('video/sitelib[sitecreatelib]')
++
++ ## Add realvideo renderer
++ if project.IsDefined("HELIX_FEATURE_VIDEO_REAL"):
++ project.AddModuleLibraries("datatype/rm/video/renderer[rvxrendlib]")
++ project.AddLibraries(GetSDKPath("rmvidcom_lib"),
++ GetSDKPath("rmvidpyld_lib"),
++ GetSDKPath("rvcodcom_lib"))
++ project.AddModuleLibraries("datatype/common/util[dtutillib]")
++ static_plugin_list[-1:-1] = ["rvrender"]
++
++ ## Add mpeg4 file format
++ if project.IsDefined("HELIX_FEATURE_PLAYBACK_LOCAL")and \
++ (project.IsDefined("HELIX_FEATURE_VIDEO_H263") or \
++ project.IsDefined("HELIX_FEATURE_VIDEO_MPEG4") or \
++ project.IsDefined("HELIX_FEATURE_AUDIO_MPEG4")):
++ static_plugin_list[-1:-1] = ["mp4fformat"]
++ project.AddModuleLibraries("datatype/common/util[dtutillib]",
++ "datatype/common/audrend",
++ "datatype/mp4/common[mp4comlib]",
++ "datatype/mp4/payload[mp4pyldlib]",
++ "datatype/mp4/fileformat[mp4fformatlib]")
++ if not project.IsDefined("HELIX_FEATURE_MP4_FILEFORMAT_M4A_ONLY"):
++ project.AddModuleLibraries("protocol/sdp[sdplib]",
++ "protocol/rtsp[rtsplib]",
++ "protocol/common/util[protutillib]",
++ "datatype/rm/common[rmcomlib]",
++ "datatype/amr/common[amrcomlib]")
++ ## Add h.263 renderer
++ if project.IsDefined("HELIX_FEATURE_VIDEO_H263"):
++ project.AddModuleLibraries("datatype/h263/payload[h263pyldlib]")
++ static_plugin_list[-1:-1] = ["h263render"]
++ ## Add MPEG4 renderer
++# if project.IsDefined("HELIX_FEATURE_VIDEO_MPEG4"):
++# static_plugin_list[-1:-1] = ["mp4xrender"]
++ ## Add mpeg 4 audio renderer
++ if project.IsDefined("HELIX_FEATURE_AUDIO_MPEG4"):
++ static_plugin_list[-1:-1] = ["mp4arender"]
++ project.AddModuleLibraries("datatype/mp4/audio/renderer[mp4arenderlib]")
++ if not project.IsDefined("HELIX_FEATURE_MP4_FILEFORMAT_M4A_ONLY"):
++ project.AddModuleLibraries("datatype/amr/common[amrcomlib]")
++ ## Add RV10 codec
++ if project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV10"):
++ project.AddLibraries(GetSDKPath("rv1dec_libs")+"[rv10lib]",
++ GetSDKPath("rv1dec_libs")+"[drv1lib]")
++ static_plugin_list[-1:-1] = ["rv10", "drv1"]
++ ## Add RV20 codec
++ if project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV20"):
++ project.AddLibraries(GetSDKPath("rvg2dec_libs")+"[rv20lib]",
++ GetSDKPath("rvg2dec_libs")+"[drv2lib]")
++ static_plugin_list[-1:-1] = ["rv20", "drv2"]
++
++ if project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV30") or \
++ project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV40"):
++ static_plugin_list[-1:-1] = ["drvc"]
++ if project.IsDefined("HELIX_FEATURE_ANSIC_RV89COMBO"):
++ project.AddLibraries(GetSDKPath("rv89combo_c_libs")+"[drvc]")
++ else:
++ project.AddLibraries(GetSDKPath("rv89combo_libs")+"[drvclib]")
++
++ if project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV30"):
++ static_plugin_list[-1:-1] = ["rv30"]
++ project.AddLibraries(GetSDKPath("rv89combo_libs")+"[rv3xlib]")
++ project.AddModuleLibraries("datatype/rm/video/codec/rv89combo[rv30]")
++
++ if project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV40"):
++ static_plugin_list[-1:-1] = ["rv40"]
++ project.AddLibraries(GetSDKPath("rv89combo_libs")+"[rv4xlib]")
++ project.AddModuleLibraries("datatype/rm/video/codec/rv89combo[rv40]")
++
++# if project.IsDefined("HELIX_FEATURE_AUDIO_CODEC_AAC"):
++# static_plugin_list[-1:-1] = ["aac4"]
++
++ CreateStaticPluginTable(static_plugin_list)
++
++project.ExportFunction("init_main", "void")
++project.ExportFunction("deinit_main", "void")
++project.ExportFunction("get_player", "void **ppPlayer",
++ "on_buffering_cb_t on_buffering_cb",
++ "on_pos_length_cb_t on_pos_length_cb")
++project.ExportFunction("player_openurl", "void *pPlayerHandle",
++ "char *pszRawURL")
++project.ExportFunction("put_player", "void *pPlayerHandle")
++project.ExportFunction("player_geturl", "void *pPlayerHandle", "char **pszURL")
++project.ExportFunction("player_begin", "void *pPlayerHandle")
++project.ExportFunction("player_stop", "void *pPlayerHandle")
++project.ExportFunction("player_pause", "void *pPlayerHandle")
++project.ExportFunction("player_seek", "void *pPlayerHandle", "int pos")
++project.ExportFunction("get_curr_playtime", "void *pPlayerHandle")
++project.ExportFunction("player_getvolume", "void *pPlayerHandle")
++project.ExportFunction("player_canseek", "void *pPlayerHandle")
++project.ExportFunction("player_setvolume", "void *pPlayerHandle", "unsigned short volumn")
++
++
++
++DLLTarget('libhelix-player')
++
++DependTarget()
++
+Index: helix-libs/clientapps/clutter/exabd.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exabd.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,245 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include <stdio.h>
++
++#include "hxtypes.h"
++
++#include "hxcom.h"
++#include "hxcomm.h"
++#include "hxmon.h"
++#include "hxcore.h"
++#include "hxengin.h"
++#include "chxpckts.h"
++#include "hxclsnk.h"
++#include "hxstrutl.h"
++#include "exabd.h"
++
++#include "print.h"
++
++#include "globals.h"
++
++struct _stGlobals*& GetGlobal(); //in main.cpp
++
++ExampleABD::ExampleABD(IUnknown* pUnknown)
++ : m_lRefCount (0)
++ , m_pUnknown (NULL)
++ , m_ulABDStartTime(0)
++ , m_ulABDResult(0)
++ , m_bABDDone(FALSE)
++{
++ if (pUnknown)
++ {
++ m_pUnknown = pUnknown;
++ m_pUnknown->AddRef();
++ }
++}
++
++ExampleABD::~ExampleABD(void)
++{
++ HX_RELEASE(m_pUnknown);
++}
++
++
++// *** IUnknown methods ***
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::QueryInterface
++// Purpose:
++// Implement this to export the interfaces supported by your
++// object.
++//
++STDMETHODIMP ExampleABD::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = (IUnknown*)(IHXAutoBWCalibrationAdviseSink*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXAutoBWCalibrationAdviseSink))
++ {
++ AddRef();
++ *ppvObj = (IHXAutoBWCalibrationAdviseSink*)this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::AddRef
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleABD::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::Release
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleABD::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++/*
++ * IHXAutoBWCalibrationAdviseSink methods
++ */
++STDMETHODIMP
++ExampleABD::AutoBWCalibrationStarted (const char* pszServer)
++{
++ if (pszServer)
++ {
++ STDOUT("ABD: contacting %s\n", pszServer);
++ }
++
++ return HXR_OK;
++}
++
++STDMETHODIMP
++ExampleABD::AutoBWCalibrationDone(HX_RESULT status,
++ UINT32 ulBW)
++{
++ m_bABDDone = TRUE;
++
++ if (HXR_OK == status)
++ {
++ m_ulABDResult = ulBW;
++ STDOUT("ABD: %lu(Kbps) %lu(ms)\n", ulBW, GetTickCount() - m_ulABDStartTime);
++ }
++ else
++ {
++ STDOUT("ABD failed: %lu\n", status);
++ }
++
++ return HXR_OK;
++}
++
++HX_RESULT
++ExampleABD::DoABD(const char* pszServer,
++ UINT32 mode,
++ UINT32 packetSize,
++ UINT32 packetNum)
++{
++ HX_RESULT rc = HXR_OK;
++ UINT32 length = 0;
++ IHXAutoBWCalibration* pABD = NULL;
++ IHXValues* pValues = NULL;
++ IHXBuffer* pBuffer = NULL;
++
++ m_ulABDStartTime = GetTickCount();
++ m_ulABDResult = 0;
++ m_bABDDone = FALSE;
++
++ if (m_pUnknown &&
++ HXR_OK == m_pUnknown->QueryInterface(IID_IHXAutoBWCalibration, (void**)&pABD))
++ {
++ pValues = (IHXValues*) new CHXHeader();
++ pValues->AddRef();
++
++ pBuffer = (IHXBuffer*) new CHXBuffer();
++ pBuffer->AddRef();
++
++ pBuffer->Set((UCHAR*)pszServer, strlen(pszServer)+1);
++ pValues->SetPropertyCString("ABDServers", pBuffer);
++
++ pValues->SetPropertyULONG32("AutoBWDetectionMode", mode);
++ pValues->SetPropertyULONG32("AutoBWDetectionPacketSize", packetSize);
++ pValues->SetPropertyULONG32("AutoBWDetectionPackets", packetNum);
++
++ pABD->AddAutoBWCalibrationSink((IHXAutoBWCalibrationAdviseSink*)this);
++ pABD->InitAutoBWCalibration(pValues);
++
++ pABD->StartAutoBWCalibration();
++
++ while (!m_bABDDone)
++ {
++ MSG msg;
++ DWORD starttime, endtime, i;
++ BOOL sleep = TRUE;
++ static const int checkinterval = 10;
++
++ starttime = GetTickCount();
++ endtime = starttime + (20);
++ i = 0;
++ while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE))
++ {
++ DispatchMessage(&msg);
++ if ((i % checkinterval) == 0)
++ {
++ if (GetTickCount() > endtime)
++ break;
++ ++i;
++ }
++ sleep = FALSE;
++ }
++
++ if (sleep)
++ Sleep(10);
++ }
++ }
++
++cleanup:
++
++ if (pABD)
++ {
++ pABD->RemoveAutoBWCalibrationSink((IHXAutoBWCalibrationAdviseSink*)this);
++ }
++
++ HX_RELEASE(pBuffer);
++ HX_RELEASE(pValues);
++ HX_RELEASE(pABD);
++
++ return rc;
++}
++
++
+Index: helix-libs/clientapps/clutter/exabd.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exabd.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,85 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _EXAMPLEABD_
++#define _EXAMPLEABD_
++
++struct IHXAutoBWCalibrationAdviseSink;
++struct IUnknown;
++
++class ExampleABD : public IHXAutoBWCalibrationAdviseSink
++{
++ private:
++ LONG32 m_lRefCount;
++ IUnknown* m_pUnknown;
++ UINT32 m_ulABDStartTime;
++ UINT32 m_ulABDResult;
++ BOOL m_bABDDone;
++
++ ~ExampleABD();
++
++ public:
++
++ ExampleABD(IUnknown* /*IN*/ pUnknown);
++
++ /*
++ * IUnknown methods
++ */
++ STDMETHOD(QueryInterface) (THIS_
++ REFIID riid,
++ void** ppvObj);
++
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /*
++ * IHXAutoBWCalibrationAdviseSink methods
++ */
++ STDMETHOD(AutoBWCalibrationStarted) (THIS_
++ const char* pszServer);
++ STDMETHOD(AutoBWCalibrationDone) (THIS_
++ HX_RESULT status,
++ UINT32 ulBW);
++
++ HX_RESULT DoABD(const char* pszServer,
++ UINT32 mode,
++ UINT32 packetSize,
++ UINT32 packetNum);
++
++ UINT32 GetABD(void) { return m_ulABDResult; };
++};
++
++#endif /* _EXAMPLEABDSNK_ */
+Index: helix-libs/clientapps/clutter/exadvsnk.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exadvsnk.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,1116 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include <stdio.h>
++
++#include "hxtypes.h"
++
++#include "hxcom.h"
++#include "hxcomm.h"
++#include "hxmon.h"
++#include "hxcore.h"
++#include "hxengin.h"
++#include "hxclsnk.h"
++#include "hxgroup.h"
++#include "hxstrutl.h"
++#include "exadvsnk.h"
++#include "hxstring.h"
++#include "hxprefs.h"
++#include "excontxt.h"
++
++#include "print.h"
++
++#include "globals.h"
++#include "player.h"
++
++struct _stGlobals*& GetGlobal(); //in main.cpp
++
++#ifdef __TCS__
++extern unsigned long gStreamTime;
++
++static int iOpened = 0;
++
++
++#if defined(__cplusplus)
++extern "C" {
++#endif /* defined(__cplusplus) */
++
++typedef enum hookBuffering {
++ eContacting = 0,
++ eConnecting = 1,
++ eBuffering = 2,
++ ePlaying = 3
++}hookBuffering;
++
++void hookRealAudio_Buffering(hookBuffering connectState, int pct);
++
++void hookRealAudio_PlayPosition(unsigned long current,unsigned long duration);
++
++typedef enum hookState {
++ ePlay = 0,
++ ePause = 1,
++ eStop = 2,
++ eResume = 3,
++ eComplete // Clip is done playing
++}hookState;
++void hookRealAudio_State(hookState newState);
++
++
++#if defined(__cplusplus)
++}
++#endif /* defined(__cplusplus) */
++
++#endif // __TCS__
++
++void PrintBuffer(const char* pszName,const unsigned char* pbBuf, unsigned int dwBytes);
++
++ExampleClientAdviceSink::ExampleClientAdviceSink(IUnknown* pUnknown, LONG32 lClientIndex, on_buffering_cb_t on_buffering_cb, on_pos_length_cb_t on_pos_length_cb, void *context)
++ : m_lRefCount (0)
++ , m_lClientIndex (lClientIndex)
++ , m_pUnknown (NULL)
++ , m_pRegistry (NULL)
++ , m_pScheduler (NULL)
++ , m_lCurrentBandwidth(0)
++ , m_lAverageBandwidth(0)
++ , m_bOnStop(0)
++ , m_pPlayer(0)
++ , m_bWaitForTrackStart(0)
++ , m_on_buffering_cb(on_buffering_cb)
++ , m_on_pos_length_cb(on_pos_length_cb)
++ , m_context(context)
++{
++ if (pUnknown)
++ {
++ m_pUnknown = pUnknown;
++ m_pUnknown->AddRef();
++
++ if (HXR_OK != m_pUnknown->QueryInterface(IID_IHXRegistry, (void**)&m_pRegistry))
++ {
++ m_pRegistry = NULL;
++ }
++
++ if (HXR_OK != m_pUnknown->QueryInterface(IID_IHXScheduler, (void**)&m_pScheduler))
++ {
++ m_pScheduler = NULL;
++ }
++
++ IHXPlayer* pPlayer;
++ if(HXR_OK == m_pUnknown->QueryInterface(IID_IHXPlayer,
++ (void**)&pPlayer))
++ {
++ m_pPlayer = pPlayer;
++
++ IHXGroupManager* pGroupMgr = NULL;
++ if(HXR_OK == m_pPlayer->QueryInterface(IID_IHXGroupManager,
++ (void**)&pGroupMgr))
++ {
++ pGroupMgr->AddSink((IHXGroupSink*)this);
++ pGroupMgr->Release();
++ }
++
++ pPlayer->AddAdviseSink(this);
++
++ }
++ }
++
++#ifdef __TCS__
++ bEnableAdviceSink = TRUE;
++ iOpened = 0;
++#endif
++}
++
++ExampleClientAdviceSink::~ExampleClientAdviceSink(void)
++{
++ if (m_pScheduler)
++ {
++ m_pScheduler->Release();
++ m_pScheduler = NULL;
++ }
++
++ if (m_pRegistry)
++ {
++ m_pRegistry->Release();
++ m_pRegistry = NULL;
++ }
++
++ if (m_pPlayer)
++ {
++ m_pPlayer->Release();
++ m_pPlayer = NULL;
++ }
++ if (m_pUnknown)
++ {
++ m_pUnknown->Release();
++ m_pUnknown = NULL;
++ }
++}
++
++
++// *** IUnknown methods ***
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::QueryInterface
++// Purpose:
++// Implement this to export the interfaces supported by your
++// object.
++//
++STDMETHODIMP ExampleClientAdviceSink::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = (IUnknown*)(IHXClientAdviseSink*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXClientAdviseSink))
++ {
++ AddRef();
++ *ppvObj = (IHXClientAdviseSink*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXGroupSink))
++ {
++ AddRef();
++ *ppvObj = (IHXGroupSink*)this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::AddRef
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleClientAdviceSink::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::Release
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleClientAdviceSink::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++/*
++ * IHXClientAdviseSink methods
++ */
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPosLength
++ * Purpose:
++ * Called to advise the client that the position or length of the
++ * current playback context has changed.
++ */
++
++#ifdef __TCS__
++static long lastPosition = -1;
++#endif
++
++STDMETHODIMP
++ExampleClientAdviceSink::OnPosLength(UINT32 ulPosition,
++ UINT32 ulLength)
++{
++ // Are we doing a multi-seek?
++ if (GetGlobal()->g_bMultiSeek)
++ {
++ // Have we run out of seek times?
++ if (GetGlobal()->g_ulMultiSeekIndex < GetGlobal()->g_ulNumMultiSeeks)
++ {
++ STDOUT("Multi-seeking the first player to %lu\n",
++ GetGlobal()->g_ulMultiSeekTime[GetGlobal()->g_ulMultiSeekIndex]);
++ GetGlobal()->g_Players[0]->Seek(GetGlobal()->g_ulMultiSeekTime[GetGlobal()->g_ulMultiSeekIndex++]);
++ }
++ else
++ {
++ // We've run out - stop the multi-seek
++ GetGlobal()->g_bMultiSeek = FALSE;
++ GetGlobal()->g_ulNumMultiSeeks = 0;
++ GetGlobal()->g_ulMultiSeekIndex = 0;
++ }
++ }
++
++ if (m_on_pos_length_cb)
++ m_on_pos_length_cb(ulPosition, ulLength, m_context);
++
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPresentationOpened
++ * Purpose:
++ * Called to advise the client a presentation has been opened.
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnPresentationOpened()
++{
++#ifdef __TCS__
++ iOpened = 1;
++ lastPosition = -1;
++#else
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnPresentationOpened()\n");
++ }
++#if defined(HELIX_FEATURE_PLAYBACK_VELOCITY)
++ // Try to get the IHXPlaybackVelocity interface
++ // from the first player
++ if (GetGlobal()->g_nPlayers > 0 && GetGlobal()->g_Players[0])
++ {
++ IHXPlaybackVelocity* pVel = NULL;
++ HX_RESULT rv = GetGlobal()->g_Players[0]->QueryInterface(IID_IHXPlaybackVelocity, (void**) &pVel);
++ if (SUCCEEDED(rv))
++ {
++ // Get the capabilities object from the player
++ rv = pVel->QueryVelocityCaps(GetGlobal()->g_pVelocityCaps);
++ if (SUCCEEDED(rv) && GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("Available Velocity Ranges:");
++ UINT32 ulNumRanges = GetGlobal()->g_pVelocityCaps->GetNumRanges();
++ for (UINT32 i = 0; i < ulNumRanges && SUCCEEDED(rv); i++)
++ {
++ INT32 lMin = 0;
++ INT32 lMax = 0;
++ rv = GetGlobal()->g_pVelocityCaps->GetRange(i, lMin, lMax);
++ if (SUCCEEDED(rv))
++ {
++ STDOUT(" [%ld,%ld]", lMin, lMax);
++ }
++ }
++ STDOUT("\n");
++ }
++ }
++ HX_RELEASE(pVel);
++ }
++#endif /* #if defined(HELIX_FEATURE_PLAYBACK_VELOCITY) */
++#endif
++
++ UINT32 sourceCount = m_pPlayer->GetSourceCount();
++ for (UINT32 sourceID = 0; sourceID < sourceCount; sourceID ++)
++ {
++ // get HXSource
++ IUnknown* pUnkSource = NULL;
++ IHXStreamSource* pStreamSrc = NULL;
++
++ if (HXR_OK != m_pPlayer->GetSource (sourceID, pUnkSource))
++ {
++ continue;
++ }
++
++ pUnkSource->QueryInterface(IID_IHXStreamSource, (void **)&pStreamSrc);
++
++ HX_RELEASE(pUnkSource);
++
++ if (!pStreamSrc)
++ {
++ continue;
++ }
++
++ UINT32 num_streams = pStreamSrc->GetStreamCount();
++
++ // get information from Streams
++ for (UINT32 streamID = 0; streamID < num_streams ; streamID++)
++ {
++ IUnknown* pUnkStream = NULL;
++
++ if (HXR_OK == pStreamSrc->GetStream(streamID, pUnkStream))
++ {
++ IHXStream* pStream = NULL;
++
++ if (HXR_OK == pUnkStream->QueryInterface(IID_IHXStream,
++ (void**)&pStream))
++ {
++ const char* pMimeType = pStream->GetStreamType();
++ if( 0 == strcmp(pMimeType, "application/ram"))
++ {
++ m_bWaitForTrackStart = TRUE;
++ }
++ else
++ {
++ m_bWaitForTrackStart = FALSE;
++ }
++ }
++ HX_RELEASE(pStream);
++ }
++ HX_RELEASE(pUnkStream);
++ if (!m_bWaitForTrackStart)
++ {
++ break;
++ }
++ }
++
++ if (!m_bWaitForTrackStart)
++ {
++ break;
++ }
++ HX_RELEASE(pStreamSrc);
++ }
++
++ if (!m_bWaitForTrackStart)
++ {
++ STDOUT("----------------clip info--------------------\n");
++ if(m_pScheduler) {
++ m_hCallback = m_pScheduler->RelativeEnter(this,50);
++ }
++ }
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPresentationClosed
++ * Purpose:
++ * Called to advise the client a presentation has been closed.
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnPresentationClosed()
++{
++#ifdef __TCS__
++ iOpened = 0;
++ lastPosition = -1;
++#else
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnPresentationClosed()\n");
++ }
++#endif
++
++ return HXR_OK;
++}
++
++void ExampleClientAdviceSink::GetStatistics (char* pszRegistryKey)
++{
++ char szRegistryValue[MAX_DISPLAY_NAME] = {0}; /* Flawfinder: ignore */
++ INT32 lValue = 0;
++ INT32 i = 0;
++ INT32 lStatistics = 8;
++ UINT32 *plValue;
++
++#ifdef __TCS__
++ return; // DISABLED FOR NOW
++#endif
++
++ // collect statistic
++ for (i = 0; i < lStatistics; i++)
++ {
++ plValue = NULL;
++ switch (i)
++ {
++ case 0:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.Normal", pszRegistryKey);
++ break;
++ case 1:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.Recovered", pszRegistryKey);
++ break;
++ case 2:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.Received", pszRegistryKey);
++ break;
++ case 3:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.Lost", pszRegistryKey);
++ break;
++ case 4:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.Late", pszRegistryKey);
++ break;
++ case 5:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.ClipBandwidth", pszRegistryKey);
++ break;
++ case 6:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.AverageBandwidth", pszRegistryKey);
++ plValue = &m_lAverageBandwidth;
++ break;
++ case 7:
++ SafeSprintf(szRegistryValue, MAX_DISPLAY_NAME, "%s.CurrentBandwidth", pszRegistryKey);
++ plValue = &m_lCurrentBandwidth;
++ break;
++ default:
++ break;
++ }
++
++ m_pRegistry->GetIntByName(szRegistryValue, lValue);
++ if (plValue)
++ {
++ if (m_bOnStop || lValue == 0)
++ {
++ lValue = *plValue;
++ }
++ else
++ {
++ *plValue = lValue;
++ }
++ }
++ if (GetGlobal()->bEnableAdviceSink || (GetGlobal()->bEnableVerboseMode && m_bOnStop))
++ {
++ STDOUT("%s = %ld\n", szRegistryValue, lValue);
++ }
++ }
++}
++
++void ExampleClientAdviceSink::GetAllStatistics(void)
++{
++ UINT32 unPlayerIndex = 0;
++ UINT32 unSourceIndex = 0;
++ UINT32 unStreamIndex = 0;
++
++ char* pszRegistryPrefix = "Statistics";
++ char szRegistryName[MAX_DISPLAY_NAME] = {0}; /* Flawfinder: ignore */
++
++#ifdef __TCS__
++ return; // DISABLED FOR NOW
++#endif
++
++ // display the content of whole statistic registry
++ if (m_pRegistry)
++ {
++ // ok, let's start from the top (player)
++ SafeSprintf(szRegistryName, MAX_DISPLAY_NAME, "%s.Player%ld", pszRegistryPrefix, m_lClientIndex);
++ if (PT_COMPOSITE == m_pRegistry->GetTypeByName(szRegistryName))
++ {
++ // display player statistic
++ GetStatistics(szRegistryName);
++
++ SafeSprintf(szRegistryName, MAX_DISPLAY_NAME, "%s.Source%ld", szRegistryName, unSourceIndex);
++ while (PT_COMPOSITE == m_pRegistry->GetTypeByName(szRegistryName))
++ {
++ // display source statistic
++ GetStatistics(szRegistryName);
++
++ SafeSprintf(szRegistryName, MAX_DISPLAY_NAME, "%s.Stream%ld", szRegistryName, unStreamIndex);
++ while (PT_COMPOSITE == m_pRegistry->GetTypeByName(szRegistryName))
++ {
++ // display stream statistic
++ GetStatistics(szRegistryName);
++
++ unStreamIndex++;
++
++ SafeSprintf(szRegistryName, MAX_DISPLAY_NAME, "%s.Player%ld.Source%ld.Stream%ld",
++ pszRegistryPrefix, unPlayerIndex, unSourceIndex, unStreamIndex);
++ }
++
++ unSourceIndex++;
++
++ SafeSprintf(szRegistryName, MAX_DISPLAY_NAME, "%s.Player%ld.Source%ld",
++ pszRegistryPrefix, unPlayerIndex, unSourceIndex);
++ }
++
++ unPlayerIndex++;
++
++ SafeSprintf(szRegistryName, MAX_DISPLAY_NAME, "%s.Player%ld", pszRegistryPrefix, unPlayerIndex);
++ }
++ }
++}
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnStatisticsChanged
++ * Purpose:
++ * Called to advise the client that the presentation statistics
++ * have changed.
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnStatisticsChanged(void)
++{
++ char szBuff[1024]; /* Flawfinder: ignore */
++ HX_RESULT res = HXR_OK;
++ UINT16 uPlayer = 0;
++
++#ifdef __TCS__
++ return HXR_OK; // DISABLED FOR NOW
++#endif
++
++ if(GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnStatisticsChanged():\n");
++
++ SafeSprintf(szBuff, 1024, "Statistics");
++ res = DumpRegTree( szBuff );
++ }
++
++ return HXR_OK;
++}
++
++HX_RESULT ExampleClientAdviceSink::DumpRegTree(const char* pszTreeName )
++{
++ const char* pszName = NULL;
++ ULONG32 ulRegID = 0;
++ HX_RESULT res = HXR_OK;
++ INT32 nVal = 0;
++ IHXBuffer* pBuff = NULL;
++ IHXValues* pValues = NULL;
++
++ //See if the name exists in the reg tree.
++ res = m_pRegistry->GetPropListByName( pszTreeName, pValues);
++ if( HXR_OK!=res || !pValues )
++ return HXR_FAIL;
++
++ //make sure this is a PT_COMPOSITE type reg entry.
++ if( PT_COMPOSITE != m_pRegistry->GetTypeByName(pszTreeName))
++ return HXR_FAIL;
++
++ //Print out the value of each member of this tree.
++ res = pValues->GetFirstPropertyULONG32( pszName, ulRegID );
++ while( HXR_OK == res )
++ {
++ //We have at least one entry. See what type it is.
++ HXPropType pt = m_pRegistry->GetTypeById(ulRegID);
++ switch(pt)
++ {
++ case PT_COMPOSITE:
++ DumpRegTree(pszName);
++ break;
++ case PT_INTEGER :
++ nVal = 0;
++ m_pRegistry->GetIntById( ulRegID, nVal );
++ STDOUT("%s : %d\n", pszName, nVal );
++ break;
++ case PT_INTREF :
++ nVal = 0;
++ m_pRegistry->GetIntById( ulRegID, nVal );
++ STDOUT("%s : %d\n", pszName, nVal );
++ break;
++ case PT_STRING :
++ pBuff = NULL;
++ m_pRegistry->GetStrById( ulRegID, pBuff );
++ STDOUT("%s : \"", pszName );
++ if( pBuff )
++ STDOUT("%s", (const char *)(pBuff->GetBuffer()) );
++ STDOUT("\"\n" );
++ HX_RELEASE(pBuff);
++ break;
++ case PT_BUFFER :
++ STDOUT("%s : BUFFER TYPE NOT SHOWN\n",
++ pszName, nVal );
++ break;
++ case PT_UNKNOWN:
++ STDOUT("%s Unkown registry type entry\n", pszName );
++ break;
++ default:
++ STDOUT("%s Unkown registry type entry\n", pszName );
++ break;
++ }
++ res = pValues->GetNextPropertyULONG32( pszName, ulRegID);
++ }
++
++ HX_RELEASE( pValues );
++
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPreSeek
++ * Purpose:
++ * Called by client engine to inform the client that a seek is
++ * about to occur. The render is informed the last time for the
++ * stream's time line before the seek, as well as the first new
++ * time for the stream's time line after the seek will be completed.
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnPreSeek( ULONG32 ulOldTime,
++ ULONG32 ulNewTime)
++{
++#if !defined(__TCS__)
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnPreSeek(%ld, %ld)\n", ulOldTime, ulNewTime);
++ }
++#endif
++
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPostSeek
++ * Purpose:
++ * Called by client engine to inform the client that a seek has
++ * just occured. The render is informed the last time for the
++ * stream's time line before the seek, as well as the first new
++ * time for the stream's time line after the seek.
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnPostSeek( ULONG32 ulOldTime,
++ ULONG32 ulNewTime)
++{
++#ifdef __TCS__
++ lastPosition = -1;
++#else
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnPostSeek(%ld, %ld)\n", ulOldTime, ulNewTime);
++ }
++#endif
++
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnStop
++ * Purpose:
++ * Called by client engine to inform the client that a stop has
++ * just occured.
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnStop(void)
++{
++ HXTimeval now;
++
++#ifdef __TCS__
++ hookRealAudio_State(eStop);
++#else
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnStop()\n");
++ }
++
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("Player %ld stopped.\n", m_lClientIndex);
++ m_bOnStop = TRUE;
++ GetAllStatistics();
++ }
++#endif
++
++ // Find out the current time and subtract the beginning time to
++ // figure out how many seconds we played
++ now = m_pScheduler->GetCurrentSchedulerTime();
++ m_ulStopTime = now.tv_sec;
++
++ GetGlobal()->g_ulNumSecondsPlayed = m_ulStopTime - m_ulStartTime;
++
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPause
++ * Purpose:
++ * Called by client engine to inform the client that a pause has
++ * just occured. The render is informed the last time for the
++ * stream's time line before the pause.
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnPause(ULONG32 ulTime)
++{
++#ifdef __TCS__
++ hookRealAudio_State(ePause);
++#else
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnPause(%ld)\n", ulTime);
++ }
++#endif
++
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnBegin
++ * Purpose:
++ * Called by client engine to inform the client that a begin or
++ * resume has just occured. The render is informed the first time
++ * for the stream's time line after the resume.
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnBegin(ULONG32 ulTime)
++{
++ HXTimeval now;
++
++#if !defined(__TCS__)
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnBegin(%ld)\n", ulTime);
++ }
++
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("Player %ld beginning playback...\n", m_lClientIndex);
++ }
++#endif
++
++ GetGlobal()->g_bOnBeginOccurred = TRUE;
++
++ // Record the current time, so we can figure out many seconds we played
++ now = m_pScheduler->GetCurrentSchedulerTime();
++ m_ulStartTime = now.tv_sec;
++
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnBuffering
++ * Purpose:
++ * Called by client engine to inform the client that buffering
++ * of data is occuring. The render is informed of the reason for
++ * the buffering (start-up of stream, seek has occured, network
++ * congestion, etc.), as well as percentage complete of the
++ * buffering process.
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnBuffering(ULONG32 ulFlags,
++ UINT16 unPercentComplete)
++{
++#ifdef __TCS__
++static UINT16 lastPct = 0;
++ if (unPercentComplete > 0)
++ {
++ UINT16 nextPct = lastPct + 10;
++ if (unPercentComplete < lastPct)
++ {
++ lastPct = 0;
++ nextPct = lastPct + 10;
++ }
++ if (unPercentComplete >= nextPct)
++ {
++ lastPct = (unPercentComplete / 10) * 10;
++ nextPct = lastPct + 10;
++ hookRealAudio_Buffering(eBuffering,lastPct);
++ }
++ }
++#else
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnBuffering(%ld, %d)\n", ulFlags, unPercentComplete);
++ }
++#endif
++ if (m_on_buffering_cb)
++ m_on_buffering_cb(ulFlags, unPercentComplete, m_context);
++
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnContacting
++ * Purpose:
++ * Called by client engine to inform the client is contacting
++ * hosts(s).
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::OnContacting(const char* pHostName)
++{
++#ifdef __TCS__
++ printf("Contacting\n");
++ hookRealAudio_Buffering(eContacting,0);
++#else
++ if (GetGlobal()->bEnableAdviceSink)
++ {
++ STDOUT("OnContacting(\"%s\")\n", pHostName);
++ }
++#endif
++
++ return HXR_OK;
++}
++
++void ExampleClientAdviceSink::PrintPropName( IHXValues* pHeader )
++{
++ if ( pHeader == NULL )
++ {
++ return ;
++ }
++
++ const char *pChar;
++ ULONG32 pValue;
++ if(HXR_OK == pHeader->GetFirstPropertyULONG32(pChar, pValue))
++ {
++ do
++ {
++ STDOUT("%s %d\n", pChar, pValue);
++ }
++ while(HXR_OK == pHeader->GetNextPropertyULONG32(pChar, pValue));
++ }
++
++ IHXBuffer *pBuffer;
++
++ if(HXR_OK == pHeader->GetFirstPropertyBuffer(pChar, pBuffer))
++ {
++ do
++ {
++ STDOUT("%s %s\n", pChar, (const char *) ( pBuffer->GetBuffer() ));
++ PrintBuffer(pChar, pBuffer->GetBuffer() ,pBuffer->GetSize());
++ HX_RELEASE(pBuffer);
++ } while(HXR_OK == pHeader->GetNextPropertyBuffer(pChar, pBuffer ));
++ }
++
++ if(HXR_OK == pHeader->GetFirstPropertyCString(pChar, pBuffer))
++ {
++ do
++ {
++ STDERR("%s %s\n", pChar, (const char *) ( pBuffer->GetBuffer() ));
++ HX_RELEASE(pBuffer);
++ } while(HXR_OK == pHeader->GetNextPropertyCString(pChar, pBuffer ));
++ }
++
++ fflush(stdout);
++}
++
++
++void ExampleClientAdviceSink::SetClipInfo( IHXPlayer* m_pRMAPlayer)
++{
++ bool bSendOnClipInfo = false;
++
++ // Get HXSource and try to get clip infor.
++ UINT32 sourceCount = m_pRMAPlayer->GetSourceCount();
++ for (UINT32 sourceID = 0; sourceID < sourceCount; sourceID ++)
++ {
++ // get HXSource
++ STDOUT("========Source %d========\n",sourceID);
++ IUnknown* pUnkSource = NULL;
++ IHXStreamSource* pStreamSrc = NULL;
++
++ if (HXR_OK != m_pRMAPlayer->GetSource (sourceID, pUnkSource))
++ {
++ continue;
++ }
++
++ pUnkSource->QueryInterface(IID_IHXStreamSource, (void **)&pStreamSrc);
++
++ HX_RELEASE(pUnkSource);
++
++ if (!pStreamSrc)
++ {
++ continue;
++ }
++
++ UINT32 num_streams = pStreamSrc->GetStreamCount();
++
++ STDOUT("====File Header====\n");
++
++ IHXValues* pFileHdr = NULL;
++ pStreamSrc->QueryInterface(IID_IHXValues, (void**)&pFileHdr);
++
++ if ( pFileHdr)
++ {
++ PrintPropName(pFileHdr);
++ }
++ HX_RELEASE(pFileHdr);
++
++ // get information from Streams
++ for (UINT32 streamID = 0; streamID < num_streams ; streamID++)
++ {
++ STDOUT("====Stream %d====\n",streamID);
++ IUnknown* pUnkStream = NULL;
++
++ if (HXR_OK == pStreamSrc->GetStream(streamID, pUnkStream))
++ {
++ IHXStream* pStream = NULL;
++
++ if (HXR_OK == pUnkStream->QueryInterface(IID_IHXStream,
++ (void**)&pStream))
++ {
++ IHXValues* pStreamHdr = pStream->GetHeader();
++ if (pStreamHdr)
++ {
++ PrintPropName(pStreamHdr);
++ }
++ HX_RELEASE(pStreamHdr);
++ }
++ HX_RELEASE(pStream);
++ }
++ HX_RELEASE(pUnkStream);
++ }
++ STDOUT("---------------------------------------------\n");
++
++ HX_RELEASE(pStreamSrc);
++ }
++}
++
++
++STDMETHODIMP ExampleClientAdviceSink::Func()
++{
++ m_hCallback = 0;
++
++ // set clip info
++ if(m_pPlayer)
++ SetClipInfo(m_pPlayer);
++
++ return HXR_OK;
++}
++
++void PrintBuffer(const char* pszName,const unsigned char* pbBuf, unsigned int dwBytes)
++{
++ if(pszName == NULL || pbBuf == NULL)
++ return;
++
++ STDOUT(" ");
++ for(unsigned int i= 0; i<dwBytes; i++) {
++ STDOUT("0x%02x ",*pbBuf++);
++ if(i % 15 == 0 && i!=0)
++ STDOUT("\n ");
++ }
++ STDOUT("\n");
++ return;
++}
++
++/*
++ * IHXGroupSink methods
++ */
++/************************************************************************
++ * Method:
++ * IHXGroupSink::GroupAdded
++ * Purpose:
++ * Notification of a new group being added to the presentation.
++ */
++STDMETHODIMP ExampleClientAdviceSink::GroupAdded( UINT16 /*IN*/ uGroupIndex,
++ IHXGroup* /*IN*/ pGroup)
++{
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXGroupSink::GroupRemoved
++ * Purpose:
++ * Notification of a group being removed from the presentation.
++ */
++STDMETHODIMP ExampleClientAdviceSink::GroupRemoved( UINT16 /*IN*/ uGroupIndex,
++ IHXGroup* /*IN*/ pGroup)
++{
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXGroupSink::AllGroupsRemoved
++ * Purpose:
++ * Notification that all groups have been removed from the
++ * current presentation.
++ */
++STDMETHODIMP ExampleClientAdviceSink::AllGroupsRemoved()
++{
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXGroupSink::TrackAdded
++ * Purpose:
++ * Notification of a new track being added to a group.
++ */
++STDMETHODIMP ExampleClientAdviceSink::TrackAdded( UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack)
++{
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXGroupSink::TrackRemoved
++ * Purpose:
++ * Notification of a track being removed from a group.
++ */
++STDMETHODIMP ExampleClientAdviceSink::TrackRemoved( UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack)
++{
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXGroupSink::TrackStarted
++ * Purpose:
++ * Notification of a track being started (to get duration, for
++ * instance...)
++ */
++STDMETHODIMP ExampleClientAdviceSink::TrackStarted( UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack)
++{
++ if ( m_bWaitForTrackStart )
++ {
++ STDOUT("----------------clip info--------------------\n");
++ if(m_pScheduler)
++ {
++ m_hCallback = m_pScheduler->RelativeEnter(this,50);
++ }
++ m_bWaitForTrackStart = FALSE;
++ }
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXGroupSink::TrackStopped
++ * Purpose:
++ * Notification of a track being stopped
++ *
++ */
++STDMETHODIMP ExampleClientAdviceSink::TrackStopped( UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack)
++{
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXGroupSink::CurrentGroupSet
++ * Purpose:
++ * This group is being currently played in the presentation.
++ */
++STDMETHODIMP ExampleClientAdviceSink::CurrentGroupSet( UINT16 /*IN*/ uGroupIndex,
++ IHXGroup* /*IN*/ pGroup)
++{
++ return HXR_OK;
++}
++
+Index: helix-libs/clientapps/clutter/exadvsnk.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exadvsnk.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,324 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _EXAMPLECLSNK_
++#define _EXAMPLECLSNK_
++
++#include "player.h"
++
++struct IHXClientAdviseSink;
++struct IHXGroupSink;
++struct IUnknown;
++struct IHXRegistry;
++struct IHXScheduler;
++struct IHXCallback;
++struct IHXPlayer;
++struct IHXGroup;
++
++class ExampleClientAdviceSink : public IHXClientAdviseSink,
++ public IHXGroupSink,
++ public IHXCallback
++{
++ private:
++ LONG32 m_lRefCount;
++ LONG32 m_lClientIndex;
++
++ IUnknown* m_pUnknown;
++ IHXRegistry* m_pRegistry;
++ IHXScheduler* m_pScheduler;
++
++ UINT32 m_ulStartTime;
++ UINT32 m_ulStopTime;
++
++ UINT32 m_lCurrentBandwidth;
++ UINT32 m_lAverageBandwidth;
++ HXBOOL m_bOnStop;
++
++ HXBOOL m_bWaitForTrackStart;
++
++ on_buffering_cb_t m_on_buffering_cb;
++ on_pos_length_cb_t m_on_pos_length_cb;
++ void *m_context; /* a argument passed by texture-helix lib */
++
++ // IHXCallback
++ IHXPlayer* m_pPlayer;
++ ULONG32 m_hCallback;
++ ~ExampleClientAdviceSink();
++ HX_RESULT DumpRegTree(const char* pszTreeName );
++
++
++ void GetStatistics (char* /*IN*/ pszRegistryKey);
++ void GetAllStatistics (void);
++ void SetClipInfo( IHXPlayer* m_pRMAPlayer);
++ void PrintPropName( IHXValues* pHeader );
++
++ public:
++
++ ExampleClientAdviceSink(IUnknown* /*IN*/ pUnknown, LONG32 /*IN*/ lClientIndex, on_buffering_cb_t on_buffer_cb, on_pos_length_cb_t on_pos_length_cb, void *context);
++
++ /*
++ * IUnknown methods
++ */
++ STDMETHOD(QueryInterface) (THIS_
++ REFIID riid,
++ void** ppvObj);
++
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /*
++ * IHXClientAdviseSink methods
++ */
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPosLength
++ * Purpose:
++ * Called to advise the client that the position or length of the
++ * current playback context has changed.
++ */
++ STDMETHOD(OnPosLength) (THIS_
++ UINT32 ulPosition,
++ UINT32 ulLength);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPresentationOpened
++ * Purpose:
++ * Called to advise the client a presentation has been opened.
++ */
++ STDMETHOD(OnPresentationOpened) (THIS);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPresentationClosed
++ * Purpose:
++ * Called to advise the client a presentation has been closed.
++ */
++ STDMETHOD(OnPresentationClosed) (THIS);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnStatisticsChanged
++ * Purpose:
++ * Called to advise the client that the presentation statistics
++ * have changed.
++ */
++ STDMETHOD(OnStatisticsChanged) (THIS);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPreSeek
++ * Purpose:
++ * Called by client engine to inform the client that a seek is
++ * about to occur. The render is informed the last time for the
++ * stream's time line before the seek, as well as the first new
++ * time for the stream's time line after the seek will be completed.
++ *
++ */
++ STDMETHOD (OnPreSeek) (THIS_
++ ULONG32 ulOldTime,
++ ULONG32 ulNewTime);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPostSeek
++ * Purpose:
++ * Called by client engine to inform the client that a seek has
++ * just occured. The render is informed the last time for the
++ * stream's time line before the seek, as well as the first new
++ * time for the stream's time line after the seek.
++ *
++ */
++ STDMETHOD (OnPostSeek) (THIS_
++ ULONG32 ulOldTime,
++ ULONG32 ulNewTime);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnStop
++ * Purpose:
++ * Called by client engine to inform the client that a stop has
++ * just occured.
++ *
++ */
++ STDMETHOD (OnStop) (THIS);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnPause
++ * Purpose:
++ * Called by client engine to inform the client that a pause has
++ * just occured. The render is informed the last time for the
++ * stream's time line before the pause.
++ *
++ */
++ STDMETHOD (OnPause) (THIS_
++ ULONG32 ulTime);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnBegin
++ * Purpose:
++ * Called by client engine to inform the client that a begin or
++ * resume has just occured. The render is informed the first time
++ * for the stream's time line after the resume.
++ *
++ */
++ STDMETHOD (OnBegin) (THIS_
++ ULONG32 ulTime);
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnBuffering
++ * Purpose:
++ * Called by client engine to inform the client that buffering
++ * of data is occuring. The render is informed of the reason for
++ * the buffering (start-up of stream, seek has occured, network
++ * congestion, etc.), as well as percentage complete of the
++ * buffering process.
++ *
++ */
++ STDMETHOD (OnBuffering) (THIS_
++ ULONG32 ulFlags,
++ UINT16 unPercentComplete);
++
++
++ /************************************************************************
++ * Method:
++ * IHXClientAdviseSink::OnContacting
++ * Purpose:
++ * Called by client engine to inform the client is contacting
++ * hosts(s).
++ *
++ */
++ STDMETHOD (OnContacting) (THIS_
++ const char* pHostName);
++
++ // IHXCallback
++ STDMETHOD(Func) (THIS);
++
++ /*
++ * IHXGroupSink methods
++ */
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::GroupAdded
++ * Purpose:
++ * Notification of a new group being added to the presentation.
++ */
++ STDMETHOD(GroupAdded) (THIS_
++ UINT16 /*IN*/ uGroupIndex,
++ IHXGroup* /*IN*/ pGroup);
++
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::GroupRemoved
++ * Purpose:
++ * Notification of a group being removed from the presentation.
++ */
++ STDMETHOD(GroupRemoved) (THIS_
++ UINT16 /*IN*/ uGroupIndex,
++ IHXGroup* /*IN*/ pGroup);
++
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::AllGroupsRemoved
++ * Purpose:
++ * Notification that all groups have been removed from the
++ * current presentation.
++ */
++ STDMETHOD(AllGroupsRemoved) (THIS);
++
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::TrackAdded
++ * Purpose:
++ * Notification of a new track being added to a group.
++ */
++ STDMETHOD(TrackAdded) (THIS_
++ UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack);
++
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::TrackRemoved
++ * Purpose:
++ * Notification of a track being removed from a group.
++ */
++ STDMETHOD(TrackRemoved) (THIS_
++ UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack);
++
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::TrackStarted
++ * Purpose:
++ * Notification of a track being started (to get duration, for
++ * instance...)
++ */
++ STDMETHOD (TrackStarted) (THIS_
++ UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack) ;
++
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::TrackStopped
++ * Purpose:
++ * Notification of a track being stopped
++ *
++ */
++ STDMETHOD(TrackStopped) (THIS_
++ UINT16 /*IN*/ uGroupIndex,
++ UINT16 /*IN*/ uTrackIndex,
++ IHXValues* /*IN*/ pTrack);
++
++ /************************************************************************
++ * Method:
++ * IHXGroupSink::CurrentGroupSet
++ * Purpose:
++ * This group is being currently played in the presentation.
++ */
++ STDMETHOD(CurrentGroupSet) (THIS_
++ UINT16 /*IN*/ uGroupIndex,
++ IHXGroup* /*IN*/ pGroup);
++
++};
++
++#endif /* _EXAMPLECLSNK_ */
+Index: helix-libs/clientapps/clutter/exaumgr.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exaumgr.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,137 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include <stdio.h>
++#include "hxtypes.h"
++#include "hxcom.h"
++#include "hxauth.h"
++#include "hxstrutl.h"
++#include "exaumgr.h"
++#include <ctype.h>
++#include "print.h"
++
++
++#include "globals.h"
++struct _stGlobals*& GetGlobal(); //in main.cpp
++
++
++
++ExampleAuthenticationManager::ExampleAuthenticationManager() :
++ m_lRefCount(0),
++ m_bSentPassword(FALSE)
++{
++}
++
++ExampleAuthenticationManager::~ExampleAuthenticationManager()
++{
++}
++
++STDMETHODIMP
++ExampleAuthenticationManager::QueryInterface(REFIID riid, void**ppvObj)
++{
++ if(IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = (IUnknown*)(IHXAuthenticationManager*)this;
++ return HXR_OK;
++ }
++ else if(IsEqualIID(riid, IID_IHXAuthenticationManager))
++ {
++ AddRef();
++ *ppvObj = (IHXAuthenticationManager*)this;
++ return HXR_OK;
++ }
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++STDMETHODIMP_(UINT32)
++ExampleAuthenticationManager::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++STDMETHODIMP_(UINT32)
++ExampleAuthenticationManager::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++STDMETHODIMP
++ExampleAuthenticationManager::HandleAuthenticationRequest(IHXAuthenticationManagerResponse* pResponse)
++{
++ char username[1024] = ""; /* Flawfinder: ignore */
++ char password[1024] = ""; /* Flawfinder: ignore */
++ HX_RESULT res = HXR_FAIL;
++
++ if( !m_bSentPassword )
++ {
++ res = HXR_OK;
++ if (GetGlobal()->bEnableVerboseMode)
++ STDOUT("\nSending Username and Password...\n");
++
++ SafeStrCpy(username, GetGlobal()->g_pszUsername, 1024);
++ SafeStrCpy(password, GetGlobal()->g_pszPassword, 1024);
++
++ //strip trailing whitespace
++ char* c;
++ for(c = username + strlen(username) - 1;
++ c > username && isspace(*c);
++ c--)
++ ;
++ *(c+1) = 0;
++
++ for(c = password + strlen(password) - 1;
++ c > password && isspace(*c);
++ c--)
++ ;
++ *(c+1) = 0;
++
++ m_bSentPassword = TRUE;
++ }
++
++ if (GetGlobal()->bEnableVerboseMode && FAILED(res) )
++ STDOUT("\nInvalid Username and/or Password.\n");
++
++ pResponse->AuthenticationRequestDone(res, username, password);
++ return res;
++}
++
+Index: helix-libs/clientapps/clutter/exaumgr.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exaumgr.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,56 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _EXAUMGR_H_
++#define _EXAUMGR_H_
++
++#include "hxauth.h"
++
++class ExampleAuthenticationManager : public IHXAuthenticationManager
++{
++private:
++ INT32 m_lRefCount;
++ HXBOOL m_bSentPassword;
++ ~ExampleAuthenticationManager();
++
++public:
++ ExampleAuthenticationManager();
++ STDMETHOD(QueryInterface) (THIS_ REFIID riid, void** ppvObj);
++ STDMETHOD_(UINT32,AddRef) (THIS);
++ STDMETHOD_(UINT32,Release) (THIS);
++
++ STDMETHOD(HandleAuthenticationRequest) (IHXAuthenticationManagerResponse* pResponse);
++};
++#endif
+Index: helix-libs/clientapps/clutter/excallback.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/excallback.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,38 @@
++#include "excallback.h"
++
++STDMETHODIMP ExCallback::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IHXCallback))
++ {
++ AddRef();
++ *ppvObj = (IHXCallback*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++STDMETHODIMP_(ULONG32) ExCallback::AddRef()
++{
++ return HXR_OK;
++}
++
++STDMETHODIMP_(ULONG32) ExCallback::Release()
++{
++ return HXR_OK;
++}
++
++STDMETHODIMP ExCallback::Func(void)
++{
++ UINT32 sleepTime = 0;
++ m_pKicker->Kick(HXGetCurrentThreadID, &sleepTime);
++ printf("Get called, sleeptime:%d\n", sleepTime);
++ m_pScheduler->RelativeEnter(this, sleepTime/1000);
++}
+Index: helix-libs/clientapps/clutter/excallback.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/excallback.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,32 @@
++#ifndef _EX_CALLBACK_H_
++#define _EX_CALLBACK_H_
++
++#include "hxcom.h"
++#include "hxengin.h"
++#include "ihxmedpltfm.h"
++#include "thrdutil.h"
++
++class ExCallback : public IHXCallback
++{
++ public:
++ ExCallback(IHXScheduler *pIHXScheduler, IHXMediaPlatformKicker *pKicker) : m_pScheduler(pIHXScheduler), m_pKicker(pKicker){};
++
++ /*
++ * * IUnknown methods
++ * */
++ STDMETHOD(QueryInterface) (THIS_ REFIID riid, void** ppvObj);
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /*
++ * * IHXCallback methods
++ * */
++ STDMETHOD(Func) (THIS);
++ private:
++ IHXScheduler *m_pScheduler;
++ IHXMediaPlatformKicker* m_pKicker;
++
++};
++
++
++#endif
+Index: helix-libs/clientapps/clutter/excontxt.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/excontxt.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,315 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include "hxtypes.h"
++
++#include "hxwintyp.h"
++#include "hxcom.h"
++#include "hxcomm.h"
++#include "hxwin.h"
++#include "fivemmap.h"
++
++#include "hxbuffer.h"
++#include "hxmangle.h"
++
++#include "hxclsnk.h"
++#include "hxgroup.h"
++#include "hxerror.h"
++#include "hxprefs.h"
++#include "hxstrutl.h"
++
++#include "exadvsnk.h"
++#include "exstateadvsnk.h"
++#include "exerror.h"
++#include "exsitsup.h"
++#include "exaumgr.h"
++#include "hxprdnld.h"
++#include "exprdnld.h"
++
++#include "excontxt.h"
++
++extern HXBOOL bEnableAdviceSink;
++
++
++ExampleClientContext::ExampleClientContext(LONG32 lClientIndex)
++ : m_lRefCount(0)
++ , m_lClientIndex(lClientIndex)
++ , m_pClientSink(NULL)
++ , m_pClientStateSink(NULL)
++ , m_pErrorSink(NULL)
++ , m_pAuthMgr(NULL)
++ , m_pSiteSupplier(NULL)
++ , m_pDefaultPrefs(NULL)
++#if defined(HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS)
++ , m_pPrgDnldStatusObserver(NULL)
++#endif // /HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS.
++{
++}
++
++
++ExampleClientContext::~ExampleClientContext()
++{
++ Close();
++};
++
++void ExampleClientContext::Init(IUnknown* /*IN*/ pUnknown,
++ IHXPreferences* /*IN*/ pPreferences,
++ char* /*IN*/ pszGUID,
++ on_buffering_cb_t on_buffering_cb,
++ on_pos_length_cb_t on_pos_length_cb,
++ on_state_change_cb_t on_state_change_cb,
++ on_new_frame_cb_t on_new_frame_cb,
++ void *context)
++{
++ char* pszCipher = NULL;
++
++
++ m_pClientSink = new ExampleClientAdviceSink(pUnknown, m_lClientIndex, on_buffering_cb, on_pos_length_cb, context);
++
++ m_pClientStateSink = new ExampleClientStateAdviceSink(pUnknown, m_lClientIndex, on_state_change_cb, context);
++ m_pErrorSink = new ExampleErrorSink(pUnknown);
++#if defined(HELIX_FEATURE_AUTHENTICATION)
++ m_pAuthMgr = new ExampleAuthenticationManager();
++ if(m_pAuthMgr)
++ {
++ m_pAuthMgr->AddRef();
++ }
++
++#endif /* #if defined(HELIX_FEATURE_AUTHENTICATION) */
++#if defined(HELIX_FEATURE_VIDEO)
++ m_pSiteSupplier = new ExampleSiteSupplier(pUnknown, on_new_frame_cb, context);
++#endif
++
++#if defined(HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS)
++ m_pPrgDnldStatusObserver = new ExamplePDStatusObserver(pUnknown);
++#endif // /HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS.
++
++ if (m_pClientSink)
++ {
++ m_pClientSink->AddRef();
++ }
++
++ if (m_pErrorSink)
++ {
++ m_pErrorSink->AddRef();
++ }
++
++ if (m_pClientStateSink)
++ m_pClientStateSink->AddRef();
++
++ if(m_pSiteSupplier)
++ {
++ m_pSiteSupplier->AddRef();
++ }
++
++ if (pPreferences)
++ {
++ m_pDefaultPrefs = pPreferences;
++ m_pDefaultPrefs->AddRef();
++ }
++
++ if (pszGUID && *pszGUID)
++ {
++ // Encode GUID
++ pszCipher = Cipher(pszGUID);
++ SafeStrCpy(m_pszGUID, pszCipher, 256);
++ }
++ else
++ {
++ m_pszGUID[0] = '\0';
++ }
++}
++
++void ExampleClientContext::Close()
++{
++ HX_RELEASE(m_pClientSink);
++ HX_RELEASE(m_pClientStateSink);
++ HX_RELEASE(m_pErrorSink);
++#if defined(HELIX_FEATURE_AUTHENTICATION)
++ HX_RELEASE(m_pAuthMgr);
++#endif /* #if defined(HELIX_FEATURE_AUTHENTICATION) */
++ HX_RELEASE(m_pSiteSupplier);
++ HX_RELEASE(m_pDefaultPrefs);
++#if defined(HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS)
++ HX_RELEASE(m_pPrgDnldStatusObserver);
++#endif // /HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS.
++}
++
++
++
++// *** IUnknown methods ***
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::QueryInterface
++// Purpose:
++// Implement this to export the interfaces supported by your
++// object.
++//
++STDMETHODIMP ExampleClientContext::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXPreferences))
++ {
++ AddRef();
++ *ppvObj = (IHXPreferences*)this;
++ return HXR_OK;
++ }
++ else if (m_pClientSink &&
++ m_pClientSink->QueryInterface(riid, ppvObj) == HXR_OK)
++ {
++ return HXR_OK;
++ }
++ else if (m_pErrorSink &&
++ m_pErrorSink->QueryInterface(riid, ppvObj) == HXR_OK)
++ {
++ return HXR_OK;
++ }
++ else if (m_pClientStateSink &&
++ m_pClientStateSink->QueryInterface(riid, ppvObj) == HXR_OK)
++ {
++ return HXR_OK;
++ }
++#if defined(HELIX_FEATURE_AUTHENTICATION)
++ else if(m_pAuthMgr &&
++ m_pAuthMgr->QueryInterface(riid, ppvObj) == HXR_OK)
++ {
++ return HXR_OK;
++ }
++#endif /* #if defined(HELIX_FEATURE_AUTHENTICATION) */
++ else if(m_pSiteSupplier &&
++ m_pSiteSupplier->QueryInterface(riid, ppvObj) == HXR_OK)
++ {
++ return HXR_OK;
++ }
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::AddRef
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleClientContext::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::Release
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleClientContext::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++
++// *** IUnknown methods ***
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IHXPreferences::ReadPref
++// Purpose:
++// Read a Preference from the registry.
++//
++STDMETHODIMP
++ExampleClientContext::ReadPref(const char* pref_key, IHXBuffer*& buffer)
++{
++ HX_RESULT hResult = HXR_OK;
++ char* pszCipher = NULL;
++
++ if ((stricmp(pref_key, CLIENT_GUID_REGNAME) == 0) &&
++ (*m_pszGUID))
++ {
++ // Create a Buffer
++ buffer = new CHXBuffer();
++ buffer->AddRef();
++
++ // Copy the encoded GUID into the buffer
++ buffer->Set((UCHAR*)m_pszGUID, strlen(m_pszGUID) + 1);
++ }
++ else if (m_pDefaultPrefs)
++ {
++ hResult = m_pDefaultPrefs->ReadPref(pref_key, buffer);
++ }
++ else
++ {
++ hResult = HXR_NOTIMPL;
++ }
++
++ return hResult;
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IHXPreferences::WritePref
++// Purpose:
++// Write a Preference to the registry.
++//
++STDMETHODIMP
++ExampleClientContext::WritePref(const char* pref_key, IHXBuffer* buffer)
++{
++ if (m_pDefaultPrefs)
++ {
++ return m_pDefaultPrefs->WritePref(pref_key, buffer);
++ }
++ else
++ {
++ return HXR_OK;
++ }
++}
++
++EHXClientState ExampleClientContext::GetState()
++{
++ return m_pClientStateSink->GetState();
++};
+Index: helix-libs/clientapps/clutter/excontxt.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/excontxt.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,106 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++#ifndef _EXCONTXT_H_
++#define _EXCONTXT_H_
++
++#include "exerror.h"
++#include "exsitsup.h"
++#include "hxprefs.h"
++#include "player.h"
++#include "hxclsnk.h"
++
++struct IUnknown;
++struct IHXPreferences;
++class ExampleClientAdviceSink;
++class ExampleClientStateAdviceSink;
++class ExampleErrorMessages;
++class ExampleAuthenticationManager;
++class ExamplePDStatusObserver;
++
++
++class ExampleClientContext : public IHXPreferences
++{
++private:
++ LONG32 m_lRefCount;
++ LONG32 m_lClientIndex;
++
++ ExampleClientAdviceSink* m_pClientSink;
++ ExampleClientStateAdviceSink* m_pClientStateSink;
++ ExampleErrorSink* m_pErrorSink;
++ ExampleAuthenticationManager* m_pAuthMgr;
++
++ ExampleSiteSupplier* m_pSiteSupplier;
++ ExamplePDStatusObserver* m_pPrgDnldStatusObserver;
++ IHXPreferences* m_pDefaultPrefs;
++ char m_pszGUID[256]; /* Flawfinder: ignore */
++
++
++public:
++
++ ExampleClientContext(LONG32 /*IN*/ lClientIndex);
++ ~ExampleClientContext();
++
++ void Init(IUnknown* /*IN*/ pUnknown,
++ IHXPreferences* /*IN*/ pPreferences,
++ char* /*IN*/ pszGUID,
++ on_buffering_cb_t on_buffering_cb = NULL,
++ on_pos_length_cb_t on_pos_length_cb = NULL,
++ on_state_change_cb_t on_state_change_cb = NULL,
++ on_new_frame_cb_t on_new_frame_cb = NULL,
++ void *context = NULL);
++ void Close();
++
++ EHXClientState GetState();
++
++ /*
++ * IUnknown methods
++ */
++ STDMETHOD(QueryInterface) (THIS_
++ REFIID riid,
++ void** ppvObj);
++
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /*
++ * IHXPreferences methods
++ */
++ STDMETHOD(ReadPref) (THIS_ const char* pref_key,
++ IHXBuffer*& buffer);
++ STDMETHOD(WritePref) (THIS_ const char* pref_key,
++ IHXBuffer* buffer);
++};
++
++#endif
+Index: helix-libs/clientapps/clutter/exerror.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exerror.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,230 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include "hxtypes.h"
++
++#include "hxcom.h"
++#include "hxcomm.h"
++#include "hxerror.h"
++#include "hxstrutl.h"
++#include "hxcore.h"
++#include "hxassert.h"
++#include "hxbuffer.h"
++
++#ifdef __TCS__
++#include "hxresult.h"
++#endif
++
++#if !defined(HELIX_CONFIG_MINIMIZE_SIZE)
++#include "HXErrorCodeStrings.h"
++#endif
++
++#include "exerror.h"
++
++#include <stdio.h>
++#include "print.h"
++
++#include "globals.h"
++struct _stGlobals*& GetGlobal(); //in main.cpp
++
++#ifdef __TCS__
++#if defined(__cplusplus)
++extern "C" {
++#endif
++
++void hookRealAudio_ReportError(int err, long errVal);
++
++#ifdef __cplusplus
++}
++#endif
++#endif
++
++ExampleErrorSink::ExampleErrorSink(IUnknown* pUnknown)
++ : m_lRefCount(0),
++ m_pPlayer(NULL)
++{
++ IHXClientEngine* pEngine = NULL;
++ pUnknown->QueryInterface(IID_IHXClientEngine, (void**)&pEngine );
++ if( pEngine )
++ {
++ IUnknown* pTmp = NULL;
++ pEngine->GetPlayer(0, pTmp);
++ m_pPlayer = (IHXPlayer*)pTmp;
++ }
++
++ HX_RELEASE( pEngine );
++ HX_ASSERT(m_pPlayer);
++}
++
++ExampleErrorSink::~ExampleErrorSink()
++{
++ HX_RELEASE(m_pPlayer);
++}
++
++// *** IUnknown methods ***
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::QueryInterface
++// Purpose:
++// Implement this to export the interfaces supported by your
++// object.
++//
++STDMETHODIMP ExampleErrorSink::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = (IUnknown*)(IHXErrorSink*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXErrorSink))
++ {
++ AddRef();
++ *ppvObj = (IHXErrorSink*) this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::AddRef
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleErrorSink::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::Release
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleErrorSink::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++/*
++ * IHXErrorSink methods
++ */
++
++STDMETHODIMP
++ExampleErrorSink::ErrorOccurred(const UINT8 unSeverity,
++ const ULONG32 ulHXCode,
++ const ULONG32 ulUserCode,
++ const char* pUserString,
++ const char* pMoreInfoURL
++ )
++{
++ char HXDefine[256]; /* Flawfinder: ignore */
++
++ // Store the code, so we can return it from main()
++ GetGlobal()->g_Error = ulHXCode;
++
++ ConvertErrorToString(ulHXCode, HXDefine, 256);
++
++#ifdef __TCS__
++ hookRealAudio_ReportError(ulHXCode,ulUserCode);
++#else
++ STDOUT("Report(%d, %ld, \"%s\", %ld, \"%s\", \"%s\")\n",
++ unSeverity,
++ ulHXCode,
++ (pUserString && *pUserString) ? pUserString : "(NULL)",
++ ulUserCode,
++ (pMoreInfoURL && *pMoreInfoURL) ? pMoreInfoURL : "(NULL)",
++ HXDefine);
++#endif
++
++ return HXR_OK;
++}
++
++void
++ExampleErrorSink::ConvertErrorToString(const ULONG32 ulHXCode, char* pszBuffer, UINT32 ulBufLen)
++{
++ IHXErrorMessages* pErrMsg = NULL;
++
++ if( !pszBuffer)
++ return;
++
++ pszBuffer[0]='\0';
++
++ HX_ASSERT(m_pPlayer);
++ if( m_pPlayer)
++ {
++ m_pPlayer->QueryInterface(IID_IHXErrorMessages, (void**)&pErrMsg);
++ if( pErrMsg )
++ {
++ IHXBuffer* pMessage = pErrMsg->GetErrorText(ulHXCode);
++ if( pMessage )
++ {
++ SafeStrCpy( pszBuffer, (const char*)pMessage->GetBuffer(), ulBufLen);
++ pMessage->Release();
++ }
++ }
++ HX_RELEASE(pErrMsg);
++ }
++
++ if( strlen(pszBuffer)==0 )
++ {
++#if !defined(HELIX_CONFIG_MINIMIZE_SIZE)
++ const char* pszHXCodeString = HXErrorCodeToString(ulHXCode);
++ if (pszHXCodeString)
++ {
++ SafeSprintf( pszBuffer, ulBufLen, "%s", pszHXCodeString);
++ }
++ else
++#endif
++ {
++ HX_ASSERT(FALSE);
++ SafeSprintf( pszBuffer, ulBufLen, "Can't convert error code %p - make sure it's defined in common/util/HXErrorCodeStrings.c", ulHXCode );
++ }
++ }
++}
++
+Index: helix-libs/clientapps/clutter/exerror.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exerror.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,92 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _EXAMPLEERRORMESSAGES_
++#define _EXAMPLEERRORMESSAGES_
++
++#include "hxerror.h"
++
++struct IUnknown;
++struct IHXErrorMessages;
++struct IHXPlayer;
++
++class ExampleErrorSink : public IHXErrorSink
++{
++public:
++
++ ExampleErrorSink(IUnknown* pUnknown);
++ ~ExampleErrorSink();
++
++ /*
++ * IUnknown methods
++ */
++ STDMETHOD(QueryInterface) (THIS_
++ REFIID riid,
++ void** ppvObj);
++
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /*
++ * IHXErrorSink methods
++ */
++
++ /************************************************************************
++ * Method:
++ * IHXErrorSink::ErrorOccurred
++ * Purpose:
++ * After you have registered your error sink with an IHXErrorSinkControl
++ * (either in the server or player core) this method will be called to
++ * report an error, event, or status message.
++ *
++ * The meaning of the arguments is exactly as described in
++ * hxerror.h
++ */
++ STDMETHOD(ErrorOccurred) (THIS_
++ const UINT8 unSeverity,
++ const ULONG32 ulHXCode,
++ const ULONG32 ulUserCode,
++ const char* pUserString,
++ const char* pMoreInfoURL
++ );
++
++protected:
++ LONG32 m_lRefCount;
++ IHXPlayer* m_pPlayer;
++
++ void ConvertErrorToString (const ULONG32 ulHXCode, char* pszBuffer, UINT32 ulBufLen);
++};
++#endif /*_EXAMPLEERRORMESSAGES_*/
+Index: helix-libs/clientapps/clutter/exprdnld.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exprdnld.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,468 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include "hxcom.h"
++#include "hxtypes.h"
++#include "hxcore.h"
++#include "hxprdnld.h"
++#include "exprdnld.h"
++#include "print.h"
++
++#include "globals.h"
++struct _stGlobals*& GetGlobal();
++
++UINT32 GetTime(); // /In main.cpp.
++
++// /#if defined(HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS)
++/************************************************************************
++ * Method:
++ * Constructor
++ */
++ExamplePDStatusObserver::ExamplePDStatusObserver(IUnknown* pUnkPlayer)
++ : m_lRefCount(0)
++ , m_pPrgDnldStatusMgr(NULL)
++ , m_pUnkPlayer(pUnkPlayer)
++ , m_pHXPlayer(NULL)
++ , m_bPlayerIsPausedByThis(FALSE)
++ , m_bFirstPDStatusMessage(TRUE)
++ , m_ulTotalDurReported(HX_PROGDOWNLD_UNKNOWN_DURATION)
++ , m_ulDurSoFar(HX_PROGDOWNLD_UNKNOWN_DURATION)
++ , m_ulCurStatusUpdateGranularity(
++ HX_PROGDOWNLD_DEFAULT_STATUSREPORT_INTERVAL_MSEC)
++ , m_bInitialPrerollUpateGranularitySet(FALSE)
++ , m_bDownloadIsComplete(FALSE)
++{
++ if (m_pUnkPlayer)
++ {
++ m_pUnkPlayer->QueryInterface(IID_IHXPlayer,
++ (void**)&m_pHXPlayer);
++
++ m_pUnkPlayer->QueryInterface(IID_IHXPDStatusMgr,
++ (void**)&m_pPrgDnldStatusMgr);
++
++ if (m_pPrgDnldStatusMgr)
++ {
++ // /Add ourselves as an observer of progressive download playback:
++ m_pPrgDnldStatusMgr->AddObserver(this);
++ // /Set granularity of status reports to 10 per second until we
++ // know enough about the situation to go back to getting reports
++ // at the default interval (every 5 seconds). Do that as soon
++ // as we receive the first progress report:
++ m_ulCurStatusUpdateGranularity = 100;
++ }
++
++ m_pUnkPlayer->AddRef();
++ }
++};
++
++/************************************************************************
++ * Method:
++ * Destructor
++ */
++ExamplePDStatusObserver::~ExamplePDStatusObserver()
++{
++ if (m_pPrgDnldStatusMgr)
++ {
++ m_pPrgDnldStatusMgr->RemoveObserver(this);
++ }
++ HX_RELEASE(m_pPrgDnldStatusMgr);
++ HX_RELEASE(m_pHXPlayer);
++ HX_RELEASE(m_pUnkPlayer);
++}
++
++/************************************************************************
++ * Method:
++ * IUnknown::QueryInterface
++ */
++STDMETHODIMP
++ExamplePDStatusObserver::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = (IUnknown*)(IHXPDStatusObserver*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXPDStatusObserver))
++ {
++ AddRef();
++ *ppvObj = (IHXPDStatusObserver*)this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++/************************************************************************
++ * Method:
++ * IUnknown::AddRef
++ */
++STDMETHODIMP_(ULONG32)
++ExamplePDStatusObserver::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++/************************************************************************
++ * Method:
++ * IUnknown::Release
++ */
++STDMETHODIMP_(ULONG32)
++ExamplePDStatusObserver::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++
++/*
++ * IHXPDStatusObserver methods
++ */
++
++/************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadProgress
++ *
++ * Purpose:
++ * Notification from IHXPDStatusMgr of download progress when
++ * file size changes.
++ *
++ * lTimeSurplus:
++ * - When negative, the absolute value of it is the estimated number
++ * of milliseconds of wall-clock time that need to pass while
++ * downloading continues before reaching the point at which playback
++ * can resume and play the remainder of the stream without having to
++ * buffer, assuming that playback is paused and remains so during
++ * that period.
++ * - When positive, it is the estimated number of milliseconds of
++ * wall-clock time between when the download should complete and when
++ * the natural content play-out duration will be reached, assuming
++ * playback is currently progressing and that no pause will occur.
++ *
++ * Note: ulNewDurSoFar can be HX_PROGDOWNLD_UNKNOWN_DURATION if the
++ * IHXMediaBytesToMediaDur was not available to, or was unable to
++ * convert the bytes to a duration for the IHXPDStatusMgr calling this:
++ */
++STDMETHODIMP
++ExamplePDStatusObserver::OnDownloadProgress(
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource,
++ UINT32 /*IN*/ ulNewDurSoFar,
++ UINT32 /*IN*/ ulNewBytesSoFar,
++ INT32 /*IN*/ lTimeSurplus)
++{
++ m_ulDurSoFar = ulNewDurSoFar;
++
++ if (m_ulCurStatusUpdateGranularity <
++ HX_PROGDOWNLD_DEFAULT_STATUSREPORT_INTERVAL_MSEC)
++ {
++ if (m_bInitialPrerollUpateGranularitySet)
++ {
++ if (HX_PROGDOWNLD_UNKNOWN_DURATION != ulNewDurSoFar &&
++ // /Preroll is done, so reset update interval back to default:
++ GetGlobal()->g_bOnBeginOccurred)
++ {
++ m_ulCurStatusUpdateGranularity =
++ HX_PROGDOWNLD_DEFAULT_STATUSREPORT_INTERVAL_MSEC;
++ m_pPrgDnldStatusMgr->SetStatusUpdateGranularityMsec(
++ m_ulCurStatusUpdateGranularity);
++ }
++ }
++ else if (!GetGlobal()->g_bOnBeginOccurred)
++ {
++ if (HXR_OK == m_pPrgDnldStatusMgr->SetStatusUpdateGranularityMsec(
++ m_ulCurStatusUpdateGranularity))
++ {
++ m_bInitialPrerollUpateGranularitySet = TRUE;
++ }
++ }
++ }
++
++ UINT32 ulCurPlayTime = 0;
++
++ HXBOOL bPauseWasAttempted = FALSE;
++ HXBOOL bPauseOccurred = FALSE;
++ HXBOOL bResumeWasAttempted = FALSE;
++ HXBOOL bResumeOccurred = FALSE;
++
++
++ if (m_pHXPlayer)
++ {
++ ulCurPlayTime = m_pHXPlayer->GetCurrentPlayTime();
++
++ if (GetGlobal()->g_bEnableSlowStart &&
++ lTimeSurplus != HX_PROGDOWNLD_UNKNOWN_TIME_SURPLUS)
++ {
++ // /"slow start" is enabled so if we have run dry of data,
++ // pause and wait for more data:
++ if (!m_bPlayerIsPausedByThis)
++ {
++ if (!m_bDownloadIsComplete && lTimeSurplus<0)
++ {
++ // /Use a 1000-millisecond allowance for variation:
++ if (lTimeSurplus < -1000)
++ {
++ bPauseWasAttempted = TRUE;
++ bPauseOccurred = m_bPlayerIsPausedByThis =
++ (HXR_OK == m_pHXPlayer->Pause());
++ }
++ }
++ }
++ else // /paused; see if we can resume yet:
++ {
++ if (lTimeSurplus > 0)
++ {
++ // /Use a 1000-millisecond allowance for variation:
++ if (lTimeSurplus > 1000)
++ {
++ bResumeWasAttempted = TRUE;
++ bResumeOccurred = (HXR_OK == m_pHXPlayer->Begin());
++ m_bPlayerIsPausedByThis = !bResumeOccurred;
++ }
++ }
++ }
++ }
++ }
++
++ if (GetGlobal()->bEnableVerboseMode && !m_bDownloadIsComplete)
++ {
++ STDOUT("\nDownload progress: (play time=%lu,",
++ ulCurPlayTime);
++ if (HX_PROGDOWNLD_UNKNOWN_TIME_SURPLUS == lTimeSurplus)
++ {
++ STDOUT(" UNKNOWN surplus|deficit)");
++ }
++ else if (HX_PROGDOWNLD_MIN_TIME_SURPLUS == lTimeSurplus)
++ {
++ STDOUT(" deficit exceeds maximum");
++ }
++ else if (HX_PROGDOWNLD_MAX_TIME_SURPLUS == lTimeSurplus)
++ {
++ STDOUT(" surplus exceeds maximum)");
++ }
++ else
++ {
++ STDOUT(" surplus=%ld milliseconds)", lTimeSurplus);
++ }
++ if (HX_PROGDOWNLD_UNKNOWN_DURATION == ulNewDurSoFar)
++ {
++ STDOUT("\n\thave UNKNOWN");
++ }
++ else
++ {
++ STDOUT("\n\thave %lu", ulNewDurSoFar);
++ }
++
++ if (HX_PROGDOWNLD_UNKNOWN_DURATION != m_ulTotalDurReported)
++ {
++ STDOUT(" of %lu msec", m_ulTotalDurReported);
++ }
++ else
++ {
++ STDOUT(" of UNKNOWN msec of media");
++ }
++ if (HX_PROGDOWNLD_UNKNOWN_FILE_SIZE != ulNewBytesSoFar)
++ {
++ STDOUT(" (%lu", ulNewBytesSoFar);
++ }
++ else
++ {
++ STDOUT(" (UNKNOWN");
++ }
++ STDOUT(" bytes downloaded so far)\n", ulNewBytesSoFar);
++
++ if (bPauseOccurred || bPauseWasAttempted)
++ {
++ STDOUT("# Waiting for more data: %splayback.\n "
++ " Should take %ld milliseconds before playback resumes.\n",
++ bPauseOccurred? "Pausing " :
++ (bPauseWasAttempted? "Failed attempting to pause "
++ : " "), -lTimeSurplus);
++ }
++ if (bResumeOccurred || bResumeWasAttempted)
++ {
++ STDOUT("# Data available: %splayback\n "
++ " Time surplus is now %ld",
++ bResumeOccurred? "Resuming " :
++ (bResumeWasAttempted? "Failed attempting to resume "
++ : " "), lTimeSurplus);
++ }
++ }
++
++ m_bFirstPDStatusMessage = FALSE;
++
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnTotalDurChanged
++ * Purpose:
++ * This is a notification if the total file duration becomes known
++ * or becomes better-known during download/playback
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ */
++STDMETHODIMP
++ExamplePDStatusObserver::OnTotalDurChanged(
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource,
++ UINT32 ulNewTotalDur)
++{
++ m_ulTotalDurReported = ulNewTotalDur;
++
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("\nOnTotalDurChanged(): to %lu milliseconds\n", ulNewTotalDur);
++ }
++
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadComplete
++ *
++ * Purpose:
++ * Notification that the entire file has been downloaded.
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ *
++ */
++STDMETHODIMP
++ExamplePDStatusObserver::OnDownloadComplete(
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource)
++{
++ m_bDownloadIsComplete = TRUE;
++
++ HXBOOL bResumeWasAttempted = FALSE;
++ HXBOOL bResumeOccurred = FALSE;
++
++ // /In case we're paused, resume now that there is no more data to get:
++ if (m_pHXPlayer && m_bPlayerIsPausedByThis)
++ {
++ bResumeWasAttempted = TRUE;
++ bResumeOccurred = (HXR_OK == m_pHXPlayer->Begin());
++ m_bPlayerIsPausedByThis = !bResumeOccurred;
++ }
++
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("\nOnDownloadComplete()\n");
++ if (bResumeOccurred || bResumeWasAttempted)
++ {
++ STDOUT("\n%splayback now that bytes are available for "
++ "uninterrupted playback\n",
++ bResumeOccurred? "Resuming " :
++ (bResumeWasAttempted? "Failed attempting to resume "
++ : " "));
++ }
++ }
++
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXPDStatusObserver::SrcClaimsSeekSupport ref: hxprdnld.h
++ * Purpose:
++ * Passes along notification from file sys that seek support
++ * is or is not claimed to be available (although sometimes HTTP
++ * server claims this when it doesn't actually support it).
++ */
++STDMETHODIMP
++ExamplePDStatusObserver::SrcClaimsSeekSupport(IHXStreamSource* pStreamSource,
++ HXBOOL bClaimsSupport)
++{
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("\nSrcClaimsSeekSupport(%sE)\n", bClaimsSupport?"TRU":"FALS");
++ }
++ return HXR_OK;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadPause
++ * Purpose:
++ * Notification that the file-download process has purposefully
++ * and temporarily halted downloading of the file
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ */
++STDMETHODIMP
++ExamplePDStatusObserver::OnDownloadPause(
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource)
++{
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("\nOnDownloadPause()\n");
++ }
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadResume
++ * Purpose:
++ * Notification that the file-download process has resumed
++ * the process of downloading the remainder of the file
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ */
++STDMETHODIMP
++ExamplePDStatusObserver::OnDownloadResume(
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource)
++{
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("\nOnDownloadResume()\n");
++ }
++ return HXR_OK;
++}
++// /#endif // /HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS.
+Index: helix-libs/clientapps/clutter/exprdnld.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exprdnld.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,196 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _EXPRDNLD_H_
++#define _EXPRDNLD_H_
++
++// /#if defined(HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS)
++
++/****************************************************************************
++ *
++ * Class:
++ *
++ * ExamplePDStatusObserver
++ *
++ * Purpose:
++ *
++ * Implementation for IHXPDStatusObserver which receives progressive-
++ * download status reports:
++ *
++ */
++class ExamplePDStatusObserver :
++ public IHXPDStatusObserver
++{
++private:
++ INT32 m_lRefCount;
++ IHXPDStatusMgr* m_pPrgDnldStatusMgr;
++ IUnknown* m_pUnkPlayer;
++ IHXPlayer* m_pHXPlayer;
++ HXBOOL m_bPlayerIsPausedByThis;
++ HXBOOL m_bFirstPDStatusMessage;
++ UINT32 m_ulTotalDurReported;
++ UINT32 m_ulDurSoFar;
++ UINT32 m_ulCurStatusUpdateGranularity;
++ HXBOOL m_bInitialPrerollUpateGranularitySet;
++ HXBOOL m_bDownloadIsComplete;
++
++ ExamplePDStatusObserver();
++ ~ExamplePDStatusObserver();
++
++public:
++ ExamplePDStatusObserver(IUnknown* pUnkPlayer);
++
++ /*
++ * IUnknown methods
++ */
++ STDMETHOD(QueryInterface) (THIS_
++ REFIID riid,
++ void** ppvObj);
++
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /*
++ * IHXPDStatusObserver methods
++ */
++
++ /************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadProgress
++ *
++ * Purpose:
++ * Notification from IHXPDStatusMgr of download progress when
++ * file size changes.
++ *
++ * lTimeSurplus:
++ * - When negative, the absolute value of it is the estimated number
++ * of milliseconds of wall-clock time that need to pass while
++ * downloading continues before reaching the point at which playback
++ * can resume and play the remainder of the stream without having to
++ * buffer, assuming that playback is paused and remains so during
++ * that period.
++ * - When positive, it is the estimated number of milliseconds of
++ * wall-clock time between when the download should complete and when
++ * the natural content play-out duration will be reached, assuming
++ * playback is currently progressing and that no pause will occur.
++ *
++ * Note: ulNewDurSoFar can be HX_PROGDOWNLD_UNKNOWN_DURATION if the
++ * IHXMediaBytesToMediaDurConverter was not available to, or was
++ * unable to convert the bytes to a duration for the IHXPDStatusMgr
++ * calling this:
++ */
++ STDMETHOD(OnDownloadProgress) (THIS_
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource,
++ UINT32 /*IN*/ ulNewDurSoFar,
++ UINT32 /*IN*/ ulNewBytesSoFar,
++ INT32 /*IN*/ lTimeSurplus);
++
++ /************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnTotalDurChanged
++ * Purpose:
++ * This is a notification if the total file duration becomes known
++ * or becomes better-known during download/playback
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ */
++ STDMETHOD(OnTotalDurChanged) (THIS_
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource,
++ UINT32 /*IN*/ ulNewDur);
++
++ /************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadComplete
++ *
++ * Purpose:
++ * Notification that the entire file has been downloaded.
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ *
++ */
++ STDMETHOD(OnDownloadComplete) (THIS_
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource);
++
++ /************************************************************************
++ * Method:
++ * IHXPDStatusObserver::SrcClaimsSeekSupport
++ *
++ * Purpose:
++ * Passes along notification from file sys that seek support
++ * is claimed to be available (although sometimes HTTP server
++ * claims this when it doesn't actually support it).
++ *
++ */
++ STDMETHOD(SrcClaimsSeekSupport) (THIS_
++ IHXStreamSource* pStreamSource,
++ HXBOOL /*IN*/ bSrcClaimsSeekSupport);
++
++ /************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadPause
++ * Purpose:
++ * Notification that the file-download process has purposefully
++ * and temporarily halted downloading of the file
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ */
++ STDMETHOD(OnDownloadPause) (THIS_
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource);
++
++ /************************************************************************
++ * Method:
++ * IHXPDStatusObserver::OnDownloadResume
++ * Purpose:
++ * Notification that the file-download process has resumed
++ * the process of downloading the remainder of the file
++ *
++ * Note: pStreamSource can be NULL. This will be true when
++ * IHXPDStatusMgr calling this is upstream of the IHXStreamSource
++ * object.
++ */
++ STDMETHOD(OnDownloadResume) (THIS_
++ IHXStreamSource* /*IN*/ /*NULL is valid value*/ pStreamSource);
++};
++// /#endif // /HELIX_FEATURE_PROGRESSIVE_DOWNLD_STATUS.
++
++#endif // _EXPRDNLD_H_
++
+Index: helix-libs/clientapps/clutter/exroot.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exroot.cpp 2008-10-13 06:54:08.000000000 -0700
+@@ -0,0 +1,672 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: unixroot.cpp,v 1.9 2007/07/06 20:54:01 jfinnecy Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++// for shared memory
++#include <sys/types.h>
++#include <sys/ipc.h>
++#include <sys/shm.h>
++#include <sys/utsname.h>
++
++#include "hxcom.h"
++#include "hxwintyp.h"
++#include "hxvsurf.h"
++#include "hxslist.h"
++#include "colormap.h"
++#include "hxprefs.h"
++#include "hxtick.h"
++#include "hxthread.h"
++#include "basesite.h"
++#include "exroot.h"
++#include "exsite.h"
++#include "unixcmap.h"
++#include "shmhelp.h"
++
++// #ifdef _DEBUG
++// #include <X11/extensions/xf86vmode.h> //for debug video sync rates..
++// #endif
++
++//Work around AIX problem.
++#ifdef _AIX
++# define MAX_SHARED_REGIONS ((UINT32)1)
++#else
++# define MAX_SHARED_REGIONS ((UINT32)9999)
++#endif
++
++CExRootSurf::CExRootSurf(IUnknown* pContext, CHXBaseSite* pSite, on_new_frame_cb_t on_new_frame_cb, void *context )
++ : CBaseRootSurface(pContext, pSite)
++ , m_bUseShm(FALSE)
++ , m_nShmId(0)
++ , m_pDisplay(NULL)
++ , m_GC(0)
++ , m_nScreenNumber(0)
++ , m_pXImage(NULL)
++ , m_pVisual(NULL)
++ , m_unDepth(0)
++ , m_pScreen(NULL)
++ , m_pYUVScratchBits(NULL)
++ , m_nYUVScratchPitch(0)
++ , m_pScratchBits(NULL)
++ , m_nScratchPitch(0)
++ , m_nBitsPerPixel(0)
++ , m_nCompositionSize(0)
++ , m_on_new_frame_cb(on_new_frame_cb)
++ , m_context(context)
++{
++}
++
++HX_RESULT CExRootSurf::Init()
++{
++ //get window and display from main Site.
++ HXxWindow* pWindow = m_pSite->GetWindow();
++ HX_ASSERT(pWindow);
++
++ m_pDisplay = (Display*)pWindow->display;
++ m_window = (Window)pWindow->window;
++
++ HX_ASSERT( m_pDisplay );
++ HX_ASSERT( m_window );
++
++ //
++ // Now see if our X11 server supports the Shared Memory extension.
++ //
++ // ShmHelp::Init(m_pDisplay);
++ // m_bUseShm = ShmHelp::ShmAvailable();
++
++ //Create the graphics context
++ XGCValues values;
++
++ XLockDisplay(m_pDisplay);
++ m_GC = XCreateGC(m_pDisplay, m_window, 0, &values);
++
++ //Get X window attributes & visual
++ XWindowAttributes attr;
++ XGetWindowAttributes(m_pDisplay, m_window, &attr);
++ XUnlockDisplay(m_pDisplay);
++ m_pVisual = attr.visual;
++
++ // get visual info & depth
++ int nv=0;
++ XVisualInfo visInfo;
++ memset(&visInfo, 0, sizeof(XVisualInfo));
++ XLockDisplay(m_pDisplay);
++ visInfo.visualid = XVisualIDFromVisual(m_pVisual);
++ XVisualInfo* pVisualInfo = XGetVisualInfo (m_pDisplay, VisualIDMask, &visInfo, &nv);
++// m_unDepth = pVisualInfo->depth;
++ m_unDepth = 24;
++ m_nScreenNumber = DefaultScreen(m_pDisplay);
++ m_pScreen = XScreenOfDisplay(m_pDisplay, m_nScreenNumber);
++ XUnlockDisplay(m_pDisplay);
++ m_colormap = HXGetXColormap(m_pDisplay, m_window);
++
++ // get pixmap (blt) information for the best depth we can display
++ int i=0;
++ int nNum=0;
++ XLockDisplay(m_pDisplay);
++ XPixmapFormatValues *pixmap_formats = XListPixmapFormats(m_pDisplay, &nNum);
++ XUnlockDisplay(m_pDisplay);
++ if(pixmap_formats)
++ {
++ for (i=0 ; i<nNum; i++)
++ {
++ if (pixmap_formats[i].depth == m_unDepth)
++ {
++ m_nBitsPerPixel = pixmap_formats[i].bits_per_pixel;
++ }
++ }
++ XFree(pixmap_formats);
++ pixmap_formats = NULL;
++ }
++
++ memset(&m_bmiSave, 0, sizeof(HXBitmapInfo));
++#if 0
++ m_bmiSave.bmiHeader.biBitCount = m_nBitsPerPixel;
++ m_bmiSave.bmiHeader.biCompression = (m_unDepth==8 ? BI_RGB : BI_BITFIELDS);
++ m_bmiSave.un.dwBitMask[0] = pVisualInfo->red_mask;
++ m_bmiSave.un.dwBitMask[1] = pVisualInfo->green_mask;
++ m_bmiSave.un.dwBitMask[2] = pVisualInfo->blue_mask;
++#else
++ /* Fake a RGB24 */
++ m_nBitsPerPixel = 24;
++ m_bmiSave.bmiHeader.biBitCount = m_nBitsPerPixel;
++ m_bmiSave.bmiHeader.biCompression = BI_RGB;
++#endif
++ //Set primary surface CID.
++ m_nCompositionSurfaceCID = GetBitmapColor(&m_bmiSave);
++ XFree( pVisualInfo );
++
++// #ifdef _DEBUG
++// //Lets find out what Hsync and Vsync rates we have for this display.
++// //Ripped from xvidtune.c
++// XF86VidModeModeLine mode_line;
++// int scrn=0;
++// int dot_clock;
++// double vsync_hz, HSyncRate,HTotal, VTotal, PixelClock;
++// if(XF86VidModeGetModeLine(m_pDisplay, scrn, &dot_clock, &mode_line))
++// {
++// PixelClock=dot_clock;
++// HTotal = mode_line.htotal;
++// VTotal = mode_line.vtotal;
++// HSyncRate = PixelClock*1000.0/HTotal;
++// vsync_hz = HSyncRate/VTotal;
++// fprintf( stderr, "This Display's Hsync rate is: %f and Vsync: %f\n",
++// HSyncRate, vsync_hz );
++// }
++
++// #endif
++
++ return HXR_OK;
++}
++
++CExRootSurf::~CExRootSurf()
++{
++ _DestroyCompositionSurface();
++
++ if( m_GC )
++ {
++ XLockDisplay(m_pDisplay);
++ XFreeGC( m_pDisplay, m_GC );
++ XUnlockDisplay(m_pDisplay);
++ m_GC=0;
++ }
++ if (m_pVisual)
++ {
++ /* PJG: don't have to free visuals */
++ m_pVisual = NULL;
++ }
++
++ if(m_bUseShm)
++ {
++ if( m_pCompositionSurface != NULL )
++ ShmHelp::DetachSharedRegion(&m_pCompositionSurface, &m_shmInfo);
++ }
++ else
++ {
++ HX_DELETE(m_pCompositionSurface);
++ m_nCompositionSize=0;
++ m_bCompositionSurfaceCreated=FALSE;
++ }
++
++ //XXXgfw any more clean up for these two?
++ HX_VECTOR_DELETE( m_pScratchBits );
++ HX_VECTOR_DELETE( m_pYUVScratchBits );
++
++}
++
++HX_RESULT CExRootSurf::_ResizeVideoBuffer( INT32 nSize)
++{
++ HX_RESULT retVal=HXR_OK;
++
++ if(nSize <= m_nCompositionSize)
++ return retVal;
++
++ if(m_bUseShm)
++ {
++ if( m_pCompositionSurface != NULL )
++ retVal = ShmHelp::DetachSharedRegion(&m_pCompositionSurface, &m_shmInfo);
++ if( retVal==HXR_OK )
++ {
++ retVal = ShmHelp::CreateSharedRegion( nSize,
++ &m_pCompositionSurface,
++ &m_nShmId,
++ &m_shmInfo
++ );
++
++ }
++ if( retVal != HXR_OK )
++ {
++ m_bCompositionSurfaceCreated = FALSE;
++ m_nCompositionSize = 0;
++ m_bUseShm = FALSE;
++ }
++ else
++ {
++ //It all worked
++ m_nCompositionSize = nSize;
++ m_bCompositionSurfaceCreated = TRUE;
++ return retVal;
++ }
++
++ }
++
++ //We need to fall through here so that if the shared memory stuff
++ //above fails we can create it the old fashioned way.
++ if(m_pCompositionSurface == NULL)
++ {
++ m_pCompositionSurface = (UCHAR*) malloc(nSize);
++ }
++ else
++ {
++ m_pCompositionSurface = (UCHAR*) realloc(m_pCompositionSurface, nSize);
++ }
++ if( m_pCompositionSurface )
++ {
++ m_nCompositionSize = nSize;
++ }
++ else
++ {
++ HX_ASSERT("We can't alloc the composition surface." == NULL );
++ m_nCompositionSize = 0;
++ }
++
++ return retVal;
++}
++
++HX_RESULT CExRootSurf::_DebugBlt( UCHAR* pImageData, HXBitmapInfoHeader* pBitmapInfo,
++ HXxRect& rDestRect, HXxRect& rSrcRect)
++{
++ HX_ASSERT( m_window );
++ HX_ASSERT( m_pDisplay );
++ HX_ASSERT( m_GC );
++ XLockDisplay(m_pDisplay);
++ XSetForeground( m_pDisplay, m_GC, WhitePixel(m_pDisplay, 0 ));
++ XSetBackground( m_pDisplay, m_GC, BlackPixel(m_pDisplay, 0 ));
++ XSetLineAttributes(m_pDisplay, m_GC, 5, LineSolid, CapRound, JoinRound );
++ XSetForeground( m_pDisplay, m_GC, WhitePixel(m_pDisplay, 0) );
++ XFillRectangle( m_pDisplay, m_window, m_GC,
++ rDestRect.left, rDestRect.top,
++ rDestRect.right-rDestRect.left,
++ rDestRect.bottom-rDestRect.top
++ );
++ XDrawRectangle( m_pDisplay, m_window, m_GC,
++ rDestRect.left, rDestRect.top,
++ rDestRect.right-rDestRect.left,
++ rDestRect.bottom-rDestRect.top
++ );
++ XUnlockDisplay(m_pDisplay);
++ return HXR_OK;
++}
++
++void CExRootSurf::_GetYUVScratchWidthHeight(UINT32* pWidth, UINT32* pHeight)
++{
++ *pWidth = m_bmiYUVScratch.bmiHeader.biWidth;
++ *pHeight = m_bmiYUVScratch.bmiHeader.biHeight;
++}
++
++XImage* CExRootSurf::_GetCompositionSurfaceDrawable()
++{
++ return m_pXImage;
++}
++
++
++
++//Not used except for XING.....
++void CExRootSurf::_CreateYUVScratchSurface(UINT32 width, UINT32 height)
++{
++ //Remove old bits....
++ HX_DELETE(m_pYUVScratchBits);
++
++ //Clear BitmapInfo struct....
++ memset(&m_bmiYUVScratch, 0, sizeof(HXBitmapInfo));
++ int nResult = MakeBitmap( &m_bmiYUVScratch,
++ sizeof(m_bmiYUVScratch),
++ CID_YUY2,
++ width,
++ height,
++ NULL,
++ 0);
++ if( nResult )
++ {
++ m_pYUVScratchBits = new UCHAR[m_bmiYUVScratch.bmiHeader.biSizeImage];
++ m_nYUVScratchPitch = GetBitmapPitch(&m_bmiYUVScratch);
++ }
++}
++
++
++void CExRootSurf::_GetYUVScratchSurfacePointer(UCHAR** pYUVBits, INT32* YUVPitch)
++{
++ *pYUVBits = m_pYUVScratchBits;
++ *YUVPitch = m_nYUVScratchPitch;
++}
++
++HX_RESULT CExRootSurf::CreateScratchSurface( int nCompositionSurfaceCID, HXxSize* pSize)
++{
++ //Remove old bits....
++ HX_DELETE(m_pScratchBits);
++
++ //Clear BitmapInfo struct....
++ memset(&m_bmiScratch, 0, sizeof(HXBitmapInfo));
++ int nResult = MakeBitmap( &m_bmiScratch,
++ sizeof(m_bmiScratch),
++ nCompositionSurfaceCID,
++ pSize->cx,
++ pSize->cy,
++ NULL,
++ 0);
++ if( nResult )
++ {
++ m_pScratchBits = new UCHAR[m_bmiScratch.bmiHeader.biSizeImage];
++ m_nScratchPitch = GetBitmapPitch(&m_bmiScratch);
++ }
++
++ return nResult? HXR_OK : HXR_FAIL;
++}
++
++HX_RESULT CExRootSurf::ScratchLock(UCHAR** pBits, INT32* pPitch)
++{
++ *pBits = m_pScratchBits;
++ *pPitch = m_nScratchPitch;
++ return HXR_OK;
++}
++
++HX_RESULT CExRootSurf::ScratchUnlock(UCHAR* pBits)
++{
++ return HXR_OK;
++}
++
++HX_RESULT CExRootSurf::_MinimalUnlock(HXxWindow* pWindow)
++{
++// Window win = m_window;
++// HX_ASSERT(win);
++// HXxSize hxxSize;
++// m_pSite->GetSize(hxxSize);
++
++// if (m_bUseShm)
++// {
++// XShmPutImage(m_pDisplay,
++// win,
++// m_GC,
++// m_pXImage,
++// 0,
++// 0,
++// 0,
++// 0,
++// hxxSize.cx,
++// hxxSize.cy,
++// False
++// );
++// }
++// else
++// {
++// XPutImage(m_pDisplay,
++// win,
++// m_GC,
++// m_pXImage,
++// 0,
++// 0,
++// 0,
++// 0,
++// hxxSize.cx,
++// hxxSize.cy
++// );
++// }
++ return HXR_OK;
++}
++
++HX_RESULT CExRootSurf::_LockComposition(UCHAR** pBits, INT32* pPitch)
++{
++ HX_RESULT retVal = HXR_OK;
++ if( !m_bCompositionSurfaceCreated || m_pCompositionSurface==NULL )
++ {
++ retVal = _CreateCompositionSurface();
++ }
++ HX_ASSERT( m_pCompositionSurface );
++ *pBits = m_pCompositionSurface;
++ *pPitch = m_nCompositionPitch;
++ return HXR_OK;
++}
++
++
++void CExRootSurf::_BltFromScratchToComposition( HXxRect& rDestRect, HXxRect& rSrcRect)
++{
++ HX_ASSERT( "Not implemented on unix yet...."==NULL );
++}
++
++HX_RESULT CExRootSurf::_CreateCompositionSurface()
++{
++ HX_RESULT retVal = HXR_FAIL;
++
++ if(m_bCompositionSurfaceCreated)
++ {
++ return HXR_OK;
++ }
++
++ HX_ASSERT( !m_bCompositionSurfaceCreated );
++ HX_ASSERT( m_pSite );
++
++ //Create a BMI to describe the composition surface
++ HXxSize hxxSize;
++ m_pSite->GetSize(hxxSize);
++ memcpy(&m_compositionSize, &hxxSize, sizeof(HXxSize)); /* Flawfinder: ignore */
++
++ // find out how big we want to allocate.
++ if (m_pSite->IsFullScreen())
++ {
++ UINT16 unDummy=0;
++ UINT16 unHorzRes=0;
++ UINT16 unVertRes=0;
++ m_pSite->_GetDeviceCaps(NULL, unDummy, unHorzRes, unVertRes );
++ m_allocatedCompositionSize.cx = unHorzRes;
++ m_allocatedCompositionSize.cy = unVertRes;
++ }
++ else
++ {
++ // we use root surface for BASIC_BLT and it assumes the offset(position)
++ // of the root site it cooresponding to is (0, 0).
++ //
++ // this is not true for "windowless" mode where the root site can be given
++ // an offset, as a result, we fail to blt the video.
++ //
++ // to fix this, we'll take the m_positionOrg into consideration when
++ // creating the composition surface, this may not be optimal but good enough
++ // for now.
++ //
++ // similar logic is also added for other platforms, we need to move this
++ // common code to the base class when we have chance to clean it up
++ if (m_compositionSize.cx && m_compositionSize.cy)
++ {
++ m_compositionSize.cx += m_pSite->m_positionOrig.x;
++ m_compositionSize.cy += m_pSite->m_positionOrig.y;
++ }
++
++ m_allocatedCompositionSize.cx = m_compositionSize.cx;
++ m_allocatedCompositionSize.cy = m_compositionSize.cy;
++ }
++
++ //XXXgfw uhhhh, OK.
++ if( m_compositionSize.cx > m_allocatedCompositionSize.cx ||
++ m_compositionSize.cy > m_allocatedCompositionSize.cy )
++ {
++ m_allocatedCompositionSize.cx = m_compositionSize.cx;
++ m_allocatedCompositionSize.cy = m_compositionSize.cy;
++ }
++
++ //Make the bitmap header struct.
++ m_bmiComposition.bmiHeader.biBitCount = m_bmiSave.bmiHeader.biBitCount;
++ m_bmiComposition.bmiHeader.biCompression = m_bmiSave.bmiHeader.biCompression;
++ m_bmiComposition.un.dwBitMask[0] = m_bmiSave.un.dwBitMask[0];
++ m_bmiComposition.un.dwBitMask[1] = m_bmiSave.un.dwBitMask[1];
++ m_bmiComposition.un.dwBitMask[2] = m_bmiSave.un.dwBitMask[2];
++ int nResult = MakeBitmap( &m_bmiComposition,
++ sizeof(m_bmiComposition),
++ m_nCompositionSurfaceCID,
++ m_allocatedCompositionSize.cx,
++ m_allocatedCompositionSize.cy,
++ NULL,
++ 0
++ );
++ m_bmiComposition.bmiHeader.biBitCount = m_bmiSave.bmiHeader.biBitCount;
++ m_bmiComposition.bmiHeader.biCompression = m_bmiSave.bmiHeader.biCompression;
++ m_bmiComposition.un.dwBitMask[0] = m_bmiSave.un.dwBitMask[0];
++ m_bmiComposition.un.dwBitMask[1] = m_bmiSave.un.dwBitMask[1];
++ m_bmiComposition.un.dwBitMask[2] = m_bmiSave.un.dwBitMask[2];
++
++ //Now create the bits....
++ _ResizeVideoBuffer( m_bmiComposition.bmiHeader.biSizeImage );
++ m_nCompositionPitch = GetBitmapPitch( &m_bmiComposition );
++
++ if( m_pXImage )
++ {
++ XFree( m_pXImage );
++ }
++
++ if( m_bUseShm )
++ {
++ XLockDisplay(m_pDisplay);
++ m_pXImage = XShmCreateImage( m_pDisplay,
++ m_pVisual,
++ m_unDepth,
++ ZPixmap,
++ (char*)m_pCompositionSurface,
++ &m_shmInfo,
++ m_allocatedCompositionSize.cx,
++ m_allocatedCompositionSize.cy
++ );
++ XUnlockDisplay(m_pDisplay);
++ }
++ else
++ {
++ XLockDisplay(m_pDisplay);
++ m_pXImage = XCreateImage( m_pDisplay,
++ m_pVisual,
++ m_unDepth,
++ ZPixmap,
++ 0,
++ (char*)m_pCompositionSurface,
++ m_allocatedCompositionSize.cx,
++ m_allocatedCompositionSize.cy,
++ 32,
++ 0);
++ XUnlockDisplay(m_pDisplay);
++ }
++
++ if( m_pXImage )
++ {
++ m_bCompositionSurfaceCreated = TRUE;
++#ifdef _BIG_ENDIAN
++ m_pXImage->byte_order = MSBFirst;
++#else
++ m_pXImage->byte_order = LSBFirst;
++#endif
++ retVal = HXR_OK;
++ }
++ return retVal;
++}
++
++void CExRootSurf::_MinimalBlt(HXxRect& destRect)
++{
++ if (m_on_new_frame_cb)
++ {
++ PlayerImgInfo Info;
++ Info.Rect.left = destRect.left;
++ Info.Rect.right = destRect.right;
++ Info.Rect.top = destRect.top;
++ Info.Rect.bottom = destRect.bottom;
++ Info.cx = m_allocatedCompositionSize.cx;
++ Info.cy = m_allocatedCompositionSize.cy;
++ m_on_new_frame_cb(m_pCompositionSurface,
++ m_bmiComposition.bmiHeader.biSizeImage,
++ &Info,
++ m_context);
++ }
++}
++
++HX_RESULT CExRootSurf::_DestroyCompositionSurface()
++{
++ HX_RESULT retVal = HXR_OK;
++ if( m_bCompositionSurfaceCreated )
++ {
++ if( m_pXImage )
++ {
++ XFree(m_pXImage);
++ m_pXImage = NULL;
++ }
++ m_bCompositionSurfaceCreated = FALSE;
++ }
++
++ return retVal;
++}
++
++
++
++HX_RESULT CExRootSurf::BeginOptimizedBlt(HXBitmapInfoHeader* pBitmapInfo)
++{
++#ifdef _DEBUG
++ fprintf(stderr, "CExRootSurf::BeginOptimizedBlt Needs to be written\n" );
++#endif
++ return HXR_NOTIMPL;
++}
++
++HX_RESULT CExRootSurf::OptimizedBlt( UCHAR* pImageBits,
++ HXxRect& rDestRect,
++ HXxRect& rSrcRect)
++{
++#ifdef _DEBUG
++ fprintf(stderr, "CExRootSurf::OptimizedBlt Needs to be written\n" );
++#endif
++ return HXR_NOTIMPL;
++}
++
++HX_RESULT CExRootSurf::EndOptimizedBlt(void)
++{
++#ifdef _DEBUG
++ fprintf(stderr, "CExRootSurf::EndOptimizedBlt Needs to be written\n" );
++#endif
++ return HXR_NOTIMPL;
++}
++
++HX_RESULT CExRootSurf::GetOptimizedFormat(HX_COMPRESSION_TYPE& ulType)
++{
++#ifdef _DEBUG
++ fprintf(stderr, "CExRootSurf::GetOptimizedFormat Needs to be written\n" );
++#endif
++ return HXR_NOTIMPL;
++}
++
++HX_RESULT CExRootSurf::GetPreferredFormat(HX_COMPRESSION_TYPE& ulType)
++{
++#ifdef _DEBUG
++ fprintf(stderr, "CExRootSurf::GetPreferredFormat Needs to be written\n" );
++#endif
++ return HXR_NOTIMPL;
++}
++
++GC CExRootSurf::GetGC()
++{
++ return m_GC;
++}
+Index: helix-libs/clientapps/clutter/exroot.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exroot.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,155 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: unixroot.h,v 1.8 2007/07/06 20:54:05 jfinnecy Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _UNIXROOT_H
++#define _UNIXROOT_H
++
++#include "baseroot.h"
++#if defined(USE_XWINDOWS)
++#include <X11/Xatom.h>
++#include <X11/Xlib.h>
++#include <X11/Xutil.h>
++#include <X11/Xos.h>
++#include <X11/Intrinsic.h>
++#include <X11/extensions/XShm.h>
++#endif
++
++#include "player.h"
++
++class CExRootSurf : public CBaseRootSurface
++{
++public:
++ CExRootSurf(IUnknown* pContext, CHXBaseSite* pSite, on_new_frame_cb_t on_new_frame_cb = NULL, void *context = NULL);
++
++ //Helpers....
++ HX_RESULT Init();
++ GC GetGC();
++
++ //public inherited stuff
++ virtual HX_RESULT CreateScratchSurface(int nCompositionSurfaceCID,
++ HXxSize* pSize);
++ virtual HX_RESULT ScratchLock(UCHAR** pBits, INT32* pPitch);
++ virtual HX_RESULT ScratchUnlock(UCHAR* pBits);
++
++ virtual HX_RESULT BeginOptimizedBlt(HXBitmapInfoHeader* pBitmapInfo);
++ virtual HX_RESULT OptimizedBlt( UCHAR* pImageBits,
++ HXxRect& rDestRect,
++ HXxRect& rSrcRect);
++ virtual HX_RESULT EndOptimizedBlt(void);
++ virtual HX_RESULT GetOptimizedFormat(HX_COMPRESSION_TYPE& ulType);
++ virtual HX_RESULT GetPreferredFormat(HX_COMPRESSION_TYPE& ulType);
++
++ XImage* _GetCompositionSurfaceDrawable();
++
++ //Shared Memory helper func for the basesurf to use.
++// HX_RESULT _DetachSharedRegion();
++// HX_RESULT _CreateSharedRegion(INT32 nSize);
++
++protected:
++
++ //Smartly handle resizing of shm buffer.
++ HX_RESULT _ResizeVideoBuffer(INT32 nSize);
++
++ //Inherited from CBaseRootSurface....
++ virtual void _BltFromScratchToComposition(HXxRect& rDestRect,
++ HXxRect& rSrcRect);
++ virtual HX_RESULT _DebugBlt( UCHAR* pImageData,
++ HXBitmapInfoHeader* pBitmapInfo,
++ HXxRect& rDestRect,
++ HXxRect& rSrcRect);
++ virtual void _GetYUVScratchWidthHeight(UINT32* pWidth, UINT32* pHeight);
++ virtual void _CreateYUVScratchSurface(UINT32 width, UINT32 height);
++ virtual void _GetYUVScratchSurfacePointer(UCHAR** pYUVBits, INT32* YUVPitch);
++ virtual HX_RESULT _MinimalUnlock(HXxWindow* pWindow);
++ virtual HX_RESULT _LockComposition(UCHAR** pBits, INT32* pPitch);
++ virtual HX_RESULT _CreateCompositionSurface();
++ virtual HX_RESULT _DestroyCompositionSurface();
++ virtual void _MinimalBlt(HXxRect& dest);
++
++
++private:
++
++ virtual ~CExRootSurf();
++
++ //Protect unintentional copy and default ctors.
++ CExRootSurf();
++ CExRootSurf( const CExRootSurf& );
++ CExRootSurf& operator=( const CExRootSurf& it );
++
++ //Shared memory members.
++ HXBOOL m_bUseShm;
++ XShmSegmentInfo m_shmInfo;
++ int m_nShmId;
++
++ //General display and GC stuff.
++ Display* m_pDisplay;
++ GC m_GC;
++ int m_nScreenNumber;
++ XImage* m_pXImage;
++ Window m_window;
++ Visual* m_pVisual;
++ unsigned int m_unDepth;
++ Screen* m_pScreen;
++ Colormap m_colormap;
++ int m_nBitsPerPixel;
++
++ //Bitmap stuff.
++ UCHAR* m_pYUVScratchBits;
++ HXBitmapInfo m_bmiYUVScratch;
++ int m_nYUVScratchPitch;
++ UCHAR* m_pScratchBits;
++ HXBitmapInfo m_bmiScratch;
++ int m_nScratchPitch;
++ HXBitmapInfo m_bmiSave;
++ ULONG32 m_nCompositionSize;
++ on_new_frame_cb_t m_on_new_frame_cb;
++ void * m_context;
++};
++
++#endif
+Index: helix-libs/clientapps/clutter/exsite.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exsite.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,2915 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: unixsite.cpp,v 1.18.2.6 2008/06/05 14:24:30 lovish Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ * Phil Dibowitz
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _UNIX
++#error This is the UNIX platform specific implementation.
++#endif
++
++//
++// System includes...
++//
++#include <stdio.h>
++#include "hlxclib/string.h"
++#if defined(USE_XWINDOWS)
++#include <X11/Intrinsic.h>
++#include <X11/Shell.h>
++#include <X11/Xlib.h>
++#include <X11/Xutil.h>
++#include <X11/keysym.h>
++#include <X11/Xos.h>
++#include <X11/cursorfont.h>
++#include <X11/extensions/XShm.h>
++#endif
++
++
++//
++// RMA includes...
++//
++#include "hxcom.h"
++#include "hxcore.h"
++#include "hxevent.h"
++#include "hxwintyp.h"
++#include "hxwin.h"
++#include "hxsite2.h"
++#include "hxtypes.h"
++#include "exsite.h"
++#include "unixcmap.h"
++#include "visuals.h"
++#include "region.h"
++#include "basesurf.h"
++#include "exroot.h"
++#include "hxthread.h"
++#include "hxtick.h"
++#include "sitetext.h"
++
++#include "unixsurf.h"
++
++#include "hxprefs.h"
++
++//
++// Global & Static global/member data....
++//
++Display *CHXExSite::zm_display = NULL;
++static CHXMapPtrToPtr z_mapSiteToWindow;
++
++//
++// Scroll bar support
++//
++#define SCROLL_BAR_WIDTH 13 //Width of scroll bar.
++//#define _ARROWS_SIDE_BY_SIDE 1 //Regular or side by side arrows?
++
++
++
++
++//
++// CHXExSite only Methods...
++//
++CHXExSite::CHXExSite( IUnknown* pContext, IUnknown* pUnkOuter, INT32 lInitialZorder, on_new_frame_cb_t on_new_frame_cb, void *context)
++ : CHXBaseSite( pContext, pUnkOuter, lInitialZorder )
++ , m_pUnixEventHandler(NULL)
++ , m_ScrollHorizButtonL(0)
++ , m_ScrollHorizButtonR(0)
++ , m_ScrollVertButtonT(0)
++ , m_ScrollVertButtonB(0)
++ , m_winFullScreenWindow(0)
++ , m_winOldParent(0)
++ , m_bScrollingInProgress(FALSE)
++ , m_nScrollDir(0)
++ , m_bLastPointInSite(FALSE)
++ , m_bDamaged(FALSE)
++ , m_bIgnoreFocusOutInFS(FALSE)
++ , m_bReparent(FALSE)
++ , m_on_new_frame_cb(on_new_frame_cb)
++ , m_context(context)
++#if defined(HELIX_CONFIG_MOBLIN)
++ , m_pAttachWindowCallback(NULL)
++ , m_pForceRedrawCallback(NULL)
++#endif
++{
++ m_ptScrollVertPosT.x = m_ptScrollVertPosT.y = 0;
++ m_ptScrollVertPosB.x = m_ptScrollVertPosB.y = 0;
++ m_ptScrollHorizPosR.x = m_ptScrollHorizPosR.y = 0;
++ m_ptScrollHorizPosL.x = m_ptScrollHorizPosL.y = 0;
++ m_ptFullScreenOffset.x = m_ptFullScreenOffset.y = 0;
++ memset( &m_PreFullScreenSize, 0, sizeof( m_PreFullScreenSize ) );
++
++ HX_ASSERT( m_pContext );
++
++ /* Replace m_pVideoSurface with my own */
++/* HX_RELEASE(m_pVideoSurface);
++ m_pVideoSurface = new CUnixSurf(m_pContext, this);
++ HX_ASSERT( m_pVideoSurface );
++ m_pVideoSurface->InitSurface(m_pContext);
++ m_pVideoSurface->AddRef();
++*/
++ IHXPreferences* pPreferences = NULL;
++ if( m_pContext && HXR_OK == m_pContext->QueryInterface( IID_IHXPreferences, (void **) &pPreferences))
++ {
++ IHXBuffer *pBuffer = NULL;
++ pPreferences->ReadPref("IgnoreFocusOutInFS", pBuffer);
++ if(pBuffer)
++ {
++ m_bIgnoreFocusOutInFS = (::atoi((const char*)pBuffer->GetBuffer()) == 1);
++ HX_RELEASE(pBuffer);
++ }
++ }
++}
++
++CHXExSite::~CHXExSite()
++{
++#if defined(HELIX_CONFIG_MOBLIN)
++ RemovePendingCallback(m_pAttachWindowCallback);
++ HX_RELEASE(m_pAttachWindowCallback);
++
++ RemovePendingCallback(m_pForceRedrawCallback);
++ HX_RELEASE(m_pForceRedrawCallback);
++#endif
++ void* pDummy;
++ if (z_mapSiteToWindow.Lookup((void*)this, pDummy))
++ {
++ z_mapSiteToWindow.RemoveKey((void*)this);
++ }
++
++ if( m_pUnixEventHandler )
++ {
++ m_pUnixEventHandler->CancelCallback();
++ HX_RELEASE(m_pUnixEventHandler);
++ }
++}
++
++HX_RESULT CHXExSite::_OpenXDisplay(char* pszDisplayString)
++{
++ HX_RESULT retVal = HXR_OK;
++
++ //Is the connection open already?
++ if( NULL==zm_display )
++ {
++ zm_display = XOpenDisplay(pszDisplayString);
++
++ //If you can't open the display your done.
++ if(NULL == zm_display )
++ {
++ HX_ASSERT("Can't open X Display..."==NULL);
++ retVal = HXR_FAIL;
++ }
++ else
++ {
++ HX_ASSERT(m_pScheduler);
++ if( m_pScheduler )
++ {
++ //UnixEventHandler scheduls itself for init callback
++ //in the ctor.
++ m_pUnixEventHandler = new UnixEventHandler(this);
++ m_pUnixEventHandler->AddRef();
++ }
++ }
++ }
++ return retVal;
++}
++
++Window CHXExSite::CreateXWindow( Window win )
++{
++ Window parentWindow;
++ HXxWindow* pWindow = NULL;
++ //If parentWin is NULL then we belong to the root window.
++ if( win )
++ {
++ parentWindow = win;
++ }
++ else
++ {
++ HX_ASSERT(zm_display);
++ XLockDisplay(zm_display);
++ parentWindow = RootWindow(zm_display, DefaultScreen(zm_display));
++ XUnlockDisplay(zm_display);
++ }
++
++ //Find the best visual to use on this display.
++ Visual* visual = GetBestVisual(zm_display);
++
++ //Get the visual info.
++ int nNotUsed=0;
++ XVisualInfo stVisInfo;
++
++ memset(&stVisInfo, 0, sizeof(XVisualInfo));
++ stVisInfo.visualid = XVisualIDFromVisual(visual);
++ XLockDisplay(zm_display);
++ XVisualInfo* pVisual = XGetVisualInfo( zm_display,
++ VisualIDMask,
++ &stVisInfo,
++ &nNotUsed );
++ XUnlockDisplay(zm_display);
++
++ // Set up attributes of the window.
++ int attrMask = CWBackPixel | CWBorderPixel;
++ XSetWindowAttributes attr;
++
++ memset(&attr, 0, sizeof(XSetWindowAttributes));
++ XLockDisplay(zm_display);
++ attr.background_pixel = BlackPixel(zm_display, DefaultScreen(zm_display));
++ attr.border_pixel = BlackPixel(zm_display, DefaultScreen(zm_display));
++ XUnlockDisplay(zm_display);
++
++ //See if the default visaul of hte screen is the same one we Want
++ //to use. If not, create a new one and install it.
++ Colormap cmap;
++ XLockDisplay(zm_display);
++ Visual* defVisual = DefaultVisual(zm_display, DefaultScreen(zm_display));
++ XUnlockDisplay(zm_display);
++ if( defVisual->visualid != stVisInfo.visualid )
++ {
++ //XXXgfw Are we leaking this colormap????
++ XLockDisplay(zm_display);
++ cmap = XCreateColormap(zm_display, parentWindow, visual, AllocNone);
++ XUnlockDisplay(zm_display);
++ attr.colormap = cmap;
++ attrMask |= CWColormap;
++ }
++
++ // Set the size/position of the window before creating.
++ XSizeHints size_hints;
++
++ size_hints.flags = PPosition | PSize;
++ size_hints.x = m_position.x;
++ size_hints.y = m_position.y;
++ size_hints.width = 1;
++ size_hints.height = 1;
++
++ //Create it.
++ XLockDisplay(zm_display);
++ Window window = XCreateWindow(zm_display,
++ parentWindow,
++ size_hints.x,
++ size_hints.y,
++ size_hints.width,
++ size_hints.height,
++ 0,
++ pVisual->depth,
++ InputOutput,
++ visual,
++ attrMask,
++ &attr);
++ XUnlockDisplay(zm_display);
++ XFree(pVisual);
++
++ //Tell the WM about this window.
++#if 0
++ XSetStandardProperties( zm_display,
++ window,
++ "CHXExSite",
++ "CHXExSite",
++ None,
++ NULL, 0,
++ &size_hints
++ );
++#endif
++
++ //Select all input events on the window since the other platforms
++ //we work with have no concept of event masks
++ XLockDisplay(zm_display);
++#if 0
++ int result = XSelectInput( zm_display, window,
++ ButtonPressMask | ButtonReleaseMask | KeyPressMask |
++ KeyReleaseMask | EnterWindowMask | LeaveWindowMask |
++ PointerMotionMask | ButtonMotionMask | KeymapStateMask |
++ ExposureMask | StructureNotifyMask | FocusChangeMask
++ );
++#else
++ int result = XSelectInput( zm_display, window, 0 );
++
++
++#endif
++ XUnlockDisplay(zm_display);
++ if( BadWindow == result )
++ {
++#ifdef _DEBUG
++ fprintf( stderr, "Can select events.\n" );
++#endif
++ }
++
++ //Map the window.
++ XLockDisplay(zm_display);
++ /* XMapWindow(zm_display, window); */
++
++ //Flush event queue.
++ XFlush(zm_display);
++ XUnlockDisplay(zm_display);
++
++
++ return window;
++}
++
++void CHXExSite::_MapHorzScroll()
++{
++#if 0
++ if( GetWindow() && GetWindow()->display && m_ScrollHorizButtonL)
++ {
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ XMapWindow( pDis, m_ScrollHorizButtonL );
++ XMapWindow( pDis, m_ScrollHorizButtonR );
++ XUnlockDisplay(pDis);
++ }
++ _DrawArrows();
++#endif
++}
++
++void CHXExSite::_MapVertScroll()
++{
++#if 0
++ if( GetWindow() && GetWindow()->display && m_ScrollVertButtonT)
++ {
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ XMapWindow( pDis, m_ScrollVertButtonT );
++ XMapWindow( pDis, m_ScrollVertButtonB );
++ XUnlockDisplay(pDis);
++ }
++ _DrawArrows();
++#endif
++}
++
++void CHXExSite::_MapScrollButtons()
++{
++#if 0
++ _MapHorzScroll();
++ _MapVertScroll();
++#endif
++}
++
++void CHXExSite::_UnmapHorzScroll()
++{
++#if 0
++ HX_ASSERT( GetWindow() );
++ if( m_ScrollHorizButtonL && GetWindow()->display )
++ {
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ XUnmapWindow( pDis, m_ScrollHorizButtonL );
++ XUnmapWindow( pDis, m_ScrollHorizButtonR );
++ XUnlockDisplay(pDis);
++ }
++#endif
++}
++void CHXExSite::_UnmapVertScroll()
++{
++#if 0
++ HX_ASSERT( GetWindow() );
++ if( m_ScrollVertButtonT && GetWindow()->display )
++ {
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ XUnmapWindow( pDis, m_ScrollVertButtonT );
++ XUnmapWindow( pDis, m_ScrollVertButtonB );
++ XUnlockDisplay(pDis);
++ }
++#endif
++}
++
++void CHXExSite::_UnmapScrollButtons()
++{
++#if 0
++ if( GetWindow() )
++ {
++ _UnmapVertScroll();
++ _UnmapHorzScroll();
++ }
++#endif
++}
++
++void CHXExSite::_DestroyScrollButtons()
++{
++ HXxWindow* pWin = GetWindow();
++ Display* pDis = (Display*)(pWin?pWin->display:NULL);
++
++ if( m_ScrollHorizButtonL && pDis )
++ {
++ XLockDisplay(pDis);
++ XDestroyWindow( pDis, m_ScrollHorizButtonL );
++ m_ScrollHorizButtonL = 0;
++ XDestroyWindow( pDis, m_ScrollHorizButtonR );
++ XUnlockDisplay(pDis);
++ m_ScrollHorizButtonR = 0;
++ }
++
++ if( m_ScrollVertButtonT && pDis)
++ {
++ XLockDisplay(pDis);
++ XDestroyWindow( pDis, m_ScrollVertButtonT );
++ m_ScrollVertButtonT = 0;
++ XDestroyWindow( pDis, m_ScrollVertButtonB );
++ XUnlockDisplay(pDis);
++ m_ScrollVertButtonB = 0;
++ }
++ m_ptScrollVertPosT.x = m_ptScrollVertPosT.y = 0;
++ m_ptScrollVertPosB.x = m_ptScrollVertPosB.y = 0;
++ m_ptScrollHorizPosR.x = m_ptScrollHorizPosR.y = 0;
++ m_ptScrollHorizPosL.x = m_ptScrollHorizPosL.y = 0;
++}
++
++void CHXExSite::_DrawArrows()
++{
++#if 0 //Paul Debug
++ //only do the work if our site is visible.
++ if( !IsSiteVisible() )
++ return;
++
++ //Draw an arrow on this window.
++ XPoint points[4];
++ int offset = SCROLL_BAR_WIDTH/10;
++ GC tmpGC;
++ XGCValues values;
++ Display* dis = (Display*)GetWindow()->display;
++
++ if( m_ScrollVertButtonB )
++ {
++ XLockDisplay(dis);
++ tmpGC = XCreateGC( dis, m_ScrollVertButtonB, 0, &values );
++ XUnlockDisplay(dis);
++ }
++ else if( m_ScrollHorizButtonL )
++ {
++ XLockDisplay(dis);
++ tmpGC = XCreateGC( dis, m_ScrollHorizButtonL, 0, &values );
++ XUnlockDisplay(dis);
++ }
++ else
++ {
++ //We don't have any scroll bars to draw....
++ return;
++ }
++
++
++ XLockDisplay(dis);
++ XSetForeground( dis, tmpGC, WhitePixel(dis, 0 ));
++ XSetBackground( dis, tmpGC, BlackPixel(dis, 0 ));
++ XUnlockDisplay(dis);
++ Colormap cmap = HXGetXColormap((Display*)GetWindow()->display,
++ (Window)GetWindow()->window);
++ XColor color;
++
++ memset(&color, 0, sizeof(XColor));
++ XLockDisplay(dis);
++ XParseColor(dis, cmap, "blue", &color);
++ XUnlockDisplay(dis);
++ HXFindBestXColor(dis, cmap, &color);
++ XLockDisplay(dis);
++ XSetForeground( dis, tmpGC, color.pixel);
++ XSetLineAttributes(dis, tmpGC, 1, LineSolid, CapRound, JoinRound );
++ XUnlockDisplay(dis);
++
++
++ //Draw up Vertical arrow.
++ if( m_ScrollVertButtonT )
++ {
++ points[0].x = offset;
++ points[0].y = SCROLL_BAR_WIDTH-offset;
++ points[1].x = SCROLL_BAR_WIDTH/2;
++ points[1].y = offset;
++ points[2].x = SCROLL_BAR_WIDTH-offset;
++ points[2].y = SCROLL_BAR_WIDTH-offset;
++ points[3].x = points[0].x;
++ points[3].y = points[0].y;
++ XLockDisplay(dis);
++ XFillPolygon( dis, m_ScrollVertButtonT, tmpGC, points, 4, Convex, CoordModeOrigin);
++ XUnlockDisplay(dis);
++ }
++
++ //Draw down Vertical arrow.
++ if( m_ScrollVertButtonB )
++ {
++ points[0].x = offset;
++ points[0].y = offset;
++ points[1].x = SCROLL_BAR_WIDTH-offset;
++ points[1].y = offset;
++ points[2].x = SCROLL_BAR_WIDTH/2;
++ points[2].y = SCROLL_BAR_WIDTH-offset;
++ points[3].x = points[0].x;
++ points[3].y = points[0].y;
++ XLockDisplay(dis);
++ XFillPolygon( dis, m_ScrollVertButtonB, tmpGC, points, 4, Convex, CoordModeOrigin);
++ XUnlockDisplay(dis);
++ }
++
++ //Draw Left Horizontal arrow.
++ if( m_ScrollHorizButtonL )
++ {
++ points[0].x = SCROLL_BAR_WIDTH-offset;
++ points[0].y = offset;
++ points[1].x = SCROLL_BAR_WIDTH-offset;
++ points[1].y = SCROLL_BAR_WIDTH-offset;
++ points[2].x = offset;
++ points[2].y = SCROLL_BAR_WIDTH/2;
++ points[3].x = points[0].x;
++ points[3].y = points[0].y;
++ XLockDisplay(dis);
++ XFillPolygon( dis, m_ScrollHorizButtonL, tmpGC, points, 4, Convex, CoordModeOrigin);
++ XUnlockDisplay(dis);
++ }
++
++ //Draw Right Horizontal arrow.
++ if( m_ScrollHorizButtonR )
++ {
++ points[0].x = offset;
++ points[0].y = SCROLL_BAR_WIDTH-offset;
++ points[1].x = offset;
++ points[1].y = offset;
++ points[2].x = SCROLL_BAR_WIDTH-offset;
++ points[2].y = SCROLL_BAR_WIDTH/2;
++ points[3].x = points[0].x;
++ points[3].y = points[0].y;
++ XLockDisplay(dis);
++ XFillPolygon( dis, m_ScrollHorizButtonR, tmpGC, points, 4, Convex, CoordModeOrigin);
++ XUnlockDisplay(dis);
++ }
++
++ //Free the GC and go.
++ XLockDisplay(dis);
++ XFreeGC( dis, tmpGC );
++ XUnlockDisplay(dis);
++#endif
++}
++
++HXBOOL CHXExSite::_InButton( HXxPoint& pt, int x, int y )
++{
++ HXBOOL retVal =FALSE;
++ if( x>= pt.x && x< pt.x+SCROLL_BAR_WIDTH && y>=pt.y && y<pt.y+SCROLL_BAR_WIDTH )
++ retVal=TRUE;
++ else
++ retVal=FALSE;
++
++ return retVal;
++}
++
++void CHXExSite::_CreateHorizScrollBar()
++{
++ HX_ASSERT( m_ScrollHorizButtonL == 0 );
++ HX_ASSERT( m_ScrollHorizButtonR == 0 );
++
++ HXxSize mySize;
++
++ HXxWindow* pParentWindow = NULL;
++ if(GetParentSite())
++ {
++ pParentWindow = GetParentSite()->GetWindow();
++ }
++ if(pParentWindow)
++ {
++ GetParentSite()->GetSize(mySize);
++ }
++
++ HX_ASSERT( pParentWindow );
++ HX_ASSERT( pParentWindow->window != 0 );
++
++ if( m_ScrollVertButtonB )
++ {
++ // if the other bar already exists, don't overlap it!
++ mySize.cx -= SCROLL_BAR_WIDTH;
++ }
++
++ m_ptScrollHorizPosL.x = m_topleft.x;
++ m_ptScrollHorizPosL.y = m_topleft.y+mySize.cy-SCROLL_BAR_WIDTH;
++
++#ifndef _ARROWS_SIDE_BY_SIDE
++ m_ptScrollHorizPosR.x = m_topleft.x+mySize.cx-SCROLL_BAR_WIDTH;
++#else
++ m_ptScrollHorizPosR.x = m_topleft.x+SCROLL_BAR_WIDTH;
++#endif
++ m_ptScrollHorizPosR.y = m_topleft.y+mySize.cy-SCROLL_BAR_WIDTH;
++
++ Display* dis = (Display*)GetWindow()->display;
++ XLockDisplay(dis);
++ Pixel blackPixel = BlackPixel( dis, DefaultScreen(dis) );
++ XUnlockDisplay(dis);
++ Pixel greyPixel = blackPixel;
++
++ Colormap cmap = HXGetXColormap(dis, (Window)GetWindow()->window);
++ XColor color;
++
++ XLockDisplay(dis);
++ XParseColor(dis, cmap, "gray", &color);
++ XUnlockDisplay(dis);
++ HXFindBestXColor(dis, cmap, &color);
++ greyPixel = color.pixel;
++
++ XLockDisplay(dis);
++ m_ScrollHorizButtonL = XCreateSimpleWindow( dis,
++ (Window)pParentWindow->window,
++ m_ptScrollHorizPosL.x, m_ptScrollHorizPosL.y,
++ SCROLL_BAR_WIDTH, SCROLL_BAR_WIDTH,
++ 1,
++ blackPixel,
++ greyPixel
++ );
++ m_ScrollHorizButtonR = XCreateSimpleWindow( dis,
++ (Window)pParentWindow->window,
++ m_ptScrollHorizPosR.x, m_ptScrollHorizPosR.y,
++ SCROLL_BAR_WIDTH, SCROLL_BAR_WIDTH,
++ 1,
++ blackPixel,
++ greyPixel
++ );
++ XUnlockDisplay(dis);
++ HX_ASSERT( m_ScrollHorizButtonR && m_ScrollHorizButtonL );
++
++}
++
++void CHXExSite::_CreateVertScrollBar()
++{
++ HX_ASSERT( m_ScrollVertButtonB == 0 );
++ HX_ASSERT( m_ScrollVertButtonT == 0 );
++
++ HXxSize mySize;
++
++ HXxWindow* pParentWindow = NULL;
++ if(GetParentSite())
++ {
++ pParentWindow = GetParentSite()->GetWindow();
++ }
++ if(pParentWindow)
++ {
++ GetParentSite()->GetSize(mySize);
++ }
++
++ HX_ASSERT( pParentWindow );
++ HX_ASSERT( pParentWindow->window != 0 );
++
++ if( m_ScrollHorizButtonR )
++ {
++ // if the other bar already exists, don't overlap it!
++ mySize.cy -= SCROLL_BAR_WIDTH;
++ }
++
++
++ m_ptScrollVertPosT.x = m_topleft.x+mySize.cx-SCROLL_BAR_WIDTH;
++ m_ptScrollVertPosT.y = m_topleft.y;
++
++ m_ptScrollVertPosB.x = m_topleft.x+mySize.cx-SCROLL_BAR_WIDTH;
++#ifndef _ARROWS_SIDE_BY_SIDE
++ m_ptScrollVertPosB.y = m_topleft.y+mySize.cy-SCROLL_BAR_WIDTH;
++#else
++ m_ptScrollVertPosB.y = m_topleft.y+SCROLL_BAR_WIDTH;
++#endif
++
++ Display* dis = (Display*)GetWindow()->display;
++ XLockDisplay(dis);
++ Pixel blackPixel = BlackPixel( dis, DefaultScreen(dis) );
++ XUnlockDisplay(dis);
++ Pixel greyPixel = blackPixel;
++ Colormap cmap = HXGetXColormap((Display*)GetWindow()->display,
++ (Window)GetWindow()->window);
++ XColor color;
++ XLockDisplay(dis);
++ XParseColor(dis, cmap, "gray", &color);
++ XUnlockDisplay(dis);
++ HXFindBestXColor(dis, cmap, &color);
++ greyPixel = color.pixel;
++
++ HX_ASSERT( GetWindow() );
++ XLockDisplay(dis);
++ m_ScrollVertButtonT = XCreateSimpleWindow( dis,
++ (Window)pParentWindow->window,
++ m_ptScrollVertPosT.x, m_ptScrollVertPosT.y,
++ SCROLL_BAR_WIDTH, SCROLL_BAR_WIDTH,
++ 1,
++ blackPixel,
++ greyPixel
++ );
++ m_ScrollVertButtonB = XCreateSimpleWindow( dis,
++ (Window)pParentWindow->window,
++ m_ptScrollVertPosB.x, m_ptScrollVertPosB.y,
++ SCROLL_BAR_WIDTH, SCROLL_BAR_WIDTH,
++ 1,
++ blackPixel,
++ greyPixel
++ );
++ XUnlockDisplay(dis);
++
++ HX_ASSERT( m_ScrollVertButtonB && m_ScrollVertButtonT );
++
++}
++
++//
++// Inherited CHXBaseSite methods.
++//
++void CHXExSite::_NeedWindowedSite()
++{
++#ifdef _DEBUG
++ fprintf( stderr, "CHXExSite::_NeedWindowedSite do something here....\n" );
++#endif
++ //Nothing to do on unix....
++}
++
++void CHXExSite::_AttachWindow()
++{
++#if 1
++ void* pDummy=NULL;
++
++ if (m_pRootSurface)
++ { /* Replace CUnixRootSurf with my own CExRootSurf */
++ HX_RELEASE(m_pRootSurface);
++ m_pRootSurface = new CExRootSurf(m_pContext, this, m_on_new_frame_cb, m_context);
++ m_pRootSurface->AddRef();
++ }
++
++ if(!z_mapSiteToWindow.Lookup((void*)this, pDummy))
++ {
++ z_mapSiteToWindow.SetAt((void*)this, (void*)m_pWindow);
++ }
++
++ //Set the display variable.
++ if( m_pWindow->display == NULL )
++ {
++ HX_ASSERT(zm_display);
++ m_pWindow->display = zm_display;
++ }
++
++ //Now that we have a window be sure to init the CExRootSurf.
++ //this lets it set up the display, colormap, etc.
++ ((CExRootSurf*)m_pRootSurface)->Init();
++#endif
++}
++
++void CHXExSite::_DetachWindow()
++{
++#if 1
++ void* pDummy;
++
++ if (z_mapSiteToWindow.Lookup((void*)this, pDummy))
++ {
++ z_mapSiteToWindow.RemoveKey((void*)this);
++ }
++#endif
++}
++
++void* CHXExSite::_Create(void* pParentWindow, UINT32 style)
++{
++ HRESULT result = HXR_OK;
++ if( m_pWindow && m_pWindow->window )
++ {
++ HX_ASSERT( "We already have created a window"==NULL);
++ return NULL;
++ }
++
++ if (pParentWindow==NULL || style)
++ {
++ m_bIsChildWindow = FALSE;
++ }
++ else
++ {
++ m_bIsChildWindow = TRUE;
++ }
++
++ if( _OpenXDisplay(NULL) != HXR_OK )
++ {
++ return NULL;
++ }
++ return (void*)CreateXWindow((Window)pParentWindow);
++}
++
++
++void CHXExSite::_Destroy(HXxWindow* pWindow)
++{
++ _DestroySliders();
++ HXxWindow* pWin = GetWindow();
++ Display* pDis = (Display*)(pWin?pWin->display:NULL);
++ if( pDis )
++ {
++ XLockDisplay(pDis);
++ XDestroyWindow( pDis, (Window)pWindow->window );
++ XUnlockDisplay(pDis);
++ }
++}
++
++void CHXExSite::_SetSize(HXxSize size)
++{
++ HX_ASSERT( m_pWindow && m_pWindow->display && m_pWindow->window);
++ //The scroll bars get resized also...
++ _DestroySliders();
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ XResizeWindow(pDis,
++ (Window) m_pWindow->window,
++ size.cx,
++ size.cy);
++ XUnlockDisplay(pDis);
++}
++
++void CHXExSite::_SetPosition(HXxPoint position)
++{
++ HX_ASSERT( m_pWindow && m_pWindow->display && m_pWindow->window);
++ _DestroyScrollButtons();
++ XLockDisplay((Display*) m_pWindow->display);
++ XMoveWindow((Display*)m_pWindow->display,
++ (Window)m_pWindow->window,
++ position.x,
++ position.y);
++ XUnlockDisplay((Display*) m_pWindow->display);
++}
++
++void CHXExSite::_DamageRect(HXxRect rect)
++{
++ if(GetWindow())
++ {
++ m_bDamaged = TRUE;
++ }
++ return;
++}
++
++void CHXExSite::_DamageRegion(HXxRegion rect)
++{
++ if(GetWindow())
++ {
++ m_bDamaged = TRUE;
++ }
++ return;
++}
++
++void CHXExSite::_SendOSUpdateMessage()
++{
++ //We need to redraw our window here, m_pWindow.
++}
++
++void CHXExSite::_ShowSite(HXBOOL bShow)
++{
++ if( bShow )
++ {
++ _MapScrollButtons();
++ }
++ else
++ {
++ _UnmapScrollButtons();
++ }
++ //do nothing....
++}
++
++HXBOOL CHXExSite::_AtSystemTime()
++{
++ return TRUE;
++}
++
++void CHXExSite::_GetDeviceCaps( void* hdc,
++ UINT16& uBitsPerPixel,
++ UINT16& uHorzRes,
++ UINT16& uVertRes )
++{
++ Screen* pScreen = NULL;
++ HXxWindow* pWin = GetWindow();
++ HX_ASSERT( pWin );
++ if( pWin )
++ {
++ Display* dis = (Display*)pWin->display;
++ HX_ASSERT( dis );
++ if( dis )
++ {
++ Display* pDisp = (Display*)GetWindow()->display;
++ XLockDisplay(pDisp);
++ pScreen = DefaultScreenOfDisplay(pDisp);
++ XUnlockDisplay(pDisp);
++
++ uBitsPerPixel = pScreen->root_depth;
++ uHorzRes = pScreen->width;
++ uVertRes = pScreen->height;
++ }
++ }
++}
++
++void CHXExSite::_GetWindowRect(HXxRect* destRect)
++{
++ HX_ASSERT( "Doesn't seem to be used anywhere"==NULL );
++}
++
++void CHXExSite::_DestroySliders()
++{
++ _DestroyScrollButtons();
++}
++
++void CHXExSite::_ForwardUpdateEvent(HXxEvent* pEvent)
++{
++ GC gc = NULL;
++ AddRef();
++
++ HX_ASSERT(GetWindow()->window);
++ HX_ASSERT(m_pUser);
++ if(m_bIsChildWindow)
++ {
++ //Create a clip region that excludes our higher z-order
++ //siblings and is clipped to our parent.
++ if( !m_bRegionIsValid )
++ {
++ RecomputeClip();
++ }
++
++ // The problem is that regions are locked to the origin so we
++ // will need to reverse shift the region before we set the
++ // origin of the graph port! get the GC from the video surface
++ gc = ((CExRootSurf*)m_pRootSurface)->GetGC();
++ HX_ASSERT( gc );
++
++ //Actually setup our clip region
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ XSetRegion( pDis, gc, (Region) m_Region );
++ XUnlockDisplay(pDis);
++ }
++
++ XEvent* pXEvent = (XEvent*) pEvent->param2;
++ XExposeEvent* exposeEvent = (XExposeEvent*) pXEvent;
++
++ // get the rect for this site with respect to our parent
++ HXRECTANGLE exposedRect = { exposeEvent->x,
++ exposeEvent->y,
++ exposeEvent->width,
++ exposeEvent->height };
++ HXREGION* exposedRegion = HXCreateRegion();
++ HXUnionRectWithRegion(&exposedRect, exposedRegion, exposedRegion);
++
++ // does the site intersect the current clipping region?
++ HXREGION* resultRegion = HXCreateRegion();
++ HXIntersectRegion(exposedRegion, m_Region, resultRegion);
++ HXBOOL bSiteIntersectsExposed = (HXEmptyRegion(resultRegion)==FALSE);
++
++ HXDestroyRegion(resultRegion);
++ HXDestroyRegion(exposedRegion);
++
++ // if the exposed region intersects the sites clipping region
++ if(bSiteIntersectsExposed)
++ {
++ m_pUser->HandleEvent(pEvent);
++ }
++
++ //If the user doesn't handle the standard update event then send
++ //them the cross platform HX_SURFACE_UPDATE event don't damage the
++ //original event structure
++ if(!pEvent->handled && m_pUser )
++ {
++ HX_ASSERT(GetWindow());
++ HXxEvent event;
++ event.event = HX_SURFACE_UPDATE;
++ event.window = GetWindow()->window;
++ event.param1 = m_pVideoSurface;
++ event.param2 = GetWindow();
++ event.result = 0;
++ event.handled = FALSE;
++ m_pUser->HandleEvent(&event);
++ pEvent->handled = event.handled;
++ }
++
++
++ //reset the gc to use no region
++ if(m_bIsChildWindow && gc)
++ {
++ Display* pDisp = (Display*)GetWindow()->display;
++ XLockDisplay(pDisp);
++ XSetClipMask(pDisp, gc, None);
++ XUnlockDisplay(pDisp);
++ }
++
++ //Handle the drawing of our arrows...
++ _DrawArrows();
++
++ //Now do all our children....
++ CHXMapPtrToPtr::Iterator i = m_ChildrenMap.Begin();
++ for(;i!=m_ChildrenMap.End();++i)
++ {
++ CHXExSite* pSite = (CHXExSite*) *i;
++ pSite->_ForwardUpdateEvent(pEvent);
++ }
++
++ Release();
++}
++
++UINT32 CHXExSite::_MapKeySymToHXVK(KeySym sym, UINT32& uFlags )
++{
++ //XXXgfw if we add the extended flag in the HX_KEYBOARD event
++ //structure then we can modify the flags here to show that these
++ //keys are 'extended' in the windows sense.
++ UINT32 ulRet = 0;
++ switch( sym )
++ {
++ case XK_Shift_R:
++ ulRet = XK_Shift_L;
++ break;
++ case XK_Alt_R:
++ ulRet = XK_Alt_L;
++ break;
++ case XK_KP_Home:
++ ulRet = XK_Home;
++ break;
++ case XK_KP_Next:
++ ulRet = XK_Next;
++ break;
++ case XK_KP_Prior:
++ ulRet = XK_Prior;
++ break;
++ case XK_KP_Enter:
++ ulRet = XK_Return;
++ break;
++ case XK_KP_End:
++ ulRet = XK_End;
++ break;
++ case XK_KP_Begin:
++ ulRet = XK_Begin;
++ break;
++ case XK_KP_Left:
++ ulRet = XK_Left;
++ break;
++ case XK_KP_Up:
++ ulRet = XK_Up;
++ break;
++ case XK_Control_R:
++ ulRet = XK_Control_L;
++ break;
++ case XK_KP_Right:
++ ulRet = XK_Right;
++ break;
++ case XK_KP_Down:
++ ulRet = XK_Down;
++ break;
++ case XK_KP_Insert:
++ ulRet = XK_Insert;
++ break;
++ case XK_KP_Delete:
++ ulRet = XK_Delete;
++ break;
++ default:
++ ulRet = sym;
++ break;
++ }
++ if( ulRet != sym )
++ {
++ //We have mapped a key from Right hand side, keypad, arrows
++ //or other parts of an extended keyboard. Set the flag.
++ uFlags |= HX_EXTENDED_KEY_MASK;
++ }
++ return ulRet;
++}
++
++
++HXBOOL CHXExSite::_ConvertToHXEvent(HXxEvent* pEvent )
++{
++ // get original events info from pEvent
++ XEvent* pXEvent = (XEvent*) pEvent->param2;
++ XButtonEvent* buttonEvent = (XButtonEvent*) pXEvent;
++
++
++ //===============================================================
++ // Convert all other event to RMA generic events and pass back.
++ //===============================================================
++ if( ((pEvent->event == ButtonPress) ||
++ (pEvent->event == ButtonRelease) ||
++ (pEvent->event == MotionNotify ) ||
++ (pEvent->event == EnterNotify) ||
++ (pEvent->event == FocusIn) ||
++ (pEvent->event == FocusOut) ||
++ (pEvent->event == KeyPress) ||
++ (pEvent->event == KeyRelease) ||
++ (pEvent->event == LeaveNotify))
++ )
++ {
++ // set modifier flags for all events....
++ UINT32 flags = 0;
++
++ // create new HXxEvent
++ HXxEvent theEvent;
++
++ //XXXgfw ouch....
++ static HXxPoint realPt = {0,0};
++
++ //Init certain members.
++ memset(&theEvent, 0, sizeof(HXxEvent));
++ theEvent.window = pEvent->window;
++ theEvent.handled = FALSE;
++
++ //
++ // NOTE:
++ //
++ // theEvent must be filled in by *ALL* event types.
++ // theEvent will be memcopied into the pEvent passed
++ // back to the basesite at the end of the method.
++ //
++
++ //==================================================
++ // LEAVE NOTIFY EVENT
++ //==================================================
++ if( pEvent->event==LeaveNotify)
++ {
++ if( m_pTopLevelSite->m_pMouseInSite )
++ {
++ HXxPoint oobPoint;
++ oobPoint.x = -1;
++ oobPoint.y = -1;
++ HXxEvent Outevent = { HX_MOUSE_LEAVE,
++ m_pWindow->window,
++ (void*)&oobPoint,
++ 0, 0,
++ FALSE };
++ m_pTopLevelSite->m_pMouseInSite->EventOccurred(&Outevent);
++ m_pTopLevelSite->m_pMouseInSite = NULL;
++ }
++ pEvent->handled=TRUE;
++ return TRUE;
++ }
++
++ //==================================================
++ // ENTER NOTIFY EVENT
++ //==================================================
++ if( pEvent->event==EnterNotify)
++ {
++ pEvent->handled=TRUE;
++ return TRUE;
++ }
++
++ //==================================================
++ // KEY PRESS/RELEASE EVENT
++ //==================================================
++ if ( pEvent->event == KeyPress || pEvent->event==KeyRelease )
++ {
++ XKeyEvent* pKeyEvent = (XKeyEvent*)pEvent->param2;
++
++ //
++ //Set the event type
++ //
++ theEvent.event = pEvent->event==KeyPress?HX_KEY_DOWN:HX_KEY_UP;
++
++ //
++ // Fill in the scan/key code.
++ //
++ flags = pKeyEvent->keycode;
++ flags &= 0x000000ff; //the scan code only gets bits 0-7
++
++ //
++ // build key modifier list...
++ //
++ if( pKeyEvent->state & ShiftMask )
++ flags |= HX_SHIFT_MASK;
++
++ if( pKeyEvent->state & ControlMask )
++ flags |= HX_CTRL_MASK;
++
++ if( pKeyEvent->state & LockMask )
++ flags |= HX_CAPS_LOCK_MASK;
++
++ if( pKeyEvent->state & Mod1Mask)
++ flags |= HX_ALT_MASK;
++
++ if( pKeyEvent->state & Mod2Mask)
++ flags |= HX_NUM_LOCK_MASK;
++
++ if( pKeyEvent->state & Mod5Mask)
++ flags |= HX_SCROLL_LOCK_MASK;
++
++ //
++ //Store the char pressed.
++ //
++ KeySym sym;
++ char szBuf[10]; /* Flawfinder: ignore */
++ int nNum;
++
++ //Save the state of the keys...
++ unsigned int unSave = pKeyEvent->state;
++ pKeyEvent->state=0;
++
++ //Lookup the key without any state.
++ nNum = XLookupString( pKeyEvent, szBuf, 10, &sym, NULL );
++ if( nNum > 0 )
++ {
++ theEvent.param1 = (void*)*szBuf;
++ }
++ else
++ {
++ theEvent.param1 = (void*)_MapKeySymToHXVK(sym, flags);
++ flags |= HX_VIRTUAL_KEY_MASK;
++ }
++ //restore the state of the event
++ pKeyEvent->state = unSave;
++
++ //Set the flags...
++ theEvent.param2 = (void*)flags;
++
++ //Check for HX_CHAR needed or not.
++ if( theEvent.event == HX_KEY_DOWN )
++ {
++ //We have to send an extra HX_CHAR event
++ HXxEvent extraEvent;
++ memcpy( &extraEvent, &theEvent, sizeof( extraEvent ) ); /* Flawfinder: ignore */
++
++ //Change the type.
++ extraEvent.event = HX_CHAR;
++
++ //
++ //Change the keycode to an translated ascii char.
++ //
++ KeySym sym;
++ char szBuf[10]; /* Flawfinder: ignore */
++ int nNum;
++
++ nNum = XLookupString( pKeyEvent, szBuf, 10, &sym, NULL );
++
++ if( nNum > 0 )
++ {
++ extraEvent.param1 = (void*)*szBuf;
++ }
++ else
++ {
++ extraEvent.param1 = (void*)_MapKeySymToHXVK(sym, flags);
++ flags |= HX_VIRTUAL_KEY_MASK;
++ }
++ extraEvent.param2 = (void*)flags;
++
++ //
++ // Now send the extra event....
++ //
++ CHXBaseSite::EventOccurred(&extraEvent);
++ }
++ }
++
++ //==================================================
++ // FOCUS OUT EVENT
++ //==================================================
++ if ( pEvent->event == FocusOut )
++ {
++ theEvent.event = HX_LOSE_FOCUS;
++ }
++
++ if ( pEvent->event == FocusIn )
++ {
++ theEvent.event = HX_SET_FOCUS;
++ }
++
++ //==================================================
++ // MOUSE MOVE EVENT
++ //==================================================
++ if( pEvent->event == MotionNotify )
++ {
++ XMotionEvent* pp = (XMotionEvent*)pEvent->param2;
++ theEvent.event = HX_MOUSE_MOVE;
++
++ if( pp->state&Button1Mask )
++ flags |= HX_PRIMARY_BUTTON;
++
++ if( pp->state&Button2Mask )
++ flags |= HX_CONTEXT_BUTTON;
++
++ if( pp->state&Button3Mask )
++ flags |= HX_THIRD_BUTTON;
++
++ if(pp->state & ShiftMask)
++ flags |= HX_SHIFT_KEY;
++
++ if(pp->state & ControlMask)
++ flags |= HX_CTRL_KEY;
++
++ if(pp->state & Mod1Mask)
++ flags |= HX_ALT_COMMAND_KEY;
++
++ theEvent.param2 = (void*) flags;
++
++ //Grab the X and Y.
++ theEvent.param1 = (void*) &realPt;
++ realPt.x = pp->x;
++ realPt.y = pp->y;
++ }
++
++ //==================================================
++ // BUTTON PRESS/RELEASE EVENT
++ //==================================================
++ if((pEvent->event == ButtonPress) || (pEvent->event == ButtonRelease))
++ {
++ // remap event
++ if (pEvent->event == ButtonPress)
++ {
++ if (buttonEvent->button == Button3)
++ theEvent.event = HX_CONTEXT_BUTTON_DOWN;
++ else
++ theEvent.event = HX_PRIMARY_BUTTON_DOWN;
++ }
++ else if (pEvent->event == ButtonRelease)
++ {
++ if (buttonEvent->button == Button3)
++ theEvent.event = HX_CONTEXT_BUTTON_UP;
++ else
++ theEvent.event = HX_PRIMARY_BUTTON_UP;
++ }
++
++ if(buttonEvent->state & ShiftMask)
++ flags |= HX_SHIFT_KEY;
++
++ if(buttonEvent->state & ControlMask)
++ flags |= HX_CTRL_KEY;
++
++ theEvent.param2 = (void*) flags;
++
++ //Grab the X and Y.
++ theEvent.param1 = (void*) &realPt;
++ realPt.x = buttonEvent->x;
++ realPt.y = buttonEvent->y;
++ }
++
++ //Copy the new event back into the passed in one for
++ //all events that fall through here...
++ memcpy( pEvent, &theEvent, sizeof(HXxEvent) ); /* Flawfinder: ignore */
++
++#if defined(_DEBUG)
++ //If the users presses control-primary button
++ //dump info on all sites. If shift-context, then
++ //just this site.
++ if( (buttonEvent->state&ControlMask)&&
++ (theEvent.event==HX_PRIMARY_BUTTON_DOWN))
++ {
++ DisplayAllSiteData();
++ }
++ if( (buttonEvent->state&ShiftMask)&&
++ (theEvent.event==HX_PRIMARY_BUTTON_DOWN))
++ {
++ DisplaySiteData("");
++ }
++#endif
++ }
++ return pEvent->handled;
++}
++
++
++void CHXExSite::CheckColorSettings()
++{
++#if !defined(HELIX_FEATURE_HARDWARE_COLOR_CONTROLS)
++ CHXBaseSite::CheckColorSettings();
++#else
++ CUnixSurf* pSurf = (CUnixSurf*)m_pVideoSurface;
++ if( !pSurf->HasHWColorConrols() )
++ {
++ CHXBaseSite::CheckColorSettings();
++ }
++ else
++ {
++ pSurf->SetHWColorControls();
++
++ //We do all color stuff except sharpmess in hardware.
++ float fCurrentSharpness;
++ INT16 bInterpolate;
++ zm_pColorAcc->GetSharpnessAdjustments(&fCurrentSharpness, &bInterpolate);
++
++ if (fCurrentSharpness != m_fSharpness)
++ {
++ zm_pColorAcc->SetSharpnessAdjustments(m_fSharpness, FALSE);
++ }
++ }
++#endif
++}
++
++//
++// OK, here it is. Take care of any OS specific duties, like scrollbar
++// stuff and expose events. Then, if the event isn't handled, convert
++// to an RMA event and return.
++HXBOOL CHXExSite::_HandleOSEvents(HXxEvent* pEvent)
++{
++ HXxPoint position = {0, 0};
++ HXxPoint point;
++
++ if( NULL==pEvent )
++ {
++ return FALSE;
++ }
++
++ return TRUE;
++
++#if defined(_DEBUG) && 0
++// fprintf( stderr, "this: %p m_pUser: %p ", this, m_pUser );
++ switch( pEvent->event )
++ {
++ case HX_MOUSE_LEAVE:
++ fprintf( stderr, "HX_MOUSE_LEAVE\n" );
++ break;
++// case HX_MOUSE_MOVE:
++// point.x = ((HXxPoint*)pEvent->param1)->x;
++// point.y = ((HXxPoint*)pEvent->param1)->y;
++// fprintf( stderr, "HX_MOUSE_MOVE: %d %d\n", point.x, point.y );
++// break;
++ case HX_MOUSE_ENTER:
++ fprintf( stderr, "HX_MOUSE_ENTER\n" );
++ break;
++// case MotionNotify:
++// point.x = ((XMotionEvent*)pEvent->param2)->x;
++// point.y = ((XMotionEvent*)pEvent->param2)->y;
++// fprintf( stderr, "MotionNotify: %d %d\n", point.x, point.y );
++// break;
++ case Expose:
++ fprintf( stderr, "Expose\n" );
++ break;
++ case EnterNotify :
++ fprintf( stderr, "EnterNotify\n" );
++ break;
++ case LeaveNotify:
++ fprintf( stderr, "LeaveNotify\n" );
++ break;
++ case KeyPress:
++ fprintf( stderr, "this: %p m_pUser: %p ", this, m_pUser );
++ fprintf( stderr, "Keypress\n\n" );
++ break;
++ case KeyRelease:
++ fprintf( stderr, "this: %p m_pUser: %p ", this, m_pUser );
++ fprintf( stderr, "KeyRelease\n" );
++ break;
++ default:
++ fprintf( stderr, "Other\n" );
++ break;
++ }
++#endif
++
++ //Find the ConfigureNotify events so we can drop to RGB from
++ //overlay while we move....
++// if( pEvent->event == ConfigureNotify && this==m_pTopLevelSite )
++// {
++// XConfigureEvent* pev = (XConfigureEvent*)pEvent->param2;
++// if( m_pWindow && pev->window == (Window)m_pWindow->window )
++// {
++// HXxPoint p;
++// _GetPositionRelativeToActualWindow( p );
++// // fprintf( stderr, "wint %p -- x,y width, height: %d %d %d %d \n",
++// // pev->window,
++// // pev->x, pev->y, pev->width, pev->height);
++// // fprintf( stderr, "size of site: %d %d\n", m_size.cx, m_size.cy);
++// // fprintf( stderr, "pos of site: %d %d\n", m_topleft.x, m_topleft.y);
++// m_pTopLevelSite->m_pMutex->Lock();
++// m_pTopLevelSite->SiteMoving(0, 0);
++// m_pTopLevelSite->m_nLastMoveTime = HX_GET_TICKCOUNT();
++// m_pTopLevelSite->ScheduleCallback(MOUSE, 100);
++// m_pTopLevelSite->m_pMutex->Unlock();
++// }
++// }
++
++ //See if we should drop out of full screen
++ if( pEvent->event == FocusOut && IsFullScreen() && !m_bIgnoreFocusOutInFS )
++ {
++// fprintf( stderr, "_HandleOSEvents: focus out: " );
++// XEvent* pXEvent = (XEvent*) pEvent->param2;
++// XFocusChangeEvent* event = (XFocusChangeEvent*) pXEvent;
++// switch( event->mode )
++// {
++// case NotifyAncestor:
++// fprintf( stderr, "NotifyAncestor\n" );
++// break;
++// case NotifyVirtual:
++// fprintf( stderr, "NotifyVirtual\n" );
++// break;
++// case NotifyInferior:
++// fprintf( stderr, "NotifyInferior\n" );
++// break;
++// case NotifyNonlinear:
++// fprintf( stderr, "NotifyNonlinear\n" );
++// break;
++// case NotifyNonlinearVirtual:
++// fprintf( stderr, "NotifyNonlinearVirtual\n" );
++// break;
++// case NotifyPointer:
++// fprintf( stderr, "NotifyPointer\n" );
++// break;
++// case NotifyPointerRoot:
++// fprintf( stderr, "NotifyPointerRoot\n" );
++// break;
++// case NotifyDetailNone:
++// fprintf( stderr, "NotifyDetailNone\n" );
++// break;
++// default:
++// fprintf( stderr, "screwed.....\n" );
++// }
++ ExitFullScreen();
++ }
++
++
++#if defined(_DEBUG) && defined(TEST_FULL_SCREEN)
++ if( pEvent->event == KeyPress )
++ {
++ KeySym sym;
++ char szBuf[10]; /* Flawfinder: ignore */
++ int nNum;
++
++ //Lookup the key without any state.
++ nNum = XLookupString( (XKeyEvent*)(pEvent->param2), szBuf, 10, &sym, NULL );
++ if( nNum > 0 )
++ {
++ if( 'f' == szBuf[0] && IsFullScreen() )
++ {
++ //Exit full screen if 'f' is pressed.....
++ m_pTopLevelSite->ExitFullScreen();
++ }
++ else if( 'f' == szBuf[0] && !IsFullScreen() )
++ {
++ //Enter full screen if 'f' is pressed.....
++ m_pTopLevelSite->EnterFullScreen();
++ }
++
++ }
++
++ }
++#endif
++
++#if defined(_DEBUG) && defined(_TEST_COLOR_CONTROLS)
++ if( pEvent->event == KeyPress )
++ {
++ KeySym sym;
++ char szBuf[10]; /* Flawfinder: ignore */
++ int nNum;
++
++ //Lookup the key without any state.
++ nNum = XLookupString( (XKeyEvent*)(pEvent->param2), szBuf, 10, &sym, NULL );
++ if( nNum > 0 )
++ {
++ if( 'b' == szBuf[0] )
++ {
++ SetBrightness( GetBrightness()-.05);
++ }
++ if( 'B' == szBuf[0] )
++ {
++ SetBrightness( GetBrightness()+.05);
++ }
++
++ if( 'c' == szBuf[0] )
++ {
++ SetContrast( GetContrast()-.05);
++ }
++ if( 'C' == szBuf[0] )
++ {
++ SetContrast( GetContrast()+.05);
++ }
++
++ if( 'h' == szBuf[0] )
++ {
++ SetHue( GetHue()-.05);
++ }
++ if( 'H' == szBuf[0] )
++ {
++ SetHue( GetHue()+.05 );
++ }
++
++ if( 's' == szBuf[0] )
++ {
++ SetSaturation( GetSaturation()-.05);
++ }
++ if( 'S' == szBuf[0] )
++ {
++ SetSaturation( GetSaturation()+.05);
++ }
++ fprintf( stderr, "colors %f %f %f %f\n",
++ GetBrightness(),
++ GetContrast(),
++ GetSaturation(),
++ GetHue());
++ }
++
++ }
++#endif
++
++ //Exit full screen on ESC pressed......
++ if( pEvent->event == KeyPress )
++ {
++ KeySym sym;
++ char szBuf[10]; /* Flawfinder: ignore */
++ int nNum;
++
++ //Lookup the key without any state.
++ nNum = XLookupString( (XKeyEvent*)(pEvent->param2), szBuf, 10, &sym, NULL );
++ if( nNum > 0 )
++ {
++ if( 27 == (int)szBuf[0] && IsFullScreen() )
++ {
++ //Exit full screen if esc is pressed.....
++ m_pTopLevelSite->ExitFullScreen();
++ }
++ }
++ }
++
++ //Find out if this is an event we are interested in. Make sure we
++ //are visible, it isn't a button, expose or FocusIn event and also
++ //make sure it is headed for our window.
++ if (!_ShouldProcess(pEvent))
++ {
++ return FALSE;
++ }
++
++
++ if(m_pUser && GetWindow() && GetWindow()->window)
++ {
++ //Do not send an update event to a hidden site.
++ if( pEvent->event == Expose ||
++ pEvent->event == FocusIn ||
++ pEvent->event == HX_SURFACE_UPDATE )
++ {
++ if( (m_ScrollVertButtonT || m_ScrollHorizButtonR) && IsSiteVisible() )
++ {
++ _DrawArrows();
++ }
++ _ForwardUpdateEvent(pEvent);
++ return TRUE;
++ }
++ else
++ {
++ // get original events info from pEvent
++ XEvent* pXEvent = (XEvent*) pEvent->param2;
++ XButtonEvent* buttonEvent = (XButtonEvent*) pXEvent;
++
++
++ //XXXgfw all this code sucks! It really need to be written
++ //for just native events or RMA events. With the change to a
++ //common site it is all screwed up. I am leaving it for now
++ //so we can get on with transparancy but get back to it!
++
++ //If the user clicks MB1 on a scroll button, handle it here and
++ //don't pass it up or let the user handle the event.
++ //Hit detection here.
++
++ ////////////////////////////////////////////////////////
++ // BEGIN SCROLLING GARBAGE
++ ////////////////////////////////////////////////////////
++ if(
++ ((pEvent->event==ButtonPress || pEvent->event==ButtonRelease) &&
++ buttonEvent->button==Button1) &&
++ (m_ScrollHorizButtonL || m_ScrollVertButtonB )
++ )
++ {
++ int buttonX=0;
++ int buttonY=0;
++
++ if( pEvent->event==ButtonRelease )
++ {
++ if( m_bScrollingInProgress )
++ {
++ m_bScrollingInProgress = FALSE;
++ m_nScrollDir = 0;
++ return TRUE ;
++ }
++ }
++ else
++ {
++ buttonX = buttonEvent->x;
++ buttonY = buttonEvent->y;
++
++ HXBOOL bPointInSite = FALSE;
++ if( m_Region )
++ bPointInSite = HXPointInRegion(m_Region, buttonX, buttonY);
++
++ if( bPointInSite )
++ {
++ if( m_ScrollHorizButtonL )
++ {
++ if( _InButton( m_ptScrollHorizPosL, buttonX, buttonY ))
++ {
++ m_bScrollingInProgress = TRUE;
++ m_nScrollDir = 1;
++ }
++ if( _InButton( m_ptScrollHorizPosR, buttonX, buttonY ))
++ {
++ m_bScrollingInProgress = TRUE;
++ m_nScrollDir = 2;
++ }
++ }
++ if( m_ScrollVertButtonT )
++ {
++ if( _InButton( m_ptScrollVertPosT, buttonX, buttonY ))
++ {
++ m_bScrollingInProgress = TRUE;
++ m_nScrollDir = 3;
++ }
++ if( _InButton( m_ptScrollVertPosB, buttonX, buttonY ))
++ {
++ m_bScrollingInProgress = TRUE;
++ m_nScrollDir = 4;
++ }
++ }
++ }
++ }
++
++ if( (m_ScrollHorizButtonL||m_ScrollVertButtonT) && m_bScrollingInProgress)
++ {
++ int xx=0;
++ int yy=0;
++ HXxWindow* pParentWindow = GetParentSite()->GetWindow();
++ //Make it scroll 10% of the parent window each click.
++ HXxSize sizeTmp;
++ GetParentSite()->GetSize(sizeTmp);
++
++ //Set it to a percentage of the slider range.
++ int incX = sizeTmp.cx/10;
++ int incY = sizeTmp.cy/10;
++
++ HX_ASSERT( pParentWindow );
++
++ xx = m_XSliderPos;
++ yy = m_YSliderPos;
++
++ if( m_nScrollDir == 1 )
++ xx-=incX;
++ if( m_nScrollDir == 2 )
++ xx+=incX;
++ if( m_nScrollDir == 3 )
++ yy-=incY;
++ if( m_nScrollDir == 4 )
++ yy+=incY;
++
++ if( xx > m_size.cx-sizeTmp.cx )
++ xx = m_size.cx-sizeTmp.cx;
++ if( yy > m_size.cy-sizeTmp.cy)
++ yy = m_size.cy-sizeTmp.cy;
++
++ if( xx < 0 )
++ xx = 0;
++ if( yy < 0 )
++ yy = 0;
++
++ m_XSliderPos = xx;
++ m_YSliderPos = yy;
++
++ HXxRect rect;
++ DamageRect(rect);
++
++ InternalForceRedraw();
++ }
++ //Only throw away the event if it had something to do with
++ //scolling.
++ if( m_bScrollingInProgress )
++ {
++ m_bScrollingInProgress = FALSE;
++ m_nScrollDir = 0;
++ return TRUE;
++ }
++ }
++ ////////////////////////////////////////////////////////
++ // END SCROLLING GARBAGE
++ ////////////////////////////////////////////////////////
++ point.x = -1;
++ point.y = -1;
++
++ if( pEvent->event == MotionNotify)
++ {
++ point.x = ((XMotionEvent*)pXEvent)->x;
++ point.y = ((XMotionEvent*)pXEvent)->y;
++ }
++ else if( pEvent->event == ButtonPress )
++ {
++ point.x = ((XMotionEvent*)pXEvent)->x;
++ point.y = ((XMotionEvent*)pXEvent)->y;
++ }
++
++ //
++ //Give the user a chance at the native event.
++ //
++ if( m_RegionWithoutChildren && HXPointInRegion(m_RegionWithoutChildren, point.x, point.y ))
++ {
++ if( m_Region && HXPointInRegion(m_Region, point.x, point.y) )
++ {
++ if (m_pUser)
++ m_pUser->HandleEvent(pEvent);
++ }
++ else
++ {
++ INT32 handledCount = 0;
++ INT32 mapCount = 0;
++
++ //try send this to all of our children
++ _unixsitecpp1:
++ mapCount = m_ChildrenMap.GetCount();
++ CHXMapPtrToPtr::Iterator i;
++ for(i=m_ChildrenMap.Begin() ; i!=m_ChildrenMap.End() ; ++i)
++ {
++ CHXBaseSite* pSite = (CHXBaseSite*) *i;
++ pSite->_HandleOSEvents(pEvent);
++ if (pEvent->handled)
++ {
++ break;
++ }
++ handledCount+=pEvent->handled;
++ pEvent->handled=0;
++
++ if (m_ChildrenMap.GetCount() != mapCount)
++ {
++ goto _unixsitecpp1;
++ }
++ }
++ if (handledCount)
++ {
++ pEvent->handled = 1;
++ }
++ HX_ASSERT(handledCount<2);
++ }
++ }
++ pEvent->handled=FALSE;
++ }
++ }
++
++ return FALSE;
++}
++
++void CHXExSite::_GenerateOSEvent(HXxEvent* pEvent, HXxEvent* pEvent2)
++{
++ //XXXgfw Not needed on UNIX I guess???
++}
++
++void CHXExSite::_GenerateSetCursorEvent()
++{
++#ifdef _DEBUG
++ fprintf( stderr, "CHXExSite::_GenerateSetCursorEvent\n" );
++#endif
++ //XXXgfw do we need this??
++}
++
++void CHXExSite::_TryCreateXSlider()
++{
++#if 0
++ if( !m_ScrollHorizButtonL && IsSiteVisible() )
++ _CreateHorizScrollBar();
++#endif
++}
++
++void CHXExSite::_SetXSliderValues(INT32 range, INT32 pageSize)
++{
++ //XXXgfw this is a do nothing as long as we only have
++ //scroll buttons on unix and not real scroll bars.
++}
++
++void CHXExSite::_TryCreateYSlider()
++{
++#if 0
++ if( !m_ScrollVertButtonT && IsSiteVisible() )
++ _CreateVertScrollBar();
++#endif
++}
++
++void CHXExSite::_SetYSliderValues(INT32 range, INT32 pageSize)
++{
++ //XXXgfw this is a do nothing as long as we only have
++ //scroll buttons on unix and not real scroll bars.
++}
++
++void CHXExSite::_GetSystemSizeOfSliders(INT32* pWidth, INT32* pHeight)
++{
++#if 0
++ *pWidth = *pHeight = SCROLL_BAR_WIDTH;
++#endif
++}
++
++HXBOOL CHXExSite::_IsWindowVisible()
++{
++#if 0
++ HX_RESULT retVal = FALSE;
++ //XXXgfw do this for now...
++ retVal = IsSiteVisible();
++ return retVal;
++#else
++ return FALSE;
++#endif
++
++}
++
++void CHXExSite::_ShowXSlider(HXBOOL bShow)
++{
++#if 0
++ if( GetWindow() )
++ {
++ if( bShow )
++ _MapHorzScroll();
++ else
++ _UnmapHorzScroll();
++ }
++#endif
++}
++
++void CHXExSite::_MoveXSlider( INT32 left,
++ INT32 top,
++ INT32 right,
++ INT32 bottom,
++ HXBOOL bRedraw )
++{
++ //Do nothing right now....
++}
++
++void CHXExSite::_ShowYSlider(HXBOOL bShow)
++{
++#if 0
++ if( GetWindow() )
++ {
++ if( bShow )
++ _MapVertScroll();
++ else
++ _UnmapVertScroll();
++ }
++#endif
++}
++
++void CHXExSite::_MoveYSlider( INT32 left,
++ INT32 top,
++ INT32 right,
++ INT32 bottom,
++ HXBOOL bRedraw)
++{
++ //do nothing right now...
++}
++
++HXBOOL CHXExSite::_DoesXSliderExist()
++{
++ return FALSE;
++// return (m_ScrollHorizButtonL!=0);
++}
++
++void* CHXExSite::_GetContainingWindow()
++{
++ //XXXgfw Do we need this???
++ return NULL;
++}
++
++void CHXExSite::_GetCursorPos(HXxPoint* pPoint)
++{
++ //Return the cursor pos in screen coords.
++ Window rootWin;
++ Window childWin;
++ int rootX=0;
++ int rootY=0;
++ int childX=0;
++ int childY=0;
++ unsigned int mask=0;
++ Bool ret=FALSE;
++
++ HX_ASSERT(GetWindow());
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ ret = XQueryPointer(pDis,
++ (Window)GetWindow()->window,
++ &rootWin,
++ &childWin,
++ &rootX, &rootY,
++ &childX, &childY,
++ &mask);
++ XUnlockDisplay(pDis);
++
++ if(ret)
++ {
++ pPoint->x = rootX;
++ pPoint->y = rootY;
++ }
++}
++void* CHXExSite::_GetWindowWithCursor()
++{
++#if 0
++ //Return the cursor pos in screen coords.
++ void* pRet = NULL;
++ int rootX = 0;
++ int rootY = 0;
++ int childX= 0;
++ int childY= 0;
++ unsigned int mask = 0;
++ Bool ret = FALSE;
++ Window rootWin;
++ Window childWin;
++
++ HX_ASSERT(GetWindow());
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ ret = XQueryPointer(pDis,
++ (Window)GetWindow()->window,
++ &rootWin,
++ &childWin,
++ &rootX, &rootY,
++ &childX, &childY,
++ &mask);
++ XUnlockDisplay(pDis);
++
++ if(ret)
++ {
++ pRet = (void*)childWin;
++ }
++ return pRet;
++#else
++ HX_ASSERT( "Not implemented..." == NULL );
++ return NULL;
++#endif
++}
++
++void CHXExSite::_MapPointToOSWindow(HXxPoint* pPt, void** pWindowHandle)
++{
++ //XXXgfw we could query the window tree and traverse down but that
++ //is really slow and this isn't used right now.
++ HX_ASSERT( "Not implemented..." == NULL );
++}
++
++void CHXExSite::_ReInitPrimarySurface()
++{
++ //Nothing to do in unix here right?
++}
++
++HXBOOL CHXExSite::_MoveWindow( void* win,
++ INT32 X,
++ INT32 Y,
++ INT32 nWidth,
++ INT32 nHeight,
++ HXBOOL bRepaint)
++{
++#if 0
++ //XXXgfw we still have to do bRepaint....
++ HX_ASSERT( m_pWindow && m_pWindow->window && m_pWindow->display);
++ _DestroyScrollButtons();
++ XLockDisplay((Display*) m_pWindow->display);
++ XMoveResizeWindow( (Display*)m_pWindow->display,
++ (Window)m_pWindow->window,
++ X,
++ Y,
++ nWidth,
++ nHeight
++ );
++ XUnlockDisplay((Display*) m_pWindow->display);
++#else
++ HX_ASSERT( "Not implemented..." == NULL );
++#endif
++ return TRUE;
++}
++
++HXBOOL CHXExSite::_UpdateWindow(void* hWnd)
++{
++ //We need to generate a repaint here of the window....
++ return TRUE;
++}
++
++HXBOOL CHXExSite::_ShowWindow(void* hWnd, INT32 nCmdShow)
++{
++#if 0
++ HX_ASSERT( nCmdShow==HX_SHOW_WINDOW || nCmdShow==HX_HIDE_WINDOW);
++ if( !m_pWindow || !m_pWindow->window || !m_pWindow->display )
++ return FALSE;
++
++ if( nCmdShow == HX_SHOW_WINDOW )
++ {
++ _MapScrollButtons();
++ XLockDisplay((Display*) m_pWindow->display);
++ XMapWindow( (Display*)m_pWindow->display, (Window)m_pWindow->window );
++ XUnlockDisplay((Display*) m_pWindow->display);
++ }
++ else
++ {
++ _UnmapScrollButtons();
++ XLockDisplay((Display*) m_pWindow->display);
++ XUnmapWindow( (Display*)m_pWindow->display, (Window)m_pWindow->window );
++ XUnlockDisplay((Display*) m_pWindow->display);
++ }
++#endif
++ return TRUE;
++}
++
++HXBOOL CHXExSite::_SetWindowPos(void* hWnd,
++ void* hWndInsertAfter,
++ INT32 X,
++ INT32 Y,
++ INT32 cx,
++ INT32 cy,
++ INT32 uFlags)
++{
++#ifdef _DEBUG
++ fprintf( stderr, "Now what on earth is this suppose to do??\n" );
++#endif
++ return TRUE;
++}
++
++HXBOOL CHXExSite::_SetWindowRgn(void* hWnd, HXREGION* hRgn, HXBOOL bRedraw)
++{
++#if 0
++ HX_ASSERT( GetWindow() );
++ Display* pDis = (Display*)GetWindow()->display;
++ XLockDisplay(pDis);
++ XSetRegion( pDis,
++ (GC)m_pVideoSurface->_GetDC(NULL),
++ (Region)hRgn
++ );
++ XUnlockDisplay(pDis);
++ if( bRedraw )
++ {
++ HX_ASSERT("Redraw asked for here"==NULL );
++ }
++#endif
++ return TRUE;
++}
++
++void CHXExSite::_SetFocus(void* pWindow)
++{
++#if 0
++ XWindowAttributes attr;
++ HXxWindow* pWin = GetWindow();
++
++ HX_ASSERT(pWin);
++ HX_ASSERT(pWindow);
++
++ XLockDisplay((Display*) pWin->display);
++ XGetWindowAttributes((Display*)pWin->display, (Window)pWindow, &attr);
++ XUnlockDisplay((Display*) pWin->display);
++ if( attr.map_state == IsViewable )
++ {
++ XLockDisplay((Display*) pWin->display);
++ XSetInputFocus( (Display*)pWin->display,
++ (Window)pWindow,
++ RevertToParent,
++ CurrentTime
++ );
++ XUnlockDisplay((Display*) pWin->display);
++ }
++
++ return;
++#endif
++}
++
++HX_RESULT CHXExSite::_EnterFullScreen(HXxWindow* pWindow)
++{
++#if 0
++ HXxWindow* pWin = GetWindow();
++ HX_ASSERT( pWin && pWin->display && pWin->display);
++ HX_ASSERT( this == m_pTopLevelSite );
++
++ if( 0 != m_winFullScreenWindow || IsFullScreen() )
++ {
++ //We are already in full screen
++ return HXR_FAIL;
++ }
++
++ //Create a override redirect window to fill the root.
++ XSizeHints size_hints;
++ XLockDisplay((Display*) pWin->display);
++ Screen* pScreen = XDefaultScreenOfDisplay((Display*)pWin->display);
++ XUnlockDisplay((Display*) pWin->display);
++ UINT16 uHorzRes = WidthOfScreen(pScreen);
++ UINT16 uVertRes = HeightOfScreen(pScreen);
++ int attrMask = 0;
++ XSetWindowAttributes attr;
++
++ memset(&attr, 0, sizeof(XSetWindowAttributes));
++ attrMask = CWOverrideRedirect | CWBorderPixel |
++ CWBackPixel | CWCursor;
++ attr.cursor = None;
++ attr.override_redirect = True;
++ XLockDisplay((Display*)pWin->display);
++ attr.background_pixel = BlackPixel((Display*)pWin->display,
++ DefaultScreen((Display*)pWin->display));
++ attr.border_pixel = BlackPixel((Display*)pWin->display,
++ DefaultScreen((Display*)pWin->display));
++ XUnlockDisplay((Display*)pWin->display);
++
++ size_hints.flags = PPosition | PSize;
++ size_hints.x = 0;
++ size_hints.y = 0;
++ size_hints.width = uHorzRes;
++ size_hints.height = uVertRes;
++
++ //Create it.
++ XLockDisplay((Display*) pWin->display);
++ Window window = XCreateWindow((Display*)pWin->display,
++ DefaultRootWindow((Display*)pWin->display),
++ size_hints.x,
++ size_hints.y,
++ size_hints.width,
++ size_hints.height,
++ 0,
++ CopyFromParent,
++ InputOutput,
++ CopyFromParent,
++ attrMask,
++ &attr);
++
++ //Tell the WM about this window.
++ XSetStandardProperties( (Display*)pWin->display,
++ window,
++ "unixfullscreen",
++ "unixfullscreen",
++ None,
++ NULL, 0,
++ &size_hints
++ );
++
++ int result = XSelectInput( zm_display, window,
++ ButtonPressMask | ButtonReleaseMask | KeyPressMask |
++ KeyReleaseMask | EnterWindowMask | LeaveWindowMask |
++ PointerMotionMask | ButtonMotionMask | KeymapStateMask |
++ ExposureMask | StructureNotifyMask | FocusChangeMask
++ );
++
++ //Map the window.
++ XMapWindow((Display*)pWin->display, window);
++ XUnlockDisplay((Display*) pWin->display);
++
++
++ //Get ready to resize the presentation....
++ if(m_pTopLevelSite)
++ {
++ m_pTopLevelSite->m_bDisableForceRedraw = TRUE;
++ }
++
++ //Maintain aspect ratio and Scale it.
++ float fXScale = (float)uHorzRes/(float)(m_size.cx);
++ float fYScale = (float)uVertRes/(float)(m_size.cy);
++ float fScale = (fXScale<fYScale) ? fXScale : fYScale;
++ int nWidth = (int)(fScale*m_size.cx+.5);
++ int nHeight = (int)(fScale*m_size.cy+.5);
++
++ //Center the presentation and save the old size
++ memcpy( &m_PreFullScreenSize, &m_size, sizeof( HXxSize) ); /* Flawfinder: ignore */
++ HXxSize size = {nWidth, nHeight};
++
++ if( nWidth<uHorzRes )
++ m_ptFullScreenOffset.x = (uHorzRes-nWidth)/2;
++
++ if( nHeight<uVertRes )
++ m_ptFullScreenOffset.y = (uVertRes-nHeight)/2;
++
++ //Reparent our main window.......
++ Window winRootParent = 0;
++ Window winParent = 0;
++ Window* pwinChildren = NULL;
++ unsigned int nNumChildren = 0;
++ XLockDisplay((Display*) pWin->display);
++ XQueryTree( (Display*)pWin->display,
++ (Window)pWin->window,
++ &winRootParent,
++ &winParent,
++ &pwinChildren,
++ &nNumChildren
++ );
++ //Free unused children list.
++ XFree( pwinChildren );
++ XUnlockDisplay((Display*) pWin->display);
++
++ HX_ASSERT( winParent );
++ m_winOldParent = winParent;
++ XLockDisplay((Display*) pWin->display);
++ XReparentWindow( (Display*)pWin->display,
++ (Window)pWin->window,
++ window,
++ m_ptFullScreenOffset.x,
++ m_ptFullScreenOffset.y
++ );
++
++ //Flush event queue.
++ XSync((Display*)pWin->display, False);
++ XUnlockDisplay((Display*) pWin->display);
++
++ //Save it
++ m_winFullScreenWindow = window;
++ m_bInFullScreen = TRUE;
++
++ //Now resize it...
++ SetSize(m_size);
++ //Redraw the presentation....
++ m_pTopLevelSite->m_bDisableForceRedraw = FALSE;
++ _ForceRedrawAll();
++
++ //Give it focus....
++ _SetFocus( (void*)pWin->window );
++
++ // now eat all the focusouts that came as a result of this reparent...
++ XEvent event;
++ XLockDisplay((Display*) pWin->display);
++ HXBOOL status = XCheckTypedWindowEvent((Display*)pWin->display, (Window)pWin->window,
++ FocusOut, &event);
++ XUnlockDisplay((Display*) pWin->display);
++ while (m_bWindowCreatedByCreate && status)
++ {
++ // just discarding these
++ XLockDisplay((Display*) pWin->display);
++ status = XCheckTypedWindowEvent((Display*)pWin->display, (Window)pWin->window,
++ FocusOut, &event);
++ XUnlockDisplay((Display*) pWin->display);
++ }
++
++ //Update the status text...
++ if(m_pStatusText)
++ {
++ m_pStatusText->ParentChangedSize();
++ m_pStatusText->Show();
++ }
++
++#else
++ HX_ASSERT( "Not implemented..." == NULL );
++#endif
++ return HXR_OK;
++}
++
++HX_RESULT CHXExSite::_ExitFullScreen()
++{
++#if 0
++ HX_ASSERT( this == m_pTopLevelSite );
++
++ HXxWindow* pWin = GetWindow();
++
++ HX_ASSERT( pWin && pWin->display && pWin->window );
++
++ //Give the window back to the TLC.
++
++ XLockDisplay((Display*) pWin->display);
++ XReparentWindow( (Display*)pWin->display,
++ (Window)pWin->window,
++ m_winOldParent,
++ m_position.x, m_position.y
++ );
++ XUnlockDisplay((Display*) pWin->display);
++
++ //Just kill our window and take us out of full screen....
++ if( 0 != m_winFullScreenWindow )
++ {
++ XLockDisplay((Display*) pWin->display);
++ XDestroyWindow( (Display*)pWin->display, m_winFullScreenWindow );
++ XUnlockDisplay((Display*) pWin->display);
++ m_winFullScreenWindow = 0;
++ }
++
++ m_bDisableForceRedraw = TRUE;
++
++ m_bInFullScreen = FALSE;
++ HXxSize size = {0,0};
++ memcpy( &size, &m_PreFullScreenSize, sizeof(HXxSize) ); /* Flawfinder: ignore */
++ m_PreFullScreenSize.cx = m_PreFullScreenSize.cy = 0;
++
++ SetSize(size);
++ _SetFocus( (void*)pWin->window );
++ m_ptFullScreenOffset.x = 0;
++ m_ptFullScreenOffset.y = 0;
++
++
++ m_bDisableForceRedraw = FALSE;
++ _ForceRedrawAll();
++
++ if(m_pStatusText)
++ {
++ m_pStatusText->ParentChangedSize();
++ m_pStatusText->Hide();
++ }
++
++ //move the site back to where it was.
++ if( m_pTopLevelSite )
++ {
++ m_pTopLevelSite->_SetPosition(m_CreateWindowPos);
++ }
++
++ return HXR_OK;
++#else
++ HX_ASSERT( "Not implemented..." == NULL );
++#endif
++}
++
++HX_RESULT CHXExSite::_EnterFullScreenNoNewWindow()
++{
++#if 0
++ HXxWindow* pWin = GetWindow();
++
++ HX_ASSERT( pWin && pWin->display && pWin->display);
++ HX_ASSERT( this == m_pTopLevelSite );
++
++ if(IsFullScreen() || !pWin)
++ {
++ //We are already in full screen
++ return HXR_FAIL;
++ }
++
++ //Get the screen size.
++ XLockDisplay((Display*) pWin->display);
++ Screen* pScreen = XDefaultScreenOfDisplay((Display*)pWin->display);
++ UINT16 uHorzRes = WidthOfScreen(pScreen);
++ UINT16 uVertRes = HeightOfScreen(pScreen);
++ XUnlockDisplay((Display*)pWin->display);
++
++ //Get ready to resize the presentation....
++ if( m_pTopLevelSite )
++ {
++ m_pTopLevelSite->m_bDisableForceRedraw = TRUE;
++ }
++
++ //Maintain aspect ratio and Scale it.
++ float fXScale = (float)uHorzRes/(float)(m_size.cx);
++ float fYScale = (float)uVertRes/(float)(m_size.cy);
++ float fScale = (fXScale<fYScale) ? fXScale : fYScale;
++ int nWidth = (int)(fScale*m_size.cx+.5);
++ int nHeight = (int)(fScale*m_size.cy+.5);
++
++ //Center the presentation and save the old size
++ memcpy( &m_PreFullScreenSize, &m_size, sizeof( HXxSize) ); /* Flawfinder: ignore */
++
++ HXxSize size = {nWidth, nHeight};
++
++ if( nWidth < uHorzRes )
++ {
++ m_ptFullScreenOffset.x = (uHorzRes - nWidth)/2;
++ }
++
++ if( nHeight < uVertRes )
++ {
++ m_ptFullScreenOffset.y = (uVertRes - nHeight)/2;
++ }
++
++ //Reparent our main window.......
++ Window winRootParent = 0;
++ Window winParent = 0;
++ Window* pwinChildren = NULL;
++ unsigned int nNumChildren = 0;
++ XLockDisplay((Display*) pWin->display);
++ XQueryTree( (Display*)pWin->display,
++ (Window)pWin->window,
++ &winRootParent,
++ &winParent,
++ &pwinChildren,
++ &nNumChildren
++ );
++
++ //Free unused children list.
++ XFree( pwinChildren );
++ XUnlockDisplay((Display*) pWin->display);
++
++ HX_ASSERT( winParent );
++ m_winOldParent = winParent;
++
++ m_bInFullScreen = TRUE;
++
++ //Now resize it...
++ SetSize(m_size);
++
++ //Redraw the presentation....
++ if( m_pTopLevelSite )
++ {
++ m_pTopLevelSite->m_bDisableForceRedraw = FALSE;
++ }
++
++ _ForceRedrawAll();
++
++ //Give it focus....
++ _SetFocus( (void*)pWin->window );
++
++ // now eat all the focusouts that came as a result of this reparent...
++ XEvent event;
++ XLockDisplay((Display*) pWin->display);
++ HXBOOL status = XCheckTypedWindowEvent((Display*)pWin->display, (Window)pWin->window,
++ FocusOut, &event);
++ XUnlockDisplay((Display*) pWin->display);
++ while (m_bWindowCreatedByCreate && status)
++ {
++ // just discarding these
++ XLockDisplay((Display*) pWin->display);
++ status = XCheckTypedWindowEvent((Display*)pWin->display, (Window)pWin->window,
++ FocusOut, &event);
++ XUnlockDisplay((Display*) pWin->display);
++ }
++
++ //Update the status text...
++ if(m_pStatusText)
++ {
++ m_pStatusText->ParentChangedSize();
++ m_pStatusText->Show();
++ }
++#if defined(HELIX_CONFIG_MOBLIN)
++ if(!m_pAttachWindowCallback)
++ {
++ m_pAttachWindowCallback = new CHXGenericCallback((void*)this, (fGenericCBFunc)AttachWindowCallback);
++ m_pAttachWindowCallback->AddRef();
++ }
++ if(!m_pForceRedrawCallback)
++ {
++ m_pForceRedrawCallback = new CHXGenericCallback((void*)this, (fGenericCBFunc)ForceRedrawCallback);
++ m_pForceRedrawCallback->AddRef();
++ }
++
++ // schedule callback for Attaching Window
++ if(m_pAttachWindowCallback)
++ {
++ m_pAttachWindowCallback->CallbackScheduled(m_pScheduler->RelativeEnter(m_pAttachWindowCallback, 100));
++ }
++ if(m_pForceRedrawCallback)
++ {
++ m_pForceRedrawCallback->CallbackScheduled(m_pScheduler->RelativeEnter(m_pForceRedrawCallback, 500));
++ }
++
++#endif
++#else
++ HX_ASSERT( "Not implemented..." == NULL );
++#endif
++ return HXR_OK;
++}
++
++#if defined(HELIX_CONFIG_MOBLIN)
++void CHXExSite::AttachWindowCallback(void* pParam)
++{
++ CHXExSite* pObj = (CHXExSite*)pParam;
++ if (pObj)
++ {
++ pObj->_AttachWindow();
++ }
++}
++
++
++void CHXExSite::ForceRedrawCallback(void* pParam)
++{
++ CHXExSite* pObj = (CHXExSite*)pParam;
++
++ if (pObj)
++ {
++ UINT32 ulNumOfChildren = pObj->GetNumberOfChildSites();
++ if(pObj->m_pTopLevelSite)
++ {
++ pObj->m_pTopLevelSite->m_bDisableForceRedraw = FALSE;
++ }
++ for ( UINT32 i = 0; i < ulNumOfChildren; ++i )
++ {
++ SPIHXSite spChildSite;
++ if ( SUCCEEDED( pObj->GetNthChildSite( i, *spChildSite.AsInOutParam() ) )
++ && spChildSite.IsValid() )
++ {
++ spChildSite->DamageRegion( NULL );
++ spChildSite->ForceRedraw();
++ }
++
++ }
++ }
++}
++
++void CHXExSite::RemovePendingCallback(CHXGenericCallback* pCB)
++{
++ if (pCB &&
++ pCB->GetPendingCallback() &&
++ m_pScheduler)
++ {
++ m_pScheduler->Remove(pCB->GetPendingCallback());
++ pCB->CallbackCanceled();
++ }
++}
++#endif
++
++HX_RESULT CHXExSite::_EnterFullScreenExt(HXxWindow* pWindow, IHXValues* pValues)
++{
++#if 0
++ m_bReparent = FALSE;
++ HX_RESULT res = HXR_OK;
++ UINT32 ulReparent = 0;
++
++ if (pValues)
++ {
++ pValues->GetPropertyULONG32("Reparent", ulReparent);
++ }
++
++ m_bReparent = (HXBOOL)ulReparent;
++
++ if (m_bReparent)
++ {
++ res = _EnterFullScreen(pWindow);
++ }
++ else
++ {
++ res = _EnterFullScreenNoNewWindow();
++ }
++
++ CHXBaseSite::FullScreenEntered(res);
++ return res;
++#else
++ HX_ASSERT( "Not implemented..." == NULL );
++ return HXR_OK; /* this makes compiler happy */
++#endif
++}
++
++HX_RESULT CHXExSite::_ExitFullScreenExt()
++{
++#if 0
++ HX_RESULT res = _ExitFullScreen();
++#if defined(HELIX_CONFIG_MOBLIN)
++ // schedule callback for attaching window
++ if(m_pAttachWindowCallback)
++ {
++ m_pAttachWindowCallback->CallbackScheduled(m_pScheduler->RelativeEnter(m_pAttachWindowCallback, 100));
++ }
++ // schedule callback for Force Redraw the window
++ if(m_pForceRedrawCallback)
++ {
++ m_pForceRedrawCallback->CallbackScheduled(m_pScheduler->RelativeEnter(m_pForceRedrawCallback, 500));
++ }
++#endif
++ CHXBaseSite::FullScreenExited(res);
++
++ return res;
++#else
++ HX_ASSERT( "Not implemented..." == NULL );
++ return HXR_OK; /* this makes compiler happy */
++#endif
++
++}
++
++HX_RESULT CHXExSite::_EventOccurred(HXxEvent* pEvent)
++{
++ return HXR_OK;
++}
++
++HX_RESULT CHXExSite::_TestFullScreen( void* hTestBitmap,
++ const char* pszStatusText )
++{
++#ifdef _DEBUG
++ fprintf( stderr, "Going to test full screen....\n" );
++#endif
++ return HXR_OK;
++}
++
++void CHXExSite::ProcessEvent(HXxEvent* pEvent)
++{
++ if(pEvent)
++ {
++ //Expose event compression. Combine all outstanding expose events
++ //into one big region.
++ if(Expose==pEvent->event)
++ {
++ _CollapseExposeEvents((XEvent*)pEvent->param2);
++ }
++ }
++
++ //Send the event to each registered UnixSite.
++ void* pSite = NULL;
++ void* pWindow = NULL;
++ POSITION pos = z_mapSiteToWindow.GetStartPosition();
++ while( pos )
++ {
++ z_mapSiteToWindow.GetNextAssoc(pos, pSite, pWindow);
++ CHXExSite* pSiteWindowed = (CHXExSite*)pSite;
++ CHXExSite* pTopLevel = NULL;
++ HX_ASSERT(pSiteWindowed);
++ pSiteWindowed->AddRef();
++ pTopLevel = (CHXExSite*)pSiteWindowed->GetTopLevelSite();
++
++ if(pEvent)
++ {
++ //Call back into the basesite's event loop.
++ pTopLevel->EventOccurred(pEvent);
++ }
++
++ //XXXgfw As a workaround for the overlay not moving while the
++ //player is paused, we will check it here and update it if needed.
++
++ //XXXRGG We might be able to use X's ConfigureNotify messages instead
++ //of doing a refresh every 50 ms.
++ pTopLevel->_UpdateOverlayIfNeeded();
++
++ pSiteWindowed->Release();
++ }
++}
++
++void CHXExSite::_CollapseExposeEvents(XEvent* xevent)
++{
++ Display* display = xevent->xany.display;
++ Window window = xevent->xany.window;
++ XExposeEvent* expose_event = (XExposeEvent*)xevent;
++ XEvent new_event;
++ XExposeEvent* new_expose_event = (XExposeEvent*)&new_event;
++ ushort x1;
++ ushort y1;
++ ushort x2;
++ ushort y2;
++ ushort x3;
++ ushort y3;
++
++ x1 = expose_event->x;
++ y1 = expose_event->y;
++ x2 = x1 + expose_event->width;
++ y2 = y1 + expose_event->height;
++ XLockDisplay(display);
++ HXBOOL status = XCheckWindowEvent(display, window, ExposureMask, &new_event);
++ XUnlockDisplay(display);
++ while( status)
++ {
++ if (new_expose_event->x < x1)
++ x1 = new_expose_event->x;
++
++ if (new_expose_event->y < y1)
++ y1 = new_expose_event->y;
++
++ x3 = new_expose_event->x + new_expose_event->width;
++ if (x3 > x2)
++ x2 = x3;
++
++ y3 = new_expose_event->y + new_expose_event->height;
++ if (y3 > y2)
++ y2 = y3;
++ XLockDisplay(display);
++ status = XCheckWindowEvent(display, window, ExposureMask, &new_event);
++ XUnlockDisplay(display);
++
++ }
++
++ expose_event->x = x1;
++ expose_event->y = y1;
++ expose_event->width = x2 - x1;
++ expose_event->height = y2 - y1;
++ expose_event->count = new_expose_event->count;
++}
++
++
++HXBOOL CHXExSite::_ShouldProcess(HXxEvent* pEvent)
++{
++ HXBOOL bShouldProcessThisEvent = TRUE;
++
++
++ if( !IsSiteVisible() )
++ {
++ switch (pEvent->event)
++ {
++ case ButtonPress:
++ case ButtonRelease:
++ case Expose:
++ case FocusIn:
++ bShouldProcessThisEvent = FALSE;
++ break;
++ default:
++ break;
++ }
++ }
++
++ if(m_pWindow && m_pWindow->window!=pEvent->window)
++ {
++ bShouldProcessThisEvent = FALSE;
++ }
++ return bShouldProcessThisEvent;
++}
++
++
++///////////////////////////////////////////////////////
++//
++// UnixEventHandler methods...
++//
++CHXExSite::UnixEventHandler::UnixEventHandler(CHXExSite* pParent)
++ : m_pParent(pParent),
++ m_lRefCount(0),
++ m_cbHandle(0)
++{
++ HX_ASSERT(m_pParent);
++ HX_ASSERT(m_pParent->m_pScheduler);
++ m_cbHandle = m_pParent->m_pScheduler->RelativeEnter((IHXCallback*)this, 30);
++}
++
++CHXExSite::UnixEventHandler::~UnixEventHandler()
++{
++ CancelCallback();
++}
++
++void
++CHXExSite::UnixEventHandler::CancelCallback()
++{
++ if( m_cbHandle && m_pParent && m_pParent->m_pScheduler )
++ {
++ UINT32 tempHandle = m_cbHandle;
++ m_cbHandle = 0;
++ m_pParent->m_pScheduler->Remove(tempHandle);
++ }
++}
++
++HX_RESULT CHXExSite::UnixEventHandler::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IHXCallback))
++ {
++ AddRef();
++ *ppvObj = (IHXCallback*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++ULONG32 CHXExSite::UnixEventHandler::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++ULONG32 CHXExSite::UnixEventHandler::Release()
++{
++ HX_ASSERT(m_lRefCount>0);
++ if( InterlockedDecrement(&m_lRefCount)>0 )
++ {
++ return m_lRefCount;
++ }
++ delete this;
++ return 0;
++}
++
++//IHXCallback methods
++HX_RESULT CHXExSite::UnixEventHandler::Func()
++{
++ XEvent xevent;
++ static HXxEvent pnevent;
++
++ m_cbHandle = 0;
++ XLockDisplay(m_pParent->zm_display);
++ int status = XPending(m_pParent->zm_display);
++ XUnlockDisplay(m_pParent->zm_display);
++ while(status)
++ {
++ XLockDisplay(m_pParent->zm_display);
++ XNextEvent(m_pParent->zm_display, &xevent);
++ XUnlockDisplay(m_pParent->zm_display);
++
++ // package native event in HXxEvent and send to dispatcher
++ pnevent.event = xevent.type;
++ pnevent.window = (void *)xevent.xany.window;
++ pnevent.param1 = xevent.xany.display;
++ pnevent.param2 = &xevent;
++
++ m_pParent->ProcessEvent(&pnevent);
++ XLockDisplay(m_pParent->zm_display);
++ status = XPending(m_pParent->zm_display);
++ XUnlockDisplay(m_pParent->zm_display);
++ }
++
++ if (m_pParent && m_pParent->m_pScheduler)
++ {
++ m_cbHandle = m_pParent->m_pScheduler->RelativeEnter((IHXCallback*)this, 30);
++ }
++ return HXR_OK;
++}
++
++void CHXExSite::_UpdateOverlayIfNeeded()
++{
++ if( m_pVideoSurface )
++ {
++ if( m_pVideoSurface->m_nBltMode == HX_OVERLAY_BLT )
++ {
++ ULONG32 ulNow = HX_GET_BETTERTICKCOUNT();
++ CUnixSurf* pSurf = (CUnixSurf*)m_pVideoSurface;
++ if( ulNow- pSurf->m_ulLastOverlayUpdateTime > 50 )
++ {
++ SiteMoving(0,0);
++ }
++ }
++ }
++ LISTPOSITION pos = m_ChildrenInZOrder.GetHeadPosition();
++ while(pos)
++ {
++ CHXExSite* pSite = (CHXExSite*)m_ChildrenInZOrder.GetNext(pos);
++ pSite->_UpdateOverlayIfNeeded();
++ }
++}
++
++
++HXBOOL CHXExSite::_ShouldEnterForceRedraw()
++{
++ if( !m_bDamaged || !m_pUser || !IsSiteVisible() )
++ {
++ return FALSE;
++ }
++
++ if(InterlockedIncrement(&m_lBltEntryCount)>1)
++ {
++ InterlockedDecrement(&m_lBltEntryCount);
++ return FALSE;
++ }
++
++ return TRUE;
++}
++
++void CHXExSite::_ExitForceRedraw()
++{
++ InterlockedDecrement(&m_lBltEntryCount);
++}
++
+Index: helix-libs/clientapps/clutter/exsite.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exsite.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,272 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: unixsite.h,v 1.10.2.3 2008/06/05 14:24:30 lovish Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ * Phil Dibowitz (jaymzh)
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _UNIXSITE_H
++#define _UNIXSITE_H
++
++#if defined(USE_XWINDOWS)
++#include <X11/Xatom.h>
++#include <X11/Xlib.h>
++#include <X11/Xutil.h>
++#include <X11/Xos.h>
++#include <X11/Intrinsic.h>
++#include <X11/extensions/XShm.h>
++#endif
++
++#include "basesite.h"
++#include "hxcbobj.h"
++#include "player.h"
++
++class CHXExSite : public CHXBaseSite
++{
++public:
++
++ friend class CExSurf;
++ friend class CExRootSurf;
++
++ CHXExSite( IUnknown* pContext,
++ IUnknown* pUnkOuter,
++ INT32 lInitialZorder,
++ on_new_frame_cb_t on_new_frame_cb = NULL,
++ void *context = NULL);
++
++ static void ProcessEvent(HXxEvent* pEvent);
++ Window CreateXWindow( Window win );
++
++ void _ForwardUpdateEvent(HXxEvent* pEvent);
++
++ //static member vars.
++ static Display* zm_display;
++ void _UpdateOverlayIfNeeded();
++ HXBOOL m_bIgnoreFocusOutInFS;
++
++ //We override this.
++ void CheckColorSettings();
++
++protected:
++
++ virtual ~CHXExSite();
++
++ //
++ // CHXExSite only methods....
++ //
++ HX_RESULT _OpenXDisplay(char* DiplayString);
++ static void _CollapseExposeEvents(XEvent* xevent);
++ HXBOOL _ShouldProcess(HXxEvent* pEvent);
++ void _DrawArrows();
++ void _CreateHorizScrollBar(void);
++ void _CreateVertScrollBar(void);
++ HXBOOL _InButton(HXxPoint& pt, int x, int y );
++ void _DestroyScrollButtons();
++ void _MapScrollButtons();
++ void _MapHorzScroll();
++ void _MapVertScroll();
++ void _UnmapHorzScroll();
++ void _UnmapVertScroll();
++ void _UnmapScrollButtons();
++ void _BuildClipRegion();
++ void _ReleaseClippingRegion();
++
++ //
++ // Seperate object for our callbacks to keep the events flowing.
++ //
++ class UnixEventHandler : public IHXCallback
++ {
++ public:
++ UnixEventHandler(CHXExSite* pParent);
++
++ //IUnknown methods
++ virtual HX_RESULT QueryInterface(REFIID riid, void** ppvObj);
++ virtual ULONG32 AddRef();
++ virtual ULONG32 Release();
++
++ //IHXCallback methods
++ virtual HX_RESULT Func();
++ void CancelCallback();
++
++ private:
++ virtual ~UnixEventHandler();
++
++ UnixEventHandler();
++ UnixEventHandler(const UnixEventHandler&);
++ UnixEventHandler& operator=(const UnixEventHandler& it );
++
++ CHXExSite* m_pParent;
++ LONG32 m_lRefCount;
++ CallbackHandle m_cbHandle;
++
++ IUnknown* m_pUnkPlayer;
++ };
++
++
++ //
++ // CHXBaseSite inherited methods
++ //
++ virtual void _NeedWindowedSite();
++ virtual void _AttachWindow();
++ virtual void _DetachWindow();
++ virtual void* _Create(void* ParentWindow, UINT32 style);
++ virtual void _Destroy(HXxWindow* pWindow);
++ virtual void _SetSize(HXxSize size);
++ virtual void _SetPosition(HXxPoint position);
++ virtual void _DamageRect(HXxRect rect);
++ virtual void _DamageRegion(HXxRegion rect);
++ virtual HXBOOL _ShouldEnterForceRedraw();
++ virtual void _ExitForceRedraw();
++ virtual void _SendOSUpdateMessage();
++ virtual void _ShowSite(HXBOOL bShow);
++ virtual HXBOOL _AtSystemTime();
++ virtual void _GetDeviceCaps( void* hdc,
++ UINT16& uBitesPerPixel,
++ UINT16& uHorzRes,
++ UINT16& uVertRes );
++ virtual void _GetWindowRect(HXxRect* destRect);
++ virtual void _DestroySliders();
++ virtual HXBOOL _HandleOSEvents(HXxEvent* pEvent);
++ virtual HXBOOL _ConvertToHXEvent(HXxEvent* pEvent);
++ virtual void _GenerateOSEvent(HXxEvent* pEvent, HXxEvent* pEvent2);
++ virtual void _GenerateSetCursorEvent();
++ virtual void _TryCreateXSlider();
++ virtual void _SetXSliderValues(INT32 range, INT32 pageSize);
++ virtual void _TryCreateYSlider();
++ virtual void _SetYSliderValues(INT32 range, INT32 pageSize);
++ virtual void _GetSystemSizeOfSliders(INT32* pWidth, INT32* pHeight);
++ virtual HXBOOL _IsWindowVisible();
++ virtual void _ShowXSlider(HXBOOL bShow);
++ virtual void _MoveXSlider( INT32 left,
++ INT32 top,
++ INT32 right,
++ INT32 bottom,
++ HXBOOL bRedraw );
++ virtual void _ShowYSlider(HXBOOL bShow);
++ virtual void _MoveYSlider( INT32 left,
++ INT32 top,
++ INT32 right,
++ INT32 bottom,
++ HXBOOL bRedraw);
++ virtual HXBOOL _DoesXSliderExist();
++ virtual void* _GetContainingWindow();
++ virtual void _GetCursorPos(HXxPoint* pPoint);
++ virtual void _MapPointToOSWindow(HXxPoint* pPt, void** pWindowHandle);
++ virtual void* _GetWindowWithCursor();
++ virtual void _ReInitPrimarySurface();
++ virtual HXBOOL _MoveWindow( void* ,
++ INT32 X,
++ INT32 Y,
++ INT32 nWidth,
++ INT32 nHeight,
++ HXBOOL bRepaint);
++ virtual HXBOOL _UpdateWindow(void* hWnd);
++ virtual HXBOOL _ShowWindow(void* hWnd, INT32 nCmdShow);
++ virtual HXBOOL _SetWindowPos(void* hWnd,
++ void* hWndInsertAfter,
++ INT32 X,
++ INT32 Y,
++ INT32 cx,
++ INT32 cy,
++ INT32 uFlags);
++ virtual HXBOOL _SetWindowRgn(void* hWnd, HXREGION* hRgn, HXBOOL bRedraw);
++ virtual void _SetFocus(void* pWindow);
++
++ virtual HX_RESULT _EnterFullScreen(HXxWindow* pWindow = NULL);
++ virtual HX_RESULT _EventOccurred(HXxEvent* pEvent);
++ virtual HX_RESULT _ExitFullScreen();
++ virtual HX_RESULT _TestFullScreen( void* hTestBitmap,
++ const char* pszStatusText );
++ virtual HX_RESULT _EnterFullScreenExt(HXxWindow* pWindow, IHXValues* pValues);
++ virtual HX_RESULT _ExitFullScreenExt();
++#if defined(HELIX_CONFIG_MOBLIN)
++ static void AttachWindowCallback(void *pParam);
++ static void ForceRedrawCallback(void *pParam);
++ void RemovePendingCallback(CHXGenericCallback* pCB);
++
++ CHXGenericCallback* m_pAttachWindowCallback;
++ CHXGenericCallback* m_pForceRedrawCallback;
++#endif
++ HXBOOL m_bReparent;
++
++private:
++
++ //Protect unintentional copy and default ctors.
++ CHXExSite();
++ CHXExSite( const CHXExSite& );
++ CHXExSite& operator=( const CHXExSite& it );
++ HX_RESULT _EnterFullScreenNoNewWindow();
++
++ //member vars.
++ UnixEventHandler* m_pUnixEventHandler;
++ static Cursor zm_GrabCursor;
++ Window m_ScrollHorizButtonL;
++ Window m_ScrollHorizButtonR;
++ Window m_ScrollVertButtonT;
++ Window m_ScrollVertButtonB;
++ Window m_winFullScreenWindow;
++ Window m_winOldParent;
++ HXxPoint m_ptScrollHorizPosL;
++ HXxPoint m_ptScrollHorizPosR;
++ HXxPoint m_ptScrollVertPosT;
++ HXxPoint m_ptScrollVertPosB;
++ HXxPoint m_ptFullScreenOffset;
++ HXxSize m_PreFullScreenSize;
++ HXBOOL m_bScrollingInProgress;
++ int m_nScrollDir;
++ HXBOOL m_bLastPointInSite;
++ HXBOOL m_bDamaged;
++ //
++ //Private helpers...
++ //
++
++ //returns the HX_VK associated with this keysym....
++ UINT32 _MapKeySymToHXVK(KeySym tmpSym, UINT32& uFlags);
++ on_new_frame_cb_t m_on_new_frame_cb;
++ void *m_context;
++};
++
++#endif //_UNIXSITE_H
+Index: helix-libs/clientapps/clutter/exsitsup.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exsitsup.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,455 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifdef _WIN16
++#include <windows.h>
++#endif
++
++#include "hxcom.h"
++#include "hxtypes.h"
++#include "hxwintyp.h"
++#include "hxwin.h"
++#include "ihxpckts.h"
++#include "hxcomm.h"
++#include "fivemmap.h"
++#include "hxstring.h" // CHXString
++#include "exsite.h"
++#include "exsitsup.h"
++#include "pckunpck.h" // CreateBufferCCF
++#include "ciddefs.h" // CID_RGB32
++#if defined(HELIX_FEATURE_PNG)
++#include "pxpngenc.h" // PXPNGEncode::EncodeToPNGBuffer
++#endif // HELIX_FEATURE_PNG
++#include "print.h"
++
++
++#include "globals.h"
++struct _stGlobals*& GetGlobal();
++
++/************************************************************************
++ * Method:
++ * Constructor
++ */
++ ExampleSiteSupplier::ExampleSiteSupplier(IUnknown* pUnkPlayer, on_new_frame_cb_t on_new_frame_cb = NULL, void *context = NULL)
++ : m_lRefCount(0)
++ , m_pSiteManager(NULL)
++ , m_pSite(NULL)
++ , m_pSiteCapture(NULL)
++ , m_pCaptureBuffer(NULL)
++ , m_pCCF(NULL)
++ , m_pUnkPlayer(pUnkPlayer)
++ , m_on_new_frame_cb(on_new_frame_cb)
++ , m_context(context)
++{
++ if (m_pUnkPlayer)
++ {
++ m_pUnkPlayer->QueryInterface(IID_IHXSiteManager,
++ (void**)&m_pSiteManager);
++
++ //printf("pauldebug:m_pUnkplayer->QueryInterface for m_pCCF calling\n");
++ m_pUnkPlayer->QueryInterface(IID_IHXCommonClassFactory,
++ (void**)&m_pCCF);
++ //printf("pauldebug:m_pUnkplayer->QueryInterface for m_pCCF called\n");
++
++ m_pUnkPlayer->AddRef();
++ }
++};
++
++/************************************************************************
++ * Method:
++ * Destructor
++ */
++ExampleSiteSupplier::~ExampleSiteSupplier()
++{
++ HX_RELEASE(m_pSiteManager);
++ HX_RELEASE(m_pSite);
++ HX_RELEASE(m_pSiteCapture);
++ HX_RELEASE(m_pCaptureBuffer);
++ HX_RELEASE(m_pCCF);
++ HX_RELEASE(m_pUnkPlayer);
++}
++
++/************************************************************************
++ * Method:
++ * IUnknown::QueryInterface
++ */
++ STDMETHODIMP
++ExampleSiteSupplier::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = (IUnknown*)(IHXSiteSupplier*)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXSiteSupplier))
++ {
++ AddRef();
++ *ppvObj = (IHXSiteSupplier*)this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++/************************************************************************
++ * Method:
++ * IUnknown::AddRef
++ */
++ STDMETHODIMP_(ULONG32)
++ExampleSiteSupplier::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++/************************************************************************
++ * Method:
++ * IUnknown::Release
++ */
++ STDMETHODIMP_(ULONG32)
++ExampleSiteSupplier::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++/************************************************************************
++ * Method:
++ * IHXSiteSupplier::SitesNeeded
++ * Purpose:
++ * Called to inform the site supplier that a site with a particular
++ * set of characteristics is needed. If the site supplier can
++ * fulfill the request it should call the site manager and add one
++ * or more new sites.
++ * Note that the request for sites is associated with a Request ID
++ * the client core will inform the site supplier when this requested
++ * site is no longer needed.
++ */
++STDMETHODIMP
++ExampleSiteSupplier::SitesNeeded
++(
++ UINT32 uRequestID,
++ IHXValues* pProps
++ )
++{
++ /*
++ * Don't create a site if the -NULL_RENDER command line option
++ * was given. - jfarr
++ */
++ if (GetGlobal()->g_bNullRender)
++ {
++ return (HXR_OK);
++ }
++
++ /*
++ * If there are no properties, then we can't really create a
++ * site, because we have no idea what type of site is desired!
++ */
++ if (!pProps)
++ {
++ return HXR_INVALID_PARAMETER;
++ }
++
++ HRESULT hres = HXR_OK;
++ IHXValues* pSiteProps = NULL;
++ IHXSiteWindowed* pSiteWindowed = NULL;
++ IHXBuffer* pValue = NULL;
++ UINT32 style = 0;
++ IHXSite* pSite = NULL;
++
++#if 0
++ // Just let the RMA client core create a windowed site for us.
++ hres = m_pCCF->CreateInstance(CLSID_IHXSiteWindowed,(void**)&pSiteWindowed);
++ if (HXR_OK != hres)
++ {
++ goto exit;
++ }
++#else
++ {
++ *(void **)&pSiteWindowed = (IUnknown*)(IHXSiteWindowed*)(new CHXExSite(GetGlobal()->pMediaPlatform, NULL, 0, m_on_new_frame_cb, m_context));
++ hres = ((IUnknown*)*(void **)&pSiteWindowed)->QueryInterface(IID_IHXSiteWindowed, (void**)&pSiteWindowed);
++ if (HXR_OK != hres)
++ {
++ goto exit;
++ }
++ }
++#endif
++
++ hres = pSiteWindowed->QueryInterface(IID_IHXSite,(void**)&pSite);
++ if (HXR_OK != hres)
++ {
++ goto exit;
++ }
++
++ if( !m_pSite )
++ {
++ m_pSite = pSite;
++ m_pSite->AddRef();
++ }
++
++
++ hres = pSiteWindowed->QueryInterface(IID_IHXValues,(void**)&pSiteProps);
++ if (HXR_OK != hres)
++ {
++ goto exit;
++ }
++
++ /*
++ * We need to figure out what type of site we are supposed to
++ * to create. We need to "switch" between site user and site
++ * properties. So look for the well known site user properties
++ * that are mapped onto sites...
++ */
++ hres = pProps->GetPropertyCString("playto",pValue);
++ if (HXR_OK == hres)
++ {
++ pSiteProps->SetPropertyCString("channel",pValue);
++ HX_RELEASE(pValue);
++ }
++ else
++ {
++ hres = pProps->GetPropertyCString("name",pValue);
++ if (HXR_OK == hres)
++ {
++ pSiteProps->SetPropertyCString("LayoutGroup",pValue);
++ HX_RELEASE(pValue);
++ }
++ }
++
++#ifdef _WINDOWS
++ style = WS_OVERLAPPED | WS_VISIBLE | WS_CLIPCHILDREN;
++#endif
++
++ hres = pSiteWindowed->Create(NULL, style);
++ if (HXR_OK != hres)
++ {
++ goto exit;
++ }
++
++ /*
++ * We need to wait until we have set all the properties before
++ * we add the site.
++ */
++ hres = m_pSiteManager->AddSite(pSite);
++ if (HXR_OK != hres)
++ {
++ goto exit;
++ }
++#ifdef _WINDOWS
++ {
++ HXxWindow* pWindow = pSiteWindowed->GetWindow();
++ if (pWindow && pWindow->window) ::SetForegroundWindow( (HWND)(pWindow->window) );
++ }
++#endif
++ m_CreatedSites.SetAt((void*)uRequestID,pSite);
++ pSite->AddRef();
++
++exit:
++
++ HX_RELEASE(pSiteProps);
++ HX_RELEASE(pSiteWindowed);
++ HX_RELEASE(pSite);
++
++ return hres;
++}
++
++/************************************************************************
++ * Method:
++ * IHXSiteSupplier::SitesNotNeeded
++ * Purpose:
++ * Called to inform the site supplier that all sites from a previos
++ * site request are no longer needed. If the site supplier had
++ * previously created non-persistant sites (like popup windows)
++ * to fulfill a request for sites it should call the site manager
++ * and remove those sites.
++ */
++STDMETHODIMP
++ExampleSiteSupplier::SitesNotNeeded(UINT32 uRequestID)
++{
++ IHXSite* pSite = NULL;
++ IHXSiteWindowed* pSiteWindowed = NULL;
++ void* pVoid = NULL;
++
++ if (!m_CreatedSites.Lookup((void*)uRequestID,pVoid))
++ {
++ return HXR_INVALID_PARAMETER;
++ }
++ pSite = (IHXSite*)pVoid;
++
++ m_pSiteManager->RemoveSite(pSite);
++
++ // Need to actually do the work on destroying the window
++ // and all that jazz.
++ pSite->QueryInterface(IID_IHXSiteWindowed,(void**)&pSiteWindowed);
++
++ pSiteWindowed->Destroy();
++
++ // ref count = 2
++ pSiteWindowed->Release();
++
++ // ref count = 1; deleted from this object's view!
++ pSite->Release();
++
++ m_CreatedSites.RemoveKey((void*)uRequestID);
++
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXSiteSupplier::BeginChangeLayout
++ * Purpose:
++ * Called to inform the site supplier a layout change has beginning
++ * it can expect to recieve SitesNeeded() and SitesNotNeeded() calls
++ * while a layout change is in progress,
++ */
++STDMETHODIMP
++ExampleSiteSupplier::BeginChangeLayout()
++{
++ return HXR_OK;
++}
++
++/************************************************************************
++ * Method:
++ * IHXSiteSupplier::DoneChangeLayout
++ * Purpose:
++ * Called to inform the site supplier the layout change has been
++ * completed.
++ */
++STDMETHODIMP
++ExampleSiteSupplier::DoneChangeLayout()
++{
++ return HXR_OK;
++}
++
++HX_RESULT
++ExampleSiteSupplier::CaptureImage(CHXString pszFileName, INT32 dWidth, INT32 dHeight)
++{
++ HX_RESULT res=HXR_FAIL;
++
++ // Get the IHXSiteCapture object from the site
++ if (m_pSiteCapture == NULL)
++ {
++ if (m_pSite && m_pSite->QueryInterface(IID_IHXSiteCapture, (void**)&m_pSiteCapture) == HXR_OK)
++ {
++ m_pSiteCapture->AddRef();
++ }
++ }
++
++ // Create the buffer that will receive the image data
++ if (m_pCaptureBuffer == NULL)
++ {
++ CreateBufferCCF(m_pCaptureBuffer, m_pCCF);
++ if (!m_pCaptureBuffer)
++ {
++ return HXR_OUTOFMEMORY;
++ }
++ }
++
++ HXBOOL bCanCapture = FALSE;
++
++ // Check if the site is available to capture an image
++ if (m_pSiteCapture && (res = m_pSiteCapture->CanCapture(bCanCapture)) == HXR_OK && bCanCapture)
++ {
++ HX_RESULT res;
++ HXxSize outputSize;
++ outputSize.cx = dWidth;
++ outputSize.cy = dHeight;
++ m_strFileName = pszFileName;
++
++ // Asynchronous call. CaptureDone() will be called with result.
++ res = m_pSiteCapture->Capture((IHXSiteCaptureResponse*)this, m_pCaptureBuffer, &outputSize, CID_RGB32);
++ }
++
++ return res;
++
++}
++
++//
++// IHXSiteCaptureResponse::CaptureDone
++//
++// Called when the site has captured the next frame.
++// bmiOutputFormat points to image format description which
++// is valid until the completion of CaptureDone.
++// bmiOutputFormat can be different for every capture.
++// pCaptureBuffer holds the image if supplied in
++// Capture() method. pCaptureBuffer is automatically
++// resized if it has insufficient size to hold the image
++// data.
++//
++// status may be:
++// HXR_FAIL -- No capture was done. General Error. All data is invalid.
++// HXR_OK -- Capture was done. Both variables are valid.
++STDMETHODIMP
++ExampleSiteSupplier::CaptureDone(REF(HX_RESULT) status,
++ REF(HXBitmapInfoHeader) bmiOutputFormat,
++ REF(IHXBuffer*) pCaptureBuffer)
++{
++ if (status == HXR_OK)
++ {
++#if defined(HELIX_FEATURE_PNG)
++ // Convert capture buffer into PNG
++ IHXBuffer* pConvertedBuffer=NULL;
++ HX_RESULT res = HXR_OK;
++ res = PXPNGEncode::EncodeToPNGBuffer(pCaptureBuffer, &bmiOutputFormat, m_pCCF, pConvertedBuffer);
++ if (res == HXR_OK && !m_strFileName.IsEmpty())
++ {
++ CHXString strTail = m_strFileName.Right(4);
++ if (strTail.CompareNoCase(".png") != 0)
++ {
++ m_strFileName += ".png";
++ }
++
++ FILE* fp = fopen(m_strFileName, "wb");
++ if (fp)
++ {
++ fwrite(pConvertedBuffer->GetBuffer(), 1, pConvertedBuffer->GetSize(), fp);
++ fclose(fp);
++ STDOUT("Captured image to PNG file: %s\n", (const char*)m_strFileName);
++ STDOUT("File size: %ld\n", pConvertedBuffer->GetSize());
++ }
++ HX_RELEASE(pConvertedBuffer);
++ }
++#endif // HELIX_FEATURE_PNG
++ }
++
++ return status;
++}
+Index: helix-libs/clientapps/clutter/exsitsup.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exsitsup.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,154 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _EXSITSUP_H_
++#define _EXSITSUP_H_
++
++#include "fivemmap.h"
++#include "player.h"
++
++/****************************************************************************
++ *
++ * Class:
++ *
++ * ExampleSiteSupplier
++ *
++ * Purpose:
++ *
++ * Implementation for ragui's IHXSiteSupplier
++ *
++ */
++class ExampleSiteSupplier :
++ public IHXSiteSupplier
++ , public IHXSiteCaptureResponse
++{
++private:
++ LONG32 m_lRefCount;
++ IHXSiteManager* m_pSiteManager;
++ IHXSite* m_pSite;
++ IHXSiteCapture* m_pSiteCapture;
++ IHXBuffer* m_pCaptureBuffer;
++ IHXCommonClassFactory* m_pCCF;
++ IUnknown* m_pUnkPlayer;
++ FiveMinuteMap m_CreatedSites;
++ CHXString m_strFileName;
++ on_new_frame_cb_t m_on_new_frame_cb;
++ void * m_context;
++
++ ~ExampleSiteSupplier();
++
++public:
++ ExampleSiteSupplier(IUnknown* pUnkPlayer, on_new_frame_cb_t new_frame_cb = NULL, void *context = NULL);
++
++ /*
++ * IUnknown methods
++ */
++ STDMETHOD(QueryInterface) (THIS_
++ REFIID riid,
++ void** ppvObj);
++
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /*
++ * IHXSiteSupplier methods
++ */
++
++ /************************************************************************
++ * Method:
++ * IHXSiteSupplier::SitesNeeded
++ * Purpose:
++ * Called to inform the site supplier that a site with a particular
++ * set of characteristics is needed. If the site supplier can
++ * fulfill the request it should call the site manager and add one
++ * or more new sites.
++ * Note that the request for sites is associated with a Request ID
++ * the client core will inform the site supplier when this requested
++ * site is no longer needed.
++ */
++ STDMETHOD(SitesNeeded) (THIS_
++ UINT32 uRequestID,
++ IHXValues* pSiteProps);
++
++ /************************************************************************
++ * Method:
++ * IHXSiteSupplier::SitesNotNeeded
++ * Purpose:
++ * Called to inform the site supplier that all sites from a previos
++ * site request are no longer needed. If the site supplier had
++ * previously created non-persistant sites (like popup windows)
++ * to fulfill a request for sites it should call the site manager
++ * and remove those sites.
++ */
++ STDMETHOD(SitesNotNeeded)
++ (THIS_
++ UINT32 uRequestID);
++
++
++ /************************************************************************
++ * Method:
++ * IHXSiteSupplier::BeginChangeLayout
++ * Purpose:
++ * Called to inform the site supplier a layout change has beginning
++ * it can expect to recieve SitesNeeded() and SitesNotNeeded() calls
++ * while a layout change is in progress,
++ */
++ STDMETHOD(BeginChangeLayout) (THIS);
++
++ /************************************************************************
++ * Method:
++ * IHXSiteSupplier::DoneChangeLayout
++ * Purpose:
++ * Called to inform the site supplier the layout change has been
++ * completed.
++ */
++ STDMETHOD(DoneChangeLayout) (THIS);
++
++ /*
++ * IHXSiteCaptureResponse
++ */
++ STDMETHOD(CaptureDone) (THIS_
++ REF(HX_RESULT) status,
++ REF(HXBitmapInfoHeader) bmiOutputFormat,
++ REF(IHXBuffer*) pImageDataBuffer
++ );
++
++ HX_RESULT CaptureImage(CHXString pFileName, INT32 dWidth, INT32 dHeight);
++
++};
++
++#endif // _EXSITSUP_H_
++
+Index: helix-libs/clientapps/clutter/exstateadvsnk.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exstateadvsnk.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,229 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include <stdio.h>
++
++#include "hxtypes.h"
++
++#include "hxcom.h"
++#include "hxcomm.h"
++#include "hxmon.h"
++#include "hxcore.h"
++#include "hxengin.h"
++#include "hxclsnk.h"
++#include "hxgroup.h"
++#include "hxstrutl.h"
++#include "exstateadvsnk.h"
++#include "hxstring.h"
++#include "hxprefs.h"
++#include "excontxt.h"
++
++#include "print.h"
++
++#include "globals.h"
++#include "player.h"
++
++struct _stGlobals*& GetGlobal(); //in main.cpp
++
++#ifdef __TCS__
++extern unsigned long gStreamTime;
++
++static int iOpened = 0;
++
++
++#if defined(__cplusplus)
++extern "C" {
++#endif /* defined(__cplusplus) */
++
++typedef enum hookBuffering {
++ eContacting = 0,
++ eConnecting = 1,
++ eBuffering = 2,
++ ePlaying = 3
++}hookBuffering;
++
++void hookRealAudio_Buffering(hookBuffering connectState, int pct);
++
++void hookRealAudio_PlayPosition(unsigned long current,unsigned long duration);
++
++typedef enum hookState {
++ ePlay = 0,
++ ePause = 1,
++ eStop = 2,
++ eResume = 3,
++ eComplete // Clip is done playing
++}hookState;
++void hookRealAudio_State(hookState newState);
++
++
++#if defined(__cplusplus)
++}
++#endif /* defined(__cplusplus) */
++
++#endif // __TCS__
++
++void PrintBuffer(const char* pszName,const unsigned char* pbBuf, unsigned int dwBytes);
++
++ExampleClientStateAdviceSink::ExampleClientStateAdviceSink(IUnknown* pUnknown, LONG32 lClientIndex, on_state_change_cb_t on_state_change_cb, void *context)
++ : m_lRefCount (0)
++ , m_lClientIndex (lClientIndex)
++ , m_pUnknown (NULL)
++ , m_State (HX_CLIENT_STATE_READY)
++ , m_state_change_cb(on_state_change_cb)
++ , m_context(context)
++{
++ if (pUnknown)
++ {
++ m_pUnknown = pUnknown;
++ m_pUnknown->AddRef();
++
++ IHXPlayer* pPlayer;
++ IHXClientStateAdviseSinkControl *pStateControl;
++ if(HXR_OK == m_pUnknown->QueryInterface(IID_IHXPlayer,
++ (void**)&pPlayer))
++ {
++ m_pPlayer = pPlayer;
++
++
++ }
++
++ if (HXR_OK == m_pUnknown->QueryInterface(IID_IHXClientStateAdviseSinkControl, (void **)&pStateControl))
++ {
++ pStateControl->AddClientStateAdviseSink(this);
++ }
++ }
++
++#ifdef __TCS__
++ bEnableAdviceSink = TRUE;
++ iOpened = 0;
++#endif
++}
++
++ExampleClientStateAdviceSink::~ExampleClientStateAdviceSink(void)
++{
++
++ if (m_pPlayer)
++ {
++ m_pPlayer->Release();
++ m_pPlayer = NULL;
++ }
++ if (m_pUnknown)
++ {
++ m_pUnknown->Release();
++ m_pUnknown = NULL;
++ }
++}
++
++
++// *** IUnknown methods ***
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::QueryInterface
++// Purpose:
++// Implement this to export the interfaces supported by your
++// object.
++//
++STDMETHODIMP ExampleClientStateAdviceSink::QueryInterface(REFIID riid, void** ppvObj)
++{
++ if (IsEqualIID(riid, IID_IUnknown))
++ {
++ AddRef();
++ *ppvObj = (IUnknown*)(IHXClientStateAdviseSink *)this;
++ return HXR_OK;
++ }
++ else if (IsEqualIID(riid, IID_IHXClientStateAdviseSink))
++ {
++ AddRef();
++ *ppvObj = (IHXClientStateAdviseSink*)this;
++ return HXR_OK;
++ }
++
++ *ppvObj = NULL;
++ return HXR_NOINTERFACE;
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::AddRef
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleClientStateAdviceSink::AddRef()
++{
++ return InterlockedIncrement(&m_lRefCount);
++}
++
++/////////////////////////////////////////////////////////////////////////
++// Method:
++// IUnknown::Release
++// Purpose:
++// Everyone usually implements this the same... feel free to use
++// this implementation.
++//
++STDMETHODIMP_(ULONG32) ExampleClientStateAdviceSink::Release()
++{
++ if (InterlockedDecrement(&m_lRefCount) > 0)
++ {
++ return m_lRefCount;
++ }
++
++ delete this;
++ return 0;
++}
++
++
++/************************************************************************
++ * Method:
++ * IHXClientStateAdviseSink::OnStateChange
++ * Purpose:
++ * Called to advise the client state has changed state
++ */
++STDMETHODIMP ExampleClientStateAdviceSink::OnStateChange(UINT16 uOldState, UINT16 uNewState)
++{
++ if (m_state_change_cb)
++ m_state_change_cb(uOldState, uNewState, m_context);
++
++ m_State = uNewState;
++ return HXR_OK;
++}
++
++EHXClientState ExampleClientStateAdviceSink::GetState()
++{
++ return m_State;
++}
++
++
+Index: helix-libs/clientapps/clutter/exstateadvsnk.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/exstateadvsnk.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,108 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _EXAMPLE_CLIENT_STATE_ADVISE_SNK_H_
++#define _EXAMPLE_CLIENT_STATE_ADVISE_SNK_H_
++
++#include "player.h"
++
++struct IHXClientStateAdviseSink;
++struct IHXGroupSink;
++struct IUnknown;
++struct IHXRegistry;
++struct IHXScheduler;
++struct IHXCallback;
++struct IHXPlayer;
++struct IHXGroup;
++
++class ExampleClientStateAdviceSink : public IHXClientStateAdviseSink
++{
++ private:
++ LONG32 m_lRefCount;
++ LONG32 m_lClientIndex;
++
++ IUnknown* m_pUnknown;
++
++ UINT32 m_ulStartTime;
++ UINT32 m_ulStopTime;
++
++ UINT32 m_lCurrentBandwidth;
++ UINT32 m_lAverageBandwidth;
++ HXBOOL m_bOnStop;
++
++ HXBOOL m_bWaitForTrackStart;
++
++ on_state_change_cb_t m_state_change_cb;
++ void *m_context;
++ EHXClientState m_State;
++
++ // IHXCallback
++ IHXPlayer* m_pPlayer;
++ ULONG32 m_hCallback;
++ ~ExampleClientStateAdviceSink();
++
++
++ public:
++
++ ExampleClientStateAdviceSink(IUnknown* /*IN*/ pUnknown, LONG32 /*IN*/ lClientIndex, on_state_change_cb_t on_state_change_cb = NULL, void *context = NULL);
++
++ /*
++ * IUnknown methods
++ */
++ STDMETHOD(QueryInterface) (THIS_
++ REFIID riid,
++ void** ppvObj);
++
++ STDMETHOD_(ULONG32,AddRef) (THIS);
++
++ STDMETHOD_(ULONG32,Release) (THIS);
++
++ /***********************************************************************
++ * Method:
++ * IHXClientStateAdviseSink::OnStateChange
++ * Purpose:
++ * Called by client engine to inform the client that the state has changed.
++ * States are defined in the enum EHXClientState, defined in this file.
++ *
++ */
++ STDMETHOD(OnStateChange) (THIS_
++ UINT16 uOldState,
++ UINT16 uNewState
++ ) ;
++
++ EHXClientState GetState();
++};
++
++#endif /* _EXAMPLECLSNK_ */
+Index: helix-libs/clientapps/clutter/fivemmap.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/fivemmap.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,175 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include <string.h>
++#include "hxtypes.h"
++#include "fivemmap.h"
++
++void* FiveMinuteMap::GetFirstValue()
++{
++ m_nCursor = 0;
++
++ if (m_nMapSize)
++ {
++ return m_pValueArray[m_nCursor];
++ }
++ else
++ {
++ return NULL;
++ }
++}
++
++void* FiveMinuteMap::GetNextValue()
++{
++ m_nCursor++;
++
++ if (m_nCursor < m_nMapSize)
++ {
++ return m_pValueArray[m_nCursor];
++ }
++ else
++ {
++ return NULL;
++ }
++}
++
++HXBOOL FiveMinuteMap::Lookup(void* Key, void*& Value) const
++{
++ HXBOOL bFound = FALSE;
++ int nIndex = 0;
++
++ // If Key is alrady in the list, replace value
++ for (; nIndex < m_nMapSize; nIndex++)
++ {
++ if (m_pKeyArray[nIndex] == Key)
++ {
++ Value = m_pValueArray[nIndex];
++ bFound = TRUE;
++ goto exit;
++ }
++ }
++
++exit:
++ return bFound;
++}
++
++void FiveMinuteMap::RemoveKey(void* Key)
++{
++ HXBOOL bFound = FALSE;
++ int nIndex = 0;
++
++ // If Key is alrady in the list, replace value
++ for (; nIndex < m_nMapSize; nIndex++)
++ {
++ if (m_pKeyArray[nIndex] == Key)
++ {
++ if (nIndex < (m_nMapSize-1))
++ {
++ memmove(&(m_pKeyArray[nIndex]),&(m_pKeyArray[nIndex+1]),sizeof(void*)*(m_nMapSize-(nIndex+1)));
++ memmove(&(m_pValueArray[nIndex]),&(m_pValueArray[nIndex+1]),sizeof(void*)*(m_nMapSize-(nIndex+1)));
++ }
++ m_nMapSize--;
++ goto exit;
++ }
++ }
++
++exit:
++ (NULL); // We're done!
++}
++
++void FiveMinuteMap::RemoveValue(void* Value)
++{
++ HXBOOL bFound = FALSE;
++ int nIndex = 0;
++
++ // If Value is alrady in the list, replace value
++ for (; nIndex < m_nMapSize; nIndex++)
++ {
++ if (m_pValueArray[nIndex] == Value)
++ {
++ if (nIndex < (m_nMapSize-1))
++ {
++ memmove(&(m_pKeyArray[nIndex]),&(m_pKeyArray[nIndex+1]),sizeof(void*)*(m_nMapSize-(nIndex+1)));
++ memmove(&(m_pValueArray[nIndex]),&(m_pValueArray[nIndex+1]),sizeof(void*)*(m_nMapSize-(nIndex+1)));
++ }
++ m_nMapSize--;
++ goto exit;
++ }
++ }
++
++exit:
++ (NULL); // We're done!
++}
++
++
++void FiveMinuteMap::SetAt(void* Key, void* Value)
++{
++ int nIndex = 0;
++
++ // If Key is alrady in the list, replace value
++ for (; nIndex < m_nMapSize; nIndex++)
++ {
++ if (m_pKeyArray[nIndex] == Key)
++ {
++ m_pValueArray[nIndex] = Value;
++ goto exit;
++ }
++ }
++
++ // If we have room, add it to the end!
++ if (m_nAllocSize == m_nMapSize)
++ {
++ m_nAllocSize += AllocationSize;
++ void** pNewKeys = new void*[m_nAllocSize];
++ void** pNewValues = new void*[m_nAllocSize];
++
++ memcpy(pNewKeys,m_pKeyArray,sizeof(void*)*m_nMapSize); /* Flawfinder: ignore */
++ memcpy(pNewValues,m_pValueArray,sizeof(void*)*m_nMapSize); /* Flawfinder: ignore */
++
++ delete [] m_pKeyArray;
++ delete [] m_pValueArray;
++
++ m_pKeyArray = pNewKeys;
++ m_pValueArray = pNewValues;
++ }
++
++ m_pKeyArray[m_nMapSize] = Key;
++ m_pValueArray[m_nMapSize] = Value;
++ m_nMapSize++;
++
++exit:
++ (NULL); // We're done!
++}
++
+Index: helix-libs/clientapps/clutter/fivemmap.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/fivemmap.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,79 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _FIVEMMAP_H_
++#define _FIVEMMAP_H_
++
++#ifndef _HXTYPES_H_
++#error FiveMinuteMap assumes pntypes.h.
++#endif
++
++class FiveMinuteMap
++{
++ const int AllocationSize;
++
++ void** m_pKeyArray;
++ void** m_pValueArray;
++ int m_nMapSize;
++ int m_nAllocSize;
++ int m_nCursor;
++public:
++ FiveMinuteMap()
++ : m_pKeyArray(NULL)
++ , m_pValueArray(NULL)
++ , m_nMapSize(0)
++ , m_nAllocSize(0)
++ , m_nCursor(0)
++ , AllocationSize(10)
++ {};
++
++ ~FiveMinuteMap()
++ {
++ delete [] m_pKeyArray;
++ delete [] m_pValueArray;
++ };
++
++ int GetCount() {return m_nMapSize;}
++
++ void* GetFirstValue();
++ void* GetNextValue();
++
++ HXBOOL Lookup(void* Key, void*& Value) const;
++ void RemoveKey(void* Key);
++ void RemoveValue(void* Value);
++ void SetAt(void* Key, void* Value);
++};
++
++#endif /* _FIVEMMAP_H_ */
+Index: helix-libs/clientapps/clutter/globals.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/globals.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,150 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++/****************************************************************************
++ *
++ * Test Client:
++ *
++ *
++ * This is an test client running on Windows, Mac, and Unix without a GUI.
++ *
++ */
++
++#ifndef _SPLAY_GLOBALS_H
++#define _SPLAY_GLOBALS_H
++
++#include "dllacces.h"
++#include "dllpath.h"
++#include "hxengin.h"
++#include "hxplayvelocity.h"
++#include "hxcore.h"
++#include "ihxmedpltfm.h"
++#include "excontxt.h"
++#include "preflist.h"
++
++#define HX_COMMAND_BUFFER_SIZE 256
++#define HX_MAX_NUM_MULTI_SEEKS 10
++struct _stGlobals
++{
++ _stGlobals()
++ : g_pDLLAccess(NULL),
++ g_nPlayers(0),
++ m_fpHXMediaPlatformOpen(NULL),
++ m_fpHXCreateMediaPlatform(NULL),
++ m_fpHXMediaPlatformClose(NULL),
++ m_fpCreateEngine(NULL),
++ m_fpCloseEngine(NULL),
++ m_fpSetDLLAccessPath(NULL),
++ bEnableAdviceSink(FALSE),
++ bEnableVerboseMode(FALSE),
++ g_bEnableSlowStart(TRUE),
++ g_bOnBeginOccurred(FALSE),
++ g_pszUsername( NULL),
++ g_pszPassword(NULL),
++ g_pszGUIDFile(NULL),
++ g_pszGUIDList(NULL),
++ g_Error(HXR_OK),
++ g_ulNumSecondsPlayed(0),
++ pMediaPlatform(NULL),
++ g_pIHXKicker(NULL),
++ bUseLegacyAPIs(FALSE),
++ pEngine(NULL),
++ g_pQuickSeek(NULL),
++ g_bNullRender(FALSE),
++ g_bUserStop(FALSE),
++ g_bInitVelocity(FALSE),
++ g_bABD(FALSE),
++ g_pVelocityCaps(NULL),
++ g_ulNumMultiSeeks(0),
++ g_ulMultiSeekIndex(0),
++ g_bMultiSeek(FALSE),
++ g_uThreadIDForKicker(-1)
++ {
++ memset(g_szCommandBuffer, 0, HX_COMMAND_BUFFER_SIZE);
++ memset(g_szPriorCommandBuffer, 0, HX_COMMAND_BUFFER_SIZE);
++ memset(g_Players, 0, sizeof(g_Players));
++ memset(g_pszURLs, 0, sizeof(g_pszURLs));
++ memset(g_pClientContexts, 0, sizeof(g_pClientContexts));
++ }
++
++ #define MAX_NUM_PLAYERS 256
++ IHXPlayer* g_Players[MAX_NUM_PLAYERS];
++ char *g_pszURLs[MAX_NUM_PLAYERS];
++ ExampleClientContext *g_pClientContexts[MAX_NUM_PLAYERS];
++ int g_nPlayers;
++ DLLAccessPath g_statclnt;
++ DLLAccess* g_pDLLAccess;
++ CHXPrefList g_prefList;
++
++ FPHXMEDIAPLATFORMOPEN m_fpHXMediaPlatformOpen;
++ FPHXCREATEMEDIAPLATFORM m_fpHXCreateMediaPlatform;
++ FPHXMEDIAPLATFORMCLOSE m_fpHXMediaPlatformClose;
++
++ FPRMCREATEENGINE m_fpCreateEngine;
++ FPRMCLOSEENGINE m_fpCloseEngine;
++ FPRMSETDLLACCESSPATH m_fpSetDLLAccessPath;
++
++ HXBOOL bEnableAdviceSink;
++ HXBOOL bEnableVerboseMode;
++ HXBOOL g_bEnableSlowStart;
++ HXBOOL g_bOnBeginOccurred;
++ char* g_pszUsername;
++ char* g_pszPassword;
++ char* g_pszGUIDFile;
++ char* g_pszGUIDList;
++ HX_RESULT g_Error;
++ UINT32 g_ulNumSecondsPlayed;
++ IHXMediaPlatform* pMediaPlatform;
++ IHXMediaPlatformKicker* g_pIHXKicker;
++ UINT32 g_uThreadIDForKicker;
++ pthread_t g_pThreadKickmanId;
++ HXBOOL bUseLegacyAPIs;
++ IHXClientEngine* pEngine;
++ IHXQuickSeek* g_pQuickSeek;
++ HXBOOL g_bNullRender;
++ HXBOOL g_bUserStop;
++ HXBOOL g_bInitVelocity;
++ HXBOOL g_bABD;
++ IHXPlaybackVelocityCaps* g_pVelocityCaps;
++ HXBOOL g_bMultiSeek;
++ UINT32 g_ulMultiSeekTime[HX_MAX_NUM_MULTI_SEEKS];
++ UINT32 g_ulNumMultiSeeks;
++ UINT32 g_ulMultiSeekIndex;
++ char g_szCommandBuffer[HX_COMMAND_BUFFER_SIZE];
++ char g_szPriorCommandBuffer[HX_COMMAND_BUFFER_SIZE];
++};
++
++
++#endif // _SPLAY_GLOBALS_H
+Index: helix-libs/clientapps/clutter/iids.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/iids.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,50 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++// define all guids here once...
++#define INITGUID
++#define NCIHACK
++#include "hxtypes.h"
++#include "hxcom.h"
++#include "hxiids.h"
++#include "hxpiids.h"
++#if defined _WINDOWS
++#if defined (HELIX_FEATURE_DIRECT_SOUND)
++#include "dsound.h"
++#endif /* HELIX_FEATURE_DIRECT_SOUND */
++#if defined (HELIX_FEATURE_VIDEO) && !defined(_WINCE)
++#include "ddraw.h"
++#endif /* HELIX_FEATURE_VIDEO */
++#endif
+Index: helix-libs/clientapps/clutter/linux2.pcf
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/linux2.pcf 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,42 @@
++#
++# ***** BEGIN LICENSE BLOCK *****
++# Version: RCSL 1.0/RPSL 1.0
++#
++# Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++#
++# The contents of this file, and the files included with this file, are
++# subject to the current version of the RealNetworks Public Source License
++# Version 1.0 (the "RPSL") available at
++# http://www.helixcommunity.org/content/rpsl unless you have licensed
++# the file under the RealNetworks Community Source License Version 1.0
++# (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++# in which case the RCSL will apply. You may also obtain the license terms
++# directly from RealNetworks. You may not use this file except in
++# compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++# applicable to this file, the RCSL. Please see the applicable RPSL or
++# RCSL for the rights, obligations and limitations governing use of the
++# contents of the file.
++#
++# This file is part of the Helix DNA Technology. RealNetworks is the
++# developer of the Original Code and owns the copyrights in the portions
++# it created.
++#
++# This file, and the files included with this file, is distributed and made
++# available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++# EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++# INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++# FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++#
++# Technology Compatibility Kit Test Suite(s) Location:
++# http://www.helixcommunity.org/content/tck
++#
++# Contributor(s):
++#
++# ***** END LICENSE BLOCK *****
++#
++
++project.AddSystemLibraries("dl", "m", "pthread")
++
++if (project.IsDefined("HELIX_FEATURE_VIDEO") and
++ project.IsDefined("USE_XWINDOWS")):
++ project.AddSystemLibraries("X11")
+Index: helix-libs/clientapps/clutter/player.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/player.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,1057 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++/****************************************************************************
++ *
++ * Test Client:
++ *
++ *
++ * This is an test client running on Windows, Mac, and Unix without a GUI.
++ *
++ */
++#include "hxtypes.h"
++
++#include <stdlib.h>
++
++#include "hlxclib/time.h"
++#include "ihxmedpltfm.h"
++#include "hxwintyp.h"
++#include "hxcom.h"
++#include "ihxpckts.h"
++#include "hxcomm.h"
++#include "hxmon.h"
++#include "hxfiles.h"
++#include "hxengin.h"
++#include "hxcore.h"
++#include "hxclsnk.h"
++#include "hxgroup.h"
++#include "hxerror.h"
++#include "hxauth.h"
++#include "hxwin.h"
++#include "hxprefs.h"
++#include "hxtbuf.h"
++#include "fivemmap.h"
++#include "dllacces.h"
++#include "hxausvc.h"
++#include "hxstrutl.h"
++#include "hxgroup.h"
++#include "hxwin.h"
++#include "hxtick.h"
++#include "hxbuffer.h"
++#include "hxplayvelocity.h"
++#include "pckunpck.h" // For CreateAndSetBufferCCF()
++#include "hxvctrl.h"
++#include "hxbsrc.h"
++#include "excallback.h"
++#include "pthread.h"
++
++#if defined(HELIX_FEATURE_PRESENTATION_FEATURE_SELECTION)
++#include "hxpfs.h"
++#endif // HELIX_FEATURE_PRESENTATION_FEATURE_SELECTION.
++
++#if defined(HELIX_FEATURE_PREFERENCES)
++#include "preflist.h"
++#endif /* #if defined(HELIX_FEATURE_PREFERENCES) */
++#include "exadvsnk.h"
++#include "exerror.h"
++#include "exsitsup.h"
++#include "exaumgr.h"
++#if defined(_WIN32)
++#include "exabd.h"
++#endif
++#include "excontxt.h"
++#include "print.h"
++#if defined(USE_XWINDOWS)
++#include <X11/Xlib.h>
++#endif
++#if defined (_UNIX)
++#include <stdio.h>
++#include <sys/time.h>
++#include <sys/types.h>
++#include <unistd.h>
++#include <termios.h>
++#endif
++#if defined(_WINDOWS)
++#include <conio.h>
++#endif
++
++#ifdef __TCS__
++#include <unistd.h>
++#if defined(__cplusplus)
++extern "C" {
++#endif /* defined(__cplusplus) */
++ extern unsigned long tmosTimSleep(unsigned long ticks);
++ unsigned long gForcePlayerToStop = 0;
++#if defined(__cplusplus)
++}
++#endif /* defined(__cplusplus) */
++#endif
++
++#if defined (_MACINTOSH) || defined (_MAC_UNIX)
++bool gMacPlayerIsDone = false;
++#endif
++
++
++#if defined _VXWORKS
++#include "sys/times.h"
++#include "string.h"
++#include "hxtime.h"
++#endif
++
++#if defined(_MACINTOSH)
++#ifndef _MAC_MACHO
++#include <sioux.h>
++#include <console.h>
++#endif
++#endif
++
++#include "dllpath.h"
++
++#ifdef _SYMBIAN
++#include <e32svr.h>
++#include "platform/symbian/symbian_event_hndlr.h"
++#endif
++
++ENABLE_DLLACCESS_PATHS(g_SPlayAccessPath);
++
++// typedef for SetDLLAccessPath
++
++
++#include "thrdutil.h"
++
++#if defined(_AIX)
++#include <strings.h>
++#endif
++
++#if defined _DEBUG || defined DEBUG
++#include "debug.h"
++#endif
++
++#ifndef MAX_PATH
++#define MAX_PATH 256
++#endif //!MAX_PATH
++
++#if defined(HELIX_CONFIG_NOSTATICS)
++# include "globals/hxglobals.h"
++#endif
++
++#define MAX_NUM_URLS 10
++
++#include "globals.h" //for global struct.
++
++#include "player.h"
++
++#if defined(_WINDOWS) && defined(_STATICALLY_LINKED)
++HINSTANCE g_hInstance = NULL;
++#endif
++
++struct _stGlobals*& GetGlobal()
++{
++#if defined(HELIX_CONFIG_NOSTATICS)
++ static const struct _stGlobals* const _g_pstGlobals = NULL;
++ struct _stGlobals*& g_pstGlobals = (struct _stGlobals*&)HXGlobalPtr::Get(&_g_pstGlobals);
++#else
++ static struct _stGlobals* g_pstGlobals = NULL;
++#endif
++ if( g_pstGlobals == NULL )
++ {
++ g_pstGlobals = new struct _stGlobals();
++ }
++ return g_pstGlobals;
++
++}
++
++
++// Constants
++const int DEFAULT_TIME_DELTA = 2000;
++const int DEFAULT_STOP_TIME = -1;
++const int SLEEP_TIME = 5;
++const int GUID_LEN = 64;
++
++// Function prototypes
++void PrintUsage(const char* pszAppName);
++HXBOOL AllPlayersDone(int nNumPlayers, IHXPlayer** ppPlayers);
++void StopAllPlayers(int nNumPlayers, IHXPlayer** ppPlayers);
++HXBOOL ReadGUIDFile();
++char* GetAppName(char* pszArgv0);
++
++#ifdef __TCS__
++#if defined(__cplusplus)
++extern "C" {
++#endif /* defined(__cplusplus) */
++
++ extern void _alloc_stats(int verbose);
++#if defined(__cplusplus)
++}
++#endif /* defined(__cplusplus) */
++
++static IHXPlayer** g_Players;
++static int g_nPlayers = 0;
++static long evtCount = 0;
++static long evtFullCount = 0;
++#endif
++
++
++
++#if defined(HELIX_FEATURE_PRESENTATION_FEATURE_SELECTION)
++HX_RESULT
++DumpPFdata(IHXPresentationFeatureManager* pPFMgr,
++ const char* pszPFName)
++{
++ HX_RESULT hxr = HXR_OK;
++
++ IHXBuffer* pFeatureCurrentSetting = NULL;
++ IHXValues* pFeatureOptions = NULL;
++
++ if (!pPFMgr || !pszPFName)
++ {
++ hxr = HXR_INVALID_PARAMETER;
++ }
++ else
++ {
++ // List all the options for this PF:
++ HX_RESULT hxr = pPFMgr->GetPresentationFeature(
++ pszPFName,
++ pFeatureCurrentSetting,
++ pFeatureOptions);
++
++ if (FAILED(hxr))
++ {
++ // PF doesn't exist!
++ STDOUT("\t%s - No such presentation feature\n\n", pszPFName);
++ }
++ else
++ {
++ // Now, go through pFeatureOptions and display
++ // them and their "is-selectable"-flag values:
++ const char* pszPFOptionName = NULL;
++ const char* pszPFCurSetting = pFeatureCurrentSetting?
++ (const char*)pFeatureCurrentSetting->GetBuffer() : NULL;
++ UINT32 bPFOptionIsSelectableFlag = FALSE;
++ IHXBuffer* pPFOptionIsSelectableFlag = NULL;
++
++ HX_ASSERT(pszPFCurSetting);
++ STDOUT("\t%s\t(Current setting == \"%s\")\n", pszPFName, pszPFCurSetting?
++ pszPFCurSetting : "<ERROR: THIS PF HAS NO CURRENT SETTING!>");
++
++ if (!pFeatureOptions) // NULL is OK; that means freeform (open-ended):
++ {
++ STDOUT("\t\t(%s's options are freeform, i.e., open-ended)\n",
++ pszPFName);
++ }
++ else // List all the options and their flags:
++ {
++ if (HXR_OK == pFeatureOptions->GetFirstPropertyCString(pszPFOptionName,
++ pPFOptionIsSelectableFlag) && *pszPFOptionName)
++ {
++ do
++ {
++ const UCHAR* pIsSelFlag = pPFOptionIsSelectableFlag->GetBuffer();
++ if (pIsSelFlag && *pIsSelFlag)
++ {
++ // Anything but '0' (zero) is treated as '1' (is selectable):
++ bPFOptionIsSelectableFlag = (HXBOOL)('0' != *pIsSelFlag &&
++ '\0' == *(pIsSelFlag+1));
++ }
++ else
++ {
++ // Set the error, but we'll go ahead and treat it as '0':
++ hxr = HXR_INVALID_PARAMETER;
++ bPFOptionIsSelectableFlag = FALSE;
++ }
++
++ STDOUT("\t\t%s\t\tIs selectable: %s\n",
++ pszPFOptionName, bPFOptionIsSelectableFlag? "yes":"no");
++ // Release it to get the next PF:
++ HX_RELEASE(pPFOptionIsSelectableFlag);
++ } while (HXR_OK == pFeatureOptions->GetNextPropertyCString(
++ pszPFOptionName, pPFOptionIsSelectableFlag));
++ }
++ }
++
++ HX_RELEASE(pPFOptionIsSelectableFlag);
++ }
++ }
++
++ HX_RELEASE(pFeatureCurrentSetting);
++ HX_RELEASE(pFeatureOptions);
++
++ return hxr;
++}
++#endif // HELIX_FEATURE_PRESENTATION_FEATURE_SELECTION.
++
++
++char* RemoveWrappingQuotes(char* str)
++{
++ int len = strlen(str);
++ if (len > 0)
++ {
++ if (str[len-1] == '"') str[--len] = 0;
++ if (str[0] == '"') { int i = 0; do { str[i++] = str[i+1]; } while(--len); }
++ }
++ return str;
++}
++
++void *kickman(void *dummy)
++{
++ while(1) {
++ UINT32 sleepTime = 0;
++ IHXMediaPlatformKicker* pKicker = GetGlobal()->g_pIHXKicker;
++ if( pKicker )
++ {
++ pKicker->Kick(GetGlobal()->g_uThreadIDForKicker, &sleepTime);
++ }
++ usleep(sleepTime);
++ }
++}
++
++PLAYER_API int init_main( )
++{
++#if defined(_WIN32) && !defined(WIN32_PLATFORM_PSPC)
++ setvbuf(stdout, NULL, _IONBF, 0);
++#endif /* defined(_WIN32) && !defined(WIN32_PLATFORM_PSPC) */
++
++ FPHXMEDIAPLATFORMOPEN fpHXMediaPlatformOpen = NULL;
++ FPHXCREATEMEDIAPLATFORM fpHXCreateMediaPlatform = NULL;
++ FPHXMEDIAPLATFORMCLOSE fpHXMediaPlatformClose = NULL;
++
++ FPRMCREATEENGINE fpCreateEngine = NULL;
++ FPRMCLOSEENGINE fpCloseEngine = NULL;
++ FPRMSETDLLACCESSPATH fpSetDll = NULL;
++
++ HX_RESULT theErr = HXR_OK;
++ ExampleClientContext** ppExContexts = NULL;
++#if defined(HELIX_FEATURE_AUTO_BANDWIDTH_DETECTION) && defined(_WIN32)
++ ExampleABD* pABD = NULL;
++#endif
++ IHXPlayer** ppPlayers = NULL;
++ IHXQuickSeek* ppQuickSeek = NULL;
++ IHXErrorSink* pErrorSink = NULL;
++ IHXErrorSinkControl* pErrorSinkControl = NULL;
++ UINT32 ulABDResult = 0;
++ UINT32 ulProbPktSize = 0;
++ UINT32 ulProbPktNum = 0;
++#if defined(HELIX_FEATURE_PLAYBACK_VELOCITY)
++ INT32 lVelocity = 100;
++ INT32 lKeyFrameMode = 0;
++ INT32 lAutoSwitch = 0;
++#endif /* #if defined(HELIX_FEATURE_PLAYBACK_VELOCITY) */
++ CHXString* pABDServer = NULL;
++ char* pszURL[MAX_NUM_URLS];
++ char* pszURLOrig[MAX_NUM_URLS];
++ UINT32 ulNumURLsFound = 0;
++ int nNumPlayers = 1;
++ int nNumPlayRepeats = 1;
++ int nTimeDelta = DEFAULT_TIME_DELTA;
++ int nStopTime = DEFAULT_STOP_TIME;
++ bool bStopTime = true;
++ int i = 0;
++ char* pszGUIDList = NULL;
++#ifdef _MACINTOSH
++ char dllhome[MAX_PATH] = {'\0'}; /* Flawfinder: ignore */
++#elif defined(_SYMBIAN)
++ char dllhome[MAX_PATH] = "c:"; /* Flawfinder: ignore */
++#else
++ char dllhome[MAX_PATH] = {'.','\0'}; /* Flawfinder: ignore */
++#endif
++ DLLAccess* pDLLAccess = NULL;
++ char staticLibPath[MAX_PATH] = {0}; /* Flawfinder: ignore */
++#ifdef _WINDOWS
++ HINSTANCE hDll = NULL;
++#endif
++ bool bStopping = false;
++ int nPlay = 0;
++
++ // NULL out the URL arrays
++ memset(pszURL, 0, MAX_NUM_URLS * sizeof(char*));
++ memset(pszURLOrig, 0, MAX_NUM_URLS * sizeof(char*));
++
++
++ //See if the user has set their HELIX_LIBS env var. This is overridden by the
++ //-l option.
++ const char* pszHelixLibs = getenv("HELIX_LIBS");
++ if( pszHelixLibs )
++ SafeStrCpy( dllhome, pszHelixLibs, MAX_PATH);
++
++
++
++ GetGlobal()->bEnableAdviceSink = TRUE;
++ GetGlobal()->g_prefList.Add("UseOverlay", "0");
++
++ SafeSprintf(staticLibPath, MAX_PATH, "%s/%s", dllhome, "hxmedpltfm.so");
++
++ if (dllhome)
++ {
++ GetDLLAccessPath()->SetPath(DLLTYPE_COMMON, dllhome);
++ GetDLLAccessPath()->SetPath(DLLTYPE_PLUGIN, dllhome);
++ GetDLLAccessPath()->SetPath(DLLTYPE_CODEC, dllhome);
++ }
++
++ // initialize the globals
++ GetGlobal()->m_fpCreateEngine = NULL;
++ GetGlobal()->m_fpCloseEngine = NULL;
++ GetGlobal()->g_nPlayers = 0;
++
++ // prepare/load the HXCore module
++ pDLLAccess = new DLLAccess();
++
++ STDOUT("Simpleplayer is looking for the client core at %s\n", staticLibPath );
++
++ if (DLLAccess::DLL_OK != pDLLAccess->open(staticLibPath))
++ {
++ const char* pErrorString = NULL;
++ pErrorString = pDLLAccess->getErrorString();
++ STDERR("splayer: %s\n\n", pErrorString);
++#ifndef _STATICALLY_LINKED
++#ifndef _MACINTOSH
++ //Make sure the user has told us where to find the DLLs at. Either
++ //with the -l option or with the HELIX_LIBS env var.
++ STDERR("You must tell the player where to find the client core and\n");
++ STDERR("all of its supporting DLLs and codecs. Please use the -l\n");
++ STDERR("option or set your HELIX_LIBS env variable to point the player.\n");
++ STDERR("to where you have all of the DLLs installed.\n\n" );
++ //PrintUsage(argv[0]);
++#endif
++#endif
++ goto cleanup;
++ }
++
++ GetGlobal()->m_fpHXMediaPlatformOpen = (FPHXMEDIAPLATFORMOPEN) pDLLAccess->getSymbol("HXMediaPlatformOpen");
++ GetGlobal()->m_fpHXCreateMediaPlatform = (FPHXCREATEMEDIAPLATFORM) pDLLAccess->getSymbol("HXCreateMediaPlatform");
++ GetGlobal()->m_fpHXMediaPlatformClose = (FPHXMEDIAPLATFORMCLOSE) pDLLAccess->getSymbol("HXMediaPlatformClose");
++
++ GetGlobal()->m_fpCreateEngine = (FPRMCREATEENGINE) pDLLAccess->getSymbol("CreateEngine");
++ GetGlobal()->m_fpCloseEngine = (FPRMCLOSEENGINE) pDLLAccess->getSymbol("CloseEngine");
++ GetGlobal()->m_fpSetDLLAccessPath = (FPRMSETDLLACCESSPATH) pDLLAccess->getSymbol("SetDLLAccessPath");
++
++ if (GetGlobal()->m_fpHXMediaPlatformOpen == NULL ||
++ GetGlobal()->m_fpHXCreateMediaPlatform == NULL ||
++ GetGlobal()->m_fpHXMediaPlatformClose == NULL ||
++ GetGlobal()->m_fpCreateEngine == NULL ||
++ GetGlobal()->m_fpCloseEngine == NULL ||
++ GetGlobal()->m_fpSetDLLAccessPath == NULL )
++ {
++ theErr = HXR_FAILED;
++ goto cleanup;
++ }
++
++#if defined(USE_XWINDOWS) && defined(HELIX_FEATURE_VIDEO)
++ XInitThreads();
++#endif
++
++ {
++ fpHXMediaPlatformOpen = GetGlobal()->m_fpHXMediaPlatformOpen;
++ fpHXCreateMediaPlatform = GetGlobal()->m_fpHXCreateMediaPlatform;
++ fpHXMediaPlatformClose = GetGlobal()->m_fpHXMediaPlatformClose;
++
++ if (HXR_OK != fpHXMediaPlatformOpen())
++ {
++ theErr = HXR_FAILED;
++ goto cleanup;
++ }
++
++ if (HXR_OK != fpHXCreateMediaPlatform((IHXMediaPlatform**)&GetGlobal()->pMediaPlatform))
++ {
++ theErr = HXR_FAILED;
++ goto cleanup;
++ }
++
++ IHXMediaPlatform* pMediaPlatform = GetGlobal()->pMediaPlatform;
++
++
++ if (HXR_OK != pMediaPlatform->AddPluginPath("HelixSimplePlayer", dllhome))
++ {
++ theErr = HXR_FAILED;
++ goto cleanup;
++ }
++
++ if (HXR_OK != pMediaPlatform->Init(NULL))
++ {
++ theErr = HXR_FAILED;
++ goto cleanup;
++ }
++
++ IHXCommonClassFactory* pCCF = NULL;
++ if (HXR_OK != pMediaPlatform->QueryInterface(IID_IHXCommonClassFactory,
++ (void**)&pCCF))
++ {
++ theErr = HXR_FAILED;
++ goto cleanup;
++ }
++
++ if (HXR_OK != pCCF->CreateInstance(CLSID_IHXClientEngine, (void**)&GetGlobal()->pEngine))
++ {
++ HX_RELEASE(pCCF);
++ theErr = HXR_FAILED;
++ goto cleanup;
++ }
++
++ HX_RELEASE(pCCF);
++
++ IHXMediaPlatformKicker* pKicker = NULL;
++ pMediaPlatform->QueryInterface(IID_IHXMediaPlatformKicker, (void**)&pKicker);
++ HX_ASSERT(pKicker);
++ GetGlobal()->g_pIHXKicker = pKicker;
++ GetGlobal()->g_uThreadIDForKicker = HXGetCurrentThreadID();
++
++ pthread_t thread_id;
++ pthread_create(&thread_id, NULL, kickman, NULL);
++ GetGlobal()->g_pThreadKickmanId = thread_id;
++ }
++
++
++
++ {
++
++
++#if defined(_WIN32) && !defined(WIN32_PLATFORM_PSPC)
++ SetConsoleCtrlHandler((PHANDLER_ROUTINE)HandlerRoutine,
++ TRUE);
++#endif
++
++ }
++
++ return HXR_OK;
++
++ cleanup:
++ deinit_main();
++ return HXR_FAIL;
++}
++
++/* Get the least index to available entry in Getglobal()->gPlayers */
++static int get_index()
++{
++ int i;
++ /* an simple implementation */
++ for (i = 0; i < MAX_NUM_PLAYERS; i++)
++ {
++ if (GetGlobal()->g_Players[i] == NULL)
++ return i;
++ }
++
++ return -1;
++}
++
++PLAYER_API unsigned int get_curr_playtime(void *pPlayerHandle)
++{
++ unsigned int time = 0;
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ if (pPlayer)
++ time = pPlayer->GetCurrentPlayTime();
++ return time;
++}
++
++PLAYER_API int get_player(void **ppPlayerHandle, on_buffering_cb_t on_buffering_cb, on_pos_length_cb_t on_pos_length_cb, on_state_change_cb_t on_state_change_cb, on_new_frame_cb_t on_new_frame_cb, void *context)
++{
++ int index = get_index();
++ IHXPlayer **ppPlayer = (IHXPlayer **)ppPlayerHandle;
++ ExampleClientContext* pExContext = NULL;
++ pExContext = new ExampleClientContext(index);
++ if (!pExContext)
++ {
++ return HXR_UNEXPECTED;
++ }
++ pExContext->AddRef();
++
++ ppPlayer[0] = NULL;
++ IHXClientEngine* pEngine = GetGlobal()->pEngine;
++ if (HXR_OK != pEngine->CreatePlayer(*ppPlayer))
++ {
++ HX_RELEASE(pExContext);
++ return HXR_FAILED;
++ }
++#if 1
++ char* pszGUIDList = NULL;
++ //initialize the example context
++ pszGUIDList = GetGlobal()->g_pszGUIDList;
++ {
++ char pszGUID[GUID_LEN + 1]; /* Flawfinder: ignore */ // add 1 for terminator
++ char* token = NULL;
++ IHXPreferences* pPreferences = NULL;
++
++ pszGUID[0] = '\0';
++
++ if (pszGUIDList)
++ {
++ // Get next GUID from the GUID list
++ {
++ token = strtok(pszGUIDList, "\n\0");
++ }
++ if (token)
++ {
++ strncpy(pszGUID, token, GUID_LEN); /* Flawfinder: ignore */
++ pszGUID[GUID_LEN] = '\0';
++ }
++ }
++
++ ppPlayer[0]->QueryInterface(IID_IHXPreferences,
++ (void**) &pPreferences);
++
++ pExContext->Init(ppPlayer[0], pPreferences, pszGUID, on_buffering_cb, on_pos_length_cb, on_state_change_cb, on_new_frame_cb, context);
++
++ ppPlayer[0]->SetClientContext(pExContext);
++
++ HX_RELEASE(pPreferences);
++
++ IHXErrorSinkControl* pErrorSinkControl = NULL;
++ ppPlayer[0]->QueryInterface(IID_IHXErrorSinkControl,
++ (void**) &pErrorSinkControl);
++
++ if (pErrorSinkControl)
++ {
++ IHXErrorSink* pErrorSink = NULL;
++ pExContext->QueryInterface(IID_IHXErrorSink,
++ (void**) &pErrorSink);
++ if (pErrorSink)
++ {
++ pErrorSinkControl->AddErrorSink(pErrorSink, HXLOG_EMERG, HXLOG_INFO);
++ }
++ HX_RELEASE(pErrorSink);
++ }
++ HX_RELEASE(pErrorSinkControl);
++ GetGlobal()->g_prefList.SetPreferences(ppPlayer[0]);
++
++ }
++#endif
++ HX_ASSERT(GetGlobal()->g_nPlayers < MAX_NUM_PLAYERS);
++ GetGlobal()->g_Players[index] = ppPlayer[0];
++ GetGlobal()->g_pClientContexts[index] = pExContext;
++ GetGlobal()->g_nPlayers++;
++
++ return HXR_OK;
++}
++
++static int get_index_by_player( IHXPlayer *pPlayer)
++{
++ int i;
++ /* an simple implementation */
++ for (i = 0; i < MAX_NUM_PLAYERS; i++)
++ {
++ if (GetGlobal()->g_Players[i] && GetGlobal()->g_Players[i] == pPlayer)
++ return i;
++ }
++
++ return -1;
++}
++
++PLAYER_API int player_openurl( void *pPlayerHandle, char *pszRawURL)
++{
++ HX_RESULT ret;
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ int index = get_index_by_player(pPlayer);
++ if (index < 0)
++ return HXR_FAIL;
++
++ char *pszURLOrig = RemoveWrappingQuotes(pszRawURL);
++
++ //if no "://" was found lets add file:// by default so that you
++ //can refer to local content as just ./splay ~/Content/startrek.rm,
++ //for example, and not ./splay file:///home/gregory/Content/startrek.rm
++ char* pszAddOn = NULL;
++ if( strstr( pszURLOrig, "://") )
++ pszAddOn = (char *)"";
++ else
++ pszAddOn = (char *)"file://";
++
++ char *pszURL = new char[strlen(pszURLOrig)+strlen(pszAddOn)+1];
++ sprintf( pszURL, "%s%s", pszAddOn, pszURLOrig ); /* Flawfinder: ignore */
++ // Increment the number of URLs we have found
++ STDERR("opening %s on player\n", pszURL);
++
++ GetGlobal()->g_pszURLs[index] = pszURL;
++ ret = pPlayer->OpenURL(pszURL);
++
++ UINT32 sleepTime = 0;
++
++ IHXMediaPlatformKicker* pKicker = GetGlobal()->g_pIHXKicker;
++ if( pKicker )
++ {
++ pKicker->Kick(HXGetCurrentThreadID(), &sleepTime);
++ }
++
++ return ret;
++}
++
++PLAYER_API int put_player( void *pPlayerHandle)
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ int index;
++ index = get_index_by_player(pPlayer);
++ if (index < 0)
++ return HXR_FAIL;
++
++ ExampleClientContext *pClientContext = GetGlobal()->g_pClientContexts[index];
++ if (pClientContext) {
++ pClientContext->Release();
++ pClientContext = NULL;
++ }
++
++ GetGlobal()->g_pClientContexts[index] = NULL;
++ if (pPlayer) {
++ if (GetGlobal()->pEngine) {
++ GetGlobal()->pEngine->ClosePlayer(pPlayer);
++ }
++ pPlayer->Release();
++ pPlayer = NULL;
++ }
++ GetGlobal()->g_Players[index] = NULL;
++ GetGlobal()->g_nPlayers--;
++ delete [] GetGlobal()->g_pszURLs[index];
++ GetGlobal()->g_pszURLs[index] = NULL;
++
++ return HXR_OK;
++}
++
++PLAYER_API int player_geturl( void *pPlayerHandle, char **pszURL)
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ int index = get_index_by_player(pPlayer);
++ if (index >= 0) {
++ *pszURL = GetGlobal()->g_pszURLs[index];
++ return HXR_OK;
++ }
++
++ return HXR_FAIL;
++}
++
++PLAYER_API int player_begin( void *pPlayerHandle )
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ UINT32 sleepTime = 0;
++ pPlayer->Begin();
++
++#if 0
++ IHXMediaPlatformKicker* pKicker = GetGlobal()->g_pIHXKicker;
++ if( pKicker )
++ {
++ pKicker->Kick(HXGetCurrentThreadID(), &sleepTime);
++ }
++#endif
++ return HXR_OK;
++}
++
++PLAYER_API int player_pause( void *pPlayerHandle )
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ UINT32 sleepTime = 0;
++ pPlayer->Pause();
++
++#if 0
++ IHXMediaPlatformKicker* pKicker = GetGlobal()->g_pIHXKicker;
++ if( pKicker )
++ {
++ pKicker->Kick(HXGetCurrentThreadID(), &sleepTime);
++ }
++#endif
++ return HXR_OK;
++}
++
++PLAYER_API int player_stop( void *pPlayerHandle )
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ pPlayer->Stop();
++ return HXR_OK;
++}
++
++#if 0
++int main(int argc, char *argv[])
++{
++ IHXPlayer *pPlayer;
++ init_main();
++ while(1) {
++ get_player(&pPlayer);
++ player_openurl(pPlayer, argv[1]);
++ player_begin(pPlayer);
++ // sleep(2);
++ player_stop(pPlayer);
++ put_player(pPlayer);
++ }
++ deinit_main();
++ return 0;
++}
++#endif
++
++PLAYER_API int player_seek(void *pPlayerHandle, int pos)
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ if (pPlayer == NULL)
++ return HXR_FAIL;
++
++ return pPlayer->Seek(pos);
++}
++PLAYER_API int player_getvolume(void *pPlayerHandle)
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ if (pPlayer == NULL)
++ return HXR_FAIL;
++
++ int volume = 0;
++
++ IHXAudioPlayer* pAudioPlayer = NULL;
++ pPlayer->QueryInterface(IID_IHXAudioPlayer, (void**) &pAudioPlayer);
++ if (pAudioPlayer)
++ {
++ // Get the IHXVolume
++ IHXVolume* pVolume = pAudioPlayer->GetAudioVolume();
++ if (pVolume)
++ {
++ volume = pVolume->GetVolume();
++ }
++ HX_RELEASE(pVolume);
++ }
++ HX_RELEASE(pAudioPlayer);
++
++ return volume;
++}
++
++
++PLAYER_API int player_setvolume(void *pPlayerHandle, unsigned short volume)
++{
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ if (pPlayer == NULL)
++ return HXR_FAIL;
++
++ IHXAudioPlayer* pAudioPlayer = NULL;
++ pPlayer->QueryInterface(IID_IHXAudioPlayer, (void**) &pAudioPlayer);
++ if (pAudioPlayer)
++ {
++ // Get the IHXVolume
++ IHXVolume* pVolume = pAudioPlayer->GetAudioVolume();
++ if (pVolume)
++ {
++ pVolume->SetVolume(volume);
++ }
++ HX_RELEASE(pVolume);
++ }
++ HX_RELEASE(pAudioPlayer);
++}
++
++PLAYER_API int deinit_main()
++{
++
++ pthread_cancel(GetGlobal()->g_pThreadKickmanId);
++ int ret ;
++ ret = pthread_join(GetGlobal()->g_pThreadKickmanId, NULL);
++ if (ret < 0) {
++ perror("pthread_join error\n");
++ }
++#if defined(HELIX_FEATURE_PLAYBACK_VELOCITY)
++ if (GetGlobal()->g_pVelocityCaps)
++ {
++ IHXPlaybackVelocityCaps* pCaps = GetGlobal()->g_pVelocityCaps;
++ pCaps->Release();
++ GetGlobal()->g_pVelocityCaps = NULL;
++ }
++#endif /* #if defined(HELIX_FEATURE_PLAYBACK_VELOCITY) */
++
++#ifdef __TCS__
++ g_nPlayers = 0;
++#endif
++
++
++ {
++ IHXClientEngine* pEngine = GetGlobal()->pEngine;
++
++ if (pEngine)
++ {
++ IHXClientEngine2* pEngine2 = NULL;
++ if (HXR_OK == pEngine->QueryInterface(IID_IHXClientEngine2,
++ (void**)&pEngine2))
++ {
++ pEngine2->Close();
++ }
++ HX_RELEASE(pEngine2);
++ }
++ HX_RELEASE(GetGlobal()->pEngine);
++ HX_RELEASE(GetGlobal()->g_pIHXKicker);
++
++ if (GetGlobal()->pMediaPlatform)
++ {
++ // Reset() not only close the platform but also remove all
++ // persistent information(i.e. preferences) maintained by the
++ // platform
++ // GetGlobal()->pMediaPlatform->Reset(NULL);
++ GetGlobal()->pMediaPlatform->Close();
++ HX_RELEASE(GetGlobal()->pMediaPlatform);
++ }
++
++ if (GetGlobal()->m_fpHXMediaPlatformClose)
++ {
++ GetGlobal()->m_fpHXMediaPlatformClose();
++ }
++ }
++
++
++ if (GetGlobal()->bEnableVerboseMode)
++ {
++ STDOUT("\nDone.\n");
++ }
++
++ if (GetGlobal()->g_pszUsername)
++ {
++ delete [] GetGlobal()->g_pszUsername;
++ GetGlobal()->g_pszUsername = NULL;
++ }
++ if (GetGlobal()->g_pszPassword)
++ {
++ delete [] GetGlobal()->g_pszPassword;
++ GetGlobal()->g_pszPassword = NULL;
++ }
++ if (GetGlobal()->g_pszGUIDFile)
++ {
++ delete [] GetGlobal()->g_pszGUIDFile;
++ GetGlobal()->g_pszGUIDFile = NULL;
++ }
++ if (GetGlobal()->g_pszGUIDList)
++ {
++ delete [] GetGlobal()->g_pszGUIDList;
++ GetGlobal()->g_pszGUIDList = NULL;
++ }
++ // If an error occurred during playback, return that
++
++ if (GetGlobal()->g_Error != HXR_OK)
++ {
++ return GetGlobal()->g_Error;
++ }
++ // or HXR_OK (if there was more than one player)
++ else
++ {
++ return HXR_OK;
++ }
++}
++char* GetAppName(char* pszArgv0)
++{
++ char* pszAppName;
++
++ pszAppName = strrchr(pszArgv0, '\\');
++
++ if (NULL == pszAppName)
++ {
++ return pszArgv0;
++ }
++ else
++ {
++ return pszAppName + 1;
++ }
++}
++
++void PrintUsage(const char* pszAppName)
++{
++}
++
++
++
++HXBOOL ReadGUIDFile()
++{
++ HXBOOL bSuccess = FALSE;
++ FILE* pFile = NULL;
++ int nNumRead = 0;
++ int readSize = 10000;
++ char* pszBuffer = new char[readSize];
++
++ if (GetGlobal()->g_pszGUIDFile)
++ {
++ if((pFile = fopen(GetGlobal()->g_pszGUIDFile, "r")) != NULL)
++ {
++ // Read in the entire file
++ nNumRead = fread(pszBuffer, sizeof(char), readSize, pFile);
++ pszBuffer[nNumRead] = '\0';
++
++ // Store it for later parsing
++ GetGlobal()->g_pszGUIDList = new char[nNumRead + 1];
++ strcpy(GetGlobal()->g_pszGUIDList, pszBuffer); /* Flawfinder: ignore */
++
++ fclose(pFile);
++ pFile = NULL;
++
++ if (nNumRead > 0)
++ {
++ bSuccess = TRUE;
++ }
++ }
++ }
++
++ delete [] pszBuffer;
++
++ return bSuccess;
++}
++
++static int are_all_src_seekable(IHXPlayer *pPlayer)
++{
++ UINT16 nSrcCnt;
++ nSrcCnt = pPlayer->GetSourceCount();
++ HXSource *pSource = NULL; /* This is brute-force */
++ for (UINT16 i = 0; i < nSrcCnt; i++)
++ {
++ if (pPlayer->GetSource(i, (IUnknown *&)pSource) == HXR_OK)
++ {
++ if (!pSource->IsSeekable())
++ return FALSE;
++
++
++ }
++ }
++
++}
++
++PLAYER_API int player_canseek(void *pPlayerHandle)
++{
++ if (!pPlayerHandle)
++ return FALSE;
++
++ IHXPlayer *pPlayer = (IHXPlayer *)pPlayerHandle;
++ ExampleClientContext* pExContext=NULL;
++ if (pPlayer->GetClientContext((IUnknown*&)pExContext) != HXR_OK)
++ return FALSE;
++
++ if (!pExContext)
++ return FALSE;
++
++ EHXClientState State = pExContext->GetState();
++
++ int all_src_seekable = are_all_src_seekable(pPlayer);
++
++ HX_RELEASE(pExContext);
++
++ if (State < HX_CLIENT_STATE_CONNECTED)
++ return TRUE;
++
++ if (all_src_seekable && (!pPlayer->IsLive() || State == HX_CLIENT_STATE_PAUSED))
++ return TRUE;
++
++ return FALSE;
++}
++
++
+Index: helix-libs/clientapps/clutter/player.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/player.h 2008-10-13 06:54:45.000000000 -0700
+@@ -0,0 +1,60 @@
++#ifndef _PLAYER_H_
++#define _PLAYER_H_
++
++#ifdef __cplusplus
++#define PLAYER_API extern "C"
++#else
++#define PLAYER_API
++#endif
++
++/* Duplicate of EHXClientState */
++typedef enum _EPlayerStateState
++{
++ PLAYER_STATE_READY = 0, // uninitialized
++ PLAYER_STATE_CONNECTING, // attempting to connect to sources
++ PLAYER_STATE_CONNECTED, // connected to sources (realized)
++ PLAYER_STATE_OPENING, // opening sources
++ PLAYER_STATE_OPENED, // opened sources
++ PLAYER_STATE_PREFETCHING,// obtaining resources, buffering, etc.
++ PLAYER_STATE_PREFETCHED, // ready for playback at time zero
++ PLAYER_STATE_PLAYING, // currently playing
++ PLAYER_STATE_PAUSED, // paused
++ PLAYER_STATE_SEEKING // seeking
++} EHXPlayerState;
++
++typedef struct {
++ int left;
++ int top;
++ int right;
++ int bottom;
++} PlayerRect;
++
++typedef struct {
++ PlayerRect Rect;
++ unsigned int cx;
++ unsigned int cy;
++} PlayerImgInfo;
++
++typedef void (*on_pos_length_cb_t)(unsigned int, unsigned int, void *);
++typedef void (*on_buffering_cb_t)(unsigned int, unsigned short, void *);
++typedef void (*on_state_change_cb_t)(unsigned short, unsigned short, void *);
++typedef void (*on_new_frame_cb_t)(unsigned char *p, unsigned int size, PlayerImgInfo *rect, void *context);
++
++PLAYER_API int init_main();
++PLAYER_API int deinit_main();
++PLAYER_API int get_player(void **ppPlayerHandle, on_buffering_cb_t on_buffering_cb, on_pos_length_cb_t on_pos_length_cb, on_state_change_cb_t on_state_change_cb, on_new_frame_cb_t on_new_frame_cb, void *context);
++PLAYER_API int player_openurl( void *pPlayerHandle, char *pszRawURL);
++PLAYER_API int put_player( void *pPlayerHandle);
++PLAYER_API int player_geturl( void *pPlayerHandle, char **pszURL);
++PLAYER_API int player_begin( void *pPlayerHandle );
++PLAYER_API int player_stop( void *pPlayerHandle );
++PLAYER_API int player_pause( void *pPlayerHandle );
++PLAYER_API unsigned int get_curr_playtime(void *pPlayerHandle);
++PLAYER_API int player_seek(void *pPlayerHandle, int pos);
++PLAYER_API int player_getvolume(void *pPlayerHandle);
++PLAYER_API int player_setvolume(void *pPlayerHandle, unsigned short volumn);
++PLAYER_API int player_canseek(void *pPlayerHandle);
++
++
++#endif
++
+Index: helix-libs/clientapps/clutter/preflist.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/preflist.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,142 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: preflist.cpp,v 1.2 2007/07/06 20:32:36 jfinnecy Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++#include "preflist.h"
++
++#include "hxstring.h"
++#include "hxccf.h"
++#include "hxprefs.h"
++#include "ihxpckts.h"
++
++class CHXPrefInfo
++{
++public:
++ CHXPrefInfo(const char* pKey, const char* pValue);
++ ~CHXPrefInfo();
++
++ const char* Key() const { return m_key;}
++ const char* Value() const { return m_value;}
++
++private:
++ CHXString m_key;
++ CHXString m_value;
++};
++
++CHXPrefInfo::CHXPrefInfo(const char* pKey, const char* pValue) :
++ m_key(pKey),
++ m_value(pValue)
++{}
++
++CHXPrefInfo::~CHXPrefInfo()
++{}
++
++CHXPrefList::CHXPrefList()
++{}
++
++CHXPrefList::~CHXPrefList()
++{
++ Clear();
++}
++
++void CHXPrefList::Add(const char* pKey, const char* pValue)
++{
++ CHXPrefInfo* pInfo = new CHXPrefInfo(pKey, pValue);
++
++ if (pInfo)
++ {
++ if (!m_prefInfo.AddTail(pInfo))
++ {
++ // We failed to insert the preference.
++ HX_DELETE(pInfo);
++ }
++ }
++}
++
++void CHXPrefList::Clear()
++{
++ while(!m_prefInfo.IsEmpty())
++ {
++ CHXPrefInfo* pInfo = (CHXPrefInfo*)m_prefInfo.RemoveHead();
++ HX_DELETE(pInfo);
++ }
++}
++
++void CHXPrefList::SetPreferences(IUnknown* pContext)
++{
++ IHXPreferences* pPrefs = NULL;
++ IHXCommonClassFactory* pCCF = NULL;
++
++ if (pContext &&
++ (HXR_OK == pContext->QueryInterface(IID_IHXPreferences,
++ (void**)&pPrefs)) &&
++ (HXR_OK == pContext->QueryInterface(IID_IHXCommonClassFactory,
++ (void**)&pCCF)))
++ {
++ CHXSimpleList::Iterator itr = m_prefInfo.Begin();
++
++ for(; itr != m_prefInfo.End(); ++itr)
++ {
++ CHXPrefInfo* pInfo = (CHXPrefInfo*)(*itr);
++
++ IHXBuffer* pBuf = NULL;
++
++ if ((HXR_OK == pCCF->CreateInstance(CLSID_IHXBuffer,
++ (void**)&pBuf)) &&
++ (HXR_OK == pBuf->Set((const unsigned char*)pInfo->Value(),
++ strlen(pInfo->Value()))))
++ {
++ pPrefs->WritePref(pInfo->Key(), pBuf);
++ }
++
++ HX_RELEASE(pBuf);
++ }
++ }
++
++ HX_RELEASE(pPrefs);
++ HX_RELEASE(pCCF);
++}
+Index: helix-libs/clientapps/clutter/preflist.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/preflist.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,69 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: preflist.h,v 1.2 2007/07/06 20:32:36 jfinnecy Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++#ifndef PREFLIST_H
++#define PREFLIST_H
++
++#include "hxslist.h"
++
++class CHXPrefList
++{
++public:
++ CHXPrefList();
++ ~CHXPrefList();
++
++ void Add(const char* pKey, const char* pValue);
++ void Clear();
++
++ void SetPreferences(IUnknown* pContext);
++
++private:
++ CHXSimpleList m_prefInfo;
++};
++
++#endif /* PREFLIST_H */
+Index: helix-libs/clientapps/clutter/print.cpp
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/print.cpp 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,80 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#include <stdarg.h>
++#include <stdio.h>
++#include "print.h"
++#ifdef WIN32_PLATFORM_PSPC
++#include "hlxosstr.h"
++#include <winbase.h>
++#endif
++
++int print2stdout(const char* pFmt, ...)
++{
++ va_list args;
++
++ va_start(args, pFmt);
++
++#ifdef WIN32_PLATFORM_PSPC
++ char szMessage[512];
++ int ret = vsprintf(szMessage, pFmt, args);
++ OutputDebugString(OS_STRING(szMessage));
++#else
++ int ret = vfprintf(stdout, pFmt, args);
++#endif
++
++ va_end(args);
++
++ return ret;
++}
++
++int print2stderr(const char* pFmt, ...)
++{
++ va_list args;
++
++ va_start(args, pFmt);
++
++#ifdef WIN32_PLATFORM_PSPC
++ char szMessage[512];
++ int ret = vsprintf(szMessage, pFmt, args);
++ OutputDebugString(OS_STRING(szMessage));
++#else
++ int ret = vfprintf(stderr, pFmt, args);
++#endif
++
++ va_end(args);
++
++ return ret;
++}
+Index: helix-libs/clientapps/clutter/print.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/print.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,60 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Version: RCSL 1.0/RPSL 1.0
++ *
++ * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file, are
++ * subject to the current version of the RealNetworks Public Source License
++ * Version 1.0 (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the RealNetworks Community Source License Version 1.0
++ * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++ * in which case the RCSL will apply. You may also obtain the license terms
++ * directly from RealNetworks. You may not use this file except in
++ * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++ * applicable to this file, the RCSL. Please see the applicable RPSL or
++ * RCSL for the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the portions
++ * it created.
++ *
++ * This file, and the files included with this file, is distributed and made
++ * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++ * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++ * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++ * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef PRINT_H
++#define PRINT_H
++
++#ifdef __cplusplus
++extern "C" {
++#endif
++
++#ifdef _SYMBIAN
++#include "platform/symbian/symbian_print.h"
++
++#define STDOUT symbianPrint
++#define STDERR symbianPrint
++#else
++int print2stdout(const char* pFmt, ...);
++int print2stderr(const char* pFmt, ...);
++#define STDOUT print2stdout
++#define STDERR print2stderr
++#endif
++
++#ifdef __cplusplus
++};
++#endif
++
++
++#endif /* PRINT_H */
+Index: helix-libs/clientapps/clutter/shmhelp.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/shmhelp.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,88 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: shmhelp.h,v 1.5 2007/07/06 20:54:01 jfinnecy Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#if defined(USE_XWINDOWS)
++#include <X11/X.h>
++#include <X11/Xlib.h>
++#include <X11/extensions/XShm.h>
++#endif
++
++#include "hxcom.h"
++#include "hxtypes.h"
++
++
++class ShmHelp
++{
++ public:
++
++ //Helpers
++ static void Init(Display* pDisplay );
++ static HXBOOL ShmAvailable();
++ static HX_RESULT DetachSharedRegion(UCHAR**ppMem, XShmSegmentInfo* pInfo );
++ static HX_RESULT CreateSharedRegion( INT32 nSize,
++ UCHAR**ppMem,
++ int* pnShmID,
++ XShmSegmentInfo* pInfo );
++
++
++ protected:
++
++ private:
++ static HXBOOL zm_bUseShm;
++
++ //The X11 Segment ID....
++ static int zm_nSegment;
++ static Display* zm_pDisplay;
++
++ ShmHelp();
++ ShmHelp(Display*);
++ ~ShmHelp();
++
++};
++
+Index: helix-libs/clientapps/clutter/unix.pcf
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/unix.pcf 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,65 @@
++#
++# ***** BEGIN LICENSE BLOCK *****
++# Version: RCSL 1.0/RPSL 1.0
++#
++# Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
++#
++# The contents of this file, and the files included with this file, are
++# subject to the current version of the RealNetworks Public Source License
++# Version 1.0 (the "RPSL") available at
++# http://www.helixcommunity.org/content/rpsl unless you have licensed
++# the file under the RealNetworks Community Source License Version 1.0
++# (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
++# in which case the RCSL will apply. You may also obtain the license terms
++# directly from RealNetworks. You may not use this file except in
++# compliance with the RPSL or, if you have a valid RCSL with RealNetworks
++# applicable to this file, the RCSL. Please see the applicable RPSL or
++# RCSL for the rights, obligations and limitations governing use of the
++# contents of the file.
++#
++# This file is part of the Helix DNA Technology. RealNetworks is the
++# developer of the Original Code and owns the copyrights in the portions
++# it created.
++#
++# This file, and the files included with this file, is distributed and made
++# available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
++# EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
++# INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
++# FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
++#
++# Technology Compatibility Kit Test Suite(s) Location:
++# http://www.helixcommunity.org/content/tck
++#
++# Contributor(s):
++#
++# ***** END LICENSE BLOCK *****
++#
++
++
++if( ('HELIX_FEATURE_MINI_SITE' not in project.defines) and
++ (platform.name in ('linux2', 'linux-i386')) and
++ ('HELIX_FEATURE_VIDEO' in project.defines) and
++ (project.BuildOption("nodll"))
++ ):
++ project.sys_libraries.append('Xv', 'Xext')
++
++
++
++
++if project.BuildOption("nodll"):
++ if project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV20"):
++ if platform.name in ('linux2', 'linux-i386', 'win32') and sysinfo.arch == 'i386':
++ project.AddLibraries(GetSDKPath("rvg2dec_libs") + '[adecg2]')
++ else:
++ project.AddLibraries(GetSDKPath("rvg2dec_libs") + '[cdecg2]')
++
++ if project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV30") or \
++ project.IsDefined("HELIX_FEATURE_VIDEO_CODEC_RV40"):
++ if project.IsDefined("HELIX_FEATURE_ANSIC_RV89COMBO"):
++ project.AddLibraries(GetSDKPath("rv89combo_c_libs")+"[cdec]")
++ else:
++ if platform.name in ('linux2', 'linux-i386') and sysinfo.arch == 'i386':
++ project.AddLibraries(GetSDKPath("rv89combo_libs")+"[adec40]")
++ else:
++ project.AddLibraries(GetSDKPath("rv89combo_libs")+"[cdec40]")
++
+Index: helix-libs/clientapps/clutter/unixcmap.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/unixcmap.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,51 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: unixcmap.h,v 1.3 2007/07/06 20:54:01 jfinnecy Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++EXTERN_C Colormap HXGetXColormap(Display* pDisplay, Window window);
++EXTERN_C void HXFindBestXColor(Display* pDisplay, Colormap cmap, XColor* desired);
+Index: helix-libs/clientapps/clutter/visuals.h
+===================================================================
+--- /dev/null 1970-01-01 00:00:00.000000000 +0000
++++ helix-libs/clientapps/clutter/visuals.h 2008-10-13 06:05:49.000000000 -0700
+@@ -0,0 +1,74 @@
++/* ***** BEGIN LICENSE BLOCK *****
++ * Source last modified: $Id: visuals.h,v 1.4 2007/07/06 20:54:01 jfinnecy Exp $
++ *
++ * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
++ *
++ * The contents of this file, and the files included with this file,
++ * are subject to the current version of the RealNetworks Public
++ * Source License (the "RPSL") available at
++ * http://www.helixcommunity.org/content/rpsl unless you have licensed
++ * the file under the current version of the RealNetworks Community
++ * Source License (the "RCSL") available at
++ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
++ * will apply. You may also obtain the license terms directly from
++ * RealNetworks. You may not use this file except in compliance with
++ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
++ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
++ * the rights, obligations and limitations governing use of the
++ * contents of the file.
++ *
++ * Alternatively, the contents of this file may be used under the
++ * terms of the GNU General Public License Version 2 (the
++ * "GPL") in which case the provisions of the GPL are applicable
++ * instead of those above. If you wish to allow use of your version of
++ * this file only under the terms of the GPL, and not to allow others
++ * to use your version of this file under the terms of either the RPSL
++ * or RCSL, indicate your decision by deleting the provisions above
++ * and replace them with the notice and other provisions required by
++ * the GPL. If you do not delete the provisions above, a recipient may
++ * use your version of this file under the terms of any one of the
++ * RPSL, the RCSL or the GPL.
++ *
++ * This file is part of the Helix DNA Technology. RealNetworks is the
++ * developer of the Original Code and owns the copyrights in the
++ * portions it created.
++ *
++ * This file, and the files included with this file, is distributed
++ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
++ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
++ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
++ * ENJOYMENT OR NON-INFRINGEMENT.
++ *
++ * Technology Compatibility Kit Test Suite(s) Location:
++ * http://www.helixcommunity.org/content/tck
++ *
++ * Contributor(s):
++ *
++ * ***** END LICENSE BLOCK ***** */
++
++#ifndef _UNIX
++#error This is the UNIX platform specific implementation.
++#endif
++
++#ifndef _VISUALS_H_
++#define _VISUALS_H_
++
++#if defined(USE_XWINDOWS)
++#include <X11/Xlib.h>
++#include <X11/Xutil.h>
++#include <X11/Xos.h>
++#endif
++
++//
++// These functions are loaded with dlsym() so turn off name mangling
++// with extern "C".
++//
++extern "C" {
++
++Visual* GetBestVisual(Display* display);
++Visual* GetVisual(Display* display, long mask, XVisualInfo* templ);
++
++}
++
++#endif // _VISUALS_H_
diff --git a/meta-extras/packages/helix/helix-libs/helix-player.pc b/meta-extras/packages/helix/helix-libs/helix-player.pc
new file mode 100644
index 0000000000..5d2994809e
--- /dev/null
+++ b/meta-extras/packages/helix/helix-libs/helix-player.pc
@@ -0,0 +1,11 @@
+prefix=/usr
+exec_prefix=${prefix}
+libdir=${exec_prefix}/lib
+includedir=${prefix}/include
+
+Name: helix-player
+Description: Helix Player Interface
+Version: 4.1.0
+Libs: -L${libdir} -lhelix-player -lstdc++
+Cflags: -I/opt/helix/include -D_UNIX
+Requires:
diff --git a/meta-extras/packages/helix/helix-libs/hxclient.pc b/meta-extras/packages/helix/helix-libs/hxclient.pc
new file mode 100644
index 0000000000..8f64d25670
--- /dev/null
+++ b/meta-extras/packages/helix/helix-libs/hxclient.pc
@@ -0,0 +1,11 @@
+prefix=/opt/helix
+exec_prefix=${prefix}
+libdir=${exec_prefix}/lib
+includedir=${prefix}/include
+
+Name: hxclient
+Description: Helix Client Libraries off the Atlas Branch
+Version: 4.1.0
+Libs: -L${libdir} -lhxclient -lstdc++
+Cflags: -I${includedir} -D_UNIX
+Requires: