Compare commits
No commits in common. "main" and "gh-pages" have entirely different histories.
18
.gitignore
vendored
18
.gitignore
vendored
@ -1,18 +0,0 @@
|
||||
.deps/
|
||||
.libs/
|
||||
*.a
|
||||
*.la
|
||||
*.lo
|
||||
*.o
|
||||
*.pc
|
||||
Makefile
|
||||
Makefile.in
|
||||
.dirstamp
|
||||
|
||||
/aclocal.m4
|
||||
/autom4te.cache/
|
||||
/build-aux/
|
||||
/config.*
|
||||
/configure
|
||||
/libtool
|
||||
/stamp-h1
|
502
LICENSE.LGPL
502
LICENSE.LGPL
@ -1,502 +0,0 @@
|
||||
GNU LESSER GENERAL PUBLIC LICENSE
|
||||
Version 2.1, February 1999
|
||||
|
||||
Copyright (C) 1991, 1999 Free Software Foundation, Inc.
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
[This is the first released version of the Lesser GPL. It also counts
|
||||
as the successor of the GNU Library Public License, version 2, hence
|
||||
the version number 2.1.]
|
||||
|
||||
Preamble
|
||||
|
||||
The licenses for most software are designed to take away your
|
||||
freedom to share and change it. By contrast, the GNU General Public
|
||||
Licenses are intended to guarantee your freedom to share and change
|
||||
free software--to make sure the software is free for all its users.
|
||||
|
||||
This license, the Lesser General Public License, applies to some
|
||||
specially designated software packages--typically libraries--of the
|
||||
Free Software Foundation and other authors who decide to use it. You
|
||||
can use it too, but we suggest you first think carefully about whether
|
||||
this license or the ordinary General Public License is the better
|
||||
strategy to use in any particular case, based on the explanations below.
|
||||
|
||||
When we speak of free software, we are referring to freedom of use,
|
||||
not price. Our General Public Licenses are designed to make sure that
|
||||
you have the freedom to distribute copies of free software (and charge
|
||||
for this service if you wish); that you receive source code or can get
|
||||
it if you want it; that you can change the software and use pieces of
|
||||
it in new free programs; and that you are informed that you can do
|
||||
these things.
|
||||
|
||||
To protect your rights, we need to make restrictions that forbid
|
||||
distributors to deny you these rights or to ask you to surrender these
|
||||
rights. These restrictions translate to certain responsibilities for
|
||||
you if you distribute copies of the library or if you modify it.
|
||||
|
||||
For example, if you distribute copies of the library, whether gratis
|
||||
or for a fee, you must give the recipients all the rights that we gave
|
||||
you. You must make sure that they, too, receive or can get the source
|
||||
code. If you link other code with the library, you must provide
|
||||
complete object files to the recipients, so that they can relink them
|
||||
with the library after making changes to the library and recompiling
|
||||
it. And you must show them these terms so they know their rights.
|
||||
|
||||
We protect your rights with a two-step method: (1) we copyright the
|
||||
library, and (2) we offer you this license, which gives you legal
|
||||
permission to copy, distribute and/or modify the library.
|
||||
|
||||
To protect each distributor, we want to make it very clear that
|
||||
there is no warranty for the free library. Also, if the library is
|
||||
modified by someone else and passed on, the recipients should know
|
||||
that what they have is not the original version, so that the original
|
||||
author's reputation will not be affected by problems that might be
|
||||
introduced by others.
|
||||
|
||||
Finally, software patents pose a constant threat to the existence of
|
||||
any free program. We wish to make sure that a company cannot
|
||||
effectively restrict the users of a free program by obtaining a
|
||||
restrictive license from a patent holder. Therefore, we insist that
|
||||
any patent license obtained for a version of the library must be
|
||||
consistent with the full freedom of use specified in this license.
|
||||
|
||||
Most GNU software, including some libraries, is covered by the
|
||||
ordinary GNU General Public License. This license, the GNU Lesser
|
||||
General Public License, applies to certain designated libraries, and
|
||||
is quite different from the ordinary General Public License. We use
|
||||
this license for certain libraries in order to permit linking those
|
||||
libraries into non-free programs.
|
||||
|
||||
When a program is linked with a library, whether statically or using
|
||||
a shared library, the combination of the two is legally speaking a
|
||||
combined work, a derivative of the original library. The ordinary
|
||||
General Public License therefore permits such linking only if the
|
||||
entire combination fits its criteria of freedom. The Lesser General
|
||||
Public License permits more lax criteria for linking other code with
|
||||
the library.
|
||||
|
||||
We call this license the "Lesser" General Public License because it
|
||||
does Less to protect the user's freedom than the ordinary General
|
||||
Public License. It also provides other free software developers Less
|
||||
of an advantage over competing non-free programs. These disadvantages
|
||||
are the reason we use the ordinary General Public License for many
|
||||
libraries. However, the Lesser license provides advantages in certain
|
||||
special circumstances.
|
||||
|
||||
For example, on rare occasions, there may be a special need to
|
||||
encourage the widest possible use of a certain library, so that it becomes
|
||||
a de-facto standard. To achieve this, non-free programs must be
|
||||
allowed to use the library. A more frequent case is that a free
|
||||
library does the same job as widely used non-free libraries. In this
|
||||
case, there is little to gain by limiting the free library to free
|
||||
software only, so we use the Lesser General Public License.
|
||||
|
||||
In other cases, permission to use a particular library in non-free
|
||||
programs enables a greater number of people to use a large body of
|
||||
free software. For example, permission to use the GNU C Library in
|
||||
non-free programs enables many more people to use the whole GNU
|
||||
operating system, as well as its variant, the GNU/Linux operating
|
||||
system.
|
||||
|
||||
Although the Lesser General Public License is Less protective of the
|
||||
users' freedom, it does ensure that the user of a program that is
|
||||
linked with the Library has the freedom and the wherewithal to run
|
||||
that program using a modified version of the Library.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow. Pay close attention to the difference between a
|
||||
"work based on the library" and a "work that uses the library". The
|
||||
former contains code derived from the library, whereas the latter must
|
||||
be combined with the library in order to run.
|
||||
|
||||
GNU LESSER GENERAL PUBLIC LICENSE
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License Agreement applies to any software library or other
|
||||
program which contains a notice placed by the copyright holder or
|
||||
other authorized party saying it may be distributed under the terms of
|
||||
this Lesser General Public License (also called "this License").
|
||||
Each licensee is addressed as "you".
|
||||
|
||||
A "library" means a collection of software functions and/or data
|
||||
prepared so as to be conveniently linked with application programs
|
||||
(which use some of those functions and data) to form executables.
|
||||
|
||||
The "Library", below, refers to any such software library or work
|
||||
which has been distributed under these terms. A "work based on the
|
||||
Library" means either the Library or any derivative work under
|
||||
copyright law: that is to say, a work containing the Library or a
|
||||
portion of it, either verbatim or with modifications and/or translated
|
||||
straightforwardly into another language. (Hereinafter, translation is
|
||||
included without limitation in the term "modification".)
|
||||
|
||||
"Source code" for a work means the preferred form of the work for
|
||||
making modifications to it. For a library, complete source code means
|
||||
all the source code for all modules it contains, plus any associated
|
||||
interface definition files, plus the scripts used to control compilation
|
||||
and installation of the library.
|
||||
|
||||
Activities other than copying, distribution and modification are not
|
||||
covered by this License; they are outside its scope. The act of
|
||||
running a program using the Library is not restricted, and output from
|
||||
such a program is covered only if its contents constitute a work based
|
||||
on the Library (independent of the use of the Library in a tool for
|
||||
writing it). Whether that is true depends on what the Library does
|
||||
and what the program that uses the Library does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Library's
|
||||
complete source code as you receive it, in any medium, provided that
|
||||
you conspicuously and appropriately publish on each copy an
|
||||
appropriate copyright notice and disclaimer of warranty; keep intact
|
||||
all the notices that refer to this License and to the absence of any
|
||||
warranty; and distribute a copy of this License along with the
|
||||
Library.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy,
|
||||
and you may at your option offer warranty protection in exchange for a
|
||||
fee.
|
||||
|
||||
2. You may modify your copy or copies of the Library or any portion
|
||||
of it, thus forming a work based on the Library, and copy and
|
||||
distribute such modifications or work under the terms of Section 1
|
||||
above, provided that you also meet all of these conditions:
|
||||
|
||||
a) The modified work must itself be a software library.
|
||||
|
||||
b) You must cause the files modified to carry prominent notices
|
||||
stating that you changed the files and the date of any change.
|
||||
|
||||
c) You must cause the whole of the work to be licensed at no
|
||||
charge to all third parties under the terms of this License.
|
||||
|
||||
d) If a facility in the modified Library refers to a function or a
|
||||
table of data to be supplied by an application program that uses
|
||||
the facility, other than as an argument passed when the facility
|
||||
is invoked, then you must make a good faith effort to ensure that,
|
||||
in the event an application does not supply such function or
|
||||
table, the facility still operates, and performs whatever part of
|
||||
its purpose remains meaningful.
|
||||
|
||||
(For example, a function in a library to compute square roots has
|
||||
a purpose that is entirely well-defined independent of the
|
||||
application. Therefore, Subsection 2d requires that any
|
||||
application-supplied function or table used by this function must
|
||||
be optional: if the application does not supply it, the square
|
||||
root function must still compute square roots.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If
|
||||
identifiable sections of that work are not derived from the Library,
|
||||
and can be reasonably considered independent and separate works in
|
||||
themselves, then this License, and its terms, do not apply to those
|
||||
sections when you distribute them as separate works. But when you
|
||||
distribute the same sections as part of a whole which is a work based
|
||||
on the Library, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the
|
||||
entire whole, and thus to each and every part regardless of who wrote
|
||||
it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest
|
||||
your rights to work written entirely by you; rather, the intent is to
|
||||
exercise the right to control the distribution of derivative or
|
||||
collective works based on the Library.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Library
|
||||
with the Library (or with a work based on the Library) on a volume of
|
||||
a storage or distribution medium does not bring the other work under
|
||||
the scope of this License.
|
||||
|
||||
3. You may opt to apply the terms of the ordinary GNU General Public
|
||||
License instead of this License to a given copy of the Library. To do
|
||||
this, you must alter all the notices that refer to this License, so
|
||||
that they refer to the ordinary GNU General Public License, version 2,
|
||||
instead of to this License. (If a newer version than version 2 of the
|
||||
ordinary GNU General Public License has appeared, then you can specify
|
||||
that version instead if you wish.) Do not make any other change in
|
||||
these notices.
|
||||
|
||||
Once this change is made in a given copy, it is irreversible for
|
||||
that copy, so the ordinary GNU General Public License applies to all
|
||||
subsequent copies and derivative works made from that copy.
|
||||
|
||||
This option is useful when you wish to copy part of the code of
|
||||
the Library into a program that is not a library.
|
||||
|
||||
4. You may copy and distribute the Library (or a portion or
|
||||
derivative of it, under Section 2) in object code or executable form
|
||||
under the terms of Sections 1 and 2 above provided that you accompany
|
||||
it with the complete corresponding machine-readable source code, which
|
||||
must be distributed under the terms of Sections 1 and 2 above on a
|
||||
medium customarily used for software interchange.
|
||||
|
||||
If distribution of object code is made by offering access to copy
|
||||
from a designated place, then offering equivalent access to copy the
|
||||
source code from the same place satisfies the requirement to
|
||||
distribute the source code, even though third parties are not
|
||||
compelled to copy the source along with the object code.
|
||||
|
||||
5. A program that contains no derivative of any portion of the
|
||||
Library, but is designed to work with the Library by being compiled or
|
||||
linked with it, is called a "work that uses the Library". Such a
|
||||
work, in isolation, is not a derivative work of the Library, and
|
||||
therefore falls outside the scope of this License.
|
||||
|
||||
However, linking a "work that uses the Library" with the Library
|
||||
creates an executable that is a derivative of the Library (because it
|
||||
contains portions of the Library), rather than a "work that uses the
|
||||
library". The executable is therefore covered by this License.
|
||||
Section 6 states terms for distribution of such executables.
|
||||
|
||||
When a "work that uses the Library" uses material from a header file
|
||||
that is part of the Library, the object code for the work may be a
|
||||
derivative work of the Library even though the source code is not.
|
||||
Whether this is true is especially significant if the work can be
|
||||
linked without the Library, or if the work is itself a library. The
|
||||
threshold for this to be true is not precisely defined by law.
|
||||
|
||||
If such an object file uses only numerical parameters, data
|
||||
structure layouts and accessors, and small macros and small inline
|
||||
functions (ten lines or less in length), then the use of the object
|
||||
file is unrestricted, regardless of whether it is legally a derivative
|
||||
work. (Executables containing this object code plus portions of the
|
||||
Library will still fall under Section 6.)
|
||||
|
||||
Otherwise, if the work is a derivative of the Library, you may
|
||||
distribute the object code for the work under the terms of Section 6.
|
||||
Any executables containing that work also fall under Section 6,
|
||||
whether or not they are linked directly with the Library itself.
|
||||
|
||||
6. As an exception to the Sections above, you may also combine or
|
||||
link a "work that uses the Library" with the Library to produce a
|
||||
work containing portions of the Library, and distribute that work
|
||||
under terms of your choice, provided that the terms permit
|
||||
modification of the work for the customer's own use and reverse
|
||||
engineering for debugging such modifications.
|
||||
|
||||
You must give prominent notice with each copy of the work that the
|
||||
Library is used in it and that the Library and its use are covered by
|
||||
this License. You must supply a copy of this License. If the work
|
||||
during execution displays copyright notices, you must include the
|
||||
copyright notice for the Library among them, as well as a reference
|
||||
directing the user to the copy of this License. Also, you must do one
|
||||
of these things:
|
||||
|
||||
a) Accompany the work with the complete corresponding
|
||||
machine-readable source code for the Library including whatever
|
||||
changes were used in the work (which must be distributed under
|
||||
Sections 1 and 2 above); and, if the work is an executable linked
|
||||
with the Library, with the complete machine-readable "work that
|
||||
uses the Library", as object code and/or source code, so that the
|
||||
user can modify the Library and then relink to produce a modified
|
||||
executable containing the modified Library. (It is understood
|
||||
that the user who changes the contents of definitions files in the
|
||||
Library will not necessarily be able to recompile the application
|
||||
to use the modified definitions.)
|
||||
|
||||
b) Use a suitable shared library mechanism for linking with the
|
||||
Library. A suitable mechanism is one that (1) uses at run time a
|
||||
copy of the library already present on the user's computer system,
|
||||
rather than copying library functions into the executable, and (2)
|
||||
will operate properly with a modified version of the library, if
|
||||
the user installs one, as long as the modified version is
|
||||
interface-compatible with the version that the work was made with.
|
||||
|
||||
c) Accompany the work with a written offer, valid for at
|
||||
least three years, to give the same user the materials
|
||||
specified in Subsection 6a, above, for a charge no more
|
||||
than the cost of performing this distribution.
|
||||
|
||||
d) If distribution of the work is made by offering access to copy
|
||||
from a designated place, offer equivalent access to copy the above
|
||||
specified materials from the same place.
|
||||
|
||||
e) Verify that the user has already received a copy of these
|
||||
materials or that you have already sent this user a copy.
|
||||
|
||||
For an executable, the required form of the "work that uses the
|
||||
Library" must include any data and utility programs needed for
|
||||
reproducing the executable from it. However, as a special exception,
|
||||
the materials to be distributed need not include anything that is
|
||||
normally distributed (in either source or binary form) with the major
|
||||
components (compiler, kernel, and so on) of the operating system on
|
||||
which the executable runs, unless that component itself accompanies
|
||||
the executable.
|
||||
|
||||
It may happen that this requirement contradicts the license
|
||||
restrictions of other proprietary libraries that do not normally
|
||||
accompany the operating system. Such a contradiction means you cannot
|
||||
use both them and the Library together in an executable that you
|
||||
distribute.
|
||||
|
||||
7. You may place library facilities that are a work based on the
|
||||
Library side-by-side in a single library together with other library
|
||||
facilities not covered by this License, and distribute such a combined
|
||||
library, provided that the separate distribution of the work based on
|
||||
the Library and of the other library facilities is otherwise
|
||||
permitted, and provided that you do these two things:
|
||||
|
||||
a) Accompany the combined library with a copy of the same work
|
||||
based on the Library, uncombined with any other library
|
||||
facilities. This must be distributed under the terms of the
|
||||
Sections above.
|
||||
|
||||
b) Give prominent notice with the combined library of the fact
|
||||
that part of it is a work based on the Library, and explaining
|
||||
where to find the accompanying uncombined form of the same work.
|
||||
|
||||
8. You may not copy, modify, sublicense, link with, or distribute
|
||||
the Library except as expressly provided under this License. Any
|
||||
attempt otherwise to copy, modify, sublicense, link with, or
|
||||
distribute the Library is void, and will automatically terminate your
|
||||
rights under this License. However, parties who have received copies,
|
||||
or rights, from you under this License will not have their licenses
|
||||
terminated so long as such parties remain in full compliance.
|
||||
|
||||
9. You are not required to accept this License, since you have not
|
||||
signed it. However, nothing else grants you permission to modify or
|
||||
distribute the Library or its derivative works. These actions are
|
||||
prohibited by law if you do not accept this License. Therefore, by
|
||||
modifying or distributing the Library (or any work based on the
|
||||
Library), you indicate your acceptance of this License to do so, and
|
||||
all its terms and conditions for copying, distributing or modifying
|
||||
the Library or works based on it.
|
||||
|
||||
10. Each time you redistribute the Library (or any work based on the
|
||||
Library), the recipient automatically receives a license from the
|
||||
original licensor to copy, distribute, link with or modify the Library
|
||||
subject to these terms and conditions. You may not impose any further
|
||||
restrictions on the recipients' exercise of the rights granted herein.
|
||||
You are not responsible for enforcing compliance by third parties with
|
||||
this License.
|
||||
|
||||
11. If, as a consequence of a court judgment or allegation of patent
|
||||
infringement or for any other reason (not limited to patent issues),
|
||||
conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot
|
||||
distribute so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you
|
||||
may not distribute the Library at all. For example, if a patent
|
||||
license would not permit royalty-free redistribution of the Library by
|
||||
all those who receive copies directly or indirectly through you, then
|
||||
the only way you could satisfy both it and this License would be to
|
||||
refrain entirely from distribution of the Library.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under any
|
||||
particular circumstance, the balance of the section is intended to apply,
|
||||
and the section as a whole is intended to apply in other circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any
|
||||
patents or other property right claims or to contest validity of any
|
||||
such claims; this section has the sole purpose of protecting the
|
||||
integrity of the free software distribution system which is
|
||||
implemented by public license practices. Many people have made
|
||||
generous contributions to the wide range of software distributed
|
||||
through that system in reliance on consistent application of that
|
||||
system; it is up to the author/donor to decide if he or she is willing
|
||||
to distribute software through any other system and a licensee cannot
|
||||
impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to
|
||||
be a consequence of the rest of this License.
|
||||
|
||||
12. If the distribution and/or use of the Library is restricted in
|
||||
certain countries either by patents or by copyrighted interfaces, the
|
||||
original copyright holder who places the Library under this License may add
|
||||
an explicit geographical distribution limitation excluding those countries,
|
||||
so that distribution is permitted only in or among countries not thus
|
||||
excluded. In such case, this License incorporates the limitation as if
|
||||
written in the body of this License.
|
||||
|
||||
13. The Free Software Foundation may publish revised and/or new
|
||||
versions of the Lesser General Public License from time to time.
|
||||
Such new versions will be similar in spirit to the present version,
|
||||
but may differ in detail to address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Library
|
||||
specifies a version number of this License which applies to it and
|
||||
"any later version", you have the option of following the terms and
|
||||
conditions either of that version or of any later version published by
|
||||
the Free Software Foundation. If the Library does not specify a
|
||||
license version number, you may choose any version ever published by
|
||||
the Free Software Foundation.
|
||||
|
||||
14. If you wish to incorporate parts of the Library into other free
|
||||
programs whose distribution conditions are incompatible with these,
|
||||
write to the author to ask for permission. For software which is
|
||||
copyrighted by the Free Software Foundation, write to the Free
|
||||
Software Foundation; we sometimes make exceptions for this. Our
|
||||
decision will be guided by the two goals of preserving the free status
|
||||
of all derivatives of our free software and of promoting the sharing
|
||||
and reuse of software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
|
||||
WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
|
||||
EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
|
||||
OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
|
||||
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
|
||||
LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
|
||||
THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||
|
||||
16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
|
||||
WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
|
||||
AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
|
||||
FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
|
||||
CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
|
||||
LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
|
||||
RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
|
||||
FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
|
||||
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
|
||||
DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Libraries
|
||||
|
||||
If you develop a new library, and you want it to be of the greatest
|
||||
possible use to the public, we recommend making it free software that
|
||||
everyone can redistribute and change. You can do so by permitting
|
||||
redistribution under these terms (or, alternatively, under the terms of the
|
||||
ordinary General Public License).
|
||||
|
||||
To apply these terms, attach the following notices to the library. It is
|
||||
safest to attach them to the start of each source file to most effectively
|
||||
convey the exclusion of warranty; and each file should have at least the
|
||||
"copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the library's name and a brief idea of what it does.>
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This library is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU Lesser General Public
|
||||
License as published by the Free Software Foundation; either
|
||||
version 2.1 of the License, or (at your option) any later version.
|
||||
|
||||
This library is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
Lesser General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Lesser General Public
|
||||
License along with this library; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
You should also get your employer (if you work as a programmer) or your
|
||||
school, if any, to sign a "copyright disclaimer" for the library, if
|
||||
necessary. Here is a sample; alter the names:
|
||||
|
||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the
|
||||
library `Frob' (a library for tweaking knobs) written by James Random Hacker.
|
||||
|
||||
<signature of Ty Coon>, 1 April 1990
|
||||
Ty Coon, President of Vice
|
||||
|
||||
That's all there is to it!
|
72
Makefile.am
72
Makefile.am
@ -1,72 +0,0 @@
|
||||
# -*- Makefile -*-
|
||||
|
||||
ACLOCAL_AMFLAGS = -I m4
|
||||
|
||||
AM_CPPFLAGS = -I${top_srcdir}
|
||||
AM_CXXFLAGS = -Wall -Wextra -Wno-unknown-pragmas -Wshadow
|
||||
if ENABLE_DEBUG
|
||||
AM_CPPFLAGS += -DDEBUG
|
||||
AM_CXXFLAGS += -g
|
||||
endif
|
||||
|
||||
lib_LTLIBRARIES = libebml.la
|
||||
libebml_la_SOURCES = \
|
||||
src/Debug.cpp \
|
||||
src/EbmlBinary.cpp \
|
||||
src/EbmlContexts.cpp \
|
||||
src/EbmlCrc32.cpp \
|
||||
src/EbmlDate.cpp \
|
||||
src/EbmlDummy.cpp \
|
||||
src/EbmlElement.cpp \
|
||||
src/EbmlFloat.cpp \
|
||||
src/EbmlHead.cpp \
|
||||
src/EbmlMaster.cpp \
|
||||
src/EbmlSInteger.cpp \
|
||||
src/EbmlStream.cpp \
|
||||
src/EbmlString.cpp \
|
||||
src/EbmlSubHead.cpp \
|
||||
src/EbmlUInteger.cpp \
|
||||
src/EbmlUnicodeString.cpp \
|
||||
src/EbmlVersion.cpp \
|
||||
src/EbmlVoid.cpp \
|
||||
src/IOCallback.cpp \
|
||||
src/MemIOCallback.cpp \
|
||||
src/MemReadIOCallback.cpp \
|
||||
src/SafeReadIOCallback.cpp \
|
||||
src/StdIOCallback.cpp
|
||||
libebml_la_LDFLAGS = -version-info 4:0:0 -no-undefined
|
||||
|
||||
nobase_include_HEADERS = \
|
||||
ebml/c/libebml_t.h \
|
||||
ebml/Debug.h \
|
||||
ebml/EbmlBinary.h \
|
||||
ebml/EbmlConfig.h \
|
||||
ebml/EbmlContexts.h \
|
||||
ebml/EbmlCrc32.h \
|
||||
ebml/EbmlDate.h \
|
||||
ebml/EbmlDummy.h \
|
||||
ebml/EbmlElement.h \
|
||||
ebml/EbmlEndian.h \
|
||||
ebml/EbmlFloat.h \
|
||||
ebml/EbmlHead.h \
|
||||
ebml/EbmlId.h \
|
||||
ebml/EbmlMaster.h \
|
||||
ebml/EbmlSInteger.h \
|
||||
ebml/EbmlStream.h \
|
||||
ebml/EbmlString.h \
|
||||
ebml/EbmlSubHead.h \
|
||||
ebml/EbmlTypes.h \
|
||||
ebml/EbmlUInteger.h \
|
||||
ebml/EbmlUnicodeString.h \
|
||||
ebml/EbmlVersion.h \
|
||||
ebml/EbmlVoid.h \
|
||||
ebml/IOCallback.h \
|
||||
ebml/MemIOCallback.h \
|
||||
ebml/MemReadIOCallback.h \
|
||||
ebml/SafeReadIOCallback.h \
|
||||
ebml/StdIOCallback.h
|
||||
|
||||
pkgconfigdir = ${libdir}/pkgconfig
|
||||
pkgconfig_DATA = libebml.pc
|
||||
|
||||
${pkgconfig_DATA}: config.status
|
28
README.md
28
README.md
@ -1,28 +0,0 @@
|
||||
# libebml
|
||||
a C++ libary to parse EBML files
|
||||
|
||||
Specifications may be rendered at http://matroska-org.github.io/libebml/
|
||||
|
||||
# Building and installing
|
||||
|
||||
## Building a released version
|
||||
|
||||
libebml is based on autoconf and automake and requires only a C++
|
||||
compiler. This means that the normal build process consists of the
|
||||
usual three steps:
|
||||
|
||||
1. Configuration: `./configure`
|
||||
2. Building: `make`
|
||||
3. Installation (run this as root): `make install`
|
||||
|
||||
## Building from git
|
||||
|
||||
If you're building from git you must have the GNU autotools
|
||||
(`autoconf`, `automake`, `libtoolize`) installed. Then run the
|
||||
following two commands:
|
||||
|
||||
1. `libtoolize`
|
||||
2. `autoreconf -vi`
|
||||
|
||||
Afterwards continue with the steps listed for building a released
|
||||
version.
|
14
configure.ac
14
configure.ac
@ -1,14 +0,0 @@
|
||||
AC_INIT([libebml], [1.3.4])
|
||||
AC_CONFIG_AUX_DIR([build-aux])
|
||||
AC_CONFIG_HEADERS([config.h])
|
||||
AC_CONFIG_MACRO_DIR([m4])
|
||||
AM_INIT_AUTOMAKE([foreign subdir-objects tar-pax])
|
||||
AC_PROG_CXX
|
||||
LT_INIT
|
||||
AC_ARG_ENABLE([debug],
|
||||
AS_HELP_STRING([--enable-debug], [Add -g -DDEBUG to compile flags]),
|
||||
[enable_debug="$withval"], [enable_debug=no])
|
||||
AM_CONDITIONAL([ENABLE_DEBUG], [test "$enable_debug" = yes])
|
||||
AC_CONFIG_FILES([Makefile libebml.pc])
|
||||
AC_CHECK_HEADERS([winapifamily.h])
|
||||
AC_OUTPUT
|
170
ebml/Debug.h
170
ebml/Debug.h
@ -1,170 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: Debug.h 639 2004-07-09 20:59:14Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
#ifndef LIBEBML_DEBUG_H
|
||||
#define LIBEBML_DEBUG_H
|
||||
|
||||
#include <stdarg.h> // va_list
|
||||
#include <string.h>
|
||||
|
||||
#ifdef WIN32
|
||||
#include <windows.h>
|
||||
#else
|
||||
#include <stdio.h>
|
||||
#endif // WIN32
|
||||
|
||||
#include "EbmlConfig.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
static const int MAX_PREFIX_LENGTH = 128;
|
||||
|
||||
#if defined(LIBEBML_DEBUG)
|
||||
// define the working debugging class
|
||||
|
||||
class EBML_DLL_API ADbg
|
||||
{
|
||||
public:
|
||||
ADbg(int level = 0);
|
||||
virtual ~ADbg();
|
||||
|
||||
/// \todo make an inline function to test the level first and the process
|
||||
int OutPut(int level, const char * format,...) const;
|
||||
|
||||
int OutPut(const char * format,...) const;
|
||||
|
||||
inline int setLevel(const int level) {
|
||||
return my_level = level;
|
||||
}
|
||||
|
||||
inline bool setIncludeTime(const bool included = true) {
|
||||
return my_time_included = included;
|
||||
}
|
||||
|
||||
bool setDebugFile(const char * NewFilename);
|
||||
bool unsetDebugFile();
|
||||
|
||||
inline bool setUseFile(const bool usefile = true) {
|
||||
return my_use_file = usefile;
|
||||
}
|
||||
|
||||
inline const char * setPrefix(const char * string) {
|
||||
return strncpy(prefix, string, MAX_PREFIX_LENGTH);
|
||||
}
|
||||
|
||||
private:
|
||||
int my_level;
|
||||
bool my_time_included;
|
||||
bool my_use_file;
|
||||
bool my_debug_output;
|
||||
|
||||
int _OutPut(const char * format,va_list params) const;
|
||||
|
||||
char prefix[MAX_PREFIX_LENGTH];
|
||||
|
||||
#ifdef WIN32
|
||||
HANDLE hFile;
|
||||
#else
|
||||
FILE *hFile;
|
||||
#endif // WIN32
|
||||
};
|
||||
|
||||
#else // defined(LIBEBML_DEBUG)
|
||||
|
||||
// define a class that does nothing (no output)
|
||||
|
||||
class EBML_DLL_API ADbg
|
||||
{
|
||||
public:
|
||||
ADbg(int /* level */ = 0){}
|
||||
virtual ~ADbg() {}
|
||||
|
||||
inline int OutPut(int /* level */, const char * /* format */,...) const {
|
||||
return 0;
|
||||
}
|
||||
|
||||
inline int OutPut(const char * /* format */,...) const {
|
||||
return 0;
|
||||
}
|
||||
|
||||
inline int setLevel(const int level) {
|
||||
return level;
|
||||
}
|
||||
|
||||
inline bool setIncludeTime(const bool /* included */ = true) {
|
||||
return true;
|
||||
}
|
||||
|
||||
inline bool setDebugFile(const char * /* NewFilename */) {
|
||||
return true;
|
||||
}
|
||||
|
||||
inline bool unsetDebugFile() {
|
||||
return true;
|
||||
}
|
||||
|
||||
inline bool setUseFile(const bool /* usefile */ = true) {
|
||||
return true;
|
||||
}
|
||||
|
||||
inline const char * setPrefix(const char * string) {
|
||||
return string;
|
||||
}
|
||||
};
|
||||
|
||||
#endif // defined(LIBEBML_DEBUG)
|
||||
|
||||
extern class EBML_DLL_API ADbg globalDebug;
|
||||
|
||||
|
||||
#ifdef LIBEBML_DEBUG
|
||||
#define EBML_TRACE globalDebug.OutPut
|
||||
#else
|
||||
#define EBML_TRACE
|
||||
#endif
|
||||
|
||||
// Unfortunately the Visual C++ new operator doesn't throw a std::bad_alloc. One solution is to
|
||||
// define out own new operator. But we can't do this globally, since we allow static linking.
|
||||
// The other is to check every new allocation with an MATROSKA_ASSERT_NEW.
|
||||
#ifdef _MSC_VER
|
||||
#define EBML_ASSERT_NEW(p) if(p==0)throw std::bad_alloc()
|
||||
#else
|
||||
#define EBML_ASSERT_NEW(p) assert(p!=0)
|
||||
#endif
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif
|
@ -1,107 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Julien Coloos <suiryc @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_BINARY_H
|
||||
#define LIBEBML_BINARY_H
|
||||
|
||||
#include <cstdlib>
|
||||
#include <cstring>
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
// ----- Added 10/15/2003 by jcsston from Zen -----
|
||||
#if defined (__BORLANDC__) //Maybe other compilers?
|
||||
#include <mem.h>
|
||||
#endif //__BORLANDC__
|
||||
// ------------------------------------------------
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\class EbmlBinary
|
||||
\brief Handle all operations on an EBML element that contains "unknown" binary data
|
||||
|
||||
\todo handle fix sized elements (like UID of CodecID)
|
||||
*/
|
||||
class EBML_DLL_API EbmlBinary : public EbmlElement {
|
||||
public:
|
||||
EbmlBinary();
|
||||
EbmlBinary(const EbmlBinary & ElementToClone);
|
||||
virtual ~EbmlBinary(void);
|
||||
|
||||
virtual bool ValidateSize() const {return IsFiniteSize() && GetSize() < 0x7FFFFFFF;} // we don't mind about what's inside
|
||||
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||
|
||||
void SetBuffer(const binary *Buffer, const uint32 BufferSize) {
|
||||
Data = (binary *) Buffer;
|
||||
SetSize_(BufferSize);
|
||||
SetValueIsSet();
|
||||
}
|
||||
|
||||
binary *GetBuffer() const {return Data;}
|
||||
|
||||
void CopyBuffer(const binary *Buffer, const uint32 BufferSize) {
|
||||
if (Data != NULL)
|
||||
free(Data);
|
||||
Data = (binary *)malloc(BufferSize * sizeof(binary));
|
||||
memcpy(Data, Buffer, BufferSize);
|
||||
SetSize_(BufferSize);
|
||||
SetValueIsSet();
|
||||
}
|
||||
|
||||
operator const binary &() const;
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return false;
|
||||
}
|
||||
|
||||
bool operator==(const EbmlBinary & ElementToCompare) const;
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
binary *Data; // the binary data inside the element
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_BINARY_H
|
@ -1,125 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlConfig.h 1241 2006-01-25 00:59:45Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
|
||||
#ifndef LIBEBML_CONFIG_H
|
||||
#define LIBEBML_CONFIG_H
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#if defined(__linux__)
|
||||
#include <endian.h>
|
||||
#if __BYTE_ORDER == __LITTLE_ENDIAN
|
||||
#undef WORDS_BIGENDIAN
|
||||
#elif __BYTE_ORDER == __BIG_ENDIAN
|
||||
#define WORDS_BIGENDIAN 1
|
||||
#endif
|
||||
#else
|
||||
// automatic endianess detection working on GCC
|
||||
#if !defined(WORDS_BIGENDIAN)
|
||||
#if (defined (__arm__) && ! defined (__ARMEB__)) || defined (__i386__) || defined (__i860__) || defined (__ns32000__) || defined (__vax__) || defined (__amd64__) || defined (__x86_64__)
|
||||
#undef WORDS_BIGENDIAN
|
||||
#elif defined (__sparc__) || defined (__alpha__) || defined (__PPC__) || defined (__mips__) || defined (__ppc__) || defined (__BIG_ENDIAN__)
|
||||
#define WORDS_BIGENDIAN 1
|
||||
#else
|
||||
// not automatically detected, put it yourself
|
||||
#undef WORDS_BIGENDIAN // for my testing platform (x86)
|
||||
#endif
|
||||
#endif // not autoconf
|
||||
#endif
|
||||
|
||||
#define LIBEBML_NAMESPACE libebml
|
||||
#if defined(NO_NAMESPACE) // for older GCC
|
||||
# define START_LIBEBML_NAMESPACE
|
||||
# define END_LIBEBML_NAMESPACE
|
||||
#else // NO_NAMESPACE
|
||||
# define START_LIBEBML_NAMESPACE namespace LIBEBML_NAMESPACE {
|
||||
# define END_LIBEBML_NAMESPACE };
|
||||
#endif // NO_NAMESPACE
|
||||
|
||||
|
||||
// There are special implementations for certain platforms. For example on Windows
|
||||
// we use the Win32 file API. here we set the appropriate macros.
|
||||
#if defined(_WIN32)||defined(WIN32)
|
||||
|
||||
# if defined(EBML_DLL)
|
||||
# if defined(EBML_DLL_EXPORT)
|
||||
# define EBML_DLL_API __declspec(dllexport)
|
||||
# else // EBML_DLL_EXPORT
|
||||
# define EBML_DLL_API __declspec(dllimport)
|
||||
# endif // EBML_DLL_EXPORT
|
||||
# else // EBML_DLL
|
||||
# define EBML_DLL_API
|
||||
# endif // EBML_DLL
|
||||
|
||||
# ifdef _MSC_VER
|
||||
# pragma warning(disable:4786) // length of internal identifiers
|
||||
# endif // _MSC_VER
|
||||
#else
|
||||
# define EBML_DLL_API
|
||||
#endif // WIN32 || _WIN32
|
||||
|
||||
|
||||
#ifndef countof
|
||||
#define countof(x) (sizeof(x)/sizeof(x[0]))
|
||||
#endif
|
||||
|
||||
|
||||
// The LIBEBML_DEBUG symbol is defined, when we are creating a debug build. In this
|
||||
// case the debug logging code is compiled in.
|
||||
#if (defined(DEBUG)||defined(_DEBUG)) && !defined(LIBEBML_DEBUG)
|
||||
#define LIBEBML_DEBUG
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_WINAPIFAMILY_H
|
||||
# include <winapifamily.h>
|
||||
# if !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
|
||||
# undef LIBEBML_DEBUG
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifdef __GNUC__
|
||||
#define EBML_PRETTYLONGINT(c) (c ## ll)
|
||||
#else // __GNUC__
|
||||
#define EBML_PRETTYLONGINT(c) (c)
|
||||
#endif // __GNUC__
|
||||
|
||||
#if defined(__BORLANDC__) && __BORLANDC__ >= 0x0581 //Borland C++ Builder 2006 preview
|
||||
#include <stdlib.h> //malloc(), free()
|
||||
#include <memory.h> //memcpy()
|
||||
#endif //__BORLANDC__
|
||||
|
||||
#endif // LIBEBML_CONFIG_H
|
@ -1,60 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlContexts.h 736 2004-08-28 14:05:09Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_CONTEXTS_H
|
||||
#define LIBEBML_CONTEXTS_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
extern const EbmlSemanticContext EBML_DLL_API EbmlHead_Context;
|
||||
extern const EbmlSemanticContext EBML_DLL_API EVersion_Context;
|
||||
extern const EbmlSemanticContext EBML_DLL_API EReadVersion_Context;
|
||||
extern const EbmlSemanticContext EBML_DLL_API EMaxIdLength_Context;
|
||||
extern const EbmlSemanticContext EBML_DLL_API EMaxSizeLength_Context;
|
||||
extern const EbmlSemanticContext EBML_DLL_API EDocType_Context;
|
||||
extern const EbmlSemanticContext EBML_DLL_API EDocTypeVersion_Context;
|
||||
extern const EbmlSemanticContext EBML_DLL_API EDocTypeReadVersion_Context;
|
||||
|
||||
#define Context_EbmlHead EbmlHead_Context
|
||||
|
||||
// global elements
|
||||
extern const EbmlSemanticContext EBML_DLL_API & GetEbmlGlobal_Context();
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_CONTEXTS_H
|
141
ebml/EbmlCrc32.h
141
ebml/EbmlCrc32.h
@ -1,141 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
*/
|
||||
#ifndef LIBEBML_CRC32_H
|
||||
#define LIBEBML_CRC32_H
|
||||
|
||||
#include <cassert>
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlBinary.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DECLARE_EBML_BINARY(EbmlCrc32)
|
||||
public:
|
||||
EbmlCrc32(const EbmlCrc32 & ElementToClone);
|
||||
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() == 4);}
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
// filepos_t UpdateSize(bool bWithDefault = false);
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return false;
|
||||
}
|
||||
|
||||
void AddElementCRC32(EbmlElement &ElementToCRC);
|
||||
bool CheckElementCRC32(EbmlElement &ElementToCRC);
|
||||
|
||||
/*!
|
||||
Use this to quickly check a CRC32 with some data
|
||||
\return True if inputCRC matches CRC32 generated from input data
|
||||
*/
|
||||
static bool CheckCRC(uint32 inputCRC, const binary *input, uint32 length);
|
||||
/*!
|
||||
Calls Update() and Finalize(), use to create a CRC32 in one go
|
||||
*/
|
||||
void FillCRC32(const binary *input, uint32 length);
|
||||
/*!
|
||||
Add data to the CRC table, in other words process some data bit by bit
|
||||
*/
|
||||
void Update(const binary *input, uint32 length);
|
||||
/*!
|
||||
Use this with Update() to Finalize() or Complete the CRC32
|
||||
*/
|
||||
void Finalize();
|
||||
/*!
|
||||
Returns a uint32 that has the value of the CRC32
|
||||
*/
|
||||
uint32 GetCrc32() const {
|
||||
return m_crc_final;
|
||||
};
|
||||
|
||||
void ForceCrc32(uint32 NewValue) { m_crc_final = NewValue; SetValueIsSet();}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
void ResetCRC();
|
||||
void UpdateByte(binary b);
|
||||
|
||||
static const uint32 m_tab[256];
|
||||
uint32 m_crc;
|
||||
uint32 m_crc_final;
|
||||
|
||||
EBML_CONCRETE_CLASS(EbmlCrc32)
|
||||
};
|
||||
|
||||
template <class T>
|
||||
inline unsigned int GetAlignment(T */* dummy */=NULL) // VC60 workaround
|
||||
{
|
||||
#if defined(_MSC_VER) && (_MSC_VER >= 1300)
|
||||
return __alignof(T);
|
||||
#elif defined(__GNUC__)
|
||||
return __alignof__(T);
|
||||
#else
|
||||
return sizeof(T);
|
||||
#endif
|
||||
}
|
||||
|
||||
template <class T>
|
||||
inline bool IsPowerOf2(T n)
|
||||
{
|
||||
return n > 0 && (n & (n-1)) == 0;
|
||||
}
|
||||
|
||||
template <class T1, class T2>
|
||||
inline T2 ModPowerOf2(T1 a, T2 b)
|
||||
{
|
||||
assert(IsPowerOf2(b));
|
||||
return T2(a) & (b-1);
|
||||
}
|
||||
|
||||
inline bool IsAlignedOn(const void *p, unsigned int alignment)
|
||||
{
|
||||
return IsPowerOf2(alignment) ? ModPowerOf2((uintptr_t)p, alignment) == 0 : (uintptr_t)p % alignment == 0;
|
||||
}
|
||||
|
||||
template <class T>
|
||||
inline bool IsAligned(const void *p, T */* dummy */=NULL) // VC60 workaround
|
||||
{
|
||||
return IsAlignedOn(p, GetAlignment<T>());
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_CRC32_H
|
100
ebml/EbmlDate.h
100
ebml/EbmlDate.h
@ -1,100 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_DATE_H
|
||||
#define LIBEBML_DATE_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\class EbmlDate
|
||||
\brief Handle all operations related to an EBML date
|
||||
*/
|
||||
class EBML_DLL_API EbmlDate : public EbmlElement {
|
||||
public:
|
||||
EbmlDate() :EbmlElement(8, false), myDate(0) {}
|
||||
EbmlDate(const EbmlDate & ElementToClone);
|
||||
|
||||
/*!
|
||||
\brief set the date with a UNIX/C/EPOCH form
|
||||
\param NewDate UNIX/C date in UTC (no timezone)
|
||||
*/
|
||||
void SetEpochDate(int64 NewDate) {myDate = (NewDate - UnixEpochDelay) * 1000000000; SetValueIsSet();}
|
||||
EbmlDate &SetValue(int64 NewValue) {SetEpochDate(NewValue); return *this;}
|
||||
|
||||
/*!
|
||||
\brief get the date with a UNIX/C/EPOCH form
|
||||
\note the date is in UTC (no timezone)
|
||||
*/
|
||||
int64 GetEpochDate() const {return int64(myDate/1000000000 + UnixEpochDelay);}
|
||||
int64 GetValue() const {return GetEpochDate();}
|
||||
|
||||
virtual bool ValidateSize() const {return IsFiniteSize() && ((GetSize() == 8) || (GetSize() == 0));}
|
||||
|
||||
/*!
|
||||
\note no Default date handled
|
||||
*/
|
||||
filepos_t UpdateSize(bool /* bWithDefault = false */, bool /* bForceRender = false */) {
|
||||
if(!ValueIsSet())
|
||||
SetSize_(0);
|
||||
else
|
||||
SetSize_(8);
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return false;
|
||||
}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
|
||||
int64 myDate; ///< internal format of the date
|
||||
|
||||
static const uint64 UnixEpochDelay;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_DATE_H
|
@ -1,69 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_DUMMY_H
|
||||
#define LIBEBML_DUMMY_H
|
||||
|
||||
#include "EbmlBinary.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
class EBML_DLL_API EbmlDummy : public EbmlBinary {
|
||||
public:
|
||||
EbmlDummy() :DummyId(DummyRawId) {}
|
||||
EbmlDummy(const EbmlId & aId) :EbmlBinary(), DummyId(aId) {}
|
||||
EbmlDummy(const EbmlDummy & ElementToClone):EbmlBinary(ElementToClone), DummyId(ElementToClone.DummyId) {}
|
||||
|
||||
bool IsDummy() const {return true;}
|
||||
bool IsDefaultValue() const {return true;}
|
||||
|
||||
virtual operator const EbmlId &() const {
|
||||
return DummyId;
|
||||
}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
const EbmlId DummyId;
|
||||
static const EbmlId DummyRawId;
|
||||
|
||||
EBML_CONCRETE_DUMMY_CLASS(EbmlDummy)
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_DUMMY_H
|
@ -1,512 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_ELEMENT_H
|
||||
#define LIBEBML_ELEMENT_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlId.h"
|
||||
#include "IOCallback.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\brief The size of the EBML-coded length
|
||||
*/
|
||||
int EBML_DLL_API CodedSizeLength(uint64 Length, unsigned int SizeLength, bool bSizeIsFinite = true);
|
||||
|
||||
/*!
|
||||
\brief The coded value of the EBML-coded length
|
||||
\note The size of OutBuffer must be 8 octets at least
|
||||
*/
|
||||
int EBML_DLL_API CodedValueLength(uint64 Length, int CodedSize, binary * OutBuffer);
|
||||
|
||||
/*!
|
||||
\brief Read an EBML-coded value from a buffer
|
||||
\return the value read
|
||||
*/
|
||||
uint64 EBML_DLL_API ReadCodedSizeValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown);
|
||||
|
||||
/*!
|
||||
\brief The size of the EBML-coded signed length
|
||||
*/
|
||||
int EBML_DLL_API CodedSizeLengthSigned(int64 Length, unsigned int SizeLength);
|
||||
|
||||
/*!
|
||||
\brief The coded value of the EBML-coded signed length
|
||||
\note the size of OutBuffer must be 8 octets at least
|
||||
*/
|
||||
int EBML_DLL_API CodedValueLengthSigned(int64 Length, int CodedSize, binary * OutBuffer);
|
||||
|
||||
/*!
|
||||
\brief Read a signed EBML-coded value from a buffer
|
||||
\return the value read
|
||||
*/
|
||||
int64 EBML_DLL_API ReadCodedSizeSignedValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown);
|
||||
|
||||
class EbmlStream;
|
||||
class EbmlSemanticContext;
|
||||
class EbmlElement;
|
||||
|
||||
extern const EbmlSemanticContext Context_EbmlGlobal;
|
||||
|
||||
#define DEFINE_xxx_CONTEXT(x,global) \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(countof(ContextList_##x), ContextList_##x, NULL, global, NULL); \
|
||||
|
||||
#define DEFINE_xxx_MASTER(x,id,idl,parent,name,global) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(countof(ContextList_##x), ContextList_##x, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
x::x() :EbmlMaster(Context_##x) {}
|
||||
|
||||
#define DEFINE_xxx_MASTER_CONS(x,id,idl,parent,name,global) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(countof(ContextList_##x), ContextList_##x, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x);
|
||||
|
||||
#define DEFINE_xxx_MASTER_ORPHAN(x,id,idl,name,global) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(countof(ContextList_##x), ContextList_##x, NULL, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
|
||||
#define DEFINE_xxx_CLASS(x,id,idl,parent,name,global) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(0, NULL, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
x::x() {}
|
||||
|
||||
#define DEFINE_xxx_CLASS_CONS(x,id,idl,parent,name,global) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(0, NULL, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x);
|
||||
|
||||
#define DEFINE_xxx_UINTEGER_DEF(x,id,idl,parent,name,global,defval) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(0, NULL, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
x::x() :EbmlUInteger(defval) {}
|
||||
|
||||
#define DEFINE_xxx_SINTEGER_DEF(x,id,idl,parent,name,global,defval) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(0, NULL, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
x::x() :EbmlSInteger(defval) {}
|
||||
|
||||
#define DEFINE_xxx_STRING_DEF(x,id,idl,parent,name,global,defval) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(0, NULL, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
x::x() :EbmlString(defval) {}
|
||||
|
||||
#define DEFINE_xxx_FLOAT_DEF(x,id,idl,parent,name,global,defval) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(0, NULL, &Context_##parent, global, &EBML_INFO(x)); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
x::x() :EbmlFloat(defval) {}
|
||||
|
||||
#define DEFINE_xxx_CLASS_GLOBAL(x,id,idl,name,global) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_EbmlGlobal); \
|
||||
|
||||
#define DEFINE_xxx_CLASS_ORPHAN(x,id,idl,name,global) \
|
||||
const EbmlId Id_##x (id, idl); \
|
||||
const EbmlSemanticContext Context_##x = EbmlSemanticContext(0, NULL, NULL, global, NULL); \
|
||||
const EbmlCallbacks x::ClassInfos(x::Create, Id_##x, name, Context_##x); \
|
||||
|
||||
#define DEFINE_EBML_CONTEXT(x) DEFINE_xxx_CONTEXT(x,*GetEbmlGlobal_Context)
|
||||
#define DEFINE_EBML_MASTER(x,id,idl,parent,name) DEFINE_xxx_MASTER(x,id,idl,parent,name,*GetEbmlGlobal_Context)
|
||||
#define DEFINE_EBML_MASTER_ORPHAN(x,id,idl,name) DEFINE_xxx_MASTER_ORPHAN(x,id,idl,name,*GetEbmlGlobal_Context)
|
||||
#define DEFINE_EBML_CLASS(x,id,idl,parent,name) DEFINE_xxx_CLASS(x,id,idl,parent,name,*GetEbmlGlobal_Context)
|
||||
#define DEFINE_EBML_CLASS_GLOBAL(x,id,idl,name) DEFINE_xxx_CLASS_GLOBAL(x,id,idl,name,*GetEbmlGlobal_Context)
|
||||
#define DEFINE_EBML_CLASS_ORPHAN(x,id,idl,name) DEFINE_xxx_CLASS_ORPHAN(x,id,idl,name,*GetEbmlGlobal_Context)
|
||||
#define DEFINE_EBML_UINTEGER_DEF(x,id,idl,parent,name,val) DEFINE_xxx_UINTEGER_DEF(x,id,idl,parent,name,*GetEbmlGlobal_Context,val)
|
||||
#define DEFINE_EBML_STRING_DEF(x,id,idl,parent,name,val) DEFINE_xxx_STRING_DEF(x,id,idl,parent,name,*GetEbmlGlobal_Context,val)
|
||||
#define DEFINE_EBML_BINARY_CONS(x,id,idl,parent,name) DEFINE_xxx_CLASS_CONS(x,id,idl,parent,name,*GetEbmlGlobal_Context)
|
||||
|
||||
#define DEFINE_SEMANTIC_CONTEXT(x)
|
||||
#define DEFINE_START_SEMANTIC(x) static const EbmlSemantic ContextList_##x[] = {
|
||||
#define DEFINE_END_SEMANTIC(x) };
|
||||
#define DEFINE_SEMANTIC_ITEM(m,u,c) EbmlSemantic(m, u, EBML_INFO(c)),
|
||||
|
||||
#define DECLARE_EBML_MASTER(x) class EBML_DLL_API x : public EbmlMaster { \
|
||||
public: \
|
||||
x();
|
||||
#define DECLARE_EBML_UINTEGER(x) class EBML_DLL_API x : public EbmlUInteger { \
|
||||
public: \
|
||||
x();
|
||||
#define DECLARE_EBML_STRING(x) class EBML_DLL_API x : public EbmlString { \
|
||||
public: \
|
||||
x();
|
||||
#define DECLARE_EBML_BINARY(x) class EBML_DLL_API x : public EbmlBinary { \
|
||||
public: \
|
||||
x();
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
#define EBML_CONCRETE_CLASS(Type) \
|
||||
public: \
|
||||
virtual const EbmlSemanticContext &Context() const {return ClassInfos.GetContext();} \
|
||||
virtual const char *DebugName() const {return ClassInfos.GetName();} \
|
||||
virtual operator const EbmlId &() const {return ClassInfos.ClassId();} \
|
||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||
static EbmlElement & Create() {return *(new Type);} \
|
||||
static const EbmlCallbacks & ClassInfo() {return ClassInfos;} \
|
||||
static const EbmlId & ClassId() {return ClassInfos.ClassId();} \
|
||||
private: \
|
||||
static const EbmlCallbacks ClassInfos; \
|
||||
|
||||
#define EBML_CONCRETE_DUMMY_CLASS(Type) \
|
||||
public: \
|
||||
virtual const EbmlSemanticContext &Context() const {return *static_cast<EbmlSemanticContext*>(NULL);} \
|
||||
virtual const char *DebugName() const {return "DummyElement";} \
|
||||
virtual operator const EbmlId &(); \
|
||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||
static EbmlElement & Create() {return *(new Type);} \
|
||||
static const EbmlId & ClassId(); \
|
||||
static const EbmlCallbacks ClassInfos; \
|
||||
|
||||
|
||||
#define EBML_INFO(ref) ref::ClassInfo()
|
||||
#define EBML_ID(ref) ref::ClassId()
|
||||
#define EBML_CLASS_SEMCONTEXT(ref) Context_##ref
|
||||
#define EBML_CLASS_CONTEXT(ref) ref::ClassInfo().GetContext()
|
||||
#define EBML_CLASS_CALLBACK(ref) ref::ClassInfo()
|
||||
#define EBML_CONTEXT(e) (e)->Context()
|
||||
#define EBML_NAME(e) (e)->DebugName()
|
||||
|
||||
#define EBML_INFO_ID(cb) (cb).ClassId()
|
||||
#define EBML_INFO_NAME(cb) (cb).GetName()
|
||||
#define EBML_INFO_CREATE(cb) (cb).NewElement()
|
||||
#define EBML_INFO_CONTEXT(cb) (cb).GetContext()
|
||||
|
||||
#define EBML_SEM_UNIQUE(s) (s).IsUnique()
|
||||
#define EBML_SEM_CONTEXT(s) ((const EbmlCallbacks &)(s)).GetContext()
|
||||
#define EBML_SEM_CREATE(s) (s).Create()
|
||||
|
||||
#define EBML_CTX_SIZE(c) (c).GetSize()
|
||||
#define EBML_CTX_MASTER(c) (c).GetMaster()
|
||||
#define EBML_CTX_PARENT(c) (c).Parent()
|
||||
#define EBML_CTX_IDX(c,i) (c).GetSemantic(i)
|
||||
#define EBML_CTX_IDX_INFO(c,i) (const EbmlCallbacks &)((c).GetSemantic(i))
|
||||
#define EBML_CTX_IDX_ID(c,i) ((const EbmlCallbacks &)((c).GetSemantic(i))).ClassId()
|
||||
#else
|
||||
#define EBML_CONCRETE_CLASS(Type) \
|
||||
public: \
|
||||
virtual const EbmlCallbacks & Generic() const {return ClassInfos;} \
|
||||
virtual operator const EbmlId &() const {return ClassInfos.GlobalId;} \
|
||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||
static EbmlElement & Create() {return *(new Type);} \
|
||||
static const EbmlCallbacks ClassInfos; \
|
||||
|
||||
#define EBML_CONCRETE_DUMMY_CLASS(Type) \
|
||||
public: \
|
||||
virtual const EbmlCallbacks & Generic() const {return ClassInfos;} \
|
||||
virtual operator const EbmlId &(); \
|
||||
virtual EbmlElement & CreateElement() const {return Create();} \
|
||||
virtual EbmlElement * Clone() const { return new Type(*this); } \
|
||||
static EbmlElement & Create() {return *(new Type);} \
|
||||
static const EbmlCallbacks ClassInfos; \
|
||||
|
||||
|
||||
#define EBML_INFO(ref) ref::ClassInfos
|
||||
#define EBML_ID(ref) ref::ClassInfos.GlobalId
|
||||
#define EBML_CLASS_SEMCONTEXT(ref) Context_##ref
|
||||
#define EBML_CLASS_CONTEXT(ref) ref::ClassInfos.Context
|
||||
#define EBML_CLASS_CALLBACK(ref) ref::ClassInfos
|
||||
#define EBML_CONTEXT(e) (e)->Generic().Context
|
||||
#define EBML_NAME(e) (e)->Generic().DebugName
|
||||
|
||||
#define EBML_INFO_ID(cb) (cb).GlobalId
|
||||
#define EBML_INFO_NAME(cb) (cb).DebugName
|
||||
#define EBML_INFO_CREATE(cb) (cb).Create()
|
||||
#define EBML_INFO_CONTEXT(cb) (cb).Context
|
||||
|
||||
#define EBML_SEM_UNIQUE(s) (s).Unique
|
||||
#define EBML_SEM_CONTEXT(s) (s).GetCallbacks.Context
|
||||
#define EBML_SEM_CREATE(s) (s).Create()
|
||||
|
||||
#define EBML_CTX_SIZE(c) (c).Size
|
||||
#define EBML_CTX_MASTER(c) (c).MasterElt
|
||||
#define EBML_CTX_PARENT(c) (c).UpTable
|
||||
#define EBML_CTX_IDX(c,i) (c).MyTable[(i)]
|
||||
#define EBML_CTX_IDX_INFO(c,i) (c).MyTable[(i)].GetCallbacks
|
||||
#define EBML_CTX_IDX_ID(c,i) (c).MyTable[(i)].GetCallbacks.GlobalId
|
||||
#endif
|
||||
|
||||
#if !defined(INVALID_FILEPOS_T)
|
||||
#define INVALID_FILEPOS_T 0
|
||||
#endif
|
||||
|
||||
#define EBML_DEF_CONS
|
||||
#define EBML_DEF_SEP
|
||||
#define EBML_DEF_PARAM
|
||||
#define EBML_DEF_BINARY_INIT
|
||||
#define EBML_DEF_BINARY_CTX(x)
|
||||
#define EBML_DEF_SINTEGER(x)
|
||||
#define EBML_DEF_BINARY(x)
|
||||
#define EBML_EXTRA_PARAM
|
||||
#define EBML_EXTRA_CALL
|
||||
#define EBML_EXTRA_DEF
|
||||
|
||||
// functions for generic handling of data (should be static to all classes)
|
||||
/*!
|
||||
\todo Handle default value
|
||||
*/
|
||||
class EBML_DLL_API EbmlCallbacks {
|
||||
public:
|
||||
EbmlCallbacks(EbmlElement & (*Creator)(), const EbmlId & aGlobalId, const char * aDebugName, const EbmlSemanticContext & aContext);
|
||||
|
||||
inline const EbmlId & ClassId() const { return GlobalId; }
|
||||
inline const EbmlSemanticContext & GetContext() const { return Context; }
|
||||
inline const char * GetName() const { return DebugName; }
|
||||
inline EbmlElement & NewElement() const { return Create(); }
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#endif
|
||||
EbmlElement & (*Create)();
|
||||
const EbmlId & GlobalId;
|
||||
const char * DebugName;
|
||||
const EbmlSemanticContext & Context;
|
||||
};
|
||||
|
||||
/*!
|
||||
\brief contains the semantic informations for a given level and all sublevels
|
||||
\todo move the ID in the element class
|
||||
*/
|
||||
class EBML_DLL_API EbmlSemantic {
|
||||
public:
|
||||
EbmlSemantic(bool aMandatory, bool aUnique, const EbmlCallbacks & aGetCallbacks)
|
||||
:Mandatory(aMandatory), Unique(aUnique), GetCallbacks(aGetCallbacks) {}
|
||||
|
||||
inline bool IsMandatory() const { return Mandatory; }
|
||||
inline bool IsUnique() const { return Unique; }
|
||||
inline EbmlElement & Create() const { return EBML_INFO_CREATE(GetCallbacks); }
|
||||
inline operator const EbmlCallbacks &() const { return GetCallbacks; }
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#endif
|
||||
bool Mandatory; ///< wether the element is mandatory in the context or not
|
||||
bool Unique;
|
||||
const EbmlCallbacks & GetCallbacks;
|
||||
};
|
||||
|
||||
typedef const class EbmlSemanticContext & (*_GetSemanticContext)();
|
||||
|
||||
/*!
|
||||
Context of the element
|
||||
\todo allow more than one parent ?
|
||||
*/
|
||||
class EBML_DLL_API EbmlSemanticContext {
|
||||
public:
|
||||
EbmlSemanticContext(size_t aSize,
|
||||
const EbmlSemantic *aMyTable,
|
||||
const EbmlSemanticContext *aUpTable,
|
||||
const _GetSemanticContext aGetGlobalContext,
|
||||
const EbmlCallbacks *aMasterElt)
|
||||
: GetGlobalContext(aGetGlobalContext), MyTable(aMyTable), Size(aSize),
|
||||
UpTable(aUpTable), MasterElt(aMasterElt) {}
|
||||
|
||||
bool operator!=(const EbmlSemanticContext & aElt) const {
|
||||
return ((Size != aElt.Size) || (MyTable != aElt.MyTable) ||
|
||||
(UpTable != aElt.UpTable) || (GetGlobalContext != aElt.GetGlobalContext) |
|
||||
(MasterElt != aElt.MasterElt));
|
||||
}
|
||||
|
||||
inline size_t GetSize() const { return Size; }
|
||||
inline const EbmlCallbacks* GetMaster() const { return MasterElt; }
|
||||
inline const EbmlSemanticContext* Parent() const { return UpTable; }
|
||||
const EbmlSemantic & GetSemantic(size_t i) const;
|
||||
|
||||
const _GetSemanticContext GetGlobalContext; ///< global elements supported at this level
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#endif
|
||||
const EbmlSemantic *MyTable; ///< First element in the table
|
||||
size_t Size; ///< number of elements in the table
|
||||
const EbmlSemanticContext *UpTable; ///< Parent element
|
||||
/// \todo replace with the global context directly
|
||||
const EbmlCallbacks *MasterElt;
|
||||
};
|
||||
|
||||
/*!
|
||||
\class EbmlElement
|
||||
\brief Hold basic informations about an EBML element (ID + length)
|
||||
*/
|
||||
class EBML_DLL_API EbmlElement {
|
||||
public:
|
||||
EbmlElement(uint64 aDefaultSize, bool bValueSet = false);
|
||||
virtual ~EbmlElement();
|
||||
|
||||
/// Set the minimum length that will be used to write the element size (-1 = optimal)
|
||||
void SetSizeLength(int NewSizeLength) {SizeLength = NewSizeLength;}
|
||||
int GetSizeLength() const {return SizeLength;}
|
||||
|
||||
static EbmlElement * FindNextElement(IOCallback & DataStream, const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel = 1);
|
||||
static EbmlElement * FindNextID(IOCallback & DataStream, const EbmlCallbacks & ClassInfos, uint64 MaxDataSize);
|
||||
|
||||
/*!
|
||||
\brief find the next element with the same ID
|
||||
*/
|
||||
EbmlElement * FindNext(IOCallback & DataStream, uint64 MaxDataSize);
|
||||
|
||||
EbmlElement * SkipData(EbmlStream & DataStream, const EbmlSemanticContext & Context, EbmlElement * TestReadElt = NULL, bool AllowDummyElt = false);
|
||||
|
||||
/*!
|
||||
\brief Give a copy of the element, all data inside the element is copied
|
||||
\return NULL if there is not enough memory
|
||||
*/
|
||||
virtual EbmlElement * Clone() const = 0;
|
||||
|
||||
virtual operator const EbmlId &() const = 0;
|
||||
#if defined(EBML_STRICT_API)
|
||||
virtual const char *DebugName() const = 0;
|
||||
virtual const EbmlSemanticContext &Context() const = 0;
|
||||
#else
|
||||
/// return the generic callback to monitor a derived class
|
||||
virtual const EbmlCallbacks & Generic() const = 0;
|
||||
#endif
|
||||
virtual EbmlElement & CreateElement() const = 0;
|
||||
|
||||
// by default only allow to set element as finite (override when needed)
|
||||
virtual bool SetSizeInfinite(bool bIsInfinite = true) {return !bIsInfinite;}
|
||||
|
||||
virtual bool ValidateSize() const = 0;
|
||||
|
||||
uint64 GetElementPosition() const {
|
||||
return ElementPosition;
|
||||
}
|
||||
|
||||
uint64 ElementSize(bool bWithDefault = false) const; /// return the size of the header+data, before writing
|
||||
|
||||
filepos_t Render(IOCallback & output, bool bWithDefault = false, bool bKeepPosition = false, bool bForceRender = false);
|
||||
|
||||
virtual filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false) = 0; /// update the Size of the Data stored
|
||||
virtual filepos_t GetSize() const {return Size;} /// return the size of the data stored in the element, on reading
|
||||
|
||||
virtual filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA) = 0;
|
||||
virtual void Read(EbmlStream & inDataStream, const EbmlSemanticContext & Context, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt = false, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
|
||||
bool IsLocked() const {return bLocked;}
|
||||
void Lock(bool bLock = true) { bLocked = bLock;}
|
||||
|
||||
/*!
|
||||
\brief default comparison for elements that can't be compared
|
||||
*/
|
||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||
static bool CompareElements(const EbmlElement *A, const EbmlElement *B);
|
||||
|
||||
virtual bool IsDummy() const {return false;}
|
||||
virtual bool IsMaster() const {return false;}
|
||||
|
||||
uint8 HeadSize() const {
|
||||
return EBML_ID_LENGTH((const EbmlId&)*this) + CodedSizeLength(Size, SizeLength, bSizeIsFinite);
|
||||
} /// return the size of the head, on reading/writing
|
||||
|
||||
/*!
|
||||
\brief Force the size of an element
|
||||
\warning only possible if the size is "undefined"
|
||||
*/
|
||||
bool ForceSize(uint64 NewSize);
|
||||
|
||||
filepos_t OverwriteHead(IOCallback & output, bool bKeepPosition = false);
|
||||
|
||||
/*!
|
||||
\brief void the content of the element (replace by EbmlVoid)
|
||||
*/
|
||||
uint64 VoidMe(IOCallback & output, bool bWithDefault = false);
|
||||
|
||||
bool DefaultISset() const {return DefaultIsSet;}
|
||||
virtual bool IsDefaultValue() const = 0;
|
||||
bool IsFiniteSize() const {return bSizeIsFinite;}
|
||||
|
||||
/*!
|
||||
\brief set the default size of an element
|
||||
*/
|
||||
virtual void SetDefaultSize(uint64 aDefaultSize) {DefaultSize = aDefaultSize;}
|
||||
|
||||
bool ValueIsSet() const {return bValueIsSet;}
|
||||
|
||||
inline uint64 GetEndPosition() const {
|
||||
assert(bSizeIsFinite); // we don't know where the end is
|
||||
return SizePosition + CodedSizeLength(Size, SizeLength, bSizeIsFinite) + Size;
|
||||
}
|
||||
|
||||
protected:
|
||||
/*!
|
||||
\brief find any element in the stream
|
||||
\return a DummyRawElement if the element is unknown or NULL if the element dummy is not allowed
|
||||
*/
|
||||
static EbmlElement *CreateElementUsingContext(const EbmlId & aID, const EbmlSemanticContext & Context, int & LowLevel, bool IsGlobalContext, bool bAllowDummy = false, unsigned int MaxLowerLevel = 1);
|
||||
|
||||
filepos_t RenderHead(IOCallback & output, bool bForceRender, bool bWithDefault = false, bool bKeepPosition = false);
|
||||
filepos_t MakeRenderHead(IOCallback & output, bool bKeepPosition);
|
||||
|
||||
/*!
|
||||
\brief prepare the data before writing them (in case it's not already done by default)
|
||||
*/
|
||||
virtual filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false) = 0;
|
||||
|
||||
/*!
|
||||
\brief special constructor for cloning
|
||||
*/
|
||||
EbmlElement(const EbmlElement & ElementToClone);
|
||||
|
||||
inline uint64 GetDefaultSize() const {return DefaultSize;}
|
||||
inline void SetSize_(uint64 aSize) {Size = aSize;}
|
||||
inline void SetValueIsSet(bool Set = true) {bValueIsSet = Set;}
|
||||
inline void SetDefaultIsSet(bool Set = true) {DefaultIsSet = Set;}
|
||||
inline void SetSizeIsFinite(bool Set = true) {bSizeIsFinite = Set;}
|
||||
inline uint64 GetSizePosition() const {return SizePosition;}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#endif
|
||||
uint64 Size; ///< the size of the data to write
|
||||
uint64 DefaultSize; ///< Minimum data size to fill on rendering (0 = optimal)
|
||||
int SizeLength; /// the minimum size on which the size will be written (0 = optimal)
|
||||
bool bSizeIsFinite;
|
||||
uint64 ElementPosition;
|
||||
uint64 SizePosition;
|
||||
bool bValueIsSet;
|
||||
bool DefaultIsSet;
|
||||
bool bLocked;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_ELEMENT_H
|
@ -1,122 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlEndian.h 1298 2008-02-21 22:14:18Z mosu $
|
||||
\author Ingo Ralf Blum <ingoralfblum @ users.sf.net>
|
||||
\author Lasse Kärkkäinen <tronic @ users.sf.net>
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_ENDIAN_H
|
||||
#define LIBEBML_ENDIAN_H
|
||||
|
||||
#include <algorithm>
|
||||
#include <cstring>
|
||||
|
||||
#include "EbmlConfig.h" // contains _ENDIANESS_
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
enum endianess {
|
||||
big_endian, ///< PowerPC, Alpha, 68000
|
||||
little_endian ///< Intel x86 platforms
|
||||
};
|
||||
|
||||
/*!
|
||||
\class Endian
|
||||
\brief general class to handle endian-specific buffers
|
||||
\note don't forget to define/undefine _ENDIANESS_ to BIG_ENDIAN depending on your machine
|
||||
*/
|
||||
template<class TYPE, endianess ENDIAN> class Endian
|
||||
{
|
||||
public:
|
||||
Endian() {}
|
||||
|
||||
Endian(const TYPE value)
|
||||
{
|
||||
memcpy(&platform_value, &value, sizeof(TYPE));
|
||||
process_endian();
|
||||
}
|
||||
|
||||
inline Endian & Eval(const binary *endian_buffer)
|
||||
{
|
||||
//endian_value = *(TYPE *)(endian_buffer);
|
||||
memcpy(&endian_value, endian_buffer, sizeof(TYPE)); // Some (all?) RISC processors do not allow reading objects bigger than 1 byte from non-aligned addresses, and endian_buffer may point to a non-aligned address.
|
||||
process_platform();
|
||||
return *this;
|
||||
}
|
||||
|
||||
inline void Fill(binary *endian_buffer) const
|
||||
{
|
||||
//*(TYPE*)endian_buffer = endian_value;
|
||||
memcpy(endian_buffer, &endian_value, sizeof(TYPE)); // See above.
|
||||
}
|
||||
|
||||
inline operator const TYPE&() const { return platform_value; }
|
||||
// inline TYPE endian() const { return endian_value; }
|
||||
inline const TYPE &endian() const { return endian_value; }
|
||||
inline size_t size() const { return sizeof(TYPE); }
|
||||
inline bool operator!=(const binary *buffer) const {return *((TYPE*)buffer) == platform_value;}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
TYPE platform_value;
|
||||
TYPE endian_value;
|
||||
|
||||
inline void process_endian()
|
||||
{
|
||||
endian_value = platform_value;
|
||||
#ifdef WORDS_BIGENDIAN
|
||||
if (ENDIAN == little_endian)
|
||||
#else // _ENDIANESS_
|
||||
if (ENDIAN == big_endian)
|
||||
#endif // _ENDIANESS_
|
||||
std::reverse(reinterpret_cast<uint8*>(&endian_value),reinterpret_cast<uint8*>(&endian_value+1));
|
||||
}
|
||||
|
||||
inline void process_platform()
|
||||
{
|
||||
platform_value = endian_value;
|
||||
#ifdef WORDS_BIGENDIAN
|
||||
if (ENDIAN == little_endian)
|
||||
#else // _ENDIANESS_
|
||||
if (ENDIAN == big_endian)
|
||||
#endif // _ENDIANESS_
|
||||
std::reverse(reinterpret_cast<uint8*>(&platform_value),reinterpret_cast<uint8*>(&platform_value+1));
|
||||
}
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_ENDIAN_H
|
107
ebml/EbmlFloat.h
107
ebml/EbmlFloat.h
@ -1,107 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_FLOAT_H
|
||||
#define LIBEBML_FLOAT_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\class EbmlFloat
|
||||
\brief Handle all operations on a float EBML element
|
||||
*/
|
||||
class EBML_DLL_API EbmlFloat : public EbmlElement {
|
||||
public:
|
||||
enum Precision {
|
||||
FLOAT_32
|
||||
,FLOAT_64
|
||||
};
|
||||
|
||||
EbmlFloat(const Precision prec = FLOAT_32);
|
||||
EbmlFloat(const double DefaultValue, const Precision prec = FLOAT_32);
|
||||
EbmlFloat(const EbmlFloat & ElementToClone);
|
||||
|
||||
virtual bool ValidateSize() const
|
||||
{
|
||||
return (GetSize() == 4 || GetSize() == 8);
|
||||
}
|
||||
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||
|
||||
void SetPrecision(const EbmlFloat::Precision prec = FLOAT_32)
|
||||
{
|
||||
if (prec == FLOAT_64)
|
||||
SetSize_(8);
|
||||
else
|
||||
SetSize_(4); // default size
|
||||
}
|
||||
|
||||
|
||||
// EbmlFloat & operator=(const float NewValue) { Value = NewValue; return *this;}
|
||||
EbmlFloat & operator=(const double NewValue) { Value = NewValue; SetValueIsSet(); return *this;}
|
||||
|
||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||
|
||||
operator float() const;
|
||||
operator double() const;
|
||||
|
||||
EbmlFloat &SetValue(double NewValue);
|
||||
double GetValue() const;
|
||||
|
||||
void SetDefaultValue(double);
|
||||
|
||||
double DefaultVal() const;
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return (DefaultISset() && Value == DefaultValue);
|
||||
}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
double Value; /// The actual value of the element
|
||||
double DefaultValue;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_FLOAT_H
|
@ -1,53 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlHead.h 639 2004-07-09 20:59:14Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_HEAD_H
|
||||
#define LIBEBML_HEAD_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlMaster.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DECLARE_EBML_MASTER(EbmlHead)
|
||||
public:
|
||||
EbmlHead(const EbmlHead & ElementToClone) : EbmlMaster(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EbmlHead)
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_HEAD_H
|
@ -1,99 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlId.h 936 2004-11-10 20:46:28Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_ID_H
|
||||
#define LIBEBML_ID_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
#define EBML_ID_VALUE(id) (id).GetValue()
|
||||
#define EBML_ID_LENGTH(id) (id).GetLength()
|
||||
#else
|
||||
#define EBML_ID_VALUE(id) (id).Value
|
||||
#define EBML_ID_LENGTH(id) (id).Length
|
||||
#endif
|
||||
|
||||
/*!
|
||||
\class EbmlId
|
||||
*/
|
||||
class EBML_DLL_API EbmlId {
|
||||
public:
|
||||
EbmlId(const binary aValue[4], const unsigned int aLength)
|
||||
:Length(aLength)
|
||||
{
|
||||
Value = 0;
|
||||
unsigned int i;
|
||||
for (i=0; i<aLength; i++) {
|
||||
Value <<= 8;
|
||||
Value += aValue[i];
|
||||
}
|
||||
}
|
||||
|
||||
EbmlId(const uint32 aValue, const unsigned int aLength)
|
||||
:Value(aValue), Length(aLength) {}
|
||||
|
||||
inline bool operator==(const EbmlId & TestId) const
|
||||
{
|
||||
return ((TestId.Length == Length) && (TestId.Value == Value));
|
||||
}
|
||||
inline bool operator!=(const EbmlId & TestId) const
|
||||
{
|
||||
return !(*this == TestId);
|
||||
}
|
||||
|
||||
inline void Fill(binary * Buffer) const {
|
||||
unsigned int i;
|
||||
for (i = 0; i<Length; i++) {
|
||||
Buffer[i] = (Value >> (8*(Length-i-1))) & 0xFF;
|
||||
}
|
||||
}
|
||||
|
||||
inline size_t GetLength() const { return Length; }
|
||||
inline uint32 GetValue() const { return Value; }
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#endif
|
||||
uint32 Value;
|
||||
size_t Length;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_ID_H
|
@ -1,230 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlMaster.h 1232 2005-10-15 15:56:52Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_MASTER_H
|
||||
#define LIBEBML_MASTER_H
|
||||
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
#include "EbmlCrc32.h"
|
||||
|
||||
#define EBML_MASTER_ITERATOR std::vector<EbmlElement *>::iterator
|
||||
#define EBML_MASTER_CONST_ITERATOR std::vector<EbmlElement *>::const_iterator
|
||||
#define EBML_MASTER_RITERATOR std::vector<EbmlElement *>::reverse_iterator
|
||||
#define EBML_MASTER_CONST_RITERATOR std::vector<EbmlElement *>::const_reverse_iterator
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
const bool bChecksumUsedByDefault = false;
|
||||
|
||||
/*!
|
||||
\class EbmlMaster
|
||||
\brief Handle all operations on an EBML element that contains other EBML elements
|
||||
*/
|
||||
class EBML_DLL_API EbmlMaster : public EbmlElement {
|
||||
public:
|
||||
EbmlMaster(const EbmlSemanticContext & aContext, bool bSizeIsKnown = true);
|
||||
EbmlMaster(const EbmlMaster & ElementToClone);
|
||||
virtual bool ValidateSize() const {return true;}
|
||||
/*!
|
||||
\warning be carefull to clear the memory allocated in the ElementList elsewhere
|
||||
*/
|
||||
virtual ~EbmlMaster();
|
||||
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully);
|
||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||
|
||||
/*!
|
||||
\brief Set wether the size is finite (size is known in advance when writing, or infinite size is not known on writing)
|
||||
*/
|
||||
bool SetSizeInfinite(bool aIsInfinite = true) {SetSizeIsFinite(!aIsInfinite); return true;}
|
||||
|
||||
bool PushElement(EbmlElement & element);
|
||||
uint64 GetSize() const {
|
||||
if (IsFiniteSize())
|
||||
return EbmlElement::GetSize();
|
||||
else
|
||||
return (0-1);
|
||||
}
|
||||
|
||||
uint64 GetDataStart() const {
|
||||
return GetElementPosition() + EBML_ID_LENGTH((const EbmlId&)*this) + CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize());
|
||||
}
|
||||
|
||||
/*!
|
||||
\brief find the element corresponding to the ID of the element, NULL if not found
|
||||
*/
|
||||
EbmlElement *FindElt(const EbmlCallbacks & Callbacks) const;
|
||||
/*!
|
||||
\brief find the first element corresponding to the ID of the element
|
||||
*/
|
||||
EbmlElement *FindFirstElt(const EbmlCallbacks & Callbacks, bool bCreateIfNull);
|
||||
EbmlElement *FindFirstElt(const EbmlCallbacks & Callbacks) const;
|
||||
|
||||
/*!
|
||||
\brief find the element of the same type of PasElt following in the list of elements
|
||||
*/
|
||||
EbmlElement *FindNextElt(const EbmlElement & PastElt, bool bCreateIfNull);
|
||||
EbmlElement *FindNextElt(const EbmlElement & PastElt) const;
|
||||
EbmlElement *AddNewElt(const EbmlCallbacks & Callbacks);
|
||||
|
||||
/*!
|
||||
\brief add an element at a specified location
|
||||
*/
|
||||
bool InsertElement(EbmlElement & element, size_t position = 0);
|
||||
bool InsertElement(EbmlElement & element, const EbmlElement & before);
|
||||
|
||||
/*!
|
||||
\brief Read the data and keep the known children
|
||||
*/
|
||||
void Read(EbmlStream & inDataStream, const EbmlSemanticContext & Context, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
|
||||
/*!
|
||||
\brief sort Data when they can
|
||||
*/
|
||||
void Sort();
|
||||
|
||||
size_t ListSize() const {return ElementList.size();}
|
||||
std::vector<EbmlElement *> const &GetElementList() const {return ElementList;}
|
||||
std::vector<EbmlElement *> &GetElementList() {return ElementList;}
|
||||
|
||||
inline EBML_MASTER_ITERATOR begin() {return ElementList.begin();}
|
||||
inline EBML_MASTER_ITERATOR end() {return ElementList.end();}
|
||||
inline EBML_MASTER_RITERATOR rbegin() {return ElementList.rbegin();}
|
||||
inline EBML_MASTER_RITERATOR rend() {return ElementList.rend();}
|
||||
inline EBML_MASTER_CONST_ITERATOR begin() const {return ElementList.begin();}
|
||||
inline EBML_MASTER_CONST_ITERATOR end() const {return ElementList.end();}
|
||||
inline EBML_MASTER_CONST_RITERATOR rbegin() const {return ElementList.rbegin();}
|
||||
inline EBML_MASTER_CONST_RITERATOR rend() const {return ElementList.rend();}
|
||||
|
||||
EbmlElement * operator[](unsigned int position) {return ElementList[position];}
|
||||
const EbmlElement * operator[](unsigned int position) const {return ElementList[position];}
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return (ElementList.size() == 0);
|
||||
}
|
||||
virtual bool IsMaster() const {return true;}
|
||||
|
||||
/*!
|
||||
\brief verify that all mandatory elements are present
|
||||
\note usefull after reading or before writing
|
||||
*/
|
||||
bool CheckMandatory() const;
|
||||
|
||||
/*!
|
||||
\brief Remove an element from the list of the master
|
||||
*/
|
||||
void Remove(size_t Index);
|
||||
void Remove(EBML_MASTER_ITERATOR & Itr);
|
||||
void Remove(EBML_MASTER_RITERATOR & Itr);
|
||||
|
||||
/*!
|
||||
\brief remove all elements, even the mandatory ones
|
||||
*/
|
||||
void RemoveAll() {ElementList.clear();}
|
||||
|
||||
/*!
|
||||
\brief facility for Master elements to write only the head and force the size later
|
||||
\warning
|
||||
*/
|
||||
filepos_t WriteHead(IOCallback & output, int SizeLength, bool bWithDefault = false);
|
||||
|
||||
void EnableChecksum(bool bIsEnabled = true) { bChecksumUsed = bIsEnabled; }
|
||||
bool HasChecksum() const {return bChecksumUsed;}
|
||||
bool VerifyChecksum() const;
|
||||
uint32 GetCrc32() const {return Checksum.GetCrc32();}
|
||||
void ForceChecksum(uint32 NewChecksum) {
|
||||
Checksum.ForceCrc32(NewChecksum);
|
||||
bChecksumUsed = true;
|
||||
}
|
||||
|
||||
/*!
|
||||
\brief drill down all sub-elements, finding any missing elements
|
||||
*/
|
||||
std::vector<std::string> FindAllMissingElements();
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
std::vector<EbmlElement *> ElementList;
|
||||
|
||||
const EbmlSemanticContext & Context;
|
||||
|
||||
bool bChecksumUsed;
|
||||
EbmlCrc32 Checksum;
|
||||
|
||||
private:
|
||||
/*!
|
||||
\brief Add all the mandatory elements to the list
|
||||
*/
|
||||
bool ProcessMandatory();
|
||||
};
|
||||
|
||||
///< \todo add a restriction to only elements legal in the context
|
||||
template <typename Type>
|
||||
Type & GetChild(EbmlMaster & Master)
|
||||
{
|
||||
return *(static_cast<Type *>(Master.FindFirstElt(EBML_INFO(Type), true)));
|
||||
}
|
||||
// call with
|
||||
// MyDocType = GetChild<EDocType>(TestHead);
|
||||
|
||||
template <typename Type>
|
||||
Type * FindChild(EbmlMaster & Master)
|
||||
{
|
||||
return static_cast<Type *>(Master.FindFirstElt(EBML_INFO(Type), false));
|
||||
}
|
||||
|
||||
template <typename Type>
|
||||
Type & GetNextChild(EbmlMaster & Master, const Type & PastElt)
|
||||
{
|
||||
return *(static_cast<Type *>(Master.FindNextElt(PastElt, true)));
|
||||
}
|
||||
|
||||
template <typename Type>
|
||||
Type & AddNewChild(EbmlMaster & Master)
|
||||
{
|
||||
return *(static_cast<Type *>(Master.AddNewElt(EBML_INFO(Type))));
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_MASTER_H
|
@ -1,101 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Julien Coloos <suiryc @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
#ifndef LIBEBML_SINTEGER_H
|
||||
#define LIBEBML_SINTEGER_H
|
||||
|
||||
#include <cassert>
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
const int DEFAULT_INT_SIZE = 1; ///< optimal size stored
|
||||
|
||||
/*!
|
||||
\class EbmlSInteger
|
||||
\brief Handle all operations on a signed integer EBML element
|
||||
*/
|
||||
class EBML_DLL_API EbmlSInteger : public EbmlElement {
|
||||
public:
|
||||
EbmlSInteger();
|
||||
EbmlSInteger(int64 DefaultValue);
|
||||
EbmlSInteger(const EbmlSInteger & ElementToClone);
|
||||
|
||||
EbmlSInteger & operator = (int64 NewValue) {Value = NewValue; SetValueIsSet(); return *this;}
|
||||
|
||||
/*!
|
||||
Set the default size of the integer (usually 1,2,4 or 8)
|
||||
*/
|
||||
virtual void SetDefaultSize(uint64 nDefaultSize = DEFAULT_INT_SIZE) {EbmlElement::SetDefaultSize(nDefaultSize); SetSize_(nDefaultSize);}
|
||||
|
||||
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() <= 8);}
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||
|
||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||
|
||||
operator int8() const;
|
||||
operator int16() const;
|
||||
operator int32() const;
|
||||
operator int64() const;
|
||||
|
||||
EbmlSInteger &SetValue(int64 NewValue);
|
||||
int64 GetValue() const;
|
||||
|
||||
void SetDefaultValue(int64 aValue) {assert(!DefaultISset()); DefaultValue = aValue; SetDefaultIsSet();}
|
||||
|
||||
int64 DefaultVal() const {assert(DefaultISset()); return DefaultValue;}
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return (DefaultISset() && Value == DefaultValue);
|
||||
}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
int64 Value; /// The actual value of the element
|
||||
int64 DefaultValue;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_SINTEGER_H
|
@ -1,76 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_STREAM_H
|
||||
#define LIBEBML_STREAM_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "IOCallback.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\class EbmlStream
|
||||
\brief Handle an input/output stream of EBML elements
|
||||
*/
|
||||
class EBML_DLL_API EbmlStream {
|
||||
public:
|
||||
EbmlStream(IOCallback & output);
|
||||
~EbmlStream();
|
||||
|
||||
/*!
|
||||
\brief Find a possible next ID in the data stream
|
||||
\param MaxDataSize The maximum possible of the data in the element (for sanity checks)
|
||||
\note the user will have to delete that element later
|
||||
*/
|
||||
EbmlElement * FindNextID(const EbmlCallbacks & ClassInfos, uint64 MaxDataSize);
|
||||
|
||||
EbmlElement * FindNextElement(const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel = 1);
|
||||
|
||||
inline IOCallback & I_O() {return Stream;}
|
||||
operator IOCallback &() {return Stream;}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
IOCallback & Stream;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_STREAM_H
|
@ -1,88 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_STRING_H
|
||||
#define LIBEBML_STRING_H
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\class EbmlString
|
||||
\brief Handle all operations on a printable string EBML element
|
||||
*/
|
||||
class EBML_DLL_API EbmlString : public EbmlElement {
|
||||
public:
|
||||
EbmlString();
|
||||
EbmlString(const std::string & aDefaultValue);
|
||||
EbmlString(const EbmlString & ElementToClone);
|
||||
|
||||
virtual ~EbmlString() {}
|
||||
|
||||
virtual bool ValidateSize() const {return IsFiniteSize() && GetSize() < 0x7FFFFFFF;} // any size is possible
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||
|
||||
EbmlString & operator=(const std::string &);
|
||||
operator const std::string &() const;
|
||||
|
||||
EbmlString &SetValue(std::string const &NewValue);
|
||||
std::string GetValue() const;
|
||||
|
||||
void SetDefaultValue(std::string &);
|
||||
|
||||
const std::string & DefaultVal() const;
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return (DefaultISset() && Value == DefaultValue);
|
||||
}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
std::string Value; /// The actual value of the element
|
||||
std::string DefaultValue;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_STRING_H
|
@ -1,97 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlSubHead.h 639 2004-07-09 20:59:14Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_SUBHEAD_H
|
||||
#define LIBEBML_SUBHEAD_H
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "EbmlUInteger.h"
|
||||
#include "EbmlString.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DECLARE_EBML_UINTEGER(EVersion)
|
||||
public:
|
||||
EVersion(const EVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EVersion)
|
||||
};
|
||||
|
||||
DECLARE_EBML_UINTEGER(EReadVersion)
|
||||
public:
|
||||
EReadVersion(const EReadVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EReadVersion)
|
||||
};
|
||||
|
||||
DECLARE_EBML_UINTEGER(EMaxIdLength)
|
||||
public:
|
||||
EMaxIdLength(const EMaxIdLength & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EMaxIdLength)
|
||||
};
|
||||
|
||||
DECLARE_EBML_UINTEGER(EMaxSizeLength)
|
||||
public:
|
||||
EMaxSizeLength(const EMaxSizeLength & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EMaxSizeLength)
|
||||
};
|
||||
|
||||
DECLARE_EBML_STRING(EDocType)
|
||||
public:
|
||||
EDocType(const EDocType & ElementToClone) : EbmlString(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EDocType)
|
||||
};
|
||||
|
||||
DECLARE_EBML_UINTEGER(EDocTypeVersion)
|
||||
public:
|
||||
EDocTypeVersion(const EDocTypeVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EDocTypeVersion)
|
||||
};
|
||||
|
||||
DECLARE_EBML_UINTEGER(EDocTypeReadVersion)
|
||||
public:
|
||||
EDocTypeReadVersion(const EDocTypeReadVersion & ElementToClone) : EbmlUInteger(ElementToClone) {}
|
||||
|
||||
EBML_CONCRETE_CLASS(EDocTypeReadVersion)
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_SUBHEAD_H
|
@ -1,72 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlTypes.h 639 2004-07-09 20:59:14Z mosu $
|
||||
*/
|
||||
#ifndef LIBEBML_TYPES_H
|
||||
#define LIBEBML_TYPES_H
|
||||
|
||||
#include "ebml/c/libebml_t.h"
|
||||
#include "ebml/EbmlConfig.h"
|
||||
#include "EbmlEndian.h" // binary needs to be defined
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
typedef wchar_t utf16;
|
||||
typedef uint32 utf32;
|
||||
typedef char utf8;
|
||||
|
||||
typedef binary bits80[10];
|
||||
|
||||
typedef Endian<int16,little_endian> lil_int16;
|
||||
typedef Endian<int32,little_endian> lil_int32;
|
||||
typedef Endian<int64,little_endian> lil_int64;
|
||||
typedef Endian<uint16,little_endian> lil_uint16;
|
||||
typedef Endian<uint32,little_endian> lil_uint32;
|
||||
typedef Endian<uint64,little_endian> lil_uint64;
|
||||
typedef Endian<int16,big_endian> big_int16;
|
||||
typedef Endian<int32,big_endian> big_int32;
|
||||
typedef Endian<int64,big_endian> big_int64;
|
||||
typedef Endian<uint16,big_endian> big_uint16;
|
||||
typedef Endian<uint32,big_endian> big_uint32;
|
||||
typedef Endian<uint64,big_endian> big_uint64;
|
||||
typedef Endian<uint32,big_endian> checksum;
|
||||
typedef Endian<bits80,big_endian> big_80bits;
|
||||
|
||||
|
||||
enum ScopeMode {
|
||||
SCOPE_PARTIAL_DATA = 0,
|
||||
SCOPE_ALL_DATA,
|
||||
SCOPE_NO_DATA
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif
|
@ -1,99 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Julien Coloos <suiryc @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
#ifndef LIBEBML_UINTEGER_H
|
||||
#define LIBEBML_UINTEGER_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
const int DEFAULT_UINT_SIZE = 0; ///< optimal size stored
|
||||
|
||||
/*!
|
||||
\class EbmlUInteger
|
||||
\brief Handle all operations on an unsigned integer EBML element
|
||||
*/
|
||||
class EBML_DLL_API EbmlUInteger : public EbmlElement {
|
||||
public:
|
||||
EbmlUInteger();
|
||||
EbmlUInteger(uint64 DefaultValue);
|
||||
EbmlUInteger(const EbmlUInteger & ElementToClone);
|
||||
|
||||
EbmlUInteger & operator=(uint64 NewValue) {Value = NewValue; SetValueIsSet(); return *this;}
|
||||
|
||||
/*!
|
||||
Set the default size of the integer (usually 1,2,4 or 8)
|
||||
*/
|
||||
virtual void SetDefaultSize(uint64 nDefaultSize = DEFAULT_UINT_SIZE) {EbmlElement::SetDefaultSize(nDefaultSize); SetSize_(nDefaultSize);}
|
||||
|
||||
virtual bool ValidateSize() const {return IsFiniteSize() && (GetSize() <= 8);}
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||
|
||||
virtual bool IsSmallerThan(const EbmlElement *Cmp) const;
|
||||
|
||||
operator uint8() const;
|
||||
operator uint16() const;
|
||||
operator uint32() const;
|
||||
operator uint64() const;
|
||||
|
||||
EbmlUInteger &SetValue(uint64 NewValue);
|
||||
uint64 GetValue() const;
|
||||
|
||||
void SetDefaultValue(uint64);
|
||||
|
||||
uint64 DefaultVal() const;
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return (DefaultISset() && Value == DefaultValue);
|
||||
}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
uint64 Value; /// The actual value of the element
|
||||
uint64 DefaultValue;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_UINTEGER_H
|
@ -1,140 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
*/
|
||||
#ifndef LIBEBML_UNICODE_STRING_H
|
||||
#define LIBEBML_UNICODE_STRING_H
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlElement.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\class UTFstring
|
||||
A class storing strings in a wchar_t (ie, in UCS-2 or UCS-4)
|
||||
\note inspired by wstring which is not available everywhere
|
||||
*/
|
||||
class EBML_DLL_API UTFstring {
|
||||
public:
|
||||
typedef wchar_t value_type;
|
||||
|
||||
UTFstring();
|
||||
UTFstring(const wchar_t *); // should be NULL terminated
|
||||
UTFstring(const UTFstring &);
|
||||
UTFstring(std::wstring const &);
|
||||
|
||||
virtual ~UTFstring();
|
||||
bool operator==(const UTFstring&) const;
|
||||
inline bool operator!=(const UTFstring &cmp) const
|
||||
{
|
||||
return !(*this == cmp);
|
||||
}
|
||||
UTFstring & operator=(const UTFstring &);
|
||||
UTFstring & operator=(const wchar_t *);
|
||||
UTFstring & operator=(wchar_t);
|
||||
|
||||
/// Return length of string
|
||||
size_t length() const {return _Length;}
|
||||
|
||||
operator const wchar_t*() const;
|
||||
const wchar_t* c_str() const {return _Data;}
|
||||
|
||||
const std::string & GetUTF8() const {return UTF8string;}
|
||||
void SetUTF8(const std::string &);
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
size_t _Length; ///< length of the UCS string excluding the \0
|
||||
wchar_t* _Data; ///< internal UCS representation
|
||||
std::string UTF8string;
|
||||
static bool wcscmp_internal(const wchar_t *str1, const wchar_t *str2);
|
||||
void UpdateFromUTF8();
|
||||
void UpdateFromUCS2();
|
||||
};
|
||||
|
||||
|
||||
/*!
|
||||
\class EbmlUnicodeString
|
||||
\brief Handle all operations on a Unicode string EBML element
|
||||
\note internally treated as a string made of wide characters (ie UCS-2 or UCS-4 depending on the machine)
|
||||
*/
|
||||
class EBML_DLL_API EbmlUnicodeString : public EbmlElement {
|
||||
public:
|
||||
EbmlUnicodeString();
|
||||
EbmlUnicodeString(const UTFstring & DefaultValue);
|
||||
EbmlUnicodeString(const EbmlUnicodeString & ElementToClone);
|
||||
|
||||
virtual ~EbmlUnicodeString() {}
|
||||
|
||||
virtual bool ValidateSize() const {return IsFiniteSize();} // any size is possible
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
filepos_t ReadData(IOCallback & input, ScopeMode ReadFully = SCOPE_ALL_DATA);
|
||||
filepos_t UpdateSize(bool bWithDefault = false, bool bForceRender = false);
|
||||
|
||||
EbmlUnicodeString & operator=(const UTFstring &); ///< platform dependant code
|
||||
operator const UTFstring &() const;
|
||||
|
||||
EbmlUnicodeString &SetValue(UTFstring const &NewValue);
|
||||
EbmlUnicodeString &SetValueUTF8(std::string const &NewValue);
|
||||
UTFstring GetValue() const;
|
||||
std::string GetValueUTF8() const;
|
||||
|
||||
void SetDefaultValue(UTFstring &);
|
||||
|
||||
const UTFstring & DefaultVal() const;
|
||||
|
||||
bool IsDefaultValue() const {
|
||||
return (DefaultISset() && Value == DefaultValue);
|
||||
}
|
||||
|
||||
#if defined(EBML_STRICT_API)
|
||||
private:
|
||||
#else
|
||||
protected:
|
||||
#endif
|
||||
UTFstring Value; /// The actual value of the element
|
||||
UTFstring DefaultValue;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_UNICODE_STRING_H
|
@ -1,56 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_VERSION_H
|
||||
#define LIBEBML_VERSION_H
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "EbmlConfig.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
#define LIBEBML_VERSION 0x010304
|
||||
|
||||
extern const std::string EbmlCodeVersion;
|
||||
extern const std::string EbmlCodeDate;
|
||||
|
||||
/*!
|
||||
\todo Closer relation between an element and the context it comes from (context is an element attribute ?)
|
||||
*/
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_VERSION_H
|
@ -1,73 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlVoid.h 1079 2005-03-03 13:18:14Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#ifndef LIBEBML_VOID_H
|
||||
#define LIBEBML_VOID_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
#include "EbmlBinary.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DECLARE_EBML_BINARY(EbmlVoid)
|
||||
public:
|
||||
EbmlVoid(const EbmlVoid & ElementToClone) :EbmlBinary(ElementToClone){}
|
||||
|
||||
/*!
|
||||
\brief Set the size of the data (not the complete size of the element)
|
||||
*/
|
||||
void SetSize(uint64 aSize) {SetSize_(aSize);}
|
||||
|
||||
/*!
|
||||
\note overwrite to write fake data
|
||||
*/
|
||||
filepos_t RenderData(IOCallback & output, bool bForceRender, bool bWithDefault = false);
|
||||
|
||||
/*!
|
||||
\brief Replace the void element content (written) with this one
|
||||
*/
|
||||
uint64 ReplaceWith(EbmlElement & EltToReplaceWith, IOCallback & output, bool ComeBackAfterward = true, bool bWithDefault = false);
|
||||
|
||||
/*!
|
||||
\brief Void the content of an element
|
||||
*/
|
||||
uint64 Overwrite(const EbmlElement & EltToVoid, IOCallback & output, bool ComeBackAfterward = true, bool bWithDefault = false);
|
||||
|
||||
EBML_CONCRETE_CLASS(EbmlVoid)
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_VOID_H
|
@ -1,117 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Ingo Ralf Blum. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: IOCallback.h 639 2004-07-09 20:59:14Z mosu $
|
||||
*/
|
||||
#ifndef MATROSKA_IOCALLBACK_H
|
||||
#define MATROSKA_IOCALLBACK_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
|
||||
#include <cassert>
|
||||
#include <exception>
|
||||
#include <cstdio>
|
||||
// #include <iostream>
|
||||
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
enum seek_mode
|
||||
{
|
||||
seek_beginning=SEEK_SET
|
||||
,seek_end=SEEK_END
|
||||
,seek_current=SEEK_CUR
|
||||
};
|
||||
|
||||
class EBML_DLL_API IOCallback
|
||||
{
|
||||
public:
|
||||
virtual ~IOCallback(){}
|
||||
|
||||
// The read callback works like most other read functions. You specify the
|
||||
// file, the buffer and the size and the function returns the bytes read.
|
||||
// If an error occurs or the file pointer points to the end of the file 0 is returned.
|
||||
// Users are encouraged to throw a descriptive exception, when an error occurs.
|
||||
virtual uint32 read(void*Buffer,size_t Size)=0;
|
||||
|
||||
// Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
||||
// or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
||||
// or false (0), when the seek fails.
|
||||
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning)=0;
|
||||
|
||||
// This callback just works like its read pendant. It returns the number of bytes written.
|
||||
virtual size_t write(const void*Buffer,size_t Size)=0;
|
||||
|
||||
// Although the position is always positive, the return value of this callback is signed to
|
||||
// easily allow negative values for returning errors. When an error occurs, the implementor
|
||||
// should return -1 and the file pointer otherwise.
|
||||
//
|
||||
// If an error occurs, an exception should be thrown.
|
||||
virtual uint64 getFilePointer()=0;
|
||||
|
||||
// The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
||||
// library, this is equivalent to calling fclose. When the close is not successful, an exception
|
||||
// should be thrown.
|
||||
virtual void close()=0;
|
||||
|
||||
|
||||
// The readFully is made virtual to allow derived classes to use another
|
||||
// implementation for this method, which e.g. does not read any data
|
||||
// unlike this does
|
||||
void readFully(void*Buffer,size_t Size);
|
||||
|
||||
template<class STRUCT> void readStruct(STRUCT&Struct){readFully(&Struct,sizeof(Struct));}
|
||||
|
||||
void writeFully(const void*Buffer,size_t Size);
|
||||
|
||||
template<class STRUCT> void writeStruct(const STRUCT&Struct){writeFully(&Struct,sizeof(Struct));}
|
||||
};
|
||||
|
||||
/* cygwin incompatible
|
||||
template<class TRAITS> std::basic_ostream<char,TRAITS>&operator<<(std::basic_ostream<char,TRAITS>&Stream,seek_mode Mode)
|
||||
{
|
||||
switch(Mode)
|
||||
{
|
||||
#define x(y) case seek_##y: Stream<<"seek_" #y; break
|
||||
x(beginning);
|
||||
x(current);
|
||||
x(end);
|
||||
#undef x
|
||||
default:
|
||||
assert(false);
|
||||
}
|
||||
|
||||
return Stream;
|
||||
}
|
||||
*/
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // MATROSKA_IOCALLBACK_H
|
@ -1,118 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2003-2004 Jory Stone. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: MemIOCallback.h 1298 2008-02-21 22:14:18Z mosu $
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
*/
|
||||
#ifndef LIBEBML_MEMIOCALLBACK_H
|
||||
#define LIBEBML_MEMIOCALLBACK_H
|
||||
|
||||
#include "IOCallback.h"
|
||||
#include <string>
|
||||
#ifndef __BEOS__
|
||||
#include <sstream>
|
||||
#else
|
||||
#include <strstream>
|
||||
#define stringstream strstream
|
||||
#endif
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
class EBML_DLL_API MemIOCallback : public IOCallback
|
||||
{
|
||||
public:
|
||||
MemIOCallback(uint64 DefaultSize = 128);
|
||||
~MemIOCallback();
|
||||
|
||||
/*!
|
||||
Use this to copy some data to the Buffer from this classes data
|
||||
*/
|
||||
uint32 read(void *Buffer, size_t Size);
|
||||
|
||||
/*!
|
||||
Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
||||
or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
||||
or false (0), when the seek fails.
|
||||
*/
|
||||
void setFilePointer(int64 Offset, seek_mode Mode=seek_beginning);
|
||||
|
||||
/*!
|
||||
This callback just works like its read pendant. It returns the number of bytes written.
|
||||
*/
|
||||
size_t write(const void *Buffer, size_t Size);
|
||||
|
||||
/*!
|
||||
Although the position is always positive, the return value of this callback is signed to
|
||||
easily allow negative values for returning errors. When an error occurs, the implementor
|
||||
should return -1 and the file pointer otherwise.
|
||||
|
||||
If an error occurs, an exception should be thrown.
|
||||
*/
|
||||
virtual uint64 getFilePointer() {return dataBufferPos;};
|
||||
|
||||
/*!
|
||||
The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
||||
library, this is equivalent to calling fclose. When the close is not successful, an exception
|
||||
should be thrown.
|
||||
*/
|
||||
void close() {};
|
||||
|
||||
binary *GetDataBuffer() const {return dataBuffer;};
|
||||
uint64 GetDataBufferSize() {return dataBufferTotalSize;};
|
||||
void SetDataBufferSize(uint64 newDataBufferSize) {dataBufferTotalSize = newDataBufferSize;};
|
||||
/*!
|
||||
Use this to write some data from another IOCallback
|
||||
*/
|
||||
uint32 write(IOCallback & IOToRead, size_t Size);
|
||||
|
||||
bool IsOk() { return mOk; };
|
||||
const std::string &GetLastErrorStr() { return mLastErrorStr; };
|
||||
protected:
|
||||
bool mOk;
|
||||
std::string mLastErrorStr;
|
||||
|
||||
binary *dataBuffer;
|
||||
/*!
|
||||
Postion where we start 'writing' to the dataBuffer
|
||||
*/
|
||||
uint64 dataBufferPos;
|
||||
/*!
|
||||
Size of the data in the dataBuffer
|
||||
*/
|
||||
uint64 dataBufferTotalSize;
|
||||
/*!
|
||||
Size of the memory malloc()/realloc()
|
||||
*/
|
||||
uint64 dataBufferMemorySize;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_MEMIOCALLBACK_H
|
@ -1,66 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2014 Moritz Bunkus. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.matroska.org/license/lgpl/ for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\author Moritz Bunkus <moritz@bunkus.org>
|
||||
*/
|
||||
#ifndef LIBEBML_MEMREADIOCALLBACK_H
|
||||
#define LIBEBML_MEMREADIOCALLBACK_H
|
||||
|
||||
#include "IOCallback.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
class EBML_DLL_API EbmlBinary;
|
||||
|
||||
class EBML_DLL_API MemReadIOCallback : public IOCallback {
|
||||
protected:
|
||||
uint8 const *mStart, *mEnd, *mPtr;
|
||||
|
||||
public:
|
||||
MemReadIOCallback(void const *Ptr, size_t Size);
|
||||
MemReadIOCallback(EbmlBinary const &Binary);
|
||||
MemReadIOCallback(MemReadIOCallback const &Mem);
|
||||
virtual ~MemReadIOCallback();
|
||||
|
||||
uint32 read(void *Buffer, size_t Size);
|
||||
void setFilePointer(int64 Offset, seek_mode Mode = seek_beginning);
|
||||
size_t write(void const *, size_t) { return 0; }
|
||||
virtual uint64 getFilePointer() { return mPtr - mStart; }
|
||||
void close() {}
|
||||
binary const *GetDataBuffer() const { return mPtr; }
|
||||
uint64 GetDataBufferSize() const { return mEnd - mStart; }
|
||||
|
||||
protected:
|
||||
void Init(void const *Ptr, size_t Size);
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_MEMREADIOCALLBACK_H
|
@ -1,91 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2014 Moritz Bunkus. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.matroska.org/license/lgpl/ for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Moritz Bunkus <moritz@bunkus.org>
|
||||
*/
|
||||
#ifndef LIBEBML_SAFEREADIOCALLBACK_H
|
||||
#define LIBEBML_SAFEREADIOCALLBACK_H
|
||||
|
||||
#include "EbmlTypes.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
class EBML_DLL_API IOCallback;
|
||||
class EBML_DLL_API EbmlBinary;
|
||||
|
||||
class EBML_DLL_API SafeReadIOCallback {
|
||||
public:
|
||||
class EndOfStreamX {
|
||||
public:
|
||||
size_t mMissingBytes;
|
||||
EndOfStreamX(std::size_t MissingBytes);
|
||||
};
|
||||
|
||||
private:
|
||||
IOCallback *mIO;
|
||||
bool mDeleteIO;
|
||||
size_t mSize;
|
||||
|
||||
public:
|
||||
SafeReadIOCallback(IOCallback *IO, bool DeleteIO);
|
||||
SafeReadIOCallback(void const *Mem, size_t Size);
|
||||
SafeReadIOCallback(EbmlBinary const &Binary);
|
||||
~SafeReadIOCallback();
|
||||
|
||||
size_t GetPosition() const;
|
||||
size_t GetSize() const;
|
||||
size_t GetRemainingBytes() const;
|
||||
bool IsEmpty() const;
|
||||
|
||||
uint8 GetUInt8();
|
||||
uint64 GetUIntBE(size_t NumBytes);
|
||||
uint16 GetUInt16BE();
|
||||
uint32 GetUInt24BE();
|
||||
uint32 GetUInt32BE();
|
||||
uint64 GetUInt64BE();
|
||||
|
||||
void Read(void *Dst, size_t Count);
|
||||
|
||||
void Skip(size_t Count);
|
||||
void Seek(size_t Position);
|
||||
|
||||
private:
|
||||
SafeReadIOCallback(SafeReadIOCallback const &) { }
|
||||
|
||||
protected:
|
||||
void Init(IOCallback *IO, bool DeleteIO);
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_SAFEREADIOCALLBACK_H
|
@ -1,101 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Ingo Ralf Blum. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: StdIOCallback.h 1090 2005-03-16 12:47:59Z robux4 $
|
||||
*/
|
||||
#ifndef LIBEBML_STDIOCALLBACK_H
|
||||
#define LIBEBML_STDIOCALLBACK_H
|
||||
|
||||
#include "IOCallback.h"
|
||||
|
||||
#include <stdexcept>
|
||||
#include <cerrno>
|
||||
|
||||
// ----- Added 10/15/2003 by jcsston from Zen -----
|
||||
#if defined (__BORLANDC__) //Maybe other compilers?
|
||||
#include <errno.h>
|
||||
#include <stdio.h>
|
||||
#endif //__BORLANDC__
|
||||
// ------------------------------------------------
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
class EBML_DLL_API CRTError:public std::runtime_error
|
||||
{
|
||||
// Variablen...
|
||||
private:
|
||||
int Error;
|
||||
|
||||
// Methoden...
|
||||
public:
|
||||
CRTError(int Error,const std::string&Description);
|
||||
CRTError(const std::string&Description,int Error=errno);
|
||||
|
||||
int getError()const throw(){return Error;}
|
||||
};
|
||||
|
||||
// This class is currently private to the library, so there's no MATROSKA_EXPORT.
|
||||
class EBML_DLL_API StdIOCallback:public IOCallback
|
||||
{
|
||||
private:
|
||||
FILE*File;
|
||||
uint64 mCurrentPosition;
|
||||
|
||||
public:
|
||||
// StdIOCallback(const char*Path,const char*Mode);
|
||||
StdIOCallback(const char*Path, const open_mode Mode);
|
||||
virtual ~StdIOCallback()throw();
|
||||
|
||||
virtual uint32 read(void*Buffer,size_t Size);
|
||||
|
||||
// Seek to the specified position. The mode can have either SEEK_SET, SEEK_CUR
|
||||
// or SEEK_END. The callback should return true(1) if the seek operation succeeded
|
||||
// or false (0), when the seek fails.
|
||||
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning);
|
||||
|
||||
// This callback just works like its read pendant. It returns the number of bytes written.
|
||||
virtual size_t write(const void*Buffer,size_t Size);
|
||||
|
||||
// Although the position is always positive, the return value of this callback is signed to
|
||||
// easily allow negative values for returning errors. When an error occurs, the implementor
|
||||
// should return -1 and the file pointer otherwise.
|
||||
//
|
||||
// If an error occurs, an exception should be thrown.
|
||||
virtual uint64 getFilePointer();
|
||||
|
||||
// The close callback flushes the file buffers to disk and closes the file. When using the stdio
|
||||
// library, this is equivalent to calling fclose. When the close is not successful, an exception
|
||||
// should be thrown.
|
||||
virtual void close();
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif
|
@ -1,133 +0,0 @@
|
||||
/****************************************************************************
|
||||
** LIBEBML : parse EBML files, see http://ebml.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2003 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of LIBEBML.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file libebml_t.h
|
||||
\version \$Id: libebml_t.h 1298 2008-02-21 22:14:18Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Ingo Ralf Blum <ingoralfblum @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz@bunkus.org>
|
||||
|
||||
\brief Misc type definitions for the C API of LIBEBML
|
||||
|
||||
\note These types should be compiler/language independant (just platform dependant)
|
||||
\todo recover the sized types (uint16, int32, etc) here too (or maybe here only)
|
||||
*/
|
||||
|
||||
#ifndef _LIBEBML_T_H_INCLUDED_
|
||||
#define _LIBEBML_T_H_INCLUDED_
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
// Changed char is unsigned now (signedness was causing trouble in endil)
|
||||
#if defined(_WIN32)
|
||||
# if !defined(__GNUC__) // Microsoft Visual C++
|
||||
typedef signed __int64 int64;
|
||||
typedef signed __int32 int32;
|
||||
typedef signed __int16 int16;
|
||||
typedef signed __int8 int8;
|
||||
typedef __int8 character;
|
||||
typedef unsigned __int64 uint64;
|
||||
typedef unsigned __int32 uint32;
|
||||
typedef unsigned __int16 uint16;
|
||||
typedef unsigned __int8 uint8;
|
||||
# else // __GNUC__, this is mingw
|
||||
# include <stdint.h>
|
||||
typedef int64_t int64;
|
||||
typedef int32_t int32;
|
||||
typedef int16_t int16;
|
||||
typedef int8_t int8;
|
||||
typedef int8_t character;
|
||||
typedef uint64_t uint64;
|
||||
typedef uint32_t uint32;
|
||||
typedef uint16_t uint16;
|
||||
typedef uint8_t uint8;
|
||||
# endif // __GNUC__
|
||||
#elif defined(__BEOS__)
|
||||
#include <SupportDefs.h>
|
||||
#elif defined(DJGPP) /* SL : DJGPP doesn't support POSIX types ???? */
|
||||
typedef signed long long int64;
|
||||
typedef signed long int32;
|
||||
typedef signed short int16;
|
||||
typedef signed char int8;
|
||||
typedef char character;
|
||||
typedef unsigned long long uint64;
|
||||
typedef unsigned long uint32;
|
||||
typedef unsigned short uint16;
|
||||
typedef unsigned char uint8;
|
||||
#elif defined(__sun) && (defined(__svr4__) || defined(__SVR4)) // SOLARIS
|
||||
# include <inttypes.h>
|
||||
# ifdef _NO_LONGLONG
|
||||
# error This compiler does not support 64bit integers.
|
||||
# endif
|
||||
typedef int64_t int64;
|
||||
typedef int32_t int32;
|
||||
typedef int16_t int16;
|
||||
typedef int8_t int8;
|
||||
typedef int8_t character;
|
||||
typedef uint64_t uint64;
|
||||
typedef uint32_t uint32;
|
||||
typedef uint16_t uint16;
|
||||
typedef uint8_t uint8;
|
||||
#elif defined(__BEOS__)
|
||||
# include <support/SupportDefs.h>
|
||||
#else // anything else (Linux, BSD, ...)
|
||||
# include <inttypes.h>
|
||||
# include <sys/types.h>
|
||||
typedef int64_t int64;
|
||||
typedef int32_t int32;
|
||||
typedef int16_t int16;
|
||||
typedef int8_t int8;
|
||||
typedef int8_t character;
|
||||
typedef uint64_t uint64;
|
||||
typedef uint32_t uint32;
|
||||
typedef uint16_t uint16;
|
||||
typedef uint8_t uint8;
|
||||
#endif /* anything else */
|
||||
|
||||
typedef uint8 binary;
|
||||
typedef uint64 filepos_t;
|
||||
|
||||
typedef enum open_mode {
|
||||
MODE_READ,
|
||||
MODE_WRITE,
|
||||
MODE_CREATE,
|
||||
MODE_SAFE
|
||||
} open_mode;
|
||||
|
||||
#define EBML_MIN(x,y) ((x)<(y) ? (x) : (y))
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* _LIBEBML_T_H_INCLUDED_ */
|
BIN
images/body-bg.jpg
Normal file
BIN
images/body-bg.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
BIN
images/download-button.png
Normal file
BIN
images/download-button.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 26 KiB |
BIN
images/github-button.png
Normal file
BIN
images/github-button.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.5 KiB |
BIN
images/header-bg.jpg
Normal file
BIN
images/header-bg.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 9.2 KiB |
BIN
images/highlight-bg.jpg
Normal file
BIN
images/highlight-bg.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 30 KiB |
BIN
images/sidebar-bg.jpg
Normal file
BIN
images/sidebar-bg.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
76
index.html
Normal file
76
index.html
Normal file
@ -0,0 +1,76 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset='utf-8'>
|
||||
<meta http-equiv="X-UA-Compatible" content="chrome=1">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
|
||||
<link href='https://fonts.googleapis.com/css?family=Architects+Daughter' rel='stylesheet' type='text/css'>
|
||||
<link rel="stylesheet" type="text/css" href="stylesheets/stylesheet.css" media="screen">
|
||||
<link rel="stylesheet" type="text/css" href="stylesheets/pygment_trac.css" media="screen">
|
||||
<link rel="stylesheet" type="text/css" href="stylesheets/print.css" media="print">
|
||||
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
|
||||
<title>libEBML by the Matroska team</title>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<header>
|
||||
<div class="inner">
|
||||
<h1>libEBML</h1>
|
||||
<h2>a C++ libary to parse EBML files</h2>
|
||||
<a href="https://github.com/Matroska-Org/libebml" class="button"><small>View project on</small> GitHub</a>
|
||||
</div>
|
||||
</header>
|
||||
|
||||
<div id="content-wrapper">
|
||||
<div class="inner clearfix">
|
||||
<section id="main-content">
|
||||
<h3>
|
||||
<a id="ebml--extensible-binary-markup-language" class="anchor" href="#ebml--extensible-binary-markup-language" aria-hidden="true"><span class="octicon octicon-link"></span></a>EBML – Extensible Binary Markup Language</h3>
|
||||
|
||||
<p>EBML was designed to be a simplified binary extension of XML for the purpose of storing and manipulating data in a hierarchical form with variable field lengths.</p>
|
||||
|
||||
<p>It uses the same paradigms as XML files, meaning that syntax and semantics are separated. So a generic EBML library could read any format based on it. The interpretation of data is up to a specific application that knows how each elements (equivalent of XML tag) has to be handled.</p>
|
||||
|
||||
<p>Among all the advantages of XML, there are a few limitations compared to what XML can achieve:</p>
|
||||
|
||||
<ul>
|
||||
<li>There is currently no equivalent to a DTD or Schema to define known elements for a document. But we plan on adding such a level.</li>
|
||||
<li>No entity can be defined, ie an element that would be replaced by another content. We don't plan to add something like this so far.</li>
|
||||
<li>No external include of other files (like CSS, images, etc). It could be easily added as a "proprietary" element (not defined in the basic EBML format).</li>
|
||||
</ul>
|
||||
|
||||
<p>For the rest, you have all advantages like:</p>
|
||||
|
||||
<ul>
|
||||
<li>Upward compatibility when the format is updated. Something rare in binary formats, unless you have some unused space in the original format.</li>
|
||||
<li>Unlimited size of binary data.</li>
|
||||
<li>Very size efficient: only space required for a data is written (unless you specifically require more space for better updating later).</li>
|
||||
</ul>
|
||||
|
||||
<p>There is also one disadvantage commonly said about XML: it's very verbose. That's why you should have default/assumed values in you EBML-based format as much as possible. So you just describe what is really necessary.</p>
|
||||
|
||||
<p>EBML was originally created for the <a href="http://www.matroska.org">Matroska</a> project. So this is naturally the first format based on EBML to exist. You are therefore encouraged to check the specs to know how to design a format based on EBML.</p>
|
||||
|
||||
<h3>Contact</h3>
|
||||
|
||||
<p>All people that are working on EBML are related to Matroska. So you'd better contact the <a href="http://www.matroska.org/contact/index.html">Matroska team</a>.</p>
|
||||
|
||||
</section>
|
||||
|
||||
<aside id="sidebar">
|
||||
<p><a href="index.html" class="page-link">Home page</a></p>
|
||||
<p><a href="specs.html" class="page-link">Specifications</a></p>
|
||||
|
||||
<p class="repo-owner"><a href="https://github.com/Matroska-Org/libebml">libEBML</a> is maintained by the <a href="http://www.matroska.org/contact/index.html">Matroska team</a>.</p>
|
||||
|
||||
</aside>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
</body>
|
||||
</html>
|
1
javascripts/main.js
Normal file
1
javascripts/main.js
Normal file
@ -0,0 +1 @@
|
||||
console.log('This would be the main JS file.');
|
@ -1,10 +0,0 @@
|
||||
prefix=@prefix@
|
||||
exec_prefix=@exec_prefix@
|
||||
libdir=@libdir@
|
||||
includedir=@includedir@
|
||||
|
||||
Name: libebml
|
||||
Description: Library for parsing EBML data structures
|
||||
Version: @PACKAGE_VERSION@
|
||||
Libs: -L${libdir} -lebml
|
||||
Cflags: -I${includedir}
|
67
libebml.proj
67
libebml.proj
@ -1,67 +0,0 @@
|
||||
#include "*/*.proj"
|
||||
|
||||
LIB ebml
|
||||
{
|
||||
PROJECT_VERSION 1.2.3
|
||||
|
||||
INCLUDE .
|
||||
EXPINCLUDE .
|
||||
EXPDEFINE(USE_EBML_STRICT_API) EBML_STRICT_API
|
||||
DEFINE(USE_EBML_STRICT_API) EBML_STRICT_API
|
||||
|
||||
// OPTIMIZE_GLOBALLY .
|
||||
FAVOR_MAX_SPEED .
|
||||
REDUCE_SIZE .
|
||||
FASTER_FLOAT .
|
||||
|
||||
SOURCE src/Debug.cpp
|
||||
SOURCE src/EbmlBinary.cpp
|
||||
SOURCE src/EbmlContexts.cpp
|
||||
SOURCE src/EbmlCrc32.cpp
|
||||
SOURCE src/EbmlDate.cpp
|
||||
SOURCE src/EbmlDummy.cpp
|
||||
SOURCE src/EbmlElement.cpp
|
||||
SOURCE src/EbmlFloat.cpp
|
||||
SOURCE src/EbmlHead.cpp
|
||||
SOURCE src/EbmlMaster.cpp
|
||||
SOURCE src/EbmlSInteger.cpp
|
||||
SOURCE src/EbmlStream.cpp
|
||||
SOURCE src/EbmlString.cpp
|
||||
SOURCE src/EbmlSubHead.cpp
|
||||
SOURCE src/EbmlUInteger.cpp
|
||||
SOURCE src/EbmlUnicodeString.cpp
|
||||
SOURCE src/EbmlVersion.cpp
|
||||
SOURCE src/EbmlVoid.cpp
|
||||
SOURCE src/IOCallback.cpp
|
||||
SOURCE src/MemIOCallback.cpp
|
||||
SOURCE src/StdIOCallback.cpp
|
||||
SOURCE(TARGET_WIN) src/platform/win32/WinIOCallback.cpp
|
||||
|
||||
HEADER(TARGET_WIN) src/platform/win32/WinIOCallback.h
|
||||
HEADER ebml/Debug.h
|
||||
HEADER ebml/EbmlBinary.h
|
||||
HEADER ebml/EbmlConfig.h
|
||||
HEADER ebml/EbmlContexts.h
|
||||
HEADER ebml/EbmlCrc32.h
|
||||
HEADER ebml/EbmlDate.h
|
||||
HEADER ebml/EbmlDummy.h
|
||||
HEADER ebml/EbmlElement.h
|
||||
HEADER ebml/EbmlEndian.h
|
||||
HEADER ebml/EbmlFloat.h
|
||||
HEADER ebml/EbmlHead.h
|
||||
HEADER ebml/EbmlId.h
|
||||
HEADER ebml/EbmlMaster.h
|
||||
HEADER ebml/EbmlSInteger.h
|
||||
HEADER ebml/EbmlStream.h
|
||||
HEADER ebml/EbmlString.h
|
||||
HEADER ebml/EbmlSubHead.h
|
||||
HEADER ebml/EbmlTypes.h
|
||||
HEADER ebml/EbmlUInteger.h
|
||||
HEADER ebml/EbmlUnicodeString.h
|
||||
HEADER ebml/EbmlVersion.h
|
||||
HEADER ebml/EbmlVoid.h
|
||||
HEADER ebml/IOCallback.h
|
||||
HEADER ebml/MemIOCallback.h
|
||||
HEADER ebml/StdIOCallback.h
|
||||
HEADER ebml/c/libebml_t.h
|
||||
}
|
2
m4/.gitignore
vendored
2
m4/.gitignore
vendored
@ -1,2 +0,0 @@
|
||||
/libtool.m4
|
||||
/lt*.m4
|
1
params.json
Normal file
1
params.json
Normal file
@ -0,0 +1 @@
|
||||
{"name":"Libebml","tagline":"a C++ libary to parse EBML files","body":"### EBML – Extensible Binary Markup Language\r\n\r\nEBML was designed to be a simplified binary extension of XML for the purpose of storing and manipulating data in a hierarchical form with variable field lengths.\r\n\r\nIt uses the same paradigms as XML files, meaning that syntax and semantics are separated. So a generic EBML library could read any format based on it. The interpretation of data is up to a specific application that knows how each elements (equivalent of XML tag) has to be handled.\r\n\r\nAmong all the advantages of XML, there are a few limitations compared to what XML can achieve:\r\n\r\n- There is currently no equivalent to a DTD or Schema to define known elements for a document. But we plan on adding such a level.\r\n- No entity can be defined, ie an element that would be replaced by another content. We don't plan to add something like this so far.\r\n- No external include of other files (like CSS, images, etc). It could be easily added as a \"proprietary\" element (not defined in the basic EBML format).\r\n\r\nFor the rest, you have all advantages like:\r\n\r\n- Upward compatibility when the format is updated. Something rare in binary formats, unless you have some unused space in the original format.\r\n- Unlimited size of binary data.\r\n- Very size efficient: only space required for a data is written (unless you specifically require more space for better updating later).\r\n\r\nThere is also one disadvantage commonly said about XML: it's very verbose. That's why you should have default/assumed values in you EBML-based format as much as possible. So you just describe what is really necessary.\r\n\r\nEBML was originally created for the [Matroska](http://www.matroska.org) project. So this is naturally the first format based on EBML to exist. You are therefore encouraged to check the specs to know how to design a format based on EBML.\r\n","google":"","note":"Don't delete this file! It's used internally to help with page regeneration."}
|
343
specs.html
Executable file
343
specs.html
Executable file
@ -0,0 +1,343 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset='utf-8'>
|
||||
<meta http-equiv="X-UA-Compatible" content="chrome=1">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
|
||||
<link href='https://fonts.googleapis.com/css?family=Architects+Daughter' rel='stylesheet' type='text/css'>
|
||||
<link rel="stylesheet" type="text/css" href="stylesheets/stylesheet.css" media="screen">
|
||||
<link rel="stylesheet" type="text/css" href="stylesheets/pygment_trac.css" media="screen">
|
||||
<link rel="stylesheet" type="text/css" href="stylesheets/print.css" media="print">
|
||||
|
||||
<!--[if lt IE 9]>
|
||||
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
|
||||
<title>libEBML specifications</title>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<header>
|
||||
<div class="inner">
|
||||
<h1>libEBML</h1>
|
||||
<h2>a C++ libary to parse EBML files</h2>
|
||||
<a href="https://github.com/Matroska-Org/libebml" class="button"><small>View project on</small> GitHub</a>
|
||||
</div>
|
||||
</header>
|
||||
|
||||
<div id="content-wrapper">
|
||||
<div class="inner clearfix">
|
||||
<section id="main-content">
|
||||
<h3>EBML specifications</h3>
|
||||
|
||||
<h4>EBML principle</h4>
|
||||
<p>EBML is short for Extensible Binary Meta Language. EBML specifies a binary and octet (byte) aligned format inspired by the principle of XML. EBML itself is a generalized description of the technique of binary markup. Like XML, it is completely agnostic to any data that it might contain. Therein, the Matroska project is a specific implementation using the rules of EBML: It seeks to define a subset of the EBML language in the context of audio and video data (though it obviously isn't limited to this purpose). The format is made of 2 parts: the semantic and the syntax. The semantic specifies a number of IDs and their basic type and is not included in the data file/stream.</p>
|
||||
<p>Just like XML, the specific "tags" (IDs in EBML parlance) used in an EBML implementation are arbitrary. However, the semantic of EBML outlines general data types and ID's.</p>
|
||||
<p>The known basic types are:</p>
|
||||
<ul>
|
||||
<li>Signed Integer - Big-endian, any size from 1 to 8 octets</li>
|
||||
<li>Unsigned Integer - Big-endian, any size from 1 to 8 octets</li>
|
||||
<li>Float - Big-endian, defined for 4 and 8 octets (32, 64 bits)</li>
|
||||
<li>String - Printable ASCII (0x20 to 0x7E), zero-padded when needed</li>
|
||||
<li>UTF-8 - <a href="http://www.unicode.org/">Unicode string</a>, zero padded when needed (<a href="http://www.faqs.org/rfcs/rfc2279.html">RFC 2279</a>)</li>
|
||||
<li>Date - signed 8 octets integer in nanoseconds with 0 indicating the precise beginning of the millennium (at 2001-01-01T00:00:00,000000000 UTC)</li>
|
||||
<li>master-element - contains other EBML sub-elements of the next lower level</li>
|
||||
<li>Binary - not interpreted by the parser</li>
|
||||
</ul>
|
||||
<p>As well as defining standard data types, EBML uses a system of Elements to make up an EBML "document." Elements incorporate an Element ID, a descriptor for the size of the element, and the binary data itself. Futher, Elements can be nested, or contain, Elements of a lower "level."</p>
|
||||
<p>Element IDs are outlined as follows, beginning with the ID itself, followed by the Data Size, and then the non-interpreted Binary itself:</p>
|
||||
<ul>
|
||||
<li>Element ID coded with an UTF-8 like system :
|
||||
<pre>bits, big-endian
|
||||
1xxx xxxx - Class A IDs (2^7 -1 possible values) (base 0x8X)
|
||||
01xx xxxx xxxx xxxx - Class B IDs (2^14-1 possible values) (base 0x4X 0xXX)
|
||||
001x xxxx xxxx xxxx xxxx xxxx - Class C IDs (2^21-1 possible values) (base 0x2X 0xXX 0xXX)
|
||||
0001 xxxx xxxx xxxx xxxx xxxx xxxx xxxx - Class D IDs (2^28-1 possible values) (base 0x1X 0xXX 0xXX 0xXX)
|
||||
</pre>
|
||||
|
||||
Some Notes:
|
||||
<ul>
|
||||
<li>The leading bits of the Class IDs are used to identify the length of the ID. The number of leading 0's + 1 is the length of the ID in octets. We will refer to the leading bits as the Length Descriptor.</li>
|
||||
<li>Any ID where all x's are composed entirely of 1's is a Reserved ID, thus the -1 in the definitions above.</li>
|
||||
<li>The Reserved IDs (all x set to 1) are the only IDs that may change the Length Descriptor.</li>
|
||||
</ul>
|
||||
<br>
|
||||
</li>
|
||||
|
||||
<li>Data size, in octets, is also coded with an UTF-8 like system :
|
||||
<pre>bits, big-endian
|
||||
1xxx xxxx - value 0 to 2^7-2
|
||||
01xx xxxx xxxx xxxx - value 0 to 2^14-2
|
||||
001x xxxx xxxx xxxx xxxx xxxx - value 0 to 2^21-2
|
||||
0001 xxxx xxxx xxxx xxxx xxxx xxxx xxxx - value 0 to 2^28-2
|
||||
0000 1xxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx - value 0 to 2^35-2
|
||||
0000 01xx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx - value 0 to 2^42-2
|
||||
0000 001x xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx - value 0 to 2^49-2
|
||||
0000 0001 xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx - value 0 to 2^56-2
|
||||
</pre>
|
||||
<p>Since modern computers do not easily deal with data coded in sizes greater than 64 bits, any larger Element Sizes are left undefined at the moment. Currently, the Element Size coding allows for an Element to grow to 72000 To, i.e. 7x10^16 octets or 72000 terabytes, which will be sufficient for the time being.</p>
|
||||
<p>There is only one reserved word for Element Size encoding, which is an Element Size encoded to all 1's. Such a coding indicates that the size of the Element is unknown, which is a special case that we believe will be useful for live streaming purposes. However, avoid using this reserved word unnecessarily, because it makes parsing slower and more difficult to implement.</p>
|
||||
</li>
|
||||
<li>Data
|
||||
<ul>
|
||||
<li>Integers are stored in their standard big-endian form (no UTF-like encoding), only the size may differ from their usual form (24 or 40 bits for example).</li>
|
||||
<li>The Signed Integer is just the big-endian representation trimmed from some 0x00 and 0xFF where they are not meaningful (sign). For example -2 can be coded as 0xFFFFFFFFFFFFFE or 0xFFFE or 0xFE and 5 can be coded 0x000000000005 or 0x0005 or 0x05.</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
|
||||
<h4>Elements semantic</h4>
|
||||
|
||||
<table class="techdef">
|
||||
<tbody>
|
||||
<tr class="toptitle">
|
||||
<th>Element Name</th>
|
||||
<th>Level</th>
|
||||
<th title="EBML ID">Class-ID</th>
|
||||
<th title="Mandatory">Mand.</th>
|
||||
<th title="Can be found multiple times at the same level">Multi.</th>
|
||||
<th>Range</th>
|
||||
<th title="Default value if the element is not found">Default</th>
|
||||
<th>Element Type</th>
|
||||
<th>Description</th>
|
||||
</tr>
|
||||
<tr class="subclass">
|
||||
<th colspan="9">EBML Basics</th>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>EBML<a name="EBML"></a></td>
|
||||
<td>0</td>
|
||||
<td>[1A][45][DF][A3]</td>
|
||||
<td>*</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>sub-elements</td>
|
||||
<td>Set the EBML characteristics of the data to follow. Each EBML document
|
||||
has to start with this.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>EBMLVersion<a name="EBMLVersion"></a></td>
|
||||
<td>1</td>
|
||||
<td>[42][86]</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>1</td>
|
||||
<td>u-integer</td>
|
||||
<td>The version of EBML parser used to create the file.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>EBMLReadVersion<a name="EBMLReadVersion"></a></td>
|
||||
<td>1</td>
|
||||
<td>[42][F7]</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>1</td>
|
||||
<td>u-integer</td>
|
||||
<td>The minimum EBML version a parser has to support to read this file.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>EBMLMaxIDLength<a name="EBMLMaxIDLength"></a></td>
|
||||
<td>1</td>
|
||||
<td>[42][F2]</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>4</td>
|
||||
<td>u-integer</td>
|
||||
<td>The maximum length of the IDs you'll find in this file (4 or less in
|
||||
Matroska).</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>EBMLMaxSizeLength<a name="EBMLMaxSizeLength"></a></td>
|
||||
<td>1</td>
|
||||
<td>[42][F3]</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>8</td>
|
||||
<td>u-integer</td>
|
||||
<td>The maximum length of the sizes you'll find in this file (8 or less
|
||||
in Matroska). This does not override the element size indicated at the
|
||||
beginning of an element. Elements that have an indicated size which is
|
||||
larger than what is allowed by EBMLMaxSizeLength shall be considered invalid.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>DocType<a name="DocType"></a></td>
|
||||
<td>1</td>
|
||||
<td>[42][82]</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>string</td>
|
||||
<td>A string that describes the type of document that follows this EBML
|
||||
header ('matroska' in our case).</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>DocTypeVersion<a name="DocTypeVersion"></a></td>
|
||||
<td>1</td>
|
||||
<td>[42][87]</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>1</td>
|
||||
<td>u-integer</td>
|
||||
<td>The version of DocType interpreter used to create the file.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>DocTypeReadVersion<a name="DocTypeReadVersion"></a></td>
|
||||
<td>1</td>
|
||||
<td>[42][85]</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>1</td>
|
||||
<td>u-integer</td>
|
||||
<td>The minimum DocType version an interpreter has to support to read this
|
||||
file.</td>
|
||||
</tr>
|
||||
<tr class="subclass">
|
||||
<th colspan="9">Global elements (used everywhere in the format)</th>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>CRC-32<a name="CRC-32"></a></td>
|
||||
<td>1+</td>
|
||||
<td>[BF]</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>binary</td>
|
||||
<td>The CRC is computed on all the data from the last CRC element (or start
|
||||
of the upper level element), up to the CRC element, including other previous
|
||||
CRC elements. All level 1 elements should include a CRC-32.</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Void<a name="Void"></a></td>
|
||||
<td>1+</td>
|
||||
<td>[EC]</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>binary</td>
|
||||
<td>Used to void damaged data, to avoid unexpected behaviors when using
|
||||
damaged data. The content is discarded. Also used to reserve space
|
||||
in a sub-element for later use.</td>
|
||||
</tr>
|
||||
<tr class="subclass">
|
||||
<td colspan="9">signature</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>SignatureSlot<a name="SignatureSlot"></a></td>
|
||||
<td>1+</td>
|
||||
<td>[1B][53][86][67]</td>
|
||||
<td>-</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>sub-elements</td>
|
||||
<td>Contain signature of some (coming) elements in the stream.</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>SignatureAlgo<a name="SignatureAlgo"></a></td>
|
||||
<td>2+</td>
|
||||
<td>[7E][8A]</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>u-integer</td>
|
||||
<td>Signature algorithm used (1=RSA, 2=elliptic).</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>SignatureHash<a name="SignatureHash"></a></td>
|
||||
<td>2+</td>
|
||||
<td>[7E][9A]</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>u-integer</td>
|
||||
<td>Hash algorithm used (1=SHA1-160, 2=MD5).</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>SignaturePublicKey<a name="SignaturePublicKey"></a></td>
|
||||
<td>2+</td>
|
||||
<td>[7E][A5]</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>binary</td>
|
||||
<td>The public key to use with the algorithm (in the case of a PKI-based
|
||||
signature).</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>Signature<a name="Signature"></a></td>
|
||||
<td>2+</td>
|
||||
<td>[7E][B5]</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>binary</td>
|
||||
<td>The signature of the data (until a new.</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>SignatureElements<a name="SignatureElements"></a></td>
|
||||
<td>2+</td>
|
||||
<td>[7E][5B]</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>sub-elements</td>
|
||||
<td>Contains elements that will be used to compute the signature.</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>SignatureElementList<a name="SignatureElementList"></a></td>
|
||||
<td>3+</td>
|
||||
<td>[7E][7B]</td>
|
||||
<td>-</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>sub-elements</td>
|
||||
<td>A list consists of a number of consecutive elements that represent one
|
||||
case where data is used in signature. Ex: <i>Cluster|Block|BlockAdditional</i>
|
||||
means that the BlockAdditional of all Blocks in all Clusters is used for
|
||||
encryption.</td>
|
||||
</tr>
|
||||
<tr class="version2">
|
||||
<td>SignedElement<a name="SignedElement"></a></td>
|
||||
<td>4+</td>
|
||||
<td>[65][32]</td>
|
||||
<td>-</td>
|
||||
<td>*</td>
|
||||
<td>-</td>
|
||||
<td>-</td>
|
||||
<td>binary</td>
|
||||
<td>An element ID whose data will be used to compute the signature.</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
</section>
|
||||
|
||||
<aside id="sidebar">
|
||||
<p><a href="index.html" class="page-link">Home page</a></p>
|
||||
<p><a href="specs.html" class="page-link">Specifications</a></p>
|
||||
|
||||
<p class="repo-owner"><a href="https://github.com/Matroska-Org/libebml">libEBML</a> is maintained by the <a href="http://www.matroska.org/contact/index.html">Matroska team</a>.</p>
|
||||
|
||||
</aside>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
</body>
|
||||
</html>
|
240
src/Debug.cpp
240
src/Debug.cpp
@ -1,240 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: Debug.cpp 1268 2007-01-19 10:15:08Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
#include <stdio.h>
|
||||
|
||||
#ifdef WIN32
|
||||
#include <windows.h> // For OutputDebugString
|
||||
#else
|
||||
#include <time.h>
|
||||
#include <sys/time.h>
|
||||
#endif // WIN32
|
||||
|
||||
#include "ebml/Debug.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
class ADbg globalDebug;
|
||||
|
||||
#if defined(LIBEBML_DEBUG)
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
// Construction/Destruction
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
|
||||
ADbg::ADbg(int level)
|
||||
:my_level(level)
|
||||
,my_time_included(false)
|
||||
,my_use_file(false)
|
||||
,my_debug_output(true)
|
||||
,hFile(NULL)
|
||||
{
|
||||
prefix[0] = '\0';
|
||||
OutPut(-1,"ADbg Creation at debug level = %d (0x%08X)",my_level,this);
|
||||
}
|
||||
|
||||
ADbg::~ADbg()
|
||||
{
|
||||
unsetDebugFile();
|
||||
OutPut(-1,"ADbg Deletion (0x%08X)",this);
|
||||
}
|
||||
|
||||
inline int ADbg::_OutPut(const char * format,va_list params) const
|
||||
{
|
||||
int result;
|
||||
|
||||
char tst[1000];
|
||||
char myformat[256];
|
||||
|
||||
#ifdef WIN32
|
||||
if (my_time_included) {
|
||||
SYSTEMTIME time;
|
||||
GetSystemTime(&time);
|
||||
if (prefix[0] == '\0')
|
||||
wsprintfA(myformat,"%04d/%02d/%02d %02d:%02d:%02d.%03d UTC : %s\r\n",
|
||||
time.wYear,
|
||||
time.wMonth,
|
||||
time.wDay,
|
||||
time.wHour,
|
||||
time.wMinute,
|
||||
time.wSecond,
|
||||
time.wMilliseconds,
|
||||
format);
|
||||
else
|
||||
wsprintfA(myformat,"%04d/%02d/%02d %02d:%02d:%02d.%03d UTC : %s - %s\r\n",
|
||||
time.wYear,
|
||||
time.wMonth,
|
||||
time.wDay,
|
||||
time.wHour,
|
||||
time.wMinute,
|
||||
time.wSecond,
|
||||
time.wMilliseconds,
|
||||
prefix,
|
||||
format);
|
||||
} else {
|
||||
if (prefix[0] == '\0')
|
||||
wsprintfA( myformat, "%s\r\n", format);
|
||||
else
|
||||
wsprintfA( myformat, "%s - %s\r\n", prefix, format);
|
||||
}
|
||||
result = vsprintf(tst,myformat,params);
|
||||
|
||||
if (my_debug_output)
|
||||
OutputDebugStringA(tst);
|
||||
|
||||
if (my_use_file && (hFile != NULL)) {
|
||||
SetFilePointer( hFile, 0, 0, FILE_END );
|
||||
DWORD written;
|
||||
WriteFile( hFile, tst, lstrlenA(tst), &written, NULL );
|
||||
}
|
||||
#else
|
||||
if (my_time_included) {
|
||||
time_t nowSecs;
|
||||
struct tm *now;
|
||||
struct timeval tv;
|
||||
|
||||
nowSecs = time(NULL);
|
||||
gettimeofday(&tv, NULL);
|
||||
now = gmtime(&nowSecs);
|
||||
if (prefix[0] == '\0')
|
||||
sprintf(myformat,"%04d/%02d/%02d %02d:%02d:%02ld.%03ld UTC : %s\r\n",
|
||||
now->tm_year, now->tm_mon, now->tm_mday,
|
||||
now->tm_hour, now->tm_min, tv.tv_sec,
|
||||
(long)tv.tv_usec / 1000, format);
|
||||
else
|
||||
sprintf(myformat,"%04d/%02d/%02d %02d:%02d:%02ld.%03ld UTC : %s - %s\r\n",
|
||||
now->tm_year, now->tm_mon, now->tm_mday,
|
||||
now->tm_hour, now->tm_min, tv.tv_sec,
|
||||
(long)tv.tv_usec / 1000, prefix, format);
|
||||
|
||||
} else {
|
||||
if (prefix[0] == '\0')
|
||||
sprintf( myformat, "%s\r\n", format);
|
||||
else
|
||||
sprintf( myformat, "%s - %s\r\n", prefix, format);
|
||||
}
|
||||
|
||||
result = vsprintf(tst,myformat,params);
|
||||
|
||||
if (my_debug_output)
|
||||
fputs(tst, stderr);
|
||||
|
||||
if (my_use_file && (hFile != NULL))
|
||||
fputs(tst, hFile);
|
||||
#endif
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
int ADbg::OutPut(int forLevel, const char * format,...) const
|
||||
{
|
||||
int result=0;
|
||||
|
||||
if (forLevel >= my_level) {
|
||||
va_list tstlist;
|
||||
|
||||
va_start(tstlist, format);
|
||||
|
||||
result = _OutPut(format,tstlist);
|
||||
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
int ADbg::OutPut(const char * format,...) const
|
||||
{
|
||||
va_list tstlist;
|
||||
|
||||
va_start(tstlist, format);
|
||||
|
||||
return _OutPut(format,tstlist);
|
||||
}
|
||||
|
||||
bool ADbg::setDebugFile(const char * NewFilename) {
|
||||
bool result;
|
||||
result = unsetDebugFile();
|
||||
|
||||
if (!result)
|
||||
return false;
|
||||
|
||||
result = false;
|
||||
|
||||
#ifdef WIN32
|
||||
hFile = CreateFileA(NewFilename, GENERIC_WRITE, FILE_SHARE_WRITE|FILE_SHARE_READ, NULL, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL );
|
||||
|
||||
if (hFile != INVALID_HANDLE_VALUE) {
|
||||
SetFilePointer( hFile, 0, 0, FILE_END );
|
||||
|
||||
result = true;
|
||||
}
|
||||
#else
|
||||
hFile = fopen(NewFilename, "w+");
|
||||
if (hFile != NULL) {
|
||||
fseek(hFile, 0, SEEK_END);
|
||||
result = true;
|
||||
}
|
||||
#endif
|
||||
if (result)
|
||||
OutPut(-1,"Debug hFile Opening succeeded");
|
||||
|
||||
else
|
||||
OutPut(-1,"Debug hFile %s Opening failed",NewFilename);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
bool ADbg::unsetDebugFile() {
|
||||
bool result = (hFile == NULL);
|
||||
if (result)
|
||||
return true;
|
||||
|
||||
#ifdef WIN32
|
||||
result = (CloseHandle(hFile) != 0);
|
||||
#else
|
||||
result = (fclose(hFile) == 0);
|
||||
#endif
|
||||
|
||||
if (result) {
|
||||
OutPut(-1,"Debug hFile Closing succeeded");
|
||||
hFile = NULL;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
#endif // defined(LIBEBML_DEBUG)
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,106 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Julien Coloos <suiryc @ users.sf.net>
|
||||
*/
|
||||
#include <cassert>
|
||||
#include <string>
|
||||
|
||||
#include "ebml/EbmlBinary.h"
|
||||
#include "ebml/StdIOCallback.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
EbmlBinary::EbmlBinary()
|
||||
:EbmlElement(0, false), Data(NULL)
|
||||
{}
|
||||
|
||||
EbmlBinary::EbmlBinary(const EbmlBinary & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
{
|
||||
if (ElementToClone.Data == NULL)
|
||||
Data = NULL;
|
||||
else {
|
||||
Data = (binary *)malloc(GetSize() * sizeof(binary));
|
||||
assert(Data != NULL);
|
||||
memcpy(Data, ElementToClone.Data, GetSize());
|
||||
}
|
||||
}
|
||||
|
||||
EbmlBinary::~EbmlBinary(void) {
|
||||
if(Data)
|
||||
free(Data);
|
||||
}
|
||||
|
||||
EbmlBinary::operator const binary &() const {return *Data;}
|
||||
|
||||
|
||||
filepos_t EbmlBinary::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
output.writeFully(Data,GetSize());
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
/*!
|
||||
\note no Default binary value handled
|
||||
*/
|
||||
uint64 EbmlBinary::UpdateSize(bool /* bWithDefault */, bool /* bForceRender */)
|
||||
{
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
filepos_t EbmlBinary::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if (Data != NULL)
|
||||
free(Data);
|
||||
|
||||
if (ReadFully == SCOPE_NO_DATA || !GetSize()) {
|
||||
Data = NULL;
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
Data = (binary *)malloc(GetSize());
|
||||
if (Data == NULL)
|
||||
throw CRTError(std::string("Error allocating data"));
|
||||
SetValueIsSet();
|
||||
return input.read(Data, GetSize());
|
||||
}
|
||||
|
||||
bool EbmlBinary::operator==(const EbmlBinary & ElementToCompare) const
|
||||
{
|
||||
return ((GetSize() == ElementToCompare.GetSize()) && !memcmp(Data, ElementToCompare.Data, GetSize()));
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,57 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlContexts.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include "ebml/EbmlContexts.h"
|
||||
#include "ebml/EbmlCrc32.h"
|
||||
#include "ebml/EbmlVoid.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
static const EbmlSemantic EbmlGlobal_ContextList[2] =
|
||||
{
|
||||
EbmlSemantic(false, false, EBML_INFO(EbmlCrc32)), ///< EbmlCrc32
|
||||
EbmlSemantic(false, false, EBML_INFO(EbmlVoid)), ///< EbmlVoid
|
||||
};
|
||||
|
||||
const EbmlSemanticContext Context_EbmlGlobal = EbmlSemanticContext(0, NULL, NULL, *GetEbmlGlobal_Context, NULL);
|
||||
|
||||
static const EbmlSemanticContext EbmlGlobal_Context = EbmlSemanticContext(countof(EbmlGlobal_ContextList), EbmlGlobal_ContextList, NULL, *GetEbmlGlobal_Context, NULL);
|
||||
|
||||
const EbmlSemanticContext & GetEbmlGlobal_Context()
|
||||
{
|
||||
return EbmlGlobal_Context;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,350 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlCrc32.cpp 1155 2005-05-06 11:43:38Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
*/
|
||||
#include "ebml/EbmlCrc32.h"
|
||||
#include "ebml/EbmlContexts.h"
|
||||
#include "ebml/MemIOCallback.h"
|
||||
|
||||
#ifdef WORDS_BIGENDIAN
|
||||
# define CRC32_INDEX(c) (c >> 24)
|
||||
# define CRC32_SHIFTED(c) (c << 8)
|
||||
#else
|
||||
# define CRC32_INDEX(c) (c & 0xff)
|
||||
# define CRC32_SHIFTED(c) (c >> 8)
|
||||
#endif
|
||||
|
||||
const uint32 CRC32_NEGL = 0xffffffffL;
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DEFINE_EBML_CLASS_GLOBAL(EbmlCrc32, 0xBF, 1, "EBMLCrc32\0ratamadabapa");
|
||||
|
||||
const uint32 EbmlCrc32::m_tab[] = {
|
||||
#ifdef WORDS_BIGENDIAN
|
||||
0x00000000L, 0x96300777L, 0x2c610eeeL, 0xba510999L, 0x19c46d07L,
|
||||
0x8ff46a70L, 0x35a563e9L, 0xa395649eL, 0x3288db0eL, 0xa4b8dc79L,
|
||||
0x1ee9d5e0L, 0x88d9d297L, 0x2b4cb609L, 0xbd7cb17eL, 0x072db8e7L,
|
||||
0x911dbf90L, 0x6410b71dL, 0xf220b06aL, 0x4871b9f3L, 0xde41be84L,
|
||||
0x7dd4da1aL, 0xebe4dd6dL, 0x51b5d4f4L, 0xc785d383L, 0x56986c13L,
|
||||
0xc0a86b64L, 0x7af962fdL, 0xecc9658aL, 0x4f5c0114L, 0xd96c0663L,
|
||||
0x633d0ffaL, 0xf50d088dL, 0xc8206e3bL, 0x5e10694cL, 0xe44160d5L,
|
||||
0x727167a2L, 0xd1e4033cL, 0x47d4044bL, 0xfd850dd2L, 0x6bb50aa5L,
|
||||
0xfaa8b535L, 0x6c98b242L, 0xd6c9bbdbL, 0x40f9bcacL, 0xe36cd832L,
|
||||
0x755cdf45L, 0xcf0dd6dcL, 0x593dd1abL, 0xac30d926L, 0x3a00de51L,
|
||||
0x8051d7c8L, 0x1661d0bfL, 0xb5f4b421L, 0x23c4b356L, 0x9995bacfL,
|
||||
0x0fa5bdb8L, 0x9eb80228L, 0x0888055fL, 0xb2d90cc6L, 0x24e90bb1L,
|
||||
0x877c6f2fL, 0x114c6858L, 0xab1d61c1L, 0x3d2d66b6L, 0x9041dc76L,
|
||||
0x0671db01L, 0xbc20d298L, 0x2a10d5efL, 0x8985b171L, 0x1fb5b606L,
|
||||
0xa5e4bf9fL, 0x33d4b8e8L, 0xa2c90778L, 0x34f9000fL, 0x8ea80996L,
|
||||
0x18980ee1L, 0xbb0d6a7fL, 0x2d3d6d08L, 0x976c6491L, 0x015c63e6L,
|
||||
0xf4516b6bL, 0x62616c1cL, 0xd8306585L, 0x4e0062f2L, 0xed95066cL,
|
||||
0x7ba5011bL, 0xc1f40882L, 0x57c40ff5L, 0xc6d9b065L, 0x50e9b712L,
|
||||
0xeab8be8bL, 0x7c88b9fcL, 0xdf1ddd62L, 0x492dda15L, 0xf37cd38cL,
|
||||
0x654cd4fbL, 0x5861b24dL, 0xce51b53aL, 0x7400bca3L, 0xe230bbd4L,
|
||||
0x41a5df4aL, 0xd795d83dL, 0x6dc4d1a4L, 0xfbf4d6d3L, 0x6ae96943L,
|
||||
0xfcd96e34L, 0x468867adL, 0xd0b860daL, 0x732d0444L, 0xe51d0333L,
|
||||
0x5f4c0aaaL, 0xc97c0dddL, 0x3c710550L, 0xaa410227L, 0x10100bbeL,
|
||||
0x86200cc9L, 0x25b56857L, 0xb3856f20L, 0x09d466b9L, 0x9fe461ceL,
|
||||
0x0ef9de5eL, 0x98c9d929L, 0x2298d0b0L, 0xb4a8d7c7L, 0x173db359L,
|
||||
0x810db42eL, 0x3b5cbdb7L, 0xad6cbac0L, 0x2083b8edL, 0xb6b3bf9aL,
|
||||
0x0ce2b603L, 0x9ad2b174L, 0x3947d5eaL, 0xaf77d29dL, 0x1526db04L,
|
||||
0x8316dc73L, 0x120b63e3L, 0x843b6494L, 0x3e6a6d0dL, 0xa85a6a7aL,
|
||||
0x0bcf0ee4L, 0x9dff0993L, 0x27ae000aL, 0xb19e077dL, 0x44930ff0L,
|
||||
0xd2a30887L, 0x68f2011eL, 0xfec20669L, 0x5d5762f7L, 0xcb676580L,
|
||||
0x71366c19L, 0xe7066b6eL, 0x761bd4feL, 0xe02bd389L, 0x5a7ada10L,
|
||||
0xcc4add67L, 0x6fdfb9f9L, 0xf9efbe8eL, 0x43beb717L, 0xd58eb060L,
|
||||
0xe8a3d6d6L, 0x7e93d1a1L, 0xc4c2d838L, 0x52f2df4fL, 0xf167bbd1L,
|
||||
0x6757bca6L, 0xdd06b53fL, 0x4b36b248L, 0xda2b0dd8L, 0x4c1b0aafL,
|
||||
0xf64a0336L, 0x607a0441L, 0xc3ef60dfL, 0x55df67a8L, 0xef8e6e31L,
|
||||
0x79be6946L, 0x8cb361cbL, 0x1a8366bcL, 0xa0d26f25L, 0x36e26852L,
|
||||
0x95770cccL, 0x03470bbbL, 0xb9160222L, 0x2f260555L, 0xbe3bbac5L,
|
||||
0x280bbdb2L, 0x925ab42bL, 0x046ab35cL, 0xa7ffd7c2L, 0x31cfd0b5L,
|
||||
0x8b9ed92cL, 0x1daede5bL, 0xb0c2649bL, 0x26f263ecL, 0x9ca36a75L,
|
||||
0x0a936d02L, 0xa906099cL, 0x3f360eebL, 0x85670772L, 0x13570005L,
|
||||
0x824abf95L, 0x147ab8e2L, 0xae2bb17bL, 0x381bb60cL, 0x9b8ed292L,
|
||||
0x0dbed5e5L, 0xb7efdc7cL, 0x21dfdb0bL, 0xd4d2d386L, 0x42e2d4f1L,
|
||||
0xf8b3dd68L, 0x6e83da1fL, 0xcd16be81L, 0x5b26b9f6L, 0xe177b06fL,
|
||||
0x7747b718L, 0xe65a0888L, 0x706a0fffL, 0xca3b0666L, 0x5c0b0111L,
|
||||
0xff9e658fL, 0x69ae62f8L, 0xd3ff6b61L, 0x45cf6c16L, 0x78e20aa0L,
|
||||
0xeed20dd7L, 0x5483044eL, 0xc2b30339L, 0x612667a7L, 0xf71660d0L,
|
||||
0x4d476949L, 0xdb776e3eL, 0x4a6ad1aeL, 0xdc5ad6d9L, 0x660bdf40L,
|
||||
0xf03bd837L, 0x53aebca9L, 0xc59ebbdeL, 0x7fcfb247L, 0xe9ffb530L,
|
||||
0x1cf2bdbdL, 0x8ac2bacaL, 0x3093b353L, 0xa6a3b424L, 0x0536d0baL,
|
||||
0x9306d7cdL, 0x2957de54L, 0xbf67d923L, 0x2e7a66b3L, 0xb84a61c4L,
|
||||
0x021b685dL, 0x942b6f2aL, 0x37be0bb4L, 0xa18e0cc3L, 0x1bdf055aL,
|
||||
0x8def022dL
|
||||
#else
|
||||
0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL, 0x076dc419L,
|
||||
0x706af48fL, 0xe963a535L, 0x9e6495a3L, 0x0edb8832L, 0x79dcb8a4L,
|
||||
0xe0d5e91eL, 0x97d2d988L, 0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L,
|
||||
0x90bf1d91L, 0x1db71064L, 0x6ab020f2L, 0xf3b97148L, 0x84be41deL,
|
||||
0x1adad47dL, 0x6ddde4ebL, 0xf4d4b551L, 0x83d385c7L, 0x136c9856L,
|
||||
0x646ba8c0L, 0xfd62f97aL, 0x8a65c9ecL, 0x14015c4fL, 0x63066cd9L,
|
||||
0xfa0f3d63L, 0x8d080df5L, 0x3b6e20c8L, 0x4c69105eL, 0xd56041e4L,
|
||||
0xa2677172L, 0x3c03e4d1L, 0x4b04d447L, 0xd20d85fdL, 0xa50ab56bL,
|
||||
0x35b5a8faL, 0x42b2986cL, 0xdbbbc9d6L, 0xacbcf940L, 0x32d86ce3L,
|
||||
0x45df5c75L, 0xdcd60dcfL, 0xabd13d59L, 0x26d930acL, 0x51de003aL,
|
||||
0xc8d75180L, 0xbfd06116L, 0x21b4f4b5L, 0x56b3c423L, 0xcfba9599L,
|
||||
0xb8bda50fL, 0x2802b89eL, 0x5f058808L, 0xc60cd9b2L, 0xb10be924L,
|
||||
0x2f6f7c87L, 0x58684c11L, 0xc1611dabL, 0xb6662d3dL, 0x76dc4190L,
|
||||
0x01db7106L, 0x98d220bcL, 0xefd5102aL, 0x71b18589L, 0x06b6b51fL,
|
||||
0x9fbfe4a5L, 0xe8b8d433L, 0x7807c9a2L, 0x0f00f934L, 0x9609a88eL,
|
||||
0xe10e9818L, 0x7f6a0dbbL, 0x086d3d2dL, 0x91646c97L, 0xe6635c01L,
|
||||
0x6b6b51f4L, 0x1c6c6162L, 0x856530d8L, 0xf262004eL, 0x6c0695edL,
|
||||
0x1b01a57bL, 0x8208f4c1L, 0xf50fc457L, 0x65b0d9c6L, 0x12b7e950L,
|
||||
0x8bbeb8eaL, 0xfcb9887cL, 0x62dd1ddfL, 0x15da2d49L, 0x8cd37cf3L,
|
||||
0xfbd44c65L, 0x4db26158L, 0x3ab551ceL, 0xa3bc0074L, 0xd4bb30e2L,
|
||||
0x4adfa541L, 0x3dd895d7L, 0xa4d1c46dL, 0xd3d6f4fbL, 0x4369e96aL,
|
||||
0x346ed9fcL, 0xad678846L, 0xda60b8d0L, 0x44042d73L, 0x33031de5L,
|
||||
0xaa0a4c5fL, 0xdd0d7cc9L, 0x5005713cL, 0x270241aaL, 0xbe0b1010L,
|
||||
0xc90c2086L, 0x5768b525L, 0x206f85b3L, 0xb966d409L, 0xce61e49fL,
|
||||
0x5edef90eL, 0x29d9c998L, 0xb0d09822L, 0xc7d7a8b4L, 0x59b33d17L,
|
||||
0x2eb40d81L, 0xb7bd5c3bL, 0xc0ba6cadL, 0xedb88320L, 0x9abfb3b6L,
|
||||
0x03b6e20cL, 0x74b1d29aL, 0xead54739L, 0x9dd277afL, 0x04db2615L,
|
||||
0x73dc1683L, 0xe3630b12L, 0x94643b84L, 0x0d6d6a3eL, 0x7a6a5aa8L,
|
||||
0xe40ecf0bL, 0x9309ff9dL, 0x0a00ae27L, 0x7d079eb1L, 0xf00f9344L,
|
||||
0x8708a3d2L, 0x1e01f268L, 0x6906c2feL, 0xf762575dL, 0x806567cbL,
|
||||
0x196c3671L, 0x6e6b06e7L, 0xfed41b76L, 0x89d32be0L, 0x10da7a5aL,
|
||||
0x67dd4accL, 0xf9b9df6fL, 0x8ebeeff9L, 0x17b7be43L, 0x60b08ed5L,
|
||||
0xd6d6a3e8L, 0xa1d1937eL, 0x38d8c2c4L, 0x4fdff252L, 0xd1bb67f1L,
|
||||
0xa6bc5767L, 0x3fb506ddL, 0x48b2364bL, 0xd80d2bdaL, 0xaf0a1b4cL,
|
||||
0x36034af6L, 0x41047a60L, 0xdf60efc3L, 0xa867df55L, 0x316e8eefL,
|
||||
0x4669be79L, 0xcb61b38cL, 0xbc66831aL, 0x256fd2a0L, 0x5268e236L,
|
||||
0xcc0c7795L, 0xbb0b4703L, 0x220216b9L, 0x5505262fL, 0xc5ba3bbeL,
|
||||
0xb2bd0b28L, 0x2bb45a92L, 0x5cb36a04L, 0xc2d7ffa7L, 0xb5d0cf31L,
|
||||
0x2cd99e8bL, 0x5bdeae1dL, 0x9b64c2b0L, 0xec63f226L, 0x756aa39cL,
|
||||
0x026d930aL, 0x9c0906a9L, 0xeb0e363fL, 0x72076785L, 0x05005713L,
|
||||
0x95bf4a82L, 0xe2b87a14L, 0x7bb12baeL, 0x0cb61b38L, 0x92d28e9bL,
|
||||
0xe5d5be0dL, 0x7cdcefb7L, 0x0bdbdf21L, 0x86d3d2d4L, 0xf1d4e242L,
|
||||
0x68ddb3f8L, 0x1fda836eL, 0x81be16cdL, 0xf6b9265bL, 0x6fb077e1L,
|
||||
0x18b74777L, 0x88085ae6L, 0xff0f6a70L, 0x66063bcaL, 0x11010b5cL,
|
||||
0x8f659effL, 0xf862ae69L, 0x616bffd3L, 0x166ccf45L, 0xa00ae278L,
|
||||
0xd70dd2eeL, 0x4e048354L, 0x3903b3c2L, 0xa7672661L, 0xd06016f7L,
|
||||
0x4969474dL, 0x3e6e77dbL, 0xaed16a4aL, 0xd9d65adcL, 0x40df0b66L,
|
||||
0x37d83bf0L, 0xa9bcae53L, 0xdebb9ec5L, 0x47b2cf7fL, 0x30b5ffe9L,
|
||||
0xbdbdf21cL, 0xcabac28aL, 0x53b39330L, 0x24b4a3a6L, 0xbad03605L,
|
||||
0xcdd70693L, 0x54de5729L, 0x23d967bfL, 0xb3667a2eL, 0xc4614ab8L,
|
||||
0x5d681b02L, 0x2a6f2b94L, 0xb40bbe37L, 0xc30c8ea1L, 0x5a05df1bL,
|
||||
0x2d02ef8dL
|
||||
#endif
|
||||
};
|
||||
|
||||
EbmlCrc32::EbmlCrc32()
|
||||
{
|
||||
ResetCRC();
|
||||
SetDefaultSize(4);
|
||||
m_crc_final = 0;
|
||||
SetSize_(4);
|
||||
//This EbmlElement has been set
|
||||
// SetValueIsSet();
|
||||
}
|
||||
|
||||
EbmlCrc32::EbmlCrc32(const EbmlCrc32 & ElementToClone)
|
||||
:EbmlBinary(ElementToClone)
|
||||
{
|
||||
m_crc = ElementToClone.m_crc;
|
||||
m_crc_final = ElementToClone.m_crc_final;
|
||||
}
|
||||
|
||||
void EbmlCrc32::ResetCRC()
|
||||
{
|
||||
m_crc = CRC32_NEGL;
|
||||
}
|
||||
|
||||
void EbmlCrc32::UpdateByte(binary b)
|
||||
{
|
||||
m_crc = m_tab[CRC32_INDEX(m_crc) ^ b] ^ CRC32_SHIFTED(m_crc);
|
||||
}
|
||||
|
||||
void EbmlCrc32::AddElementCRC32(EbmlElement &ElementToCRC)
|
||||
{
|
||||
// Use a special IOCallback class that Render's to memory instead of to disk
|
||||
MemIOCallback memoryBuffer;
|
||||
ElementToCRC.Render(memoryBuffer, true, true);
|
||||
|
||||
Update(memoryBuffer.GetDataBuffer(), memoryBuffer.GetDataBufferSize());
|
||||
// Finalize();
|
||||
};
|
||||
|
||||
bool EbmlCrc32::CheckElementCRC32(EbmlElement &ElementToCRC)
|
||||
{
|
||||
MemIOCallback memoryBuffer;
|
||||
ElementToCRC.Render(memoryBuffer);
|
||||
|
||||
return CheckCRC(m_crc_final, memoryBuffer.GetDataBuffer(), memoryBuffer.GetDataBufferSize());
|
||||
};
|
||||
|
||||
filepos_t EbmlCrc32::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
filepos_t Result = 4;
|
||||
|
||||
if (Result != 0) {
|
||||
output.writeFully(&m_crc_final, Result);
|
||||
}
|
||||
|
||||
if (Result < GetDefaultSize()) {
|
||||
// pad the rest with 0
|
||||
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
||||
if (Pad != NULL) {
|
||||
memset(Pad, 0x00, GetDefaultSize() - Result);
|
||||
output.writeFully(Pad, GetDefaultSize() - Result);
|
||||
|
||||
Result = GetDefaultSize();
|
||||
delete [] Pad;
|
||||
}
|
||||
}
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
||||
filepos_t EbmlCrc32::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if (ReadFully != SCOPE_NO_DATA) {
|
||||
binary *Buffer = new (std::nothrow) binary[GetSize()];
|
||||
if (Buffer == NULL) {
|
||||
// impossible to read, skip it
|
||||
input.setFilePointer(GetSize(), seek_current);
|
||||
} else {
|
||||
input.readFully(Buffer, GetSize());
|
||||
|
||||
memcpy((void *)&m_crc_final, Buffer, 4);
|
||||
delete [] Buffer;
|
||||
SetValueIsSet();
|
||||
}
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
bool EbmlCrc32::CheckCRC(uint32 inputCRC, const binary *input, uint32 length)
|
||||
{
|
||||
uint32 crc = CRC32_NEGL;
|
||||
|
||||
for(; !IsAligned<uint32>(input) && length > 0; length--)
|
||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||
|
||||
while (length >= 4) {
|
||||
crc ^= *(const uint32 *)input;
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
length -= 4;
|
||||
input += 4;
|
||||
}
|
||||
|
||||
while (length--)
|
||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||
|
||||
//Now we finalize the CRC32
|
||||
crc ^= CRC32_NEGL;
|
||||
|
||||
if (crc == inputCRC)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
};
|
||||
|
||||
void EbmlCrc32::FillCRC32(const binary *s, uint32 n)
|
||||
{
|
||||
ResetCRC();
|
||||
Update(s, n);
|
||||
Finalize();
|
||||
|
||||
/*uint32 crc = CRC32_NEGL;
|
||||
|
||||
for(; !IsAligned<uint32>(s) && n > 0; n--)
|
||||
crc = m_tab[CRC32_INDEX(crc) ^ *s++] ^ CRC32_SHIFTED(crc);
|
||||
|
||||
while (n >= 4)
|
||||
{
|
||||
crc ^= *(const uint32 *)s;
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
n -= 4;
|
||||
s += 4;
|
||||
}
|
||||
|
||||
while (n--)
|
||||
crc = m_tab[CRC32_INDEX(crc) ^ *s++] ^ CRC32_SHIFTED(crc);
|
||||
|
||||
m_crc = crc;
|
||||
|
||||
//Now we finalize the CRC32
|
||||
m_crc ^= CRC32_NEGL;
|
||||
//for (unsigned int i = 0; i < 4; i++)
|
||||
// (&last_crc32)[i] = GetCrcByte(i);*/
|
||||
|
||||
}
|
||||
|
||||
void EbmlCrc32::Update(const binary *input, uint32 length)
|
||||
{
|
||||
uint32 crc = m_crc;
|
||||
|
||||
for(; !IsAligned<uint32>(input) && length > 0; length--)
|
||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||
|
||||
while (length >= 4) {
|
||||
crc ^= *(const uint32 *)input;
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
crc = m_tab[CRC32_INDEX(crc)] ^ CRC32_SHIFTED(crc);
|
||||
length -= 4;
|
||||
input += 4;
|
||||
}
|
||||
|
||||
while (length--)
|
||||
crc = m_tab[CRC32_INDEX(crc) ^ *input++] ^ CRC32_SHIFTED(crc);
|
||||
|
||||
m_crc = crc;
|
||||
}
|
||||
|
||||
void EbmlCrc32::Finalize()
|
||||
{
|
||||
//Finalize the CRC32
|
||||
m_crc ^= CRC32_NEGL;
|
||||
//Copy it over to completed CRC32 memeber
|
||||
m_crc_final = m_crc;
|
||||
//Reset the holding CRC member (m_crc)
|
||||
ResetCRC();
|
||||
//This EbmlElement has been set
|
||||
SetValueIsSet();
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,86 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlDate.cpp 1079 2005-03-03 13:18:14Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include <cassert>
|
||||
|
||||
#include "ebml/EbmlDate.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
const uint64 EbmlDate::UnixEpochDelay = 978307200; // 2001/01/01 00:00:00 UTC
|
||||
|
||||
EbmlDate::EbmlDate(const EbmlDate & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
{
|
||||
myDate = ElementToClone.myDate;
|
||||
}
|
||||
|
||||
filepos_t EbmlDate::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if ((ReadFully == SCOPE_NO_DATA) || (GetSize() == 0))
|
||||
return GetSize();
|
||||
|
||||
assert(GetSize() == 8);
|
||||
binary Buffer[8];
|
||||
input.readFully(Buffer, GetSize());
|
||||
|
||||
big_int64 b64;
|
||||
b64.Eval(Buffer);
|
||||
|
||||
myDate = b64;
|
||||
SetValueIsSet();
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
filepos_t EbmlDate::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
if (GetSize() != 0) {
|
||||
assert(GetSize() == 8);
|
||||
big_int64 b64(myDate);
|
||||
|
||||
output.writeFully(&b64.endian(),GetSize());
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
bool EbmlDate::IsSmallerThan(const EbmlElement *Cmp) const
|
||||
{
|
||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||
return this->myDate < static_cast<const EbmlDate *>(Cmp)->myDate;
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,50 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include "ebml/EbmlDummy.h"
|
||||
#include "ebml/EbmlContexts.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DEFINE_EBML_CLASS_ORPHAN(EbmlDummy, 0xFF, 1, "DummyElement");
|
||||
|
||||
const EbmlId EbmlDummy::DummyRawId = Id_EbmlDummy;
|
||||
|
||||
EbmlDummy::operator const EbmlId &()
|
||||
{
|
||||
return DummyId;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,709 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
|
||||
#include <cassert>
|
||||
#include <cstring>
|
||||
|
||||
#include "ebml/EbmlElement.h"
|
||||
#include "ebml/EbmlMaster.h"
|
||||
#include "ebml/EbmlStream.h"
|
||||
#include "ebml/EbmlVoid.h"
|
||||
#include "ebml/EbmlDummy.h"
|
||||
#include "ebml/EbmlContexts.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
/*!
|
||||
\todo handle more than CodedSize of 5
|
||||
*/
|
||||
int CodedSizeLength(uint64 Length, unsigned int SizeLength, bool bSizeFinite)
|
||||
{
|
||||
unsigned int CodedSize;
|
||||
if (bSizeFinite) {
|
||||
// prepare the head of the size (000...01xxxxxx)
|
||||
// optimal size
|
||||
if (Length < 127) // 2^7 - 1
|
||||
CodedSize = 1;
|
||||
else if (Length < 16383) // 2^14 - 1
|
||||
CodedSize = 2;
|
||||
else if (Length < 2097151L) // 2^21 - 1
|
||||
CodedSize = 3;
|
||||
else if (Length < 268435455L) // 2^28 - 1
|
||||
CodedSize = 4;
|
||||
else CodedSize = 5;
|
||||
} else {
|
||||
if (Length <= 127) // 2^7 - 1
|
||||
CodedSize = 1;
|
||||
else if (Length <= 16383) // 2^14 - 1
|
||||
CodedSize = 2;
|
||||
else if (Length <= 2097151L) // 2^21 - 1
|
||||
CodedSize = 3;
|
||||
else if (Length <= 268435455L) // 2^28 - 1
|
||||
CodedSize = 4;
|
||||
else CodedSize = 5;
|
||||
}
|
||||
|
||||
if (SizeLength > 0 && CodedSize < SizeLength) {
|
||||
// defined size
|
||||
CodedSize = SizeLength;
|
||||
}
|
||||
|
||||
return CodedSize;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo handle more than CodedSize of 5
|
||||
*/
|
||||
int CodedSizeLengthSigned(int64 Length, unsigned int SizeLength)
|
||||
{
|
||||
unsigned int CodedSize;
|
||||
// prepare the head of the size (000...01xxxxxx)
|
||||
// optimal size
|
||||
if (Length > -64 && Length < 64) // 2^6
|
||||
CodedSize = 1;
|
||||
else if (Length > -8192 && Length < 8192) // 2^13
|
||||
CodedSize = 2;
|
||||
else if (Length > -1048576L && Length < 1048576L) // 2^20
|
||||
CodedSize = 3;
|
||||
else if (Length > -134217728L && Length < 134217728L) // 2^27
|
||||
CodedSize = 4;
|
||||
else CodedSize = 5;
|
||||
|
||||
if (SizeLength > 0 && CodedSize < SizeLength) {
|
||||
// defined size
|
||||
CodedSize = SizeLength;
|
||||
}
|
||||
|
||||
return CodedSize;
|
||||
}
|
||||
|
||||
int CodedValueLength(uint64 Length, int CodedSize, binary * OutBuffer)
|
||||
{
|
||||
int _SizeMask = 0xFF;
|
||||
OutBuffer[0] = 1 << (8 - CodedSize);
|
||||
for (int i=1; i<CodedSize; i++) {
|
||||
OutBuffer[CodedSize-i] = Length & 0xFF;
|
||||
Length >>= 8;
|
||||
_SizeMask >>= 1;
|
||||
}
|
||||
// first one use a OR with the "EBML size head"
|
||||
OutBuffer[0] |= Length & 0xFF & _SizeMask;
|
||||
return CodedSize;
|
||||
}
|
||||
|
||||
int CodedValueLengthSigned(int64 Length, int CodedSize, binary * OutBuffer)
|
||||
{
|
||||
if (Length > -64 && Length < 64) // 2^6
|
||||
Length += 63;
|
||||
else if (Length > -8192 && Length < 8192) // 2^13
|
||||
Length += 8191;
|
||||
else if (Length > -1048576L && Length < 1048576L) // 2^20
|
||||
Length += 1048575L;
|
||||
else if (Length > -134217728L && Length < 134217728L) // 2^27
|
||||
Length += 134217727L;
|
||||
|
||||
return CodedValueLength(Length, CodedSize, OutBuffer);
|
||||
}
|
||||
|
||||
uint64 ReadCodedSizeValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown)
|
||||
{
|
||||
binary SizeBitMask = 1 << 7;
|
||||
uint64 Result = 0x7F;
|
||||
unsigned int SizeIdx, PossibleSizeLength = 0;
|
||||
binary PossibleSize[8];
|
||||
memset(PossibleSize, 0, 8);
|
||||
|
||||
SizeUnknown = 0x7F; // the last bit is discarded when computing the size
|
||||
for (SizeIdx = 0; SizeIdx < BufferSize && SizeIdx < 8; SizeIdx++) {
|
||||
if (InBuffer[0] & (SizeBitMask >> SizeIdx)) {
|
||||
// ID found
|
||||
PossibleSizeLength = SizeIdx + 1;
|
||||
SizeBitMask >>= SizeIdx;
|
||||
|
||||
// Guard against invalid memory accesses with incomplete IDs.
|
||||
if (PossibleSizeLength > BufferSize)
|
||||
break;
|
||||
|
||||
for (SizeIdx = 0; SizeIdx < PossibleSizeLength; SizeIdx++) {
|
||||
PossibleSize[SizeIdx] = InBuffer[SizeIdx];
|
||||
}
|
||||
for (SizeIdx = 0; SizeIdx < PossibleSizeLength - 1; SizeIdx++) {
|
||||
Result <<= 7;
|
||||
Result |= 0xFF;
|
||||
}
|
||||
|
||||
Result = 0;
|
||||
Result |= PossibleSize[0] & ~SizeBitMask;
|
||||
for (unsigned int i = 1; i<PossibleSizeLength; i++) {
|
||||
Result <<= 8;
|
||||
Result |= PossibleSize[i];
|
||||
}
|
||||
|
||||
BufferSize = PossibleSizeLength;
|
||||
|
||||
return Result;
|
||||
}
|
||||
SizeUnknown <<= 7;
|
||||
SizeUnknown |= 0xFF;
|
||||
}
|
||||
|
||||
BufferSize = 0;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int64 ReadCodedSizeSignedValue(const binary * InBuffer, uint32 & BufferSize, uint64 & SizeUnknown)
|
||||
{
|
||||
int64 Result = ReadCodedSizeValue(InBuffer, BufferSize, SizeUnknown);
|
||||
|
||||
if (BufferSize != 0) {
|
||||
switch (BufferSize) {
|
||||
case 1:
|
||||
Result -= 63;
|
||||
break;
|
||||
case 2:
|
||||
Result -= 8191;
|
||||
break;
|
||||
case 3:
|
||||
Result -= 1048575L;
|
||||
break;
|
||||
case 4:
|
||||
Result -= 134217727L;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
||||
|
||||
EbmlCallbacks::EbmlCallbacks(EbmlElement & (*Creator)(), const EbmlId & aGlobalId, const char * aDebugName, const EbmlSemanticContext & aContext)
|
||||
:Create(Creator)
|
||||
,GlobalId(aGlobalId)
|
||||
,DebugName(aDebugName)
|
||||
,Context(aContext)
|
||||
{
|
||||
assert((Create!=NULL) || !strcmp(aDebugName, "DummyElement"));
|
||||
}
|
||||
|
||||
const EbmlSemantic & EbmlSemanticContext::GetSemantic(size_t i) const
|
||||
{
|
||||
assert(i<Size);
|
||||
if (i<Size)
|
||||
return MyTable[i];
|
||||
else
|
||||
return *(EbmlSemantic*)NULL;
|
||||
}
|
||||
|
||||
|
||||
EbmlElement::EbmlElement(uint64 aDefaultSize, bool bValueSet)
|
||||
:DefaultSize(aDefaultSize)
|
||||
,SizeLength(0) ///< write optimal size by default
|
||||
,bSizeIsFinite(true)
|
||||
,ElementPosition(0)
|
||||
,SizePosition(0)
|
||||
,bValueIsSet(bValueSet)
|
||||
,DefaultIsSet(false)
|
||||
,bLocked(false)
|
||||
{
|
||||
Size = DefaultSize;
|
||||
}
|
||||
|
||||
EbmlElement::EbmlElement(const EbmlElement & ElementToClone)
|
||||
:Size(ElementToClone.Size)
|
||||
,DefaultSize(ElementToClone.DefaultSize)
|
||||
,SizeLength(ElementToClone.SizeLength)
|
||||
,bSizeIsFinite(ElementToClone.bSizeIsFinite)
|
||||
,ElementPosition(ElementToClone.ElementPosition)
|
||||
,SizePosition(ElementToClone.SizePosition)
|
||||
,bValueIsSet(ElementToClone.bValueIsSet)
|
||||
,DefaultIsSet(ElementToClone.DefaultIsSet)
|
||||
,bLocked(ElementToClone.bLocked)
|
||||
{
|
||||
}
|
||||
|
||||
EbmlElement::~EbmlElement()
|
||||
{
|
||||
assert(!bLocked);
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo this method is deprecated and should be called FindThisID
|
||||
\todo replace the new RawElement with the appropriate class (when known)
|
||||
*/
|
||||
EbmlElement * EbmlElement::FindNextID(IOCallback & DataStream, const EbmlCallbacks & ClassInfos, uint64 MaxDataSize)
|
||||
{
|
||||
binary PossibleId[4];
|
||||
int PossibleID_Length = 0;
|
||||
binary PossibleSize[8]; // we don't support size stored in more than 64 bits
|
||||
uint32 PossibleSizeLength = 0;
|
||||
uint64 SizeUnknown;
|
||||
uint64 SizeFound;
|
||||
bool bElementFound = false;
|
||||
|
||||
binary BitMask;
|
||||
uint64 aElementPosition, aSizePosition;
|
||||
while (!bElementFound) {
|
||||
// read ID
|
||||
aElementPosition = DataStream.getFilePointer();
|
||||
uint32 ReadSize = 0;
|
||||
BitMask = 1 << 7;
|
||||
while (1) {
|
||||
ReadSize += DataStream.read(&PossibleId[PossibleID_Length], 1);
|
||||
if (ReadSize == uint32(PossibleID_Length)) {
|
||||
return NULL; // no more data ?
|
||||
}
|
||||
if (++PossibleID_Length > 4) {
|
||||
return NULL; // we don't support element IDs over class D
|
||||
}
|
||||
if (PossibleId[0] & BitMask) {
|
||||
// this is the last octet of the ID
|
||||
// check wether that's the one we're looking for
|
||||
/* if (PossibleID == EBML_INFO_ID(ClassInfos)) {
|
||||
break;
|
||||
} else {
|
||||
/// \todo This element should be skipped (use a context ?)
|
||||
}*/
|
||||
bElementFound = true; /// \todo not exactly the one we're looking for
|
||||
break;
|
||||
}
|
||||
BitMask >>= 1;
|
||||
}
|
||||
|
||||
// read the data size
|
||||
aSizePosition = DataStream.getFilePointer();
|
||||
uint32 _SizeLength;
|
||||
do {
|
||||
if (PossibleSizeLength >= 8)
|
||||
// Size is larger than 8 bytes
|
||||
return NULL;
|
||||
|
||||
ReadSize += DataStream.read(&PossibleSize[PossibleSizeLength++], 1);
|
||||
_SizeLength = PossibleSizeLength;
|
||||
SizeFound = ReadCodedSizeValue(&PossibleSize[0], _SizeLength, SizeUnknown);
|
||||
} while (_SizeLength == 0);
|
||||
}
|
||||
|
||||
EbmlElement *Result = NULL;
|
||||
EbmlId PossibleID(PossibleId, PossibleID_Length);
|
||||
if (PossibleID == EBML_INFO_ID(ClassInfos)) {
|
||||
// the element is the one expected
|
||||
Result = &EBML_INFO_CREATE(ClassInfos);
|
||||
} else {
|
||||
/// \todo find the element in the context
|
||||
Result = new (std::nothrow) EbmlDummy(PossibleID);
|
||||
if(Result == NULL)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
Result->SetSizeLength(PossibleSizeLength);
|
||||
|
||||
Result->Size = SizeFound;
|
||||
|
||||
if (!Result->ValidateSize() || (SizeFound != SizeUnknown && MaxDataSize < Result->Size)) {
|
||||
delete Result;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
// check if the size is not all 1s
|
||||
if (SizeFound == SizeUnknown) {
|
||||
// Size of this element is unknown
|
||||
// only possible for Master elements
|
||||
if (!Result->SetSizeInfinite()) {
|
||||
/// \todo the element is not allowed to be infinite
|
||||
delete Result;
|
||||
return NULL;
|
||||
}
|
||||
} else Result->SetSizeInfinite(false);
|
||||
Result->ElementPosition = aElementPosition;
|
||||
Result->SizePosition = aSizePosition;
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
||||
|
||||
/*!
|
||||
\todo replace the new RawElement with the appropriate class (when known)
|
||||
\todo skip data for Dummy elements when they are not allowed
|
||||
\todo better check of the size checking for upper elements (using a list of size for each level)
|
||||
\param LowLevel Will be returned with the level of the element found compared to the context given
|
||||
*/
|
||||
EbmlElement * EbmlElement::FindNextElement(IOCallback & DataStream, const EbmlSemanticContext & Context, int & UpperLevel,
|
||||
uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel)
|
||||
{
|
||||
int PossibleID_Length = 0;
|
||||
binary PossibleIdNSize[16];
|
||||
int PossibleSizeLength;
|
||||
uint64 SizeUnknown;
|
||||
int ReadIndex = 0; // trick for the algo, start index at 0
|
||||
uint32 ReadSize = 0;
|
||||
uint64 SizeFound;
|
||||
int SizeIdx;
|
||||
bool bFound;
|
||||
int UpperLevel_original = UpperLevel;
|
||||
|
||||
do {
|
||||
// read a potential ID
|
||||
do {
|
||||
assert(ReadIndex < 16);
|
||||
// build the ID with the current Read Buffer
|
||||
bFound = false;
|
||||
binary IdBitMask = 1 << 7;
|
||||
for (SizeIdx = 0; SizeIdx < ReadIndex && SizeIdx < 4; SizeIdx++) {
|
||||
if (PossibleIdNSize[0] & (IdBitMask >> SizeIdx)) {
|
||||
// ID found
|
||||
PossibleID_Length = SizeIdx + 1;
|
||||
IdBitMask >>= SizeIdx;
|
||||
bFound = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (bFound) {
|
||||
break;
|
||||
}
|
||||
|
||||
if (ReadIndex >= 4) {
|
||||
// ID not found
|
||||
// shift left the read octets
|
||||
memmove(&PossibleIdNSize[0],&PossibleIdNSize[1], --ReadIndex);
|
||||
}
|
||||
|
||||
if (DataStream.read(&PossibleIdNSize[ReadIndex++], 1) == 0) {
|
||||
return NULL; // no more data ?
|
||||
}
|
||||
ReadSize++;
|
||||
|
||||
} while (!bFound && MaxDataSize > ReadSize);
|
||||
|
||||
SizeIdx = ReadIndex;
|
||||
ReadIndex -= PossibleID_Length;
|
||||
|
||||
// read the data size
|
||||
uint32 _SizeLength;
|
||||
PossibleSizeLength = ReadIndex;
|
||||
while (1) {
|
||||
_SizeLength = PossibleSizeLength;
|
||||
SizeFound = ReadCodedSizeValue(&PossibleIdNSize[PossibleID_Length], _SizeLength, SizeUnknown);
|
||||
if (_SizeLength != 0) {
|
||||
bFound = true;
|
||||
break;
|
||||
}
|
||||
if (PossibleSizeLength >= 8) {
|
||||
bFound = false;
|
||||
break;
|
||||
}
|
||||
if( DataStream.read( &PossibleIdNSize[SizeIdx++], 1 ) == 0 ) {
|
||||
return NULL; // no more data ?
|
||||
}
|
||||
ReadSize++;
|
||||
PossibleSizeLength++;
|
||||
}
|
||||
|
||||
if (bFound) {
|
||||
// find the element in the context and use the correct creator
|
||||
EbmlId PossibleID(PossibleIdNSize, PossibleID_Length);
|
||||
EbmlElement * Result = CreateElementUsingContext(PossibleID, Context, UpperLevel, false, AllowDummyElt, MaxLowerLevel);
|
||||
///< \todo continue is misplaced
|
||||
if (Result != NULL) {
|
||||
if (AllowDummyElt || !Result->IsDummy()) {
|
||||
Result->SetSizeLength(_SizeLength);
|
||||
|
||||
Result->Size = SizeFound;
|
||||
// UpperLevel values
|
||||
// -1 : global element
|
||||
// 0 : child
|
||||
// 1 : same level
|
||||
// + : further parent
|
||||
if (Result->ValidateSize() && (SizeFound == SizeUnknown || UpperLevel > 0 || MaxDataSize == 0 || MaxDataSize >= (PossibleID_Length + PossibleSizeLength + SizeFound))) {
|
||||
if (SizeFound == SizeUnknown) {
|
||||
Result->SetSizeInfinite();
|
||||
}
|
||||
|
||||
Result->SizePosition = DataStream.getFilePointer() - SizeIdx + EBML_ID_LENGTH(PossibleID);
|
||||
Result->ElementPosition = Result->SizePosition - EBML_ID_LENGTH(PossibleID);
|
||||
// place the file at the beggining of the data
|
||||
DataStream.setFilePointer(Result->SizePosition + _SizeLength);
|
||||
return Result;
|
||||
}
|
||||
}
|
||||
delete Result;
|
||||
}
|
||||
}
|
||||
|
||||
// recover all the data in the buffer minus one byte
|
||||
ReadIndex = SizeIdx - 1;
|
||||
memmove(&PossibleIdNSize[0], &PossibleIdNSize[1], ReadIndex);
|
||||
UpperLevel = UpperLevel_original;
|
||||
} while ( MaxDataSize > DataStream.getFilePointer() - SizeIdx + PossibleID_Length );
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo what happens if we are in a upper element with a known size ?
|
||||
*/
|
||||
EbmlElement * EbmlElement::SkipData(EbmlStream & DataStream, const EbmlSemanticContext & Context, EbmlElement * TestReadElt, bool AllowDummyElt)
|
||||
{
|
||||
EbmlElement * Result = NULL;
|
||||
if (bSizeIsFinite) {
|
||||
assert(TestReadElt == NULL);
|
||||
assert(ElementPosition < SizePosition);
|
||||
DataStream.I_O().setFilePointer(SizePosition + CodedSizeLength(Size, SizeLength, bSizeIsFinite) + Size, seek_beginning);
|
||||
// DataStream.I_O().setFilePointer(Size, seek_current);
|
||||
} else {
|
||||
/////////////////////////////////////////////////
|
||||
// read elements until an upper element is found
|
||||
/////////////////////////////////////////////////
|
||||
bool bEndFound = false;
|
||||
while (!bEndFound && Result == NULL) {
|
||||
// read an element
|
||||
/// \todo 0xFF... and true should be configurable
|
||||
// EbmlElement * NewElt;
|
||||
if (TestReadElt == NULL) {
|
||||
int bUpperElement = 0; // trick to call FindNextID correctly
|
||||
Result = DataStream.FindNextElement(Context, bUpperElement, 0xFFFFFFFFL, AllowDummyElt);
|
||||
} else {
|
||||
Result = TestReadElt;
|
||||
TestReadElt = NULL;
|
||||
}
|
||||
|
||||
if (Result != NULL) {
|
||||
unsigned int EltIndex;
|
||||
// data known in this Master's context
|
||||
for (EltIndex = 0; EltIndex < EBML_CTX_SIZE(Context); EltIndex++) {
|
||||
if (EbmlId(*Result) == EBML_CTX_IDX_ID(Context,EltIndex)) {
|
||||
// skip the data with its own context
|
||||
Result = Result->SkipData(DataStream, EBML_SEM_CONTEXT(EBML_CTX_IDX(Context,EltIndex)), NULL);
|
||||
break; // let's go to the next ID
|
||||
}
|
||||
}
|
||||
|
||||
if (EltIndex >= EBML_CTX_SIZE(Context)) {
|
||||
if (EBML_CTX_PARENT(Context) != NULL) {
|
||||
Result = SkipData(DataStream, *EBML_CTX_PARENT(Context), Result);
|
||||
} else {
|
||||
assert(Context.GetGlobalContext != NULL);
|
||||
if (Context != Context.GetGlobalContext()) {
|
||||
Result = SkipData(DataStream, Context.GetGlobalContext(), Result);
|
||||
} else {
|
||||
bEndFound = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
bEndFound = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
return Result;
|
||||
}
|
||||
|
||||
EbmlElement *EbmlElement::CreateElementUsingContext(const EbmlId & aID, const EbmlSemanticContext & Context,
|
||||
int & LowLevel, bool IsGlobalContext, bool bAllowDummy, unsigned int MaxLowerLevel)
|
||||
{
|
||||
unsigned int ContextIndex;
|
||||
EbmlElement *Result = NULL;
|
||||
|
||||
// elements at the current level
|
||||
for (ContextIndex = 0; ContextIndex < EBML_CTX_SIZE(Context); ContextIndex++) {
|
||||
if (aID == EBML_CTX_IDX_ID(Context,ContextIndex)) {
|
||||
return &EBML_SEM_CREATE(EBML_CTX_IDX(Context,ContextIndex));
|
||||
}
|
||||
}
|
||||
|
||||
// global elements
|
||||
assert(Context.GetGlobalContext != NULL); // global should always exist, at least the EBML ones
|
||||
const EbmlSemanticContext & tstContext = Context.GetGlobalContext();
|
||||
if (tstContext != Context) {
|
||||
LowLevel--;
|
||||
MaxLowerLevel--;
|
||||
// recursive is good, but be carefull...
|
||||
Result = CreateElementUsingContext(aID, tstContext, LowLevel, true, bAllowDummy, MaxLowerLevel);
|
||||
if (Result != NULL) {
|
||||
return Result;
|
||||
}
|
||||
LowLevel++;
|
||||
MaxLowerLevel++;
|
||||
} else {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
// parent elements
|
||||
if (EBML_CTX_MASTER(Context) != NULL && aID == EBML_INFO_ID(*EBML_CTX_MASTER(Context))) {
|
||||
LowLevel++; // already one level up (same as context)
|
||||
return &EBML_INFO_CREATE(*EBML_CTX_MASTER(Context));
|
||||
}
|
||||
|
||||
// check wether it's not part of an upper context
|
||||
if (EBML_CTX_PARENT(Context) != NULL) {
|
||||
LowLevel++;
|
||||
MaxLowerLevel++;
|
||||
return CreateElementUsingContext(aID, *EBML_CTX_PARENT(Context), LowLevel, IsGlobalContext, bAllowDummy, MaxLowerLevel);
|
||||
}
|
||||
|
||||
if (!IsGlobalContext && bAllowDummy) {
|
||||
LowLevel = 0;
|
||||
Result = new (std::nothrow) EbmlDummy(aID);
|
||||
}
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo verify that the size written is the same as the data written
|
||||
*/
|
||||
filepos_t EbmlElement::Render(IOCallback & output, bool bWithDefault, bool bKeepPosition, bool bForceRender)
|
||||
{
|
||||
assert(bValueIsSet || (bWithDefault && DefaultISset())); // an element is been rendered without a value set !!!
|
||||
// it may be a mandatory element without a default value
|
||||
if (!bWithDefault && IsDefaultValue()) {
|
||||
return 0;
|
||||
}
|
||||
#if defined(LIBEBML_DEBUG)
|
||||
uint64 SupposedSize = UpdateSize(bWithDefault, bForceRender);
|
||||
#endif // LIBEBML_DEBUG
|
||||
filepos_t result = RenderHead(output, bForceRender, bWithDefault, bKeepPosition);
|
||||
uint64 WrittenSize = RenderData(output, bForceRender, bWithDefault);
|
||||
#if defined(LIBEBML_DEBUG)
|
||||
if (static_cast<int64>(SupposedSize) != (0-1))
|
||||
assert(WrittenSize == SupposedSize);
|
||||
#endif // LIBEBML_DEBUG
|
||||
result += WrittenSize;
|
||||
return result;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo store the position of the Size writing for elements with unknown size
|
||||
\todo handle exceptions on errors
|
||||
\todo handle CodeSize bigger than 5 bytes
|
||||
*/
|
||||
filepos_t EbmlElement::RenderHead(IOCallback & output, bool bForceRender, bool bWithDefault, bool bKeepPosition)
|
||||
{
|
||||
if (EBML_ID_LENGTH((const EbmlId&)*this) <= 0 || EBML_ID_LENGTH((const EbmlId&)*this) > 4)
|
||||
return 0;
|
||||
|
||||
UpdateSize(bWithDefault, bForceRender);
|
||||
|
||||
return MakeRenderHead(output, bKeepPosition);
|
||||
}
|
||||
|
||||
filepos_t EbmlElement::MakeRenderHead(IOCallback & output, bool bKeepPosition)
|
||||
{
|
||||
binary FinalHead[4+8]; // Class D + 64 bits coded size
|
||||
unsigned int FinalHeadSize;
|
||||
|
||||
FinalHeadSize = EBML_ID_LENGTH((const EbmlId&)*this);
|
||||
EbmlId(*this).Fill(FinalHead);
|
||||
|
||||
int CodedSize = CodedSizeLength(Size, SizeLength, bSizeIsFinite);
|
||||
CodedValueLength(Size, CodedSize, &FinalHead[FinalHeadSize]);
|
||||
FinalHeadSize += CodedSize;
|
||||
|
||||
output.writeFully(FinalHead, FinalHeadSize);
|
||||
if (!bKeepPosition) {
|
||||
ElementPosition = output.getFilePointer() - FinalHeadSize;
|
||||
SizePosition = ElementPosition + EBML_ID_LENGTH((const EbmlId&)*this);
|
||||
}
|
||||
|
||||
return FinalHeadSize;
|
||||
}
|
||||
|
||||
uint64 EbmlElement::ElementSize(bool bWithDefault) const
|
||||
{
|
||||
if (!bWithDefault && IsDefaultValue())
|
||||
return 0; // won't be saved
|
||||
return Size + EBML_ID_LENGTH((const EbmlId&)*this) + CodedSizeLength(Size, SizeLength, bSizeIsFinite);
|
||||
}
|
||||
|
||||
bool EbmlElement::IsSmallerThan(const EbmlElement *Cmp) const
|
||||
{
|
||||
return EbmlId(*this) == EbmlId(*Cmp);
|
||||
}
|
||||
|
||||
bool EbmlElement::CompareElements(const EbmlElement *A, const EbmlElement *B)
|
||||
{
|
||||
if (EbmlId(*A) == EbmlId(*B))
|
||||
return A->IsSmallerThan(B);
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
void EbmlElement::Read(EbmlStream & inDataStream, const EbmlSemanticContext & /* Context */, int & /* UpperEltFound */, EbmlElement * & /* FoundElt */, bool /* AllowDummyElt */, ScopeMode ReadFully)
|
||||
{
|
||||
ReadData(inDataStream.I_O(), ReadFully);
|
||||
}
|
||||
|
||||
bool EbmlElement::ForceSize(uint64 NewSize)
|
||||
{
|
||||
if (bSizeIsFinite) {
|
||||
return false;
|
||||
}
|
||||
|
||||
int OldSizeLen = CodedSizeLength(Size, SizeLength, bSizeIsFinite);
|
||||
uint64 OldSize = Size;
|
||||
|
||||
Size = NewSize;
|
||||
|
||||
if (CodedSizeLength(Size, SizeLength, bSizeIsFinite) == OldSizeLen) {
|
||||
bSizeIsFinite = true;
|
||||
return true;
|
||||
}
|
||||
Size = OldSize;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
filepos_t EbmlElement::OverwriteHead(IOCallback & output, bool bKeepPosition)
|
||||
{
|
||||
if (ElementPosition == 0) {
|
||||
return 0; // the element has not been written
|
||||
}
|
||||
|
||||
uint64 CurrentPosition = output.getFilePointer();
|
||||
output.setFilePointer(GetElementPosition());
|
||||
filepos_t Result = MakeRenderHead(output, bKeepPosition);
|
||||
output.setFilePointer(CurrentPosition);
|
||||
return Result;
|
||||
}
|
||||
|
||||
uint64 EbmlElement::VoidMe(IOCallback & output, bool bWithDefault)
|
||||
{
|
||||
if (ElementPosition == 0) {
|
||||
return 0; // the element has not been written
|
||||
}
|
||||
|
||||
EbmlVoid Dummy;
|
||||
return Dummy.Overwrite(*this, output, bWithDefault);
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,157 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
|
||||
#include <cassert>
|
||||
|
||||
#include "ebml/EbmlFloat.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
EbmlFloat::EbmlFloat(const EbmlFloat::Precision prec)
|
||||
:EbmlElement(0, false)
|
||||
{
|
||||
SetPrecision(prec);
|
||||
}
|
||||
|
||||
EbmlFloat::EbmlFloat(const double aDefaultValue, const EbmlFloat::Precision prec)
|
||||
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||
{
|
||||
SetDefaultIsSet();
|
||||
SetPrecision(prec);
|
||||
}
|
||||
|
||||
EbmlFloat::EbmlFloat(const EbmlFloat & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
,Value(ElementToClone.Value)
|
||||
,DefaultValue(ElementToClone.DefaultValue)
|
||||
{
|
||||
}
|
||||
|
||||
void EbmlFloat::SetDefaultValue(double aValue)
|
||||
{
|
||||
assert(!DefaultISset());
|
||||
DefaultValue = aValue;
|
||||
SetDefaultIsSet();
|
||||
}
|
||||
|
||||
double EbmlFloat::DefaultVal() const
|
||||
{
|
||||
assert(DefaultISset());
|
||||
return DefaultValue;
|
||||
}
|
||||
|
||||
EbmlFloat::operator float() const {return float(Value);}
|
||||
EbmlFloat::operator double() const {return double(Value);}
|
||||
|
||||
double EbmlFloat::GetValue() const {return Value;}
|
||||
|
||||
EbmlFloat & EbmlFloat::SetValue(double NewValue) {
|
||||
return *this = NewValue;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo handle exception on errors
|
||||
\todo handle 10 bits precision
|
||||
*/
|
||||
filepos_t EbmlFloat::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
assert(GetSize() == 4 || GetSize() == 8);
|
||||
|
||||
if (GetSize() == 4) {
|
||||
float val = Value;
|
||||
int Tmp;
|
||||
memcpy(&Tmp, &val, 4);
|
||||
big_int32 TmpToWrite(Tmp);
|
||||
output.writeFully(&TmpToWrite.endian(), GetSize());
|
||||
} else if (GetSize() == 8) {
|
||||
double val = Value;
|
||||
int64 Tmp;
|
||||
memcpy(&Tmp, &val, 8);
|
||||
big_int64 TmpToWrite(Tmp);
|
||||
output.writeFully(&TmpToWrite.endian(), GetSize());
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
uint64 EbmlFloat::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||
{
|
||||
if (!bWithDefault && IsDefaultValue())
|
||||
return 0;
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo remove the hack for possible endianess pb (test on little & big endian)
|
||||
*/
|
||||
filepos_t EbmlFloat::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if (ReadFully != SCOPE_NO_DATA) {
|
||||
binary Buffer[20];
|
||||
assert(GetSize() <= 20);
|
||||
input.readFully(Buffer, GetSize());
|
||||
|
||||
if (GetSize() == 4) {
|
||||
big_int32 TmpRead;
|
||||
TmpRead.Eval(Buffer);
|
||||
int32 tmpp = int32(TmpRead);
|
||||
float val;
|
||||
memcpy(&val, &tmpp, 4);
|
||||
Value = val;
|
||||
SetValueIsSet();
|
||||
} else if (GetSize() == 8) {
|
||||
big_int64 TmpRead;
|
||||
TmpRead.Eval(Buffer);
|
||||
int64 tmpp = int64(TmpRead);
|
||||
double val;
|
||||
memcpy(&val, &tmpp, 8);
|
||||
Value = val;
|
||||
SetValueIsSet();
|
||||
}
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
bool EbmlFloat::IsSmallerThan(const EbmlElement *Cmp) const
|
||||
{
|
||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||
return this->Value < static_cast<const EbmlFloat *>(Cmp)->Value;
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,58 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlHead.cpp 1096 2005-03-17 09:14:52Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include "ebml/EbmlHead.h"
|
||||
#include "ebml/EbmlSubHead.h"
|
||||
#include "ebml/EbmlContexts.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DEFINE_START_SEMANTIC(EbmlHead)
|
||||
DEFINE_SEMANTIC_ITEM(true, true, EVersion) ///< EBMLVersion
|
||||
DEFINE_SEMANTIC_ITEM(true, true, EReadVersion) ///< EBMLReadVersion
|
||||
DEFINE_SEMANTIC_ITEM(true, true, EMaxIdLength) ///< EBMLMaxIdLength
|
||||
DEFINE_SEMANTIC_ITEM(true, true, EMaxSizeLength) ///< EBMLMaxSizeLength
|
||||
DEFINE_SEMANTIC_ITEM(true, true, EDocType) ///< DocType
|
||||
DEFINE_SEMANTIC_ITEM(true, true, EDocTypeVersion) ///< DocTypeVersion
|
||||
DEFINE_SEMANTIC_ITEM(true, true, EDocTypeReadVersion) ///< DocTypeReadVersion
|
||||
DEFINE_END_SEMANTIC(EbmlHead)
|
||||
|
||||
DEFINE_EBML_MASTER_ORPHAN(EbmlHead, 0x1A45DFA3, 4, "EBMLHead\0ratamapaga");
|
||||
|
||||
EbmlHead::EbmlHead()
|
||||
:EbmlMaster(EbmlHead_Context)
|
||||
{}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,582 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
|
||||
#include <cassert>
|
||||
#include <algorithm>
|
||||
|
||||
#include "ebml/EbmlMaster.h"
|
||||
#include "ebml/EbmlStream.h"
|
||||
#include "ebml/EbmlContexts.h"
|
||||
#include "ebml/MemIOCallback.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
EbmlMaster::EbmlMaster(const EbmlSemanticContext & aContext, bool bSizeIsknown)
|
||||
:EbmlElement(0), Context(aContext), bChecksumUsed(bChecksumUsedByDefault)
|
||||
{
|
||||
SetSizeIsFinite(bSizeIsknown);
|
||||
SetValueIsSet();
|
||||
ProcessMandatory();
|
||||
}
|
||||
|
||||
EbmlMaster::EbmlMaster(const EbmlMaster & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
,ElementList(ElementToClone.ListSize())
|
||||
,Context(ElementToClone.Context)
|
||||
,bChecksumUsed(ElementToClone.bChecksumUsed)
|
||||
,Checksum(ElementToClone.Checksum)
|
||||
{
|
||||
// add a clone of the list
|
||||
std::vector<EbmlElement *>::const_iterator Itr = ElementToClone.ElementList.begin();
|
||||
std::vector<EbmlElement *>::iterator myItr = ElementList.begin();
|
||||
while (Itr != ElementToClone.ElementList.end())
|
||||
{
|
||||
*myItr = (*Itr)->Clone();
|
||||
++Itr; ++myItr;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
EbmlMaster::~EbmlMaster()
|
||||
{
|
||||
assert(!IsLocked()); // you're trying to delete a locked element !!!
|
||||
|
||||
size_t Index;
|
||||
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if (!(*ElementList[Index]).IsLocked()) {
|
||||
delete ElementList[Index];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo handle exception on errors
|
||||
\todo write all the Mandatory elements in the Context, otherwise assert
|
||||
*/
|
||||
filepos_t EbmlMaster::RenderData(IOCallback & output, bool bForceRender, bool bWithDefault)
|
||||
{
|
||||
filepos_t Result = 0;
|
||||
size_t Index;
|
||||
|
||||
if (!bForceRender) {
|
||||
assert(CheckMandatory());
|
||||
}
|
||||
|
||||
if (!bChecksumUsed) { // old school
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
||||
continue;
|
||||
Result += (ElementList[Index])->Render(output, bWithDefault, false ,bForceRender);
|
||||
}
|
||||
} else { // new school
|
||||
MemIOCallback TmpBuf(GetSize() - 6);
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
||||
continue;
|
||||
(ElementList[Index])->Render(TmpBuf, bWithDefault, false ,bForceRender);
|
||||
}
|
||||
Checksum.FillCRC32(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
||||
Result += Checksum.Render(output, true, false ,bForceRender);
|
||||
output.writeFully(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
||||
Result += TmpBuf.GetDataBufferSize();
|
||||
}
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo We might be able to forbid elements that don't exist in the context
|
||||
*/
|
||||
bool EbmlMaster::PushElement(EbmlElement & element)
|
||||
{
|
||||
ElementList.push_back(&element);
|
||||
return true;
|
||||
}
|
||||
|
||||
uint64 EbmlMaster::UpdateSize(bool bWithDefault, bool bForceRender)
|
||||
{
|
||||
SetSize_(0);
|
||||
|
||||
if (!IsFiniteSize())
|
||||
return (0-1);
|
||||
|
||||
if (!bForceRender) {
|
||||
assert(CheckMandatory());
|
||||
}
|
||||
|
||||
size_t Index;
|
||||
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if (!bWithDefault && (ElementList[Index])->IsDefaultValue())
|
||||
continue;
|
||||
(ElementList[Index])->UpdateSize(bWithDefault, bForceRender);
|
||||
uint64 SizeToAdd = (ElementList[Index])->ElementSize(bWithDefault);
|
||||
#if defined(LIBEBML_DEBUG)
|
||||
if (static_cast<int64>(SizeToAdd) == (0-1))
|
||||
return (0-1);
|
||||
#endif // LIBEBML_DEBUG
|
||||
SetSize_(GetSize() + SizeToAdd);
|
||||
}
|
||||
if (bChecksumUsed) {
|
||||
SetSize_(GetSize() + Checksum.ElementSize());
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
filepos_t EbmlMaster::WriteHead(IOCallback & output, int nSizeLength, bool bWithDefault)
|
||||
{
|
||||
SetSizeLength(nSizeLength);
|
||||
return RenderHead(output, false, bWithDefault);
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo this code is very suspicious !
|
||||
*/
|
||||
filepos_t EbmlMaster::ReadData(IOCallback & input, ScopeMode /* ReadFully */)
|
||||
{
|
||||
input.setFilePointer(GetSize(), seek_current);
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
/*!
|
||||
\note Hopefully no global element is mandatory
|
||||
\todo should be called for ALL EbmlMaster element on construction
|
||||
*/
|
||||
bool EbmlMaster::ProcessMandatory()
|
||||
{
|
||||
if (EBML_CTX_SIZE(Context) == 0)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
assert(Context.GetSize() != 0);
|
||||
|
||||
unsigned int EltIdx;
|
||||
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
||||
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory() && EBML_CTX_IDX(Context,EltIdx).IsUnique()) {
|
||||
// assert(EBML_CTX_IDX(Context,EltIdx).Create != NULL);
|
||||
PushElement(EBML_SEM_CREATE(EBML_CTX_IDX(Context,EltIdx)));
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
bool EbmlMaster::CheckMandatory() const
|
||||
{
|
||||
assert(Context.GetSize() != 0);
|
||||
|
||||
unsigned int EltIdx;
|
||||
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
||||
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory()) {
|
||||
if (FindElt(EBML_CTX_IDX_INFO(Context,EltIdx)) == NULL) {
|
||||
#if defined(LIBEBML_DEBUG)
|
||||
// you are missing this Mandatory element
|
||||
// const char * MissingName = EBML_INFO_NAME(EBML_CTX_IDX_INFO(Context,EltIdx));
|
||||
#endif // LIBEBML_DEBUG
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
std::vector<std::string> EbmlMaster::FindAllMissingElements()
|
||||
{
|
||||
assert(Context.GetSize() != 0);
|
||||
|
||||
std::vector<std::string> missingElements;
|
||||
|
||||
for (size_t ChildElementNo = 0; ChildElementNo < ElementList.size(); ChildElementNo++) {
|
||||
EbmlElement *childElement = ElementList[ChildElementNo];
|
||||
if (!childElement->ValueIsSet()) {
|
||||
std::string missingValue;
|
||||
missingValue = "The Child Element \"";
|
||||
missingValue.append(EBML_NAME(childElement));
|
||||
missingValue.append("\" of EbmlMaster \"");
|
||||
missingValue.append(EBML_NAME(this));
|
||||
missingValue.append("\", does not have a value set.");
|
||||
missingElements.push_back(missingValue);
|
||||
}
|
||||
|
||||
if (childElement->IsMaster()) {
|
||||
EbmlMaster *childMaster = (EbmlMaster *)childElement;
|
||||
|
||||
std::vector<std::string> childMissingElements = childMaster->FindAllMissingElements();
|
||||
for (size_t s = 0; s < childMissingElements.size(); s++)
|
||||
missingElements.push_back(childMissingElements[s]);
|
||||
}
|
||||
}
|
||||
unsigned int EltIdx;
|
||||
for (EltIdx = 0; EltIdx < EBML_CTX_SIZE(Context); EltIdx++) {
|
||||
if (EBML_CTX_IDX(Context,EltIdx).IsMandatory()) {
|
||||
if (FindElt(EBML_CTX_IDX_INFO(Context,EltIdx)) == NULL) {
|
||||
std::string missingElement;
|
||||
missingElement = "Missing element \"";
|
||||
missingElement.append(EBML_INFO_NAME(EBML_CTX_IDX_INFO(Context,EltIdx)));
|
||||
missingElement.append("\" in EbmlMaster \"");
|
||||
missingElement.append(EBML_INFO_NAME(*EBML_CTX_MASTER(Context)));
|
||||
missingElement.append("\"");
|
||||
missingElements.push_back(missingElement);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return missingElements;
|
||||
}
|
||||
|
||||
EbmlElement *EbmlMaster::FindElt(const EbmlCallbacks & Callbacks) const
|
||||
{
|
||||
size_t Index;
|
||||
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
EbmlElement * tmp = ElementList[Index];
|
||||
if (EbmlId(*tmp) == EBML_INFO_ID(Callbacks))
|
||||
return tmp;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
EbmlElement *EbmlMaster::FindFirstElt(const EbmlCallbacks & Callbacks, bool bCreateIfNull)
|
||||
{
|
||||
size_t Index;
|
||||
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if (ElementList[Index] && EbmlId(*(ElementList[Index])) == EBML_INFO_ID(Callbacks))
|
||||
return ElementList[Index];
|
||||
}
|
||||
|
||||
if (bCreateIfNull) {
|
||||
// add the element
|
||||
EbmlElement *NewElt = &EBML_INFO_CREATE(Callbacks);
|
||||
if (NewElt == NULL)
|
||||
return NULL;
|
||||
|
||||
if (!PushElement(*NewElt)) {
|
||||
delete NewElt;
|
||||
NewElt = NULL;
|
||||
}
|
||||
return NewElt;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
EbmlElement *EbmlMaster::FindFirstElt(const EbmlCallbacks & Callbacks) const
|
||||
{
|
||||
size_t Index;
|
||||
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if (EbmlId(*(ElementList[Index])) == EBML_INFO_ID(Callbacks))
|
||||
return ElementList[Index];
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo only return elements that are from the same type !
|
||||
\todo the element might be the unique in the context !
|
||||
*/
|
||||
EbmlElement *EbmlMaster::FindNextElt(const EbmlElement & PastElt, bool bCreateIfNull)
|
||||
{
|
||||
size_t Index;
|
||||
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if ((ElementList[Index]) == &PastElt) {
|
||||
// found past element, new one is :
|
||||
Index++;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
while (Index < ElementList.size()) {
|
||||
if ((EbmlId)PastElt == (EbmlId)(*ElementList[Index]))
|
||||
break;
|
||||
Index++;
|
||||
}
|
||||
|
||||
if (Index != ElementList.size())
|
||||
return ElementList[Index];
|
||||
|
||||
if (bCreateIfNull) {
|
||||
// add the element
|
||||
EbmlElement *NewElt = &(PastElt.CreateElement());
|
||||
if (NewElt == NULL)
|
||||
return NULL;
|
||||
|
||||
if (!PushElement(*NewElt)) {
|
||||
delete NewElt;
|
||||
NewElt = NULL;
|
||||
}
|
||||
return NewElt;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
EbmlElement *EbmlMaster::FindNextElt(const EbmlElement & PastElt) const
|
||||
{
|
||||
size_t Index;
|
||||
|
||||
for (Index = 0; Index < ElementList.size(); Index++) {
|
||||
if ((ElementList[Index]) == &PastElt) {
|
||||
// found past element, new one is :
|
||||
Index++;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
while (Index < ElementList.size()) {
|
||||
if ((EbmlId)PastElt == (EbmlId)(*ElementList[Index]))
|
||||
return ElementList[Index];
|
||||
Index++;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
EbmlElement *EbmlMaster::AddNewElt(const EbmlCallbacks & Callbacks)
|
||||
{
|
||||
// add the element
|
||||
EbmlElement *NewElt = &EBML_INFO_CREATE(Callbacks);
|
||||
if (NewElt == NULL)
|
||||
return NULL;
|
||||
|
||||
if (!PushElement(*NewElt)) {
|
||||
delete NewElt;
|
||||
NewElt = NULL;
|
||||
}
|
||||
return NewElt;
|
||||
}
|
||||
|
||||
void EbmlMaster::Sort()
|
||||
{
|
||||
std::sort(ElementList.begin(), ElementList.end(), EbmlElement::CompareElements);
|
||||
}
|
||||
|
||||
/*!
|
||||
\brief Method to help reading a Master element and all subsequent children quickly
|
||||
\todo add an option to discard even unknown elements
|
||||
\todo handle when a mandatory element is not found
|
||||
*/
|
||||
void EbmlMaster::Read(EbmlStream & inDataStream, const EbmlSemanticContext & sContext, int & UpperEltFound, EbmlElement * & FoundElt, bool AllowDummyElt, ScopeMode ReadFully)
|
||||
{
|
||||
if (ReadFully == SCOPE_NO_DATA)
|
||||
return;
|
||||
|
||||
EbmlElement * ElementLevelA;
|
||||
// remove all existing elements, including the mandatory ones...
|
||||
size_t Index;
|
||||
for (Index=0; Index<ElementList.size(); Index++) {
|
||||
if (!(*ElementList[Index]).IsLocked()) {
|
||||
delete ElementList[Index];
|
||||
}
|
||||
}
|
||||
ElementList.clear();
|
||||
uint64 MaxSizeToRead;
|
||||
|
||||
if (IsFiniteSize())
|
||||
MaxSizeToRead = GetSize();
|
||||
else
|
||||
MaxSizeToRead = 0x7FFFFFFF;
|
||||
|
||||
// read blocks and discard the ones we don't care about
|
||||
if (MaxSizeToRead > 0)
|
||||
{
|
||||
inDataStream.I_O().setFilePointer(GetSizePosition() + GetSizeLength(), seek_beginning);
|
||||
ElementLevelA = inDataStream.FindNextElement(sContext, UpperEltFound, MaxSizeToRead, AllowDummyElt);
|
||||
while (ElementLevelA != NULL && UpperEltFound <= 0 && MaxSizeToRead > 0) {
|
||||
if (IsFiniteSize() && ElementLevelA->IsFiniteSize())
|
||||
MaxSizeToRead = GetEndPosition() - ElementLevelA->GetEndPosition(); // even if it's the default value
|
||||
if (!AllowDummyElt && ElementLevelA->IsDummy()) {
|
||||
if (ElementLevelA->IsFiniteSize()) {
|
||||
ElementLevelA->SkipData(inDataStream, sContext);
|
||||
delete ElementLevelA; // forget this unknown element
|
||||
} else {
|
||||
delete ElementLevelA; // forget this unknown element
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
ElementLevelA->Read(inDataStream, EBML_CONTEXT(ElementLevelA), UpperEltFound, FoundElt, AllowDummyElt, ReadFully);
|
||||
|
||||
// Discard elements that couldn't be read properly if
|
||||
// SCOPE_ALL_DATA has been requested. This can happen
|
||||
// e.g. if block data is defective.
|
||||
bool DeleteElement = true;
|
||||
|
||||
if (ElementLevelA->ValueIsSet() || (ReadFully != SCOPE_ALL_DATA)) {
|
||||
ElementList.push_back(ElementLevelA);
|
||||
DeleteElement = false;
|
||||
}
|
||||
|
||||
// just in case
|
||||
if (ElementLevelA->IsFiniteSize()) {
|
||||
ElementLevelA->SkipData(inDataStream, EBML_CONTEXT(ElementLevelA));
|
||||
if (DeleteElement)
|
||||
delete ElementLevelA;
|
||||
} else {
|
||||
if (DeleteElement)
|
||||
delete ElementLevelA;
|
||||
|
||||
if (UpperEltFound) {
|
||||
--UpperEltFound;
|
||||
if (UpperEltFound > 0 || MaxSizeToRead <= 0)
|
||||
goto processCrc;
|
||||
ElementLevelA = FoundElt;
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (UpperEltFound > 0) {
|
||||
UpperEltFound--;
|
||||
if (UpperEltFound > 0 || MaxSizeToRead <= 0)
|
||||
goto processCrc;
|
||||
ElementLevelA = FoundElt;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (UpperEltFound < 0) {
|
||||
UpperEltFound++;
|
||||
if (UpperEltFound < 0)
|
||||
goto processCrc;
|
||||
}
|
||||
|
||||
if (MaxSizeToRead <= 0)
|
||||
goto processCrc;// this level is finished
|
||||
|
||||
ElementLevelA = inDataStream.FindNextElement(sContext, UpperEltFound, MaxSizeToRead, AllowDummyElt);
|
||||
}
|
||||
if (UpperEltFound > 0) {
|
||||
FoundElt = ElementLevelA;
|
||||
}
|
||||
}
|
||||
processCrc:
|
||||
|
||||
EBML_MASTER_ITERATOR Itr, CrcItr;
|
||||
for (Itr = ElementList.begin(); Itr != ElementList.end();) {
|
||||
if ((EbmlId)(*(*Itr)) == EBML_ID(EbmlCrc32)) {
|
||||
bChecksumUsed = true;
|
||||
// remove the element
|
||||
Checksum = *(static_cast<EbmlCrc32*>(*Itr));
|
||||
CrcItr = Itr;
|
||||
break;
|
||||
}
|
||||
++Itr;
|
||||
}
|
||||
|
||||
if (bChecksumUsed)
|
||||
{
|
||||
delete *CrcItr;
|
||||
Remove(CrcItr);
|
||||
}
|
||||
|
||||
SetValueIsSet();
|
||||
}
|
||||
|
||||
void EbmlMaster::Remove(size_t Index)
|
||||
{
|
||||
if (Index < ElementList.size()) {
|
||||
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
||||
while (Index-- > 0) {
|
||||
++Itr;
|
||||
}
|
||||
|
||||
ElementList.erase(Itr);
|
||||
}
|
||||
}
|
||||
|
||||
void EbmlMaster::Remove(EBML_MASTER_ITERATOR & Itr)
|
||||
{
|
||||
ElementList.erase(Itr);
|
||||
}
|
||||
|
||||
void EbmlMaster::Remove(EBML_MASTER_RITERATOR & Itr)
|
||||
{
|
||||
ElementList.erase(Itr.base());
|
||||
}
|
||||
|
||||
bool EbmlMaster::VerifyChecksum() const
|
||||
{
|
||||
if (!bChecksumUsed)
|
||||
return true;
|
||||
|
||||
EbmlCrc32 aChecksum;
|
||||
/// \todo remove the Checksum if it's in the list
|
||||
/// \todo find another way when not all default values are saved or (unknown from the reader !!!)
|
||||
MemIOCallback TmpBuf(GetSize() - 6);
|
||||
for (size_t Index = 0; Index < ElementList.size(); Index++) {
|
||||
(ElementList[Index])->Render(TmpBuf, true, false, true);
|
||||
}
|
||||
aChecksum.FillCRC32(TmpBuf.GetDataBuffer(), TmpBuf.GetDataBufferSize());
|
||||
return (aChecksum.GetCrc32() == Checksum.GetCrc32());
|
||||
}
|
||||
|
||||
bool EbmlMaster::InsertElement(EbmlElement & element, size_t position)
|
||||
{
|
||||
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
||||
while (Itr != ElementList.end() && position--)
|
||||
{
|
||||
++Itr;
|
||||
}
|
||||
if ((Itr == ElementList.end()) && position)
|
||||
return false;
|
||||
|
||||
ElementList.insert(Itr, &element);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool EbmlMaster::InsertElement(EbmlElement & element, const EbmlElement & before)
|
||||
{
|
||||
std::vector<EbmlElement *>::iterator Itr = ElementList.begin();
|
||||
while (Itr != ElementList.end() && *Itr != &before)
|
||||
{
|
||||
++Itr;
|
||||
}
|
||||
if (Itr == ElementList.end())
|
||||
return false;
|
||||
|
||||
ElementList.insert(Itr, &element);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,153 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
#include <cassert>
|
||||
|
||||
#include "ebml/EbmlSInteger.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
EbmlSInteger::EbmlSInteger()
|
||||
:EbmlElement(DEFAULT_INT_SIZE, false)
|
||||
{}
|
||||
|
||||
EbmlSInteger::EbmlSInteger(int64 aDefaultValue)
|
||||
:EbmlElement(DEFAULT_INT_SIZE, true), Value(aDefaultValue)
|
||||
{
|
||||
SetDefaultIsSet();
|
||||
}
|
||||
|
||||
EbmlSInteger::EbmlSInteger(const EbmlSInteger & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
,Value(ElementToClone.Value)
|
||||
,DefaultValue(ElementToClone.DefaultValue)
|
||||
{
|
||||
}
|
||||
|
||||
EbmlSInteger::operator int8() const {return int8(Value);}
|
||||
EbmlSInteger::operator int16() const {return int16(Value);}
|
||||
EbmlSInteger::operator int32() const {return int32(Value);}
|
||||
EbmlSInteger::operator int64() const {return Value;}
|
||||
|
||||
int64 EbmlSInteger::GetValue() const {return Value;}
|
||||
|
||||
EbmlSInteger & EbmlSInteger::SetValue(int64 NewValue) {
|
||||
return *this = NewValue;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo handle exception on errors
|
||||
*/
|
||||
filepos_t EbmlSInteger::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
binary FinalData[8]; // we don't handle more than 64 bits integers
|
||||
unsigned int i;
|
||||
|
||||
if (GetSizeLength() > 8)
|
||||
return 0; // integer bigger coded on more than 64 bits are not supported
|
||||
|
||||
int64 TempValue = Value;
|
||||
for (i=0; i<GetSize();i++) {
|
||||
FinalData[GetSize()-i-1] = binary(TempValue & 0xFF);
|
||||
TempValue >>= 8;
|
||||
}
|
||||
|
||||
output.writeFully(FinalData,GetSize());
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
uint64 EbmlSInteger::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||
{
|
||||
if (!bWithDefault && IsDefaultValue())
|
||||
return 0;
|
||||
|
||||
if (Value <= 0x7F && Value >= (-0x80)) {
|
||||
SetSize_(1);
|
||||
} else if (Value <= 0x7FFF && Value >= (-0x8000)) {
|
||||
SetSize_(2);
|
||||
} else if (Value <= 0x7FFFFF && Value >= (-0x800000)) {
|
||||
SetSize_(3);
|
||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFF) && Value >= (EBML_PRETTYLONGINT(-0x80000000))) {
|
||||
SetSize_(4);
|
||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFF) &&
|
||||
Value >= EBML_PRETTYLONGINT(-0x8000000000)) {
|
||||
SetSize_(5);
|
||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFFFF) &&
|
||||
Value >= EBML_PRETTYLONGINT(-0x800000000000)) {
|
||||
SetSize_(6);
|
||||
} else if (Value <= EBML_PRETTYLONGINT(0x7FFFFFFFFFFFFF) &&
|
||||
Value >= EBML_PRETTYLONGINT(-0x80000000000000)) {
|
||||
SetSize_(7);
|
||||
} else {
|
||||
SetSize_(8);
|
||||
}
|
||||
|
||||
if (GetDefaultSize() > GetSize()) {
|
||||
SetSize_(GetDefaultSize());
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
filepos_t EbmlSInteger::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if (ReadFully != SCOPE_NO_DATA) {
|
||||
binary Buffer[8];
|
||||
input.readFully(Buffer, GetSize());
|
||||
|
||||
if (Buffer[0] & 0x80)
|
||||
Value = -1; // this is a negative value
|
||||
else
|
||||
Value = 0; // this is a positive value
|
||||
|
||||
for (unsigned int i=0; i<GetSize(); i++) {
|
||||
Value <<= 8;
|
||||
Value |= Buffer[i];
|
||||
}
|
||||
SetValueIsSet();
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
bool EbmlSInteger::IsSmallerThan(const EbmlElement *Cmp) const
|
||||
{
|
||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||
return this->Value < static_cast<const EbmlSInteger *>(Cmp)->Value;
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,57 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include "ebml/EbmlStream.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
EbmlStream::EbmlStream(IOCallback & DataStream)
|
||||
:Stream(DataStream)
|
||||
{}
|
||||
|
||||
EbmlStream::~EbmlStream()
|
||||
{}
|
||||
|
||||
EbmlElement * EbmlStream::FindNextID(const EbmlCallbacks & ClassInfos, uint64 MaxDataSize)
|
||||
{
|
||||
return EbmlElement::FindNextID(Stream, ClassInfos, MaxDataSize);
|
||||
}
|
||||
|
||||
EbmlElement * EbmlStream::FindNextElement(const EbmlSemanticContext & Context, int & UpperLevel, uint64 MaxDataSize, bool AllowDummyElt, unsigned int MaxLowerLevel)
|
||||
{
|
||||
return EbmlElement::FindNextElement(Stream, Context, UpperLevel, MaxDataSize, AllowDummyElt, MaxLowerLevel);
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,171 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include <cassert>
|
||||
|
||||
#include "ebml/EbmlString.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
EbmlString::EbmlString()
|
||||
:EbmlElement(0, false)
|
||||
{
|
||||
SetDefaultSize(0);
|
||||
/* done automatically
|
||||
SetSize_(Value.length());
|
||||
if (GetDefaultSize() > GetSize())
|
||||
SetSize_(GetDefaultSize());*/
|
||||
}
|
||||
|
||||
EbmlString::EbmlString(const std::string & aDefaultValue)
|
||||
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||
{
|
||||
SetDefaultSize(0);
|
||||
SetDefaultIsSet();
|
||||
/* done automatically
|
||||
SetSize_(Value.length());
|
||||
if (GetDefaultSize() > GetSize())
|
||||
SetSize_(GetDefaultSize());*/
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo Cloning should be on the same exact type !
|
||||
*/
|
||||
EbmlString::EbmlString(const EbmlString & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
,Value(ElementToClone.Value)
|
||||
,DefaultValue(ElementToClone.DefaultValue)
|
||||
{
|
||||
}
|
||||
|
||||
void EbmlString::SetDefaultValue(std::string & aValue)
|
||||
{
|
||||
assert(!DefaultISset());
|
||||
DefaultValue = aValue;
|
||||
SetDefaultIsSet();
|
||||
}
|
||||
|
||||
const std::string & EbmlString::DefaultVal() const
|
||||
{
|
||||
assert(DefaultISset());
|
||||
return DefaultValue;
|
||||
}
|
||||
|
||||
|
||||
/*!
|
||||
\todo handle exception on errors
|
||||
*/
|
||||
filepos_t EbmlString::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
filepos_t Result;
|
||||
output.writeFully(Value.c_str(), Value.length());
|
||||
Result = Value.length();
|
||||
|
||||
if (Result < GetDefaultSize()) {
|
||||
// pad the rest with 0
|
||||
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
||||
if (Pad == NULL) {
|
||||
return Result;
|
||||
}
|
||||
memset(Pad, 0x00, GetDefaultSize() - Result);
|
||||
output.writeFully(Pad, GetDefaultSize() - Result);
|
||||
Result = GetDefaultSize();
|
||||
delete [] Pad;
|
||||
}
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
||||
EbmlString::operator const std::string &() const {return Value;}
|
||||
|
||||
EbmlString & EbmlString::operator=(const std::string & NewString)
|
||||
{
|
||||
Value = NewString;
|
||||
SetValueIsSet();
|
||||
/* done automatically
|
||||
SetSize_(Value.length());
|
||||
if (GetDefaultSize() > GetSize())
|
||||
SetSize_(GetDefaultSize());*/
|
||||
return *this;
|
||||
}
|
||||
|
||||
EbmlString &EbmlString::SetValue(std::string const &NewValue) {
|
||||
return *this = NewValue;
|
||||
}
|
||||
|
||||
std::string EbmlString::GetValue() const {
|
||||
return Value;
|
||||
}
|
||||
|
||||
uint64 EbmlString::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||
{
|
||||
if (!bWithDefault && IsDefaultValue())
|
||||
return 0;
|
||||
|
||||
if (Value.length() < GetDefaultSize()) {
|
||||
SetSize_(GetDefaultSize());
|
||||
} else {
|
||||
SetSize_(Value.length());
|
||||
}
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
filepos_t EbmlString::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if (ReadFully != SCOPE_NO_DATA) {
|
||||
if (GetSize() == 0) {
|
||||
Value = "";
|
||||
SetValueIsSet();
|
||||
} else {
|
||||
char *Buffer = new (std::nothrow) char[GetSize() + 1];
|
||||
if (Buffer == NULL) {
|
||||
// unable to store the data, skip it
|
||||
input.setFilePointer(GetSize(), seek_current);
|
||||
} else {
|
||||
input.readFully(Buffer, GetSize());
|
||||
if (Buffer[GetSize()-1] != '\0') {
|
||||
Buffer[GetSize()] = '\0';
|
||||
}
|
||||
Value = Buffer;
|
||||
delete [] Buffer;
|
||||
SetValueIsSet();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,49 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlSubHead.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include "ebml/EbmlSubHead.h"
|
||||
#include "ebml/EbmlContexts.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DEFINE_EBML_UINTEGER_DEF(EVersion, 0x4286, 2, EbmlHead, "EBMLVersion", 1);
|
||||
DEFINE_EBML_UINTEGER_DEF(EReadVersion, 0x42F7, 2, EbmlHead, "EBMLReadVersion", 1);
|
||||
DEFINE_EBML_UINTEGER_DEF(EMaxIdLength, 0x42F2, 2, EbmlHead, "EBMLMaxIdLength", 4);
|
||||
DEFINE_EBML_UINTEGER_DEF(EMaxSizeLength, 0x42F3, 2, EbmlHead, "EBMLMaxSizeLength", 8);
|
||||
DEFINE_EBML_STRING_DEF (EDocType, 0x4282, 2, EbmlHead, "EBMLDocType", "matroska");
|
||||
DEFINE_EBML_UINTEGER_DEF(EDocTypeVersion, 0x4287, 2, EbmlHead, "EBMLDocTypeVersion", 1);
|
||||
DEFINE_EBML_UINTEGER_DEF(EDocTypeReadVersion, 0x4285, 2, EbmlHead, "EBMLDocTypeReadVersion", 1);
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,160 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
#include <cassert>
|
||||
|
||||
#include "ebml/EbmlUInteger.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
EbmlUInteger::EbmlUInteger()
|
||||
:EbmlElement(DEFAULT_UINT_SIZE, false)
|
||||
{}
|
||||
|
||||
EbmlUInteger::EbmlUInteger(uint64 aDefaultValue)
|
||||
:EbmlElement(DEFAULT_UINT_SIZE, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||
{
|
||||
SetDefaultIsSet();
|
||||
}
|
||||
|
||||
EbmlUInteger::EbmlUInteger(const EbmlUInteger & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
,Value(ElementToClone.Value)
|
||||
,DefaultValue(ElementToClone.DefaultValue)
|
||||
{
|
||||
}
|
||||
|
||||
void EbmlUInteger::SetDefaultValue(uint64 aValue)
|
||||
{
|
||||
assert(!DefaultISset());
|
||||
DefaultValue = aValue;
|
||||
SetDefaultIsSet();
|
||||
}
|
||||
|
||||
uint64 EbmlUInteger::DefaultVal() const
|
||||
{
|
||||
assert(DefaultISset());
|
||||
return DefaultValue;
|
||||
}
|
||||
|
||||
EbmlUInteger::operator uint8() const {return uint8(Value); }
|
||||
EbmlUInteger::operator uint16() const {return uint16(Value);}
|
||||
EbmlUInteger::operator uint32() const {return uint32(Value);}
|
||||
EbmlUInteger::operator uint64() const {return Value;}
|
||||
|
||||
uint64 EbmlUInteger::GetValue() const {return Value;}
|
||||
|
||||
EbmlUInteger & EbmlUInteger::SetValue(uint64 NewValue) {
|
||||
return *this = NewValue;
|
||||
}
|
||||
|
||||
/*!
|
||||
\todo handle exception on errors
|
||||
*/
|
||||
filepos_t EbmlUInteger::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
binary FinalData[8]; // we don't handle more than 64 bits integers
|
||||
|
||||
if (GetSizeLength() > 8)
|
||||
return 0; // integer bigger coded on more than 64 bits are not supported
|
||||
|
||||
uint64 TempValue = Value;
|
||||
for (unsigned int i=0; i<GetSize();i++) {
|
||||
FinalData[GetSize()-i-1] = TempValue & 0xFF;
|
||||
TempValue >>= 8;
|
||||
}
|
||||
|
||||
output.writeFully(FinalData,GetSize());
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
uint64 EbmlUInteger::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||
{
|
||||
if (!bWithDefault && IsDefaultValue())
|
||||
return 0;
|
||||
|
||||
if (Value <= 0xFF) {
|
||||
SetSize_(1);
|
||||
} else if (Value <= 0xFFFF) {
|
||||
SetSize_(2);
|
||||
} else if (Value <= 0xFFFFFF) {
|
||||
SetSize_(3);
|
||||
} else if (Value <= 0xFFFFFFFF) {
|
||||
SetSize_(4);
|
||||
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFF)) {
|
||||
SetSize_(5);
|
||||
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFFFF)) {
|
||||
SetSize_(6);
|
||||
} else if (Value <= EBML_PRETTYLONGINT(0xFFFFFFFFFFFFFF)) {
|
||||
SetSize_(7);
|
||||
} else {
|
||||
SetSize_(8);
|
||||
}
|
||||
|
||||
if (GetDefaultSize() > GetSize()) {
|
||||
SetSize_(GetDefaultSize());
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
filepos_t EbmlUInteger::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if (ReadFully != SCOPE_NO_DATA) {
|
||||
binary Buffer[8];
|
||||
input.readFully(Buffer, GetSize());
|
||||
Value = 0;
|
||||
|
||||
for (unsigned int i=0; i<GetSize(); i++) {
|
||||
Value <<= 8;
|
||||
Value |= Buffer[i];
|
||||
}
|
||||
SetValueIsSet();
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
bool EbmlUInteger::IsSmallerThan(const EbmlElement *Cmp) const
|
||||
{
|
||||
if (EbmlId(*this) == EbmlId(*Cmp))
|
||||
return this->Value < static_cast<const EbmlUInteger *>(Cmp)->Value;
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,374 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
*/
|
||||
|
||||
#include <cassert>
|
||||
|
||||
#if __GNUC__ == 2 && ! defined ( __OpenBSD__ )
|
||||
#include <wchar.h>
|
||||
#endif
|
||||
|
||||
#include "ebml/EbmlUnicodeString.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
// ===================== UTFstring class ===================
|
||||
|
||||
static unsigned int UTFCharLength(uint8 lead)
|
||||
{
|
||||
if (lead < 0x80)
|
||||
return 1;
|
||||
else if ((lead >> 5) == 0x6)
|
||||
return 2;
|
||||
else if ((lead >> 4) == 0xe)
|
||||
return 3;
|
||||
else if ((lead >> 3) == 0x1e)
|
||||
return 4;
|
||||
else
|
||||
// Invalid size?
|
||||
return 0;
|
||||
}
|
||||
|
||||
UTFstring::UTFstring()
|
||||
:_Length(0)
|
||||
,_Data(NULL)
|
||||
{}
|
||||
|
||||
UTFstring::UTFstring(const wchar_t * _aBuf)
|
||||
:_Length(0)
|
||||
,_Data(NULL)
|
||||
{
|
||||
*this = _aBuf;
|
||||
}
|
||||
|
||||
UTFstring::UTFstring(std::wstring const &_aBuf)
|
||||
:_Length(0)
|
||||
,_Data(NULL)
|
||||
{
|
||||
*this = _aBuf.c_str();
|
||||
}
|
||||
|
||||
UTFstring::~UTFstring()
|
||||
{
|
||||
delete [] _Data;
|
||||
}
|
||||
|
||||
UTFstring::UTFstring(const UTFstring & _aBuf)
|
||||
:_Length(0)
|
||||
,_Data(NULL)
|
||||
{
|
||||
*this = _aBuf.c_str();
|
||||
}
|
||||
|
||||
UTFstring & UTFstring::operator=(const UTFstring & _aBuf)
|
||||
{
|
||||
*this = _aBuf.c_str();
|
||||
return *this;
|
||||
}
|
||||
|
||||
UTFstring::operator const wchar_t*() const {return _Data;}
|
||||
|
||||
|
||||
UTFstring & UTFstring::operator=(const wchar_t * _aBuf)
|
||||
{
|
||||
delete [] _Data;
|
||||
if (_aBuf == NULL) {
|
||||
_Data = new wchar_t[1];
|
||||
_Data[0] = 0;
|
||||
UpdateFromUCS2();
|
||||
return *this;
|
||||
}
|
||||
|
||||
size_t aLen;
|
||||
for (aLen=0; _aBuf[aLen] != 0; aLen++);
|
||||
_Length = aLen;
|
||||
_Data = new wchar_t[_Length+1];
|
||||
for (aLen=0; _aBuf[aLen] != 0; aLen++) {
|
||||
_Data[aLen] = _aBuf[aLen];
|
||||
}
|
||||
_Data[aLen] = 0;
|
||||
UpdateFromUCS2();
|
||||
return *this;
|
||||
}
|
||||
|
||||
UTFstring & UTFstring::operator=(wchar_t _aChar)
|
||||
{
|
||||
delete [] _Data;
|
||||
_Data = new wchar_t[2];
|
||||
_Length = 1;
|
||||
_Data[0] = _aChar;
|
||||
_Data[1] = 0;
|
||||
UpdateFromUCS2();
|
||||
return *this;
|
||||
}
|
||||
|
||||
bool UTFstring::operator==(const UTFstring& _aStr) const
|
||||
{
|
||||
if ((_Data == NULL) && (_aStr._Data == NULL))
|
||||
return true;
|
||||
if ((_Data == NULL) || (_aStr._Data == NULL))
|
||||
return false;
|
||||
return wcscmp_internal(_Data, _aStr._Data);
|
||||
}
|
||||
|
||||
void UTFstring::SetUTF8(const std::string & _aStr)
|
||||
{
|
||||
UTF8string = _aStr;
|
||||
UpdateFromUTF8();
|
||||
}
|
||||
|
||||
/*!
|
||||
\see RFC 2279
|
||||
*/
|
||||
void UTFstring::UpdateFromUTF8()
|
||||
{
|
||||
delete [] _Data;
|
||||
// find the size of the final UCS-2 string
|
||||
size_t i;
|
||||
const size_t SrcLength = UTF8string.length();
|
||||
for (_Length=0, i=0; i<SrcLength; _Length++) {
|
||||
const unsigned int CharLength = UTFCharLength(static_cast<uint8>(UTF8string[i]));
|
||||
if ((CharLength >= 1) && (CharLength <= 4))
|
||||
i += CharLength;
|
||||
else
|
||||
// Invalid size?
|
||||
break;
|
||||
}
|
||||
_Data = new wchar_t[_Length+1];
|
||||
size_t j;
|
||||
for (j=0, i=0; i<SrcLength; j++) {
|
||||
const uint8 lead = static_cast<uint8>(UTF8string[i]);
|
||||
const unsigned int CharLength = UTFCharLength(lead);
|
||||
if ((CharLength < 1) || (CharLength > 4))
|
||||
// Invalid char?
|
||||
break;
|
||||
|
||||
if ((i + CharLength) > SrcLength)
|
||||
// Guard against invalid memory access beyond the end of the
|
||||
// source buffer.
|
||||
break;
|
||||
|
||||
if (CharLength == 1)
|
||||
_Data[j] = lead;
|
||||
else if (CharLength == 2)
|
||||
_Data[j] = ((lead & 0x1F) << 6) + (UTF8string[i+1] & 0x3F);
|
||||
else if (CharLength == 3)
|
||||
_Data[j] = ((lead & 0x0F) << 12) + ((UTF8string[i+1] & 0x3F) << 6) + (UTF8string[i+2] & 0x3F);
|
||||
else if (CharLength == 4)
|
||||
_Data[j] = ((lead & 0x07) << 18) + ((UTF8string[i+1] & 0x3F) << 12) + ((UTF8string[i+2] & 0x3F) << 6) + (UTF8string[i+3] & 0x3F);
|
||||
|
||||
i += CharLength;
|
||||
}
|
||||
_Data[j] = 0;
|
||||
}
|
||||
|
||||
void UTFstring::UpdateFromUCS2()
|
||||
{
|
||||
// find the size of the final UTF-8 string
|
||||
size_t i,Size=0;
|
||||
for (i=0; i<_Length; i++) {
|
||||
if (_Data[i] < 0x80) {
|
||||
Size++;
|
||||
} else if (_Data[i] < 0x800) {
|
||||
Size += 2;
|
||||
} else {
|
||||
Size += 3;
|
||||
}
|
||||
}
|
||||
std::string::value_type *tmpStr = new std::string::value_type[Size+1];
|
||||
for (i=0, Size=0; i<_Length; i++) {
|
||||
if (_Data[i] < 0x80) {
|
||||
tmpStr[Size++] = _Data[i];
|
||||
} else if (_Data[i] < 0x800) {
|
||||
tmpStr[Size++] = 0xC0 | (_Data[i] >> 6);
|
||||
tmpStr[Size++] = 0x80 | (_Data[i] & 0x3F);
|
||||
} else {
|
||||
tmpStr[Size++] = 0xE0 | (_Data[i] >> 12);
|
||||
tmpStr[Size++] = 0x80 | ((_Data[i] >> 6) & 0x3F);
|
||||
tmpStr[Size++] = 0x80 | (_Data[i] & 0x3F);
|
||||
}
|
||||
}
|
||||
tmpStr[Size] = 0;
|
||||
UTF8string = tmpStr; // implicit conversion
|
||||
delete [] tmpStr;
|
||||
|
||||
}
|
||||
|
||||
bool UTFstring::wcscmp_internal(const wchar_t *str1, const wchar_t *str2)
|
||||
{
|
||||
size_t Index=0;
|
||||
while (str1[Index] == str2[Index] && str1[Index] != 0) {
|
||||
Index++;
|
||||
}
|
||||
return (str1[Index] == str2[Index]);
|
||||
}
|
||||
|
||||
// ===================== EbmlUnicodeString class ===================
|
||||
|
||||
EbmlUnicodeString::EbmlUnicodeString()
|
||||
:EbmlElement(0, false)
|
||||
{
|
||||
SetDefaultSize(0);
|
||||
}
|
||||
|
||||
EbmlUnicodeString::EbmlUnicodeString(const UTFstring & aDefaultValue)
|
||||
:EbmlElement(0, true), Value(aDefaultValue), DefaultValue(aDefaultValue)
|
||||
{
|
||||
SetDefaultSize(0);
|
||||
SetDefaultIsSet();
|
||||
}
|
||||
|
||||
EbmlUnicodeString::EbmlUnicodeString(const EbmlUnicodeString & ElementToClone)
|
||||
:EbmlElement(ElementToClone)
|
||||
,Value(ElementToClone.Value)
|
||||
,DefaultValue(ElementToClone.DefaultValue)
|
||||
{
|
||||
}
|
||||
|
||||
void EbmlUnicodeString::SetDefaultValue(UTFstring & aValue)
|
||||
{
|
||||
assert(!DefaultISset());
|
||||
DefaultValue = aValue;
|
||||
SetDefaultIsSet();
|
||||
}
|
||||
|
||||
const UTFstring & EbmlUnicodeString::DefaultVal() const
|
||||
{
|
||||
assert(DefaultISset());
|
||||
return DefaultValue;
|
||||
}
|
||||
|
||||
|
||||
/*!
|
||||
\note limited to UCS-2
|
||||
\todo handle exception on errors
|
||||
*/
|
||||
filepos_t EbmlUnicodeString::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
uint32 Result = Value.GetUTF8().length();
|
||||
|
||||
if (Result != 0) {
|
||||
output.writeFully(Value.GetUTF8().c_str(), Result);
|
||||
}
|
||||
|
||||
if (Result < GetDefaultSize()) {
|
||||
// pad the rest with 0
|
||||
binary *Pad = new (std::nothrow) binary[GetDefaultSize() - Result];
|
||||
if (Pad != NULL) {
|
||||
memset(Pad, 0x00, GetDefaultSize() - Result);
|
||||
output.writeFully(Pad, GetDefaultSize() - Result);
|
||||
|
||||
Result = GetDefaultSize();
|
||||
delete [] Pad;
|
||||
}
|
||||
}
|
||||
|
||||
return Result;
|
||||
}
|
||||
|
||||
EbmlUnicodeString::operator const UTFstring &() const {return Value;}
|
||||
|
||||
EbmlUnicodeString & EbmlUnicodeString::operator=(const UTFstring & NewString)
|
||||
{
|
||||
Value = NewString;
|
||||
SetValueIsSet();
|
||||
return *this;
|
||||
}
|
||||
|
||||
EbmlUnicodeString &EbmlUnicodeString::SetValue(UTFstring const &NewValue) {
|
||||
return *this = NewValue;
|
||||
}
|
||||
|
||||
EbmlUnicodeString &EbmlUnicodeString::SetValueUTF8(std::string const &NewValue) {
|
||||
UTFstring NewValueUTFstring;
|
||||
NewValueUTFstring.SetUTF8(NewValue);
|
||||
return *this = NewValueUTFstring;
|
||||
}
|
||||
|
||||
UTFstring EbmlUnicodeString::GetValue() const {
|
||||
return Value;
|
||||
}
|
||||
|
||||
std::string EbmlUnicodeString::GetValueUTF8() const {
|
||||
return Value.GetUTF8();
|
||||
}
|
||||
|
||||
/*!
|
||||
\note limited to UCS-2
|
||||
*/
|
||||
uint64 EbmlUnicodeString::UpdateSize(bool bWithDefault, bool /* bForceRender */)
|
||||
{
|
||||
if (!bWithDefault && IsDefaultValue())
|
||||
return 0;
|
||||
|
||||
SetSize_(Value.GetUTF8().length());
|
||||
if (GetSize() < GetDefaultSize())
|
||||
SetSize_(GetDefaultSize());
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
/*!
|
||||
\note limited to UCS-2
|
||||
*/
|
||||
filepos_t EbmlUnicodeString::ReadData(IOCallback & input, ScopeMode ReadFully)
|
||||
{
|
||||
if (ReadFully != SCOPE_NO_DATA) {
|
||||
if (GetSize() == 0) {
|
||||
Value = UTFstring::value_type(0);
|
||||
SetValueIsSet();
|
||||
} else {
|
||||
char *Buffer = new (std::nothrow) char[GetSize()+1];
|
||||
if (Buffer == NULL) {
|
||||
// impossible to read, skip it
|
||||
input.setFilePointer(GetSize(), seek_current);
|
||||
} else {
|
||||
input.readFully(Buffer, GetSize());
|
||||
if (Buffer[GetSize()-1] != 0) {
|
||||
Buffer[GetSize()] = 0;
|
||||
}
|
||||
|
||||
Value.SetUTF8(Buffer); // implicit conversion to std::string
|
||||
delete [] Buffer;
|
||||
SetValueIsSet();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,48 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlVersion.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
|
||||
#include "ebml/EbmlVersion.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
const std::string EbmlCodeVersion = "1.3.4";
|
||||
|
||||
// Up to version 1.3.3 this library exported a build date string. As
|
||||
// this made the build non-reproducible, replace it by a placeholder to
|
||||
// remain API compatible.
|
||||
const std::string EbmlCodeDate = "Unknown";
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
137
src/EbmlVoid.cpp
137
src/EbmlVoid.cpp
@ -1,137 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2010 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: EbmlVoid.cpp 1232 2005-10-15 15:56:52Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
*/
|
||||
#include "ebml/EbmlVoid.h"
|
||||
#include "ebml/EbmlContexts.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
DEFINE_EBML_CLASS_GLOBAL(EbmlVoid, 0xEC, 1, "EBMLVoid");
|
||||
|
||||
EbmlVoid::EbmlVoid()
|
||||
{
|
||||
SetValueIsSet();
|
||||
}
|
||||
|
||||
filepos_t EbmlVoid::RenderData(IOCallback & output, bool /* bForceRender */, bool /* bWithDefault */)
|
||||
{
|
||||
// write dummy data by 4KB chunks
|
||||
static binary DummyBuf[4*1024];
|
||||
|
||||
uint64 SizeToWrite = GetSize();
|
||||
while (SizeToWrite > 4*1024) {
|
||||
output.writeFully(DummyBuf, 4*1024);
|
||||
SizeToWrite -= 4*1024;
|
||||
}
|
||||
output.writeFully(DummyBuf, SizeToWrite);
|
||||
return GetSize();
|
||||
}
|
||||
|
||||
uint64 EbmlVoid::ReplaceWith(EbmlElement & EltToReplaceWith, IOCallback & output, bool ComeBackAfterward, bool bWithDefault)
|
||||
{
|
||||
EltToReplaceWith.UpdateSize(bWithDefault);
|
||||
if (HeadSize() + GetSize() < EltToReplaceWith.GetSize() + EltToReplaceWith.HeadSize()) {
|
||||
// the element can't be written here !
|
||||
return INVALID_FILEPOS_T;
|
||||
}
|
||||
if (HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() == 1) {
|
||||
// there is not enough space to put a filling element
|
||||
return INVALID_FILEPOS_T;
|
||||
}
|
||||
|
||||
uint64 CurrentPosition = output.getFilePointer();
|
||||
|
||||
output.setFilePointer(GetElementPosition());
|
||||
EltToReplaceWith.Render(output, bWithDefault);
|
||||
|
||||
if (HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() > 1) {
|
||||
// fill the rest with another void element
|
||||
EbmlVoid aTmp;
|
||||
aTmp.SetSize_(HeadSize() + GetSize() - EltToReplaceWith.GetSize() - EltToReplaceWith.HeadSize() - 1); // 1 is the length of the Void ID
|
||||
int HeadBefore = aTmp.HeadSize();
|
||||
aTmp.SetSize_(aTmp.GetSize() - CodedSizeLength(aTmp.GetSize(), aTmp.GetSizeLength(), aTmp.IsFiniteSize()));
|
||||
int HeadAfter = aTmp.HeadSize();
|
||||
if (HeadBefore != HeadAfter) {
|
||||
aTmp.SetSizeLength(CodedSizeLength(aTmp.GetSize(), aTmp.GetSizeLength(), aTmp.IsFiniteSize()) - (HeadAfter - HeadBefore));
|
||||
}
|
||||
aTmp.RenderHead(output, false, bWithDefault); // the rest of the data is not rewritten
|
||||
}
|
||||
|
||||
if (ComeBackAfterward) {
|
||||
output.setFilePointer(CurrentPosition);
|
||||
}
|
||||
|
||||
return GetSize() + HeadSize();
|
||||
}
|
||||
|
||||
uint64 EbmlVoid::Overwrite(const EbmlElement & EltToVoid, IOCallback & output, bool ComeBackAfterward, bool bWithDefault)
|
||||
{
|
||||
// EltToVoid.UpdateSize(bWithDefault);
|
||||
if (EltToVoid.GetElementPosition() == 0) {
|
||||
// this element has never been written
|
||||
return 0;
|
||||
}
|
||||
if (EltToVoid.GetSize() + EltToVoid.HeadSize() <2) {
|
||||
// the element can't be written here !
|
||||
return 0;
|
||||
}
|
||||
|
||||
uint64 CurrentPosition = output.getFilePointer();
|
||||
|
||||
output.setFilePointer(EltToVoid.GetElementPosition());
|
||||
|
||||
// compute the size of the voided data based on the original one
|
||||
SetSize(EltToVoid.GetSize() + EltToVoid.HeadSize() - 1); // 1 for the ID
|
||||
SetSize(GetSize() - CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize()));
|
||||
// make sure we handle even the strange cases
|
||||
//uint32 A1 = GetSize() + HeadSize();
|
||||
//uint32 A2 = EltToVoid.GetSize() + EltToVoid.HeadSize();
|
||||
if (GetSize() + HeadSize() != EltToVoid.GetSize() + EltToVoid.HeadSize()) {
|
||||
SetSize(GetSize()-1);
|
||||
SetSizeLength(CodedSizeLength(GetSize(), GetSizeLength(), IsFiniteSize()) + 1);
|
||||
}
|
||||
|
||||
if (GetSize() != 0) {
|
||||
RenderHead(output, false, bWithDefault); // the rest of the data is not rewritten
|
||||
}
|
||||
|
||||
if (ComeBackAfterward) {
|
||||
output.setFilePointer(CurrentPosition);
|
||||
}
|
||||
|
||||
return EltToVoid.GetSize() + EltToVoid.HeadSize();
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,81 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Ingo Ralf Blum. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: IOCallback.cpp 639 2004-07-09 20:59:14Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
#include <sstream>
|
||||
#endif // GCC2
|
||||
#include <stdexcept>
|
||||
|
||||
|
||||
#include "ebml/IOCallback.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
void IOCallback::writeFully(const void*Buffer,size_t Size)
|
||||
{
|
||||
if (Size == 0)
|
||||
return;
|
||||
|
||||
if (Buffer == NULL)
|
||||
throw;
|
||||
|
||||
if(write(Buffer,Size) != Size) {
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
stringstream Msg;
|
||||
Msg<<"EOF in writeFully("<<Buffer<<","<<Size<<")";
|
||||
throw runtime_error(Msg.str());
|
||||
#endif // GCC2
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
void IOCallback::readFully(void*Buffer,size_t Size)
|
||||
{
|
||||
if(Buffer == NULL)
|
||||
throw;
|
||||
|
||||
if(read(Buffer,Size) != Size) {
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
stringstream Msg;
|
||||
Msg<<"EOF in readFully("<<Buffer<<","<<Size<<")";
|
||||
throw runtime_error(Msg.str());
|
||||
#endif // GCC2
|
||||
}
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,121 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2003 Jory Stone. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: MemIOCallback.cpp 693 2004-07-31 08:56:28Z robux4 $
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
*/
|
||||
|
||||
#include "ebml/MemIOCallback.h"
|
||||
#include "ebml/Debug.h"
|
||||
#include "ebml/EbmlConfig.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
MemIOCallback::MemIOCallback(uint64 DefaultSize)
|
||||
{
|
||||
//The default size of the buffer is 128 bytes
|
||||
dataBuffer = (binary *)malloc(DefaultSize);
|
||||
if (dataBuffer == NULL) {
|
||||
mOk = false;
|
||||
std::stringstream Msg;
|
||||
Msg << "Failed to alloc memory block of size ";
|
||||
// not working with VC6 Msg << DefaultSize;
|
||||
mLastErrorStr = Msg.str();
|
||||
return;
|
||||
}
|
||||
|
||||
dataBufferMemorySize = DefaultSize;
|
||||
dataBufferPos = 0;
|
||||
dataBufferTotalSize = 0;
|
||||
mOk = true;
|
||||
}
|
||||
|
||||
MemIOCallback::~MemIOCallback()
|
||||
{
|
||||
if (dataBuffer != NULL)
|
||||
free(dataBuffer);
|
||||
}
|
||||
|
||||
uint32 MemIOCallback::read(void *Buffer, size_t Size)
|
||||
{
|
||||
if (Buffer == NULL || Size < 1)
|
||||
return 0;
|
||||
//If the size is larger than than the amount left in the buffer
|
||||
if (Size + dataBufferPos > dataBufferTotalSize) {
|
||||
//We will only return the remaining data
|
||||
memcpy(Buffer, dataBuffer + dataBufferPos, dataBufferTotalSize - dataBufferPos);
|
||||
uint64 oldDataPos = dataBufferPos;
|
||||
dataBufferPos = dataBufferTotalSize;
|
||||
return dataBufferTotalSize - oldDataPos;
|
||||
}
|
||||
|
||||
//Well... We made it here, so do a quick and simple copy
|
||||
memcpy(Buffer, dataBuffer+dataBufferPos, Size);
|
||||
dataBufferPos += Size;
|
||||
|
||||
return Size;
|
||||
}
|
||||
|
||||
void MemIOCallback::setFilePointer(int64 Offset, seek_mode Mode)
|
||||
{
|
||||
if (Mode == seek_beginning)
|
||||
dataBufferPos = Offset;
|
||||
else if (Mode == seek_current)
|
||||
dataBufferPos = dataBufferPos + Offset;
|
||||
else if (Mode == seek_end)
|
||||
dataBufferPos = dataBufferTotalSize + Offset;
|
||||
}
|
||||
|
||||
size_t MemIOCallback::write(const void *Buffer, size_t Size)
|
||||
{
|
||||
if (dataBufferMemorySize < dataBufferPos + Size) {
|
||||
//We need more memory!
|
||||
dataBuffer = (binary *)realloc((void *)dataBuffer, dataBufferPos + Size);
|
||||
}
|
||||
memcpy(dataBuffer+dataBufferPos, Buffer, Size);
|
||||
dataBufferPos += Size;
|
||||
if (dataBufferPos > dataBufferTotalSize)
|
||||
dataBufferTotalSize = dataBufferPos;
|
||||
|
||||
return Size;
|
||||
}
|
||||
|
||||
uint32 MemIOCallback::write(IOCallback & IOToRead, size_t Size)
|
||||
{
|
||||
if (dataBufferMemorySize < dataBufferPos + Size) {
|
||||
//We need more memory!
|
||||
dataBuffer = (binary *)realloc((void *)dataBuffer, dataBufferPos + Size);
|
||||
}
|
||||
IOToRead.readFully(&dataBuffer[dataBufferPos], Size);
|
||||
dataBufferTotalSize = Size;
|
||||
return Size;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,92 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2014 Moritz Bunkus. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.matroska.org/license/lgpl/ for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Moritz Bunkus <moritz@bunkus.org>
|
||||
*/
|
||||
|
||||
#include <cstring>
|
||||
|
||||
#include "ebml/EbmlBinary.h"
|
||||
#include "ebml/MemReadIOCallback.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
MemReadIOCallback::MemReadIOCallback(void const *Ptr,
|
||||
size_t Size) {
|
||||
Init(Ptr, Size);
|
||||
}
|
||||
|
||||
MemReadIOCallback::MemReadIOCallback(EbmlBinary const &Binary) {
|
||||
Init(Binary.GetBuffer(), Binary.GetSize());
|
||||
}
|
||||
|
||||
MemReadIOCallback::MemReadIOCallback(MemReadIOCallback const &Mem) {
|
||||
Init(Mem.mPtr, Mem.mEnd - Mem.mPtr);
|
||||
}
|
||||
|
||||
MemReadIOCallback::~MemReadIOCallback() {
|
||||
}
|
||||
|
||||
void
|
||||
MemReadIOCallback::Init(void const *Ptr,
|
||||
size_t Size) {
|
||||
mStart = reinterpret_cast<uint8 const *>(Ptr);
|
||||
mEnd = mStart + Size;
|
||||
mPtr = mStart;
|
||||
}
|
||||
|
||||
uint32
|
||||
MemReadIOCallback::read(void *Buffer,
|
||||
size_t Size) {
|
||||
size_t RemainingBytes = mEnd - mPtr;
|
||||
if (RemainingBytes < Size)
|
||||
Size = RemainingBytes;
|
||||
|
||||
std::memcpy(Buffer, mPtr, Size);
|
||||
mPtr += Size;
|
||||
|
||||
return Size;
|
||||
}
|
||||
|
||||
void
|
||||
MemReadIOCallback::setFilePointer(int64 Offset,
|
||||
seek_mode Mode) {
|
||||
int64 NewPosition = Mode == seek_beginning ? Offset
|
||||
: Mode == seek_end ? static_cast<int64>(mEnd - mStart) + Offset
|
||||
: static_cast<int64>(mPtr - mStart) + Offset;
|
||||
|
||||
NewPosition = std::min<int64>(std::max<int64>(NewPosition, 0), mEnd - mStart);
|
||||
mPtr = mStart + NewPosition;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,174 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2014 Moritz Bunkus. All rights reserved.
|
||||
**
|
||||
** This file is part of libebml.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.matroska.org/license/lgpl/ for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id$
|
||||
\author Moritz Bunkus <moritz@bunkus.org>
|
||||
*/
|
||||
|
||||
#include <cstring>
|
||||
|
||||
#include "ebml/EbmlBinary.h"
|
||||
#include "ebml/MemReadIOCallback.h"
|
||||
#include "ebml/SafeReadIOCallback.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
SafeReadIOCallback::EndOfStreamX::EndOfStreamX(size_t MissingBytes)
|
||||
: mMissingBytes(MissingBytes)
|
||||
{
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------------
|
||||
|
||||
SafeReadIOCallback::SafeReadIOCallback(IOCallback *IO,
|
||||
bool DeleteIO) {
|
||||
Init(IO, DeleteIO);
|
||||
}
|
||||
|
||||
SafeReadIOCallback::SafeReadIOCallback(void const *Mem,
|
||||
size_t Size) {
|
||||
Init(new MemReadIOCallback(Mem, Size), true);
|
||||
}
|
||||
|
||||
SafeReadIOCallback::SafeReadIOCallback(EbmlBinary const &Binary) {
|
||||
Init(new MemReadIOCallback(Binary), true);
|
||||
}
|
||||
|
||||
SafeReadIOCallback::~SafeReadIOCallback() {
|
||||
if (mDeleteIO)
|
||||
delete mIO;
|
||||
}
|
||||
|
||||
void
|
||||
SafeReadIOCallback::Init(IOCallback *IO,
|
||||
bool DeleteIO) {
|
||||
mIO = IO;
|
||||
mDeleteIO = DeleteIO;
|
||||
int64 PrevPosition = IO->getFilePointer();
|
||||
IO->setFilePointer(0, seek_end);
|
||||
mSize = IO->getFilePointer();
|
||||
IO->setFilePointer(PrevPosition);
|
||||
}
|
||||
|
||||
size_t
|
||||
SafeReadIOCallback::GetPosition()
|
||||
const {
|
||||
return mIO->getFilePointer();
|
||||
}
|
||||
|
||||
size_t
|
||||
SafeReadIOCallback::GetSize()
|
||||
const {
|
||||
return mSize;
|
||||
}
|
||||
|
||||
size_t
|
||||
SafeReadIOCallback::GetRemainingBytes()
|
||||
const {
|
||||
return GetSize() - GetPosition();
|
||||
}
|
||||
|
||||
bool
|
||||
SafeReadIOCallback::IsEmpty()
|
||||
const {
|
||||
return !GetRemainingBytes();
|
||||
}
|
||||
|
||||
uint64
|
||||
SafeReadIOCallback::GetUIntBE(size_t NumBytes) {
|
||||
uint8 Buffer[8];
|
||||
|
||||
NumBytes = std::min<size_t>(std::max<size_t>(1, NumBytes), 8);
|
||||
uint64 Value = 0;
|
||||
uint8* Ptr = &Buffer[0];
|
||||
|
||||
Read(Buffer, NumBytes);
|
||||
|
||||
for (size_t i = 0; NumBytes > i; ++i, ++Ptr)
|
||||
Value = (Value << 8) + *Ptr;
|
||||
|
||||
return Value;
|
||||
}
|
||||
|
||||
uint8
|
||||
SafeReadIOCallback::GetUInt8() {
|
||||
return GetUIntBE(1);
|
||||
}
|
||||
|
||||
uint16
|
||||
SafeReadIOCallback::GetUInt16BE() {
|
||||
return GetUIntBE(2);
|
||||
}
|
||||
|
||||
uint32
|
||||
SafeReadIOCallback::GetUInt24BE() {
|
||||
return GetUIntBE(3);
|
||||
}
|
||||
|
||||
uint32
|
||||
SafeReadIOCallback::GetUInt32BE() {
|
||||
return GetUIntBE(4);
|
||||
}
|
||||
|
||||
uint64
|
||||
SafeReadIOCallback::GetUInt64BE() {
|
||||
return GetUIntBE(8);
|
||||
}
|
||||
|
||||
void
|
||||
SafeReadIOCallback::Skip(size_t Count) {
|
||||
int64 PrevPosition = mIO->getFilePointer();
|
||||
int64 ExpectedPosition = PrevPosition + Count;
|
||||
mIO->setFilePointer(Count, seek_current);
|
||||
int64 ActualPosition = mIO->getFilePointer();
|
||||
|
||||
if (ActualPosition != ExpectedPosition)
|
||||
throw SafeReadIOCallback::EndOfStreamX(ExpectedPosition - ActualPosition);
|
||||
}
|
||||
|
||||
void
|
||||
SafeReadIOCallback::Seek(size_t Offset) {
|
||||
mIO->setFilePointer(Offset);
|
||||
uint64 ActualPosition = mIO->getFilePointer();
|
||||
if (ActualPosition != Offset)
|
||||
throw EndOfStreamX(ActualPosition - Offset);
|
||||
}
|
||||
|
||||
void
|
||||
SafeReadIOCallback::Read(void *Dst,
|
||||
size_t Count) {
|
||||
uint64 NumRead = mIO->read(Dst, Count);
|
||||
if (NumRead != Count)
|
||||
throw SafeReadIOCallback::EndOfStreamX(Count - NumRead);
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,193 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2004 Ingo Ralf Blum. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: StdIOCallback.cpp 1298 2008-02-21 22:14:18Z mosu $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Moritz Bunkus <moritz @ bunkus.org>
|
||||
*/
|
||||
|
||||
#include <cassert>
|
||||
#include <climits>
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
#include <sstream>
|
||||
#endif // GCC2
|
||||
|
||||
#include "ebml/StdIOCallback.h"
|
||||
#include "ebml/Debug.h"
|
||||
#include "ebml/EbmlConfig.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
CRTError::CRTError(int nError, const std::string & Description)
|
||||
:std::runtime_error(Description+": "+strerror(nError))
|
||||
,Error(nError)
|
||||
{
|
||||
}
|
||||
|
||||
CRTError::CRTError(const std::string & Description,int nError)
|
||||
:std::runtime_error(Description+": "+strerror(nError))
|
||||
,Error(nError)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
StdIOCallback::StdIOCallback(const char*Path, const open_mode aMode)
|
||||
{
|
||||
assert(Path!=0);
|
||||
|
||||
const char *Mode;
|
||||
switch (aMode) {
|
||||
case MODE_READ:
|
||||
Mode = "rb";
|
||||
break;
|
||||
case MODE_SAFE:
|
||||
Mode = "rb+";
|
||||
break;
|
||||
case MODE_WRITE:
|
||||
Mode = "wb";
|
||||
break;
|
||||
case MODE_CREATE:
|
||||
Mode = "wb+";
|
||||
break;
|
||||
default:
|
||||
throw 0;
|
||||
}
|
||||
|
||||
File=fopen(Path,Mode);
|
||||
if(File==0) {
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
stringstream Msg;
|
||||
Msg<<"Can't open stdio file \""<<Path<<"\" in mode \""<<Mode<<"\"";
|
||||
throw CRTError(Msg.str());
|
||||
#endif // GCC2
|
||||
}
|
||||
mCurrentPosition = 0;
|
||||
}
|
||||
|
||||
|
||||
StdIOCallback::~StdIOCallback()throw()
|
||||
{
|
||||
close();
|
||||
}
|
||||
|
||||
|
||||
|
||||
uint32 StdIOCallback::read(void*Buffer,size_t Size)
|
||||
{
|
||||
assert(File!=0);
|
||||
|
||||
size_t result = fread(Buffer, 1, Size, File);
|
||||
mCurrentPosition += result;
|
||||
return result;
|
||||
}
|
||||
|
||||
void StdIOCallback::setFilePointer(int64 Offset,seek_mode Mode)
|
||||
{
|
||||
assert(File!=0);
|
||||
|
||||
// There is a numeric cast in the boost library, which would be quite nice for this checking
|
||||
/*
|
||||
SL : replaced because unknown class in cygwin
|
||||
assert(Offset <= numeric_limits<long>::max());
|
||||
assert(Offset >= numeric_limits<long>::min());
|
||||
*/
|
||||
|
||||
assert(Offset <= LONG_MAX);
|
||||
assert(Offset >= LONG_MIN);
|
||||
|
||||
assert(Mode==SEEK_CUR||Mode==SEEK_END||Mode==SEEK_SET);
|
||||
|
||||
if(fseek(File,Offset,Mode)!=0) {
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
ostringstream Msg;
|
||||
Msg<<"Failed to seek file "<<File<<" to offset "<<(unsigned long)Offset<<" in mode "<<Mode;
|
||||
throw CRTError(Msg.str());
|
||||
#endif // GCC2
|
||||
mCurrentPosition = ftell(File);
|
||||
} else {
|
||||
switch ( Mode ) {
|
||||
case SEEK_CUR:
|
||||
mCurrentPosition += Offset;
|
||||
break;
|
||||
case SEEK_END:
|
||||
mCurrentPosition = ftell(File);
|
||||
break;
|
||||
case SEEK_SET:
|
||||
mCurrentPosition = Offset;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
size_t StdIOCallback::write(const void*Buffer,size_t Size)
|
||||
{
|
||||
assert(File!=0);
|
||||
uint32 Result = fwrite(Buffer,1,Size,File);
|
||||
mCurrentPosition += Result;
|
||||
return Result;
|
||||
}
|
||||
|
||||
uint64 StdIOCallback::getFilePointer()
|
||||
{
|
||||
assert(File!=0);
|
||||
|
||||
#if 0
|
||||
long Result=ftell(File);
|
||||
if(Result<0) {
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
stringstream Msg;
|
||||
Msg<<"Can't tell the current file pointer position for "<<File;
|
||||
throw CRTError(Msg.str());
|
||||
#endif // GCC2
|
||||
}
|
||||
#endif
|
||||
|
||||
return mCurrentPosition;
|
||||
}
|
||||
|
||||
void StdIOCallback::close()
|
||||
{
|
||||
if(File==0)
|
||||
return;
|
||||
|
||||
if(fclose(File)!=0) {
|
||||
#if !defined(__GNUC__) || (__GNUC__ > 2)
|
||||
stringstream Msg;
|
||||
Msg<<"Can't close file "<<File;
|
||||
throw CRTError(Msg.str());
|
||||
#endif // GCC2
|
||||
}
|
||||
|
||||
File=0;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,276 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2003 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: WinIOCallback.cpp 1092 2005-03-16 13:01:15Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
\author Cyrius <suiryc @ users.sf.net>
|
||||
*/
|
||||
|
||||
#include <cassert>
|
||||
|
||||
#include "WinIOCallback.h"
|
||||
|
||||
#include "ebml/Debug.h"
|
||||
|
||||
#ifndef INVALID_SET_FILE_POINTER // found in newer platform SDKs
|
||||
#define INVALID_SET_FILE_POINTER ((DWORD)-1)
|
||||
#endif // INVALID_SET_FILE_POINTER
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
WinIOCallback::WinIOCallback(const char* Path, const open_mode aMode, DWORD dwFlags)
|
||||
:mFile(NULL), mOk(false)
|
||||
{
|
||||
mOk = open(Path, aMode, dwFlags);
|
||||
}
|
||||
|
||||
WinIOCallback::WinIOCallback(const wchar_t* Path, const open_mode aMode, DWORD dwFlags)
|
||||
:mFile(NULL), mOk(false)
|
||||
{
|
||||
mOk = open(Path, aMode, dwFlags);
|
||||
}
|
||||
|
||||
WinIOCallback::~WinIOCallback()
|
||||
{
|
||||
close();
|
||||
}
|
||||
|
||||
bool WinIOCallback::open(const char* Path, const open_mode aMode, DWORD dwFlags)
|
||||
{
|
||||
assert(Path!=0);
|
||||
|
||||
DWORD AccessMode, ShareMode, Disposition;
|
||||
|
||||
switch (aMode) {
|
||||
case MODE_READ:
|
||||
AccessMode = GENERIC_READ;
|
||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||
Disposition = OPEN_EXISTING;
|
||||
break;
|
||||
case MODE_WRITE:
|
||||
AccessMode = GENERIC_WRITE;
|
||||
ShareMode = 0;
|
||||
Disposition = OPEN_ALWAYS;
|
||||
break;
|
||||
case MODE_SAFE:
|
||||
AccessMode = GENERIC_WRITE|GENERIC_READ;
|
||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||
Disposition = OPEN_ALWAYS;
|
||||
break;
|
||||
case MODE_CREATE:
|
||||
AccessMode = GENERIC_WRITE;
|
||||
ShareMode = 0;
|
||||
Disposition = CREATE_ALWAYS;
|
||||
break;
|
||||
default:
|
||||
assert(false);
|
||||
}
|
||||
|
||||
mFile = CreateFileA(Path, AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
||||
if ((mFile == INVALID_HANDLE_VALUE) || ((long)mFile == 0xffffffff)) {
|
||||
//File was not opened
|
||||
char err_msg[256];
|
||||
DWORD error_code = GetLastError();
|
||||
// An error message about the file already existing is not really an error message :P
|
||||
if (error_code != ERROR_ALREADY_EXISTS) {
|
||||
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, 0, error_code, 0, err_msg, 255, NULL);
|
||||
EBML_TRACE("Failed to open file \"%hs\" in mode %d.", Path, aMode);
|
||||
|
||||
mLastErrorStr = err_msg;
|
||||
return mOk = false;
|
||||
}
|
||||
}
|
||||
mCurrentPosition = 0;
|
||||
|
||||
EBML_TRACE("Successfully opened file \"%hs\" in mode %d. The handle is %p\n", Path, aMode, mFile);
|
||||
|
||||
return mOk = true;
|
||||
};
|
||||
|
||||
bool WinIOCallback::open(const wchar_t* Path, const open_mode aMode, DWORD dwFlags)
|
||||
{
|
||||
assert(Path!=0);
|
||||
|
||||
DWORD AccessMode, ShareMode, Disposition;
|
||||
|
||||
switch (aMode) {
|
||||
case MODE_READ:
|
||||
AccessMode = GENERIC_READ;
|
||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||
Disposition = OPEN_EXISTING;
|
||||
break;
|
||||
case MODE_WRITE:
|
||||
AccessMode = GENERIC_WRITE;
|
||||
ShareMode = 0;
|
||||
Disposition = OPEN_ALWAYS;
|
||||
break;
|
||||
case MODE_SAFE:
|
||||
AccessMode = GENERIC_WRITE|GENERIC_READ;
|
||||
ShareMode = FILE_SHARE_READ|FILE_SHARE_WRITE;
|
||||
Disposition = OPEN_ALWAYS;
|
||||
break;
|
||||
case MODE_CREATE:
|
||||
AccessMode = GENERIC_WRITE;
|
||||
ShareMode = 0;
|
||||
Disposition = CREATE_ALWAYS;
|
||||
break;
|
||||
default:
|
||||
assert(false);
|
||||
}
|
||||
|
||||
if ((LONG)GetVersion() >= 0) {
|
||||
mFile = CreateFileW(Path, AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
||||
} else {
|
||||
int errCode;
|
||||
int pathSize = wcslen(Path);
|
||||
unsigned int bufferSize = pathSize + sizeof(wchar_t) * 2;
|
||||
std::string PathA;
|
||||
PathA.resize(bufferSize);
|
||||
errCode = WideCharToMultiByte(CP_ACP, 0, Path, pathSize, (char *)PathA.c_str(), bufferSize, NULL, NULL);
|
||||
if (errCode == 0)
|
||||
errCode = GetLastError();
|
||||
#ifdef _DEBUG
|
||||
if (errCode == ERROR_INSUFFICIENT_BUFFER) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INSUFFICIENT_BUFFER"));
|
||||
if (errCode == ERROR_INVALID_FLAGS) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INVALID_FLAGS"));
|
||||
if (errCode == ERROR_INVALID_PARAMETER) OutputDebugString(TEXT("WinIOCallback::WideCharToMultiByte::ERROR_INVALID_PARAMETER"));
|
||||
#endif
|
||||
while (errCode == ERROR_INSUFFICIENT_BUFFER) {
|
||||
// Increase the buffer size
|
||||
bufferSize += MAX_PATH;
|
||||
PathA.resize(bufferSize);
|
||||
errCode = WideCharToMultiByte(CP_ACP, WC_SEPCHARS, Path, pathSize, (char *)PathA.c_str(), bufferSize, NULL, NULL);
|
||||
if (errCode == 0)
|
||||
errCode = GetLastError();
|
||||
}
|
||||
if (errCode != 0) {
|
||||
mFile = CreateFileA(PathA.c_str(), AccessMode, ShareMode, NULL, Disposition, dwFlags, NULL);
|
||||
} else {
|
||||
mLastErrorStr = "Couldn't convert Unicode filename to ANSI.";
|
||||
return mOk = false;
|
||||
}
|
||||
}
|
||||
if ((mFile == INVALID_HANDLE_VALUE) || ((long)mFile == 0xffffffff)) {
|
||||
//File was not opened
|
||||
char err_msg[256];
|
||||
DWORD error_code = GetLastError();
|
||||
// An error message about the file already existing is not really an error message :P
|
||||
if (error_code != ERROR_ALREADY_EXISTS) {
|
||||
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, 0, error_code, 0, err_msg, 255, NULL);
|
||||
EBML_TRACE("Failed to open file \"%S\" in mode %d.", Path, aMode);
|
||||
mLastErrorStr = err_msg;
|
||||
return mOk = false;
|
||||
}
|
||||
}
|
||||
mCurrentPosition = 0;
|
||||
|
||||
EBML_TRACE("Successfully opened file \"%S\" in mode %d. The handle is %p\n", Path, aMode, mFile);
|
||||
return mOk = true;
|
||||
}
|
||||
|
||||
void WinIOCallback::close()
|
||||
{
|
||||
if (mFile) {
|
||||
CloseHandle(mFile);
|
||||
mFile = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
uint64 WinIOCallback::getFilePointer()
|
||||
{
|
||||
if (!mFile) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return mCurrentPosition;
|
||||
#if 0
|
||||
LONG High = 0;
|
||||
DWORD Low = SetFilePointer(mFile, 0, &High, FILE_CURRENT);
|
||||
if ( (Low==INVALID_SET_FILE_POINTER) && (GetLastError()!=NO_ERROR) )
|
||||
return static_cast<uint64>(-1);
|
||||
return ((uint64(High)<<32) | Low);
|
||||
#endif
|
||||
}
|
||||
|
||||
void WinIOCallback::setFilePointer(int64 Offset, seek_mode Mode)
|
||||
{
|
||||
DWORD Method;
|
||||
switch(Mode) {
|
||||
case seek_beginning:
|
||||
Method=FILE_BEGIN;
|
||||
break;
|
||||
case seek_current:
|
||||
Method=FILE_CURRENT;
|
||||
break;
|
||||
case seek_end:
|
||||
Method=FILE_END;
|
||||
break;
|
||||
default:
|
||||
assert(false);
|
||||
break;
|
||||
}
|
||||
|
||||
LONG High = LONG(Offset>>32);
|
||||
mCurrentPosition = SetFilePointer(mFile, LONG(Offset & 0xffffffff), &High, Method);
|
||||
if ( mCurrentPosition == INVALID_SET_FILE_POINTER ) {
|
||||
High = 0;
|
||||
DWORD Low = SetFilePointer(mFile, 0, &High, FILE_CURRENT);
|
||||
mCurrentPosition = ((uint64(High)<<32) | Low);
|
||||
} else {
|
||||
mCurrentPosition |= uint64(High)<<32;
|
||||
}
|
||||
}
|
||||
|
||||
uint32 WinIOCallback::read(void*Buffer,size_t Size)
|
||||
{
|
||||
DWORD BytesRead;
|
||||
if (!ReadFile(mFile, Buffer, Size, &BytesRead, NULL)) {
|
||||
return 0;
|
||||
}
|
||||
mCurrentPosition += BytesRead;
|
||||
return BytesRead;
|
||||
}
|
||||
|
||||
size_t WinIOCallback::write(const void*Buffer,size_t Size)
|
||||
{
|
||||
DWORD BytesWriten;
|
||||
if (!WriteFile(mFile, Buffer, Size, &BytesWriten, NULL)) {
|
||||
return 0;
|
||||
}
|
||||
mCurrentPosition += BytesWriten;
|
||||
return BytesWriten;
|
||||
}
|
||||
|
||||
bool WinIOCallback::SetEOF()
|
||||
{
|
||||
return SetEndOfFile(mFile) != 0;
|
||||
}
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
@ -1,75 +0,0 @@
|
||||
/****************************************************************************
|
||||
** libebml : parse EBML files, see http://embl.sourceforge.net/
|
||||
**
|
||||
** <file/class description>
|
||||
**
|
||||
** Copyright (C) 2002-2003 Steve Lhomme. All rights reserved.
|
||||
**
|
||||
** This library is free software; you can redistribute it and/or
|
||||
** modify it under the terms of the GNU Lesser General Public
|
||||
** License as published by the Free Software Foundation; either
|
||||
** version 2.1 of the License, or (at your option) any later version.
|
||||
**
|
||||
** This library is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
** Lesser General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU Lesser General Public
|
||||
** License along with this library; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** See http://www.gnu.org/licenses/lgpl-2.1.html for LGPL licensing information.
|
||||
**
|
||||
** Contact license@matroska.org if any conditions of this licensing are
|
||||
** not clear to you.
|
||||
**
|
||||
**********************************************************************/
|
||||
/*!
|
||||
\file
|
||||
\version \$Id: WinIOCallback.h 1090 2005-03-16 12:47:59Z robux4 $
|
||||
\author Steve Lhomme <robux4 @ users.sf.net>
|
||||
\author Jory Stone <jcsston @ toughguy.net>
|
||||
\author Cyrius <suiryc @ users.sf.net>
|
||||
*/
|
||||
|
||||
#ifndef LIBEBML_WINIOCALLBACK_H
|
||||
#define LIBEBML_WINIOCALLBACK_H
|
||||
|
||||
#include <windows.h>
|
||||
#include <stdexcept>
|
||||
#include <string>
|
||||
#include "ebml/IOCallback.h"
|
||||
|
||||
START_LIBEBML_NAMESPACE
|
||||
|
||||
class WinIOCallback: public IOCallback
|
||||
{
|
||||
public:
|
||||
WinIOCallback(const wchar_t* Path, const open_mode aMode, DWORD dwFlags=0);
|
||||
WinIOCallback(const char* Path, const open_mode aMode, DWORD dwFlags=0);
|
||||
virtual ~WinIOCallback();
|
||||
|
||||
bool open(const wchar_t* Path, const open_mode Mode, DWORD dwFlags=0);
|
||||
bool open(const char* Path, const open_mode Mode, DWORD dwFlags=0);
|
||||
|
||||
virtual uint32 read(void*Buffer,size_t Size);
|
||||
virtual size_t write(const void*Buffer,size_t Size);
|
||||
virtual void setFilePointer(int64 Offset,seek_mode Mode=seek_beginning);
|
||||
virtual uint64 getFilePointer();
|
||||
virtual void close();
|
||||
|
||||
bool IsOk() { return mOk; };
|
||||
const std::string &GetLastErrorStr() { return mLastErrorStr; };
|
||||
bool SetEOF();
|
||||
protected:
|
||||
bool mOk;
|
||||
std::string mLastErrorStr;
|
||||
uint64 mCurrentPosition;
|
||||
|
||||
HANDLE mFile;
|
||||
};
|
||||
|
||||
END_LIBEBML_NAMESPACE
|
||||
|
||||
#endif // LIBEBML_WINIOCALLBACK_H
|
228
stylesheets/print.css
Normal file
228
stylesheets/print.css
Normal file
@ -0,0 +1,228 @@
|
||||
html, body, div, span, applet, object, iframe,
|
||||
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
|
||||
a, abbr, acronym, address, big, cite, code,
|
||||
del, dfn, em, img, ins, kbd, q, s, samp,
|
||||
small, strike, strong, sub, sup, tt, var,
|
||||
b, u, i, center,
|
||||
dl, dt, dd, ol, ul, li,
|
||||
fieldset, form, label, legend,
|
||||
table, caption, tbody, tfoot, thead, tr, th, td,
|
||||
article, aside, canvas, details, embed,
|
||||
figure, figcaption, footer, header, hgroup,
|
||||
menu, nav, output, ruby, section, summary,
|
||||
time, mark, audio, video {
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
font: inherit;
|
||||
font-size: 100%;
|
||||
vertical-align: baseline;
|
||||
border: 0;
|
||||
}
|
||||
/* HTML5 display-role reset for older browsers */
|
||||
article, aside, details, figcaption, figure,
|
||||
footer, header, hgroup, menu, nav, section {
|
||||
display: block;
|
||||
}
|
||||
body {
|
||||
line-height: 1;
|
||||
}
|
||||
ol, ul {
|
||||
list-style: none;
|
||||
}
|
||||
blockquote, q {
|
||||
quotes: none;
|
||||
}
|
||||
blockquote:before, blockquote:after,
|
||||
q:before, q:after {
|
||||
content: '';
|
||||
content: none;
|
||||
}
|
||||
table {
|
||||
border-spacing: 0;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
body {
|
||||
font-family: 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 13px;
|
||||
line-height: 1.5;
|
||||
color: #000;
|
||||
}
|
||||
|
||||
a {
|
||||
font-weight: bold;
|
||||
color: #d5000d;
|
||||
}
|
||||
|
||||
header {
|
||||
padding-top: 35px;
|
||||
padding-bottom: 10px;
|
||||
}
|
||||
|
||||
header h1 {
|
||||
font-size: 48px;
|
||||
font-weight: bold;
|
||||
line-height: 1.2;
|
||||
color: #303030;
|
||||
letter-spacing: -1px;
|
||||
}
|
||||
|
||||
header h2 {
|
||||
font-size: 24px;
|
||||
font-weight: normal;
|
||||
line-height: 1.3;
|
||||
color: #aaa;
|
||||
letter-spacing: -1px;
|
||||
}
|
||||
#downloads {
|
||||
display: none;
|
||||
}
|
||||
#main_content {
|
||||
padding-top: 20px;
|
||||
}
|
||||
|
||||
code, pre {
|
||||
margin-bottom: 30px;
|
||||
font-family: Monaco, "Bitstream Vera Sans Mono", "Lucida Console", Terminal;
|
||||
font-size: 12px;
|
||||
color: #222;
|
||||
}
|
||||
|
||||
code {
|
||||
padding: 0 3px;
|
||||
}
|
||||
|
||||
pre {
|
||||
padding: 20px;
|
||||
overflow: auto;
|
||||
border: solid 1px #ddd;
|
||||
}
|
||||
pre code {
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
ul, ol, dl {
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
|
||||
|
||||
/* COMMON STYLES */
|
||||
|
||||
table {
|
||||
width: 100%;
|
||||
border: 1px solid #ebebeb;
|
||||
}
|
||||
|
||||
th {
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
td {
|
||||
font-weight: 300;
|
||||
text-align: center;
|
||||
border: 1px solid #ebebeb;
|
||||
}
|
||||
|
||||
form {
|
||||
padding: 20px;
|
||||
background: #f2f2f2;
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* GENERAL ELEMENT TYPE STYLES */
|
||||
|
||||
h1 {
|
||||
font-size: 2.8em;
|
||||
}
|
||||
|
||||
h2 {
|
||||
margin-bottom: 8px;
|
||||
font-size: 22px;
|
||||
font-weight: bold;
|
||||
color: #303030;
|
||||
}
|
||||
|
||||
h3 {
|
||||
margin-bottom: 8px;
|
||||
font-size: 18px;
|
||||
font-weight: bold;
|
||||
color: #d5000d;
|
||||
}
|
||||
|
||||
h4 {
|
||||
font-size: 16px;
|
||||
font-weight: bold;
|
||||
color: #303030;
|
||||
}
|
||||
|
||||
h5 {
|
||||
font-size: 1em;
|
||||
color: #303030;
|
||||
}
|
||||
|
||||
h6 {
|
||||
font-size: .8em;
|
||||
color: #303030;
|
||||
}
|
||||
|
||||
p {
|
||||
margin-bottom: 20px;
|
||||
font-weight: 300;
|
||||
}
|
||||
|
||||
a {
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
p a {
|
||||
font-weight: 400;
|
||||
}
|
||||
|
||||
blockquote {
|
||||
padding: 0 0 0 30px;
|
||||
margin-bottom: 20px;
|
||||
font-size: 1.6em;
|
||||
border-left: 10px solid #e9e9e9;
|
||||
}
|
||||
|
||||
ul li {
|
||||
padding-left: 20px;
|
||||
list-style-position: inside;
|
||||
list-style: disc;
|
||||
}
|
||||
|
||||
ol li {
|
||||
padding-left: 3px;
|
||||
list-style-position: inside;
|
||||
list-style: decimal;
|
||||
}
|
||||
|
||||
dl dd {
|
||||
font-style: italic;
|
||||
font-weight: 100;
|
||||
}
|
||||
|
||||
footer {
|
||||
padding-top: 20px;
|
||||
padding-bottom: 30px;
|
||||
margin-top: 40px;
|
||||
font-size: 13px;
|
||||
color: #aaa;
|
||||
}
|
||||
|
||||
footer a {
|
||||
color: #666;
|
||||
}
|
||||
|
||||
/* MISC */
|
||||
.clearfix:after {
|
||||
display: block;
|
||||
height: 0;
|
||||
clear: both;
|
||||
visibility: hidden;
|
||||
content: '.';
|
||||
}
|
||||
|
||||
.clearfix {display: inline-block;}
|
||||
* html .clearfix {height: 1%;}
|
||||
.clearfix {display: block;}
|
69
stylesheets/pygment_trac.css
Normal file
69
stylesheets/pygment_trac.css
Normal file
@ -0,0 +1,69 @@
|
||||
.highlight { background: #ffffff; }
|
||||
.highlight .c { color: #999988; font-style: italic } /* Comment */
|
||||
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
|
||||
.highlight .k { font-weight: bold } /* Keyword */
|
||||
.highlight .o { font-weight: bold } /* Operator */
|
||||
.highlight .cm { color: #999988; font-style: italic } /* Comment.Multiline */
|
||||
.highlight .cp { color: #999999; font-weight: bold } /* Comment.Preproc */
|
||||
.highlight .c1 { color: #999988; font-style: italic } /* Comment.Single */
|
||||
.highlight .cs { color: #999999; font-weight: bold; font-style: italic } /* Comment.Special */
|
||||
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
|
||||
.highlight .gd .x { color: #000000; background-color: #ffaaaa } /* Generic.Deleted.Specific */
|
||||
.highlight .ge { font-style: italic } /* Generic.Emph */
|
||||
.highlight .gr { color: #aa0000 } /* Generic.Error */
|
||||
.highlight .gh { color: #999999 } /* Generic.Heading */
|
||||
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
|
||||
.highlight .gi .x { color: #000000; background-color: #aaffaa } /* Generic.Inserted.Specific */
|
||||
.highlight .go { color: #888888 } /* Generic.Output */
|
||||
.highlight .gp { color: #555555 } /* Generic.Prompt */
|
||||
.highlight .gs { font-weight: bold } /* Generic.Strong */
|
||||
.highlight .gu { color: #800080; font-weight: bold; } /* Generic.Subheading */
|
||||
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
|
||||
.highlight .kc { font-weight: bold } /* Keyword.Constant */
|
||||
.highlight .kd { font-weight: bold } /* Keyword.Declaration */
|
||||
.highlight .kn { font-weight: bold } /* Keyword.Namespace */
|
||||
.highlight .kp { font-weight: bold } /* Keyword.Pseudo */
|
||||
.highlight .kr { font-weight: bold } /* Keyword.Reserved */
|
||||
.highlight .kt { color: #445588; font-weight: bold } /* Keyword.Type */
|
||||
.highlight .m { color: #009999 } /* Literal.Number */
|
||||
.highlight .s { color: #d14 } /* Literal.String */
|
||||
.highlight .na { color: #008080 } /* Name.Attribute */
|
||||
.highlight .nb { color: #0086B3 } /* Name.Builtin */
|
||||
.highlight .nc { color: #445588; font-weight: bold } /* Name.Class */
|
||||
.highlight .no { color: #008080 } /* Name.Constant */
|
||||
.highlight .ni { color: #800080 } /* Name.Entity */
|
||||
.highlight .ne { color: #990000; font-weight: bold } /* Name.Exception */
|
||||
.highlight .nf { color: #990000; font-weight: bold } /* Name.Function */
|
||||
.highlight .nn { color: #555555 } /* Name.Namespace */
|
||||
.highlight .nt { color: #000080 } /* Name.Tag */
|
||||
.highlight .nv { color: #008080 } /* Name.Variable */
|
||||
.highlight .ow { font-weight: bold } /* Operator.Word */
|
||||
.highlight .w { color: #bbbbbb } /* Text.Whitespace */
|
||||
.highlight .mf { color: #009999 } /* Literal.Number.Float */
|
||||
.highlight .mh { color: #009999 } /* Literal.Number.Hex */
|
||||
.highlight .mi { color: #009999 } /* Literal.Number.Integer */
|
||||
.highlight .mo { color: #009999 } /* Literal.Number.Oct */
|
||||
.highlight .sb { color: #d14 } /* Literal.String.Backtick */
|
||||
.highlight .sc { color: #d14 } /* Literal.String.Char */
|
||||
.highlight .sd { color: #d14 } /* Literal.String.Doc */
|
||||
.highlight .s2 { color: #d14 } /* Literal.String.Double */
|
||||
.highlight .se { color: #d14 } /* Literal.String.Escape */
|
||||
.highlight .sh { color: #d14 } /* Literal.String.Heredoc */
|
||||
.highlight .si { color: #d14 } /* Literal.String.Interpol */
|
||||
.highlight .sx { color: #d14 } /* Literal.String.Other */
|
||||
.highlight .sr { color: #009926 } /* Literal.String.Regex */
|
||||
.highlight .s1 { color: #d14 } /* Literal.String.Single */
|
||||
.highlight .ss { color: #990073 } /* Literal.String.Symbol */
|
||||
.highlight .bp { color: #999999 } /* Name.Builtin.Pseudo */
|
||||
.highlight .vc { color: #008080 } /* Name.Variable.Class */
|
||||
.highlight .vg { color: #008080 } /* Name.Variable.Global */
|
||||
.highlight .vi { color: #008080 } /* Name.Variable.Instance */
|
||||
.highlight .il { color: #009999 } /* Literal.Number.Integer.Long */
|
||||
|
||||
.type-csharp .highlight .k { color: #0000FF }
|
||||
.type-csharp .highlight .kt { color: #0000FF }
|
||||
.type-csharp .highlight .nf { color: #000000; font-weight: normal }
|
||||
.type-csharp .highlight .nc { color: #2B91AF }
|
||||
.type-csharp .highlight .nn { color: #000000 }
|
||||
.type-csharp .highlight .s { color: #A31515 }
|
||||
.type-csharp .highlight .sc { color: #A31515 }
|
898
stylesheets/stylesheet.css
Normal file
898
stylesheets/stylesheet.css
Normal file
@ -0,0 +1,898 @@
|
||||
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
|
||||
|
||||
/**
|
||||
* 1. Set default font family to sans-serif.
|
||||
* 2. Prevent iOS text size adjust after orientation change, without disabling
|
||||
* user zoom.
|
||||
*/
|
||||
|
||||
html {
|
||||
font-family: sans-serif; /* 1 */
|
||||
-webkit-text-size-adjust: 100%; /* 2 */
|
||||
-ms-text-size-adjust: 100%; /* 2 */
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove default margin.
|
||||
*/
|
||||
|
||||
body {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
/* HTML5 display definitions
|
||||
========================================================================== */
|
||||
|
||||
/**
|
||||
* Correct `block` display not defined for any HTML5 element in IE 8/9.
|
||||
* Correct `block` display not defined for `details` or `summary` in IE 10/11
|
||||
* and Firefox.
|
||||
* Correct `block` display not defined for `main` in IE 11.
|
||||
*/
|
||||
|
||||
article,
|
||||
aside,
|
||||
details,
|
||||
figcaption,
|
||||
figure,
|
||||
footer,
|
||||
header,
|
||||
hgroup,
|
||||
main,
|
||||
menu,
|
||||
nav,
|
||||
section,
|
||||
summary {
|
||||
display: block;
|
||||
}
|
||||
|
||||
/**
|
||||
* 1. Correct `inline-block` display not defined in IE 8/9.
|
||||
* 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
|
||||
*/
|
||||
|
||||
audio,
|
||||
canvas,
|
||||
progress,
|
||||
video {
|
||||
display: inline-block; /* 1 */
|
||||
vertical-align: baseline; /* 2 */
|
||||
}
|
||||
|
||||
/**
|
||||
* Prevent modern browsers from displaying `audio` without controls.
|
||||
* Remove excess height in iOS 5 devices.
|
||||
*/
|
||||
|
||||
audio:not([controls]) {
|
||||
display: none;
|
||||
height: 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address `[hidden]` styling not present in IE 8/9/10.
|
||||
* Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
|
||||
*/
|
||||
|
||||
[hidden],
|
||||
template {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* Links
|
||||
========================================================================== */
|
||||
|
||||
/**
|
||||
* Remove the gray background color from active links in IE 10.
|
||||
*/
|
||||
|
||||
a {
|
||||
background-color: transparent;
|
||||
}
|
||||
|
||||
/**
|
||||
* Improve readability when focused and also mouse hovered in all browsers.
|
||||
*/
|
||||
|
||||
a:active,
|
||||
a:hover {
|
||||
outline: 0;
|
||||
}
|
||||
|
||||
/* Text-level semantics
|
||||
========================================================================== */
|
||||
|
||||
/**
|
||||
* Address styling not present in IE 8/9/10/11, Safari, and Chrome.
|
||||
*/
|
||||
|
||||
abbr[title] {
|
||||
border-bottom: 1px dotted;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
|
||||
*/
|
||||
|
||||
b,
|
||||
strong {
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address styling not present in Safari and Chrome.
|
||||
*/
|
||||
|
||||
dfn {
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address variable `h1` font-size and margin within `section` and `article`
|
||||
* contexts in Firefox 4+, Safari, and Chrome.
|
||||
*/
|
||||
|
||||
h1 {
|
||||
margin: 0.67em 0;
|
||||
font-size: 2em;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address styling not present in IE 8/9.
|
||||
*/
|
||||
|
||||
mark {
|
||||
color: #000;
|
||||
background: #ff0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address inconsistent and variable font size in all browsers.
|
||||
*/
|
||||
|
||||
small {
|
||||
font-size: 80%;
|
||||
}
|
||||
|
||||
/**
|
||||
* Prevent `sub` and `sup` affecting `line-height` in all browsers.
|
||||
*/
|
||||
|
||||
sub,
|
||||
sup {
|
||||
position: relative;
|
||||
font-size: 75%;
|
||||
line-height: 0;
|
||||
vertical-align: baseline;
|
||||
}
|
||||
|
||||
sup {
|
||||
top: -0.5em;
|
||||
}
|
||||
|
||||
sub {
|
||||
bottom: -0.25em;
|
||||
}
|
||||
|
||||
/* Embedded content
|
||||
========================================================================== */
|
||||
|
||||
/**
|
||||
* Remove border when inside `a` element in IE 8/9/10.
|
||||
*/
|
||||
|
||||
img {
|
||||
border: 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Correct overflow not hidden in IE 9/10/11.
|
||||
*/
|
||||
|
||||
svg:not(:root) {
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
/* Grouping content
|
||||
========================================================================== */
|
||||
|
||||
/**
|
||||
* Address margin not present in IE 8/9 and Safari.
|
||||
*/
|
||||
|
||||
figure {
|
||||
margin: 1em 40px;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address differences between Firefox and other browsers.
|
||||
*/
|
||||
|
||||
hr {
|
||||
height: 0;
|
||||
-moz-box-sizing: content-box;
|
||||
box-sizing: content-box;
|
||||
}
|
||||
|
||||
/**
|
||||
* Contain overflow in all browsers.
|
||||
*/
|
||||
|
||||
pre {
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address odd `em`-unit font size rendering in all browsers.
|
||||
*/
|
||||
|
||||
code,
|
||||
kbd,
|
||||
pre,
|
||||
samp {
|
||||
font-family: monospace, monospace;
|
||||
font-size: 1em;
|
||||
}
|
||||
|
||||
/* Forms
|
||||
========================================================================== */
|
||||
|
||||
/**
|
||||
* Known limitation: by default, Chrome and Safari on OS X allow very limited
|
||||
* styling of `select`, unless a `border` property is set.
|
||||
*/
|
||||
|
||||
/**
|
||||
* 1. Correct color not being inherited.
|
||||
* Known issue: affects color of disabled elements.
|
||||
* 2. Correct font properties not being inherited.
|
||||
* 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
|
||||
*/
|
||||
|
||||
button,
|
||||
input,
|
||||
optgroup,
|
||||
select,
|
||||
textarea {
|
||||
margin: 0; /* 3 */
|
||||
font: inherit; /* 2 */
|
||||
color: inherit; /* 1 */
|
||||
}
|
||||
|
||||
/**
|
||||
* Address `overflow` set to `hidden` in IE 8/9/10/11.
|
||||
*/
|
||||
|
||||
button {
|
||||
overflow: visible;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address inconsistent `text-transform` inheritance for `button` and `select`.
|
||||
* All other form control elements do not inherit `text-transform` values.
|
||||
* Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
|
||||
* Correct `select` style inheritance in Firefox.
|
||||
*/
|
||||
|
||||
button,
|
||||
select {
|
||||
text-transform: none;
|
||||
}
|
||||
|
||||
/**
|
||||
* 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
|
||||
* and `video` controls.
|
||||
* 2. Correct inability to style clickable `input` types in iOS.
|
||||
* 3. Improve usability and consistency of cursor style between image-type
|
||||
* `input` and others.
|
||||
*/
|
||||
|
||||
button,
|
||||
html input[type="button"], /* 1 */
|
||||
input[type="reset"],
|
||||
input[type="submit"] {
|
||||
-webkit-appearance: button; /* 2 */
|
||||
cursor: pointer; /* 3 */
|
||||
}
|
||||
|
||||
/**
|
||||
* Re-set default cursor for disabled elements.
|
||||
*/
|
||||
|
||||
button[disabled],
|
||||
html input[disabled] {
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove inner padding and border in Firefox 4+.
|
||||
*/
|
||||
|
||||
button::-moz-focus-inner,
|
||||
input::-moz-focus-inner {
|
||||
padding: 0;
|
||||
border: 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Address Firefox 4+ setting `line-height` on `input` using `!important` in
|
||||
* the UA stylesheet.
|
||||
*/
|
||||
|
||||
input {
|
||||
line-height: normal;
|
||||
}
|
||||
|
||||
/**
|
||||
* It's recommended that you don't attempt to style these elements.
|
||||
* Firefox's implementation doesn't respect box-sizing, padding, or width.
|
||||
*
|
||||
* 1. Address box sizing set to `content-box` in IE 8/9/10.
|
||||
* 2. Remove excess padding in IE 8/9/10.
|
||||
*/
|
||||
|
||||
input[type="checkbox"],
|
||||
input[type="radio"] {
|
||||
box-sizing: border-box; /* 1 */
|
||||
padding: 0; /* 2 */
|
||||
}
|
||||
|
||||
/**
|
||||
* Fix the cursor style for Chrome's increment/decrement buttons. For certain
|
||||
* `font-size` values of the `input`, it causes the cursor style of the
|
||||
* decrement button to change from `default` to `text`.
|
||||
*/
|
||||
|
||||
input[type="number"]::-webkit-inner-spin-button,
|
||||
input[type="number"]::-webkit-outer-spin-button {
|
||||
height: auto;
|
||||
}
|
||||
|
||||
/**
|
||||
* 1. Address `appearance` set to `searchfield` in Safari and Chrome.
|
||||
* 2. Address `box-sizing` set to `border-box` in Safari and Chrome
|
||||
* (include `-moz` to future-proof).
|
||||
*/
|
||||
|
||||
input[type="search"] {
|
||||
-webkit-box-sizing: content-box; /* 2 */
|
||||
-moz-box-sizing: content-box;
|
||||
box-sizing: content-box;
|
||||
-webkit-appearance: textfield; /* 1 */
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove inner padding and search cancel button in Safari and Chrome on OS X.
|
||||
* Safari (but not Chrome) clips the cancel button when the search input has
|
||||
* padding (and `textfield` appearance).
|
||||
*/
|
||||
|
||||
input[type="search"]::-webkit-search-cancel-button,
|
||||
input[type="search"]::-webkit-search-decoration {
|
||||
-webkit-appearance: none;
|
||||
}
|
||||
|
||||
/**
|
||||
* Define consistent border, margin, and padding.
|
||||
*/
|
||||
|
||||
fieldset {
|
||||
padding: 0.35em 0.625em 0.75em;
|
||||
margin: 0 2px;
|
||||
border: 1px solid #c0c0c0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 1. Correct `color` not being inherited in IE 8/9/10/11.
|
||||
* 2. Remove padding so people aren't caught out if they zero out fieldsets.
|
||||
*/
|
||||
|
||||
legend {
|
||||
padding: 0; /* 2 */
|
||||
border: 0; /* 1 */
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove default vertical scrollbar in IE 8/9/10/11.
|
||||
*/
|
||||
|
||||
textarea {
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
/**
|
||||
* Don't inherit the `font-weight` (applied by a rule above).
|
||||
* NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
|
||||
*/
|
||||
|
||||
optgroup {
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
/* Tables
|
||||
========================================================================== */
|
||||
|
||||
/**
|
||||
* Remove most spacing between table cells.
|
||||
*/
|
||||
|
||||
table {
|
||||
border-spacing: 0;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
td,
|
||||
th {
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
/* LAYOUT STYLES */
|
||||
body {
|
||||
font-family: 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 15px;
|
||||
font-weight: 400;
|
||||
line-height: 1.5;
|
||||
color: #666;
|
||||
background: #fafafa url(../images/body-bg.jpg) 0 0 repeat;
|
||||
}
|
||||
|
||||
p {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
a {
|
||||
color: #2879d0;
|
||||
}
|
||||
a:hover {
|
||||
color: #2268b2;
|
||||
}
|
||||
|
||||
header {
|
||||
padding-top: 40px;
|
||||
padding-bottom: 40px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
background: #2e7bcf url(../images/header-bg.jpg) 0 0 repeat-x;
|
||||
border-bottom: solid 1px #275da1;
|
||||
}
|
||||
|
||||
header h1 {
|
||||
width: 540px;
|
||||
margin-top: 0;
|
||||
margin-bottom: 0.2em;
|
||||
font-size: 72px;
|
||||
font-weight: normal;
|
||||
line-height: 1;
|
||||
color: #fff;
|
||||
letter-spacing: -1px;
|
||||
}
|
||||
|
||||
header h2 {
|
||||
width: 540px;
|
||||
margin-top: 0;
|
||||
margin-bottom: 0;
|
||||
font-size: 26px;
|
||||
font-weight: normal;
|
||||
line-height: 1.3;
|
||||
color: #9ddcff;
|
||||
letter-spacing: 0;
|
||||
}
|
||||
|
||||
.inner {
|
||||
position: relative;
|
||||
margin: 0 auto;
|
||||
padding-left: 50px;
|
||||
}
|
||||
|
||||
#content-wrapper {
|
||||
padding-top: 30px;
|
||||
border-top: solid 1px #fff;
|
||||
}
|
||||
|
||||
#main-content {
|
||||
float: left;
|
||||
width: 900px;
|
||||
}
|
||||
|
||||
#main-content img {
|
||||
max-width: 100%;
|
||||
}
|
||||
|
||||
aside#sidebar {
|
||||
float: right;
|
||||
width: 200px;
|
||||
min-height: 504px;
|
||||
padding-left: 20px;
|
||||
font-size: 12px;
|
||||
line-height: 1.3;
|
||||
background: transparent url(../images/sidebar-bg.jpg) 0 0 no-repeat;
|
||||
}
|
||||
|
||||
aside#sidebar p.repo-owner,
|
||||
aside#sidebar p.repo-owner a {
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
#downloads {
|
||||
margin-bottom: 40px;
|
||||
}
|
||||
|
||||
a.button {
|
||||
width: 134px;
|
||||
height: 58px;
|
||||
padding-top: 22px;
|
||||
padding-left: 68px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 23px;
|
||||
line-height: 1.2;
|
||||
color: #fff;
|
||||
}
|
||||
a.button small {
|
||||
display: block;
|
||||
font-size: 11px;
|
||||
}
|
||||
header a.button {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
background: transparent url(../images/github-button.png) 0 0 no-repeat;
|
||||
}
|
||||
aside a.button {
|
||||
display: block;
|
||||
width: 138px;
|
||||
padding-left: 64px;
|
||||
margin-bottom: 20px;
|
||||
font-size: 21px;
|
||||
background: transparent url(../images/download-button.png) 0 0 no-repeat;
|
||||
}
|
||||
|
||||
aside a.page-link {
|
||||
padding-top: 20px;
|
||||
padding-left: 20px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 23px;
|
||||
line-height: 1.2;
|
||||
}
|
||||
|
||||
code, pre {
|
||||
margin-bottom: 30px;
|
||||
font-family: Monaco, "Bitstream Vera Sans Mono", "Lucida Console", Terminal, monospace;
|
||||
font-size: 13px;
|
||||
color: #222;
|
||||
}
|
||||
|
||||
code {
|
||||
padding: 0 3px;
|
||||
background-color: #f2f8fc;
|
||||
border: solid 1px #dbe7f3;
|
||||
}
|
||||
|
||||
pre {
|
||||
padding: 20px;
|
||||
overflow: auto;
|
||||
text-shadow: none;
|
||||
background: #fff;
|
||||
border: solid 1px #f2f2f2;
|
||||
}
|
||||
pre code {
|
||||
padding: 0;
|
||||
color: #2879d0;
|
||||
background-color: #fff;
|
||||
border: none;
|
||||
}
|
||||
|
||||
ul, ol, dl {
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
|
||||
|
||||
/* COMMON STYLES */
|
||||
|
||||
hr {
|
||||
height: 0;
|
||||
margin-top: 1em;
|
||||
margin-bottom: 1em;
|
||||
border: 0;
|
||||
border-top: solid 1px #ddd;
|
||||
}
|
||||
|
||||
table {
|
||||
width: 100%;
|
||||
border: 1px solid #ebebeb;
|
||||
}
|
||||
|
||||
th {
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
td {
|
||||
font-weight: 300;
|
||||
text-align: center;
|
||||
border: 1px solid #ebebeb;
|
||||
}
|
||||
|
||||
form {
|
||||
padding: 20px;
|
||||
background: #f2f2f2;
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* GENERAL ELEMENT TYPE STYLES */
|
||||
|
||||
#main-content h1 {
|
||||
margin-top: 0;
|
||||
margin-bottom: 0;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 2.8em;
|
||||
font-weight: normal;
|
||||
color: #474747;
|
||||
text-indent: 6px;
|
||||
letter-spacing: -1px;
|
||||
}
|
||||
|
||||
#main-content h1:before {
|
||||
padding-right: 0.3em;
|
||||
margin-left: -0.9em;
|
||||
color: #9ddcff;
|
||||
content: "/";
|
||||
}
|
||||
|
||||
#main-content h2 {
|
||||
margin-bottom: 8px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 22px;
|
||||
font-weight: bold;
|
||||
color: #474747;
|
||||
text-indent: 4px;
|
||||
}
|
||||
#main-content h2:before {
|
||||
padding-right: 0.3em;
|
||||
margin-left: -1.5em;
|
||||
content: "//";
|
||||
color: #9ddcff;
|
||||
}
|
||||
|
||||
#main-content h3 {
|
||||
margin-top: 24px;
|
||||
margin-bottom: 8px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 18px;
|
||||
font-weight: bold;
|
||||
color: #474747;
|
||||
text-indent: 3px;
|
||||
}
|
||||
|
||||
#main-content h3:before {
|
||||
padding-right: 0.3em;
|
||||
margin-left: -2em;
|
||||
content: "///";
|
||||
color: #9ddcff;
|
||||
}
|
||||
|
||||
#main-content h4 {
|
||||
margin-bottom: 8px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 15px;
|
||||
font-weight: bold;
|
||||
color: #474747;
|
||||
text-indent: 3px;
|
||||
}
|
||||
|
||||
h4:before {
|
||||
padding-right: 0.3em;
|
||||
margin-left: -2.8em;
|
||||
content: "////";
|
||||
color: #9ddcff;
|
||||
}
|
||||
|
||||
#main-content h5 {
|
||||
margin-bottom: 8px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: 14px;
|
||||
color: #474747;
|
||||
text-indent: 3px;
|
||||
}
|
||||
h5:before {
|
||||
padding-right: 0.3em;
|
||||
margin-left: -3.2em;
|
||||
content: "/////";
|
||||
color: #9ddcff;
|
||||
}
|
||||
|
||||
#main-content h6 {
|
||||
margin-bottom: 8px;
|
||||
font-family: 'Architects Daughter', 'Helvetica Neue', Helvetica, Arial, serif;
|
||||
font-size: .8em;
|
||||
color: #474747;
|
||||
text-indent: 3px;
|
||||
}
|
||||
h6:before {
|
||||
padding-right: 0.3em;
|
||||
margin-left: -3.7em;
|
||||
content: "//////";
|
||||
color: #9ddcff;
|
||||
}
|
||||
|
||||
p {
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
|
||||
a {
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
p a {
|
||||
font-weight: 400;
|
||||
}
|
||||
|
||||
blockquote {
|
||||
padding: 0 0 0 30px;
|
||||
margin-bottom: 20px;
|
||||
font-size: 1.6em;
|
||||
border-left: 10px solid #e9e9e9;
|
||||
}
|
||||
|
||||
ul {
|
||||
list-style-position: inside;
|
||||
list-style: disc;
|
||||
padding-left: 20px;
|
||||
}
|
||||
|
||||
ol {
|
||||
list-style-position: inside;
|
||||
list-style: decimal;
|
||||
padding-left: 3px;
|
||||
}
|
||||
|
||||
dl dd {
|
||||
font-style: italic;
|
||||
font-weight: 100;
|
||||
}
|
||||
|
||||
footer {
|
||||
padding-top: 20px;
|
||||
padding-bottom: 30px;
|
||||
margin-top: 40px;
|
||||
font-size: 13px;
|
||||
color: #aaa;
|
||||
background: transparent url('../images/hr.png') 0 0 no-repeat;
|
||||
}
|
||||
|
||||
footer a {
|
||||
color: #666;
|
||||
}
|
||||
footer a:hover {
|
||||
color: #444;
|
||||
}
|
||||
|
||||
/* MISC */
|
||||
.clearfix:after {
|
||||
display: block;
|
||||
height: 0;
|
||||
clear: both;
|
||||
visibility: hidden;
|
||||
content: '.';
|
||||
}
|
||||
|
||||
.clearfix {display: inline-block;}
|
||||
* html .clearfix {height: 1%;}
|
||||
.clearfix {display: block;}
|
||||
|
||||
table.techdef .toptitle th {
|
||||
font-weight: bold;
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
table.techdef .subclass {
|
||||
font-weight: bold;
|
||||
background-color: #eee;
|
||||
}
|
||||
|
||||
/* #Media Queries
|
||||
================================================== */
|
||||
|
||||
/* Smaller than standard 960 (devices and browsers) */
|
||||
@media only screen and (max-width: 959px) { }
|
||||
|
||||
/* Tablet Portrait size to standard 960 (devices and browsers) */
|
||||
@media only screen and (min-width: 768px) and (max-width: 959px) {
|
||||
.inner {
|
||||
width: 740px;
|
||||
}
|
||||
header h1, header h2 {
|
||||
width: 340px;
|
||||
}
|
||||
header h1 {
|
||||
font-size: 60px;
|
||||
}
|
||||
header h2 {
|
||||
font-size: 30px;
|
||||
}
|
||||
#main-content {
|
||||
width: 490px;
|
||||
}
|
||||
#main-content h1:before,
|
||||
#main-content h2:before,
|
||||
#main-content h3:before,
|
||||
#main-content h4:before,
|
||||
#main-content h5:before,
|
||||
#main-content h6:before {
|
||||
padding-right: 0;
|
||||
margin-left: 0;
|
||||
content: none;
|
||||
}
|
||||
}
|
||||
|
||||
/* All Mobile Sizes (devices and browser) */
|
||||
@media only screen and (max-width: 767px) {
|
||||
.inner {
|
||||
width: 93%;
|
||||
}
|
||||
header {
|
||||
padding: 20px 0;
|
||||
}
|
||||
header .inner {
|
||||
position: relative;
|
||||
}
|
||||
header h1, header h2 {
|
||||
width: 100%;
|
||||
}
|
||||
header h1 {
|
||||
font-size: 48px;
|
||||
}
|
||||
header h2 {
|
||||
font-size: 24px;
|
||||
}
|
||||
header a.button {
|
||||
position: relative;
|
||||
display: inline-block;
|
||||
width: auto;
|
||||
height: auto;
|
||||
padding: 5px 10px;
|
||||
margin-top: 15px;
|
||||
font-size: 13px;
|
||||
line-height: 1;
|
||||
color: #2879d0;
|
||||
text-align: center;
|
||||
background-color: #9ddcff;
|
||||
background-image: none;
|
||||
border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
-webkit-border-radius: 5px;
|
||||
}
|
||||
header a.button small {
|
||||
display: inline;
|
||||
font-size: 13px;
|
||||
}
|
||||
#main-content,
|
||||
aside#sidebar {
|
||||
float: none;
|
||||
width: 100% ! important;
|
||||
}
|
||||
aside#sidebar {
|
||||
min-height: 0;
|
||||
padding: 20px 0;
|
||||
margin-top: 20px;
|
||||
background-image: none;
|
||||
border-top: solid 1px #ddd;
|
||||
}
|
||||
aside#sidebar a.button {
|
||||
display: none;
|
||||
}
|
||||
#main-content h1:before,
|
||||
#main-content h2:before,
|
||||
#main-content h3:before,
|
||||
#main-content h4:before,
|
||||
#main-content h5:before,
|
||||
#main-content h6:before {
|
||||
padding-right: 0;
|
||||
margin-left: 0;
|
||||
content: none;
|
||||
}
|
||||
}
|
||||
|
||||
/* Mobile Landscape Size to Tablet Portrait (devices and browsers) */
|
||||
@media only screen and (min-width: 480px) and (max-width: 767px) { }
|
||||
|
||||
/* Mobile Portrait Size to Mobile Landscape Size (devices and browsers) */
|
||||
@media only screen and (max-width: 479px) { }
|
Loading…
x
Reference in New Issue
Block a user