|
@@ -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é
|
|
|
++que le présent contrat et tous les documents connexes soient
|
|
|
++rédigés en anglais.
|
|
|
++
|
|
|
++ EXHIBIT A.
|
|
|
++
|
|
|
++"Copyright © 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_
|