summaryrefslogtreecommitdiffstats
path: root/debian/compiz-fusion-bcop-trinity
diff options
context:
space:
mode:
authorMichele Calgaro <michele.calgaro@yahoo.it>2020-09-11 14:38:47 +0900
committerMichele Calgaro <michele.calgaro@yahoo.it>2020-09-11 14:38:47 +0900
commit884c8093d63402a1ad0b502244b791e3c6782be3 (patch)
treea600d4ab0d431a2bdfe4c15b70df43c14fbd8dd0 /debian/compiz-fusion-bcop-trinity
parent14e1aa2006796f147f3f4811fb908a6b01e79253 (diff)
downloadextra-dependencies-884c8093d63402a1ad0b502244b791e3c6782be3.tar.gz
extra-dependencies-884c8093d63402a1ad0b502244b791e3c6782be3.zip
Added debian extra dependency packages.
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
Diffstat (limited to 'debian/compiz-fusion-bcop-trinity')
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/AUTHORS1
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/COPYING340
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/ChangeLog0
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/INSTALL236
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/Makefile.am7
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/NEWS1
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/README0
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/VERSION1
-rwxr-xr-xdebian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/autogen.sh13
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/bcop.pc.in13
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/configure.ac27
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/changelog60
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/compat1
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/control18
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/copyright34
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/dirs1
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/docs2
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/099-trinity.diff13
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/series1
-rwxr-xr-xdebian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/rules19
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/format1
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/options6
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/Makefile.am10
-rwxr-xr-xdebian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.in75
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.xslt1724
-rw-r--r--debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity_0.8.4.orig.tar.xzbin0 -> 16320 bytes
26 files changed, 2604 insertions, 0 deletions
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/AUTHORS b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/AUTHORS
new file mode 100644
index 00000000..5689d64f
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/AUTHORS
@@ -0,0 +1 @@
+Dennis Kasprzyk <onestone@beryl-project.org> \ No newline at end of file
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/COPYING b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/COPYING
new file mode 100644
index 00000000..623b6258
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/COPYING
@@ -0,0 +1,340 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 2, June 1991
+
+ Copyright (C) 1989, 1991 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.
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it. (Some other Free Software Foundation software is covered by
+the GNU Library General Public License instead.) You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, 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 or use pieces of it
+in new free programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must show them these terms so they know their
+rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ Finally, any free program is threatened constantly by software
+patents. We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary. To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License. The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+ 1. You may copy and distribute verbatim copies of the Program's
+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 give any other recipients of the Program a copy of this License
+along with the Program.
+
+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 Program or any portion
+of it, thus forming a work based on the Program, 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) You must cause the modified files to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ b) You must cause any work that you distribute or publish, that in
+ whole or in part contains or is derived from the Program or any
+ part thereof, to be licensed as a whole at no charge to all third
+ parties under the terms of this License.
+
+ c) If the modified program normally reads commands interactively
+ when run, you must cause it, when started running for such
+ interactive use in the most ordinary way, to print or display an
+ announcement including an appropriate copyright notice and a
+ notice that there is no warranty (or else, saying that you provide
+ a warranty) and that users may redistribute the program under
+ these conditions, and telling the user how to view a copy of this
+ License. (Exception: if the Program itself is interactive but
+ does not normally print such an announcement, your work based on
+ the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Program,
+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 Program, 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 Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+ a) 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; or,
+
+ b) Accompany it with a written offer, valid for at least three
+ years, to give any third party, for a charge no more than your
+ cost of physically performing source distribution, a complete
+ machine-readable copy of the corresponding source code, to be
+ distributed under the terms of Sections 1 and 2 above on a medium
+ customarily used for software interchange; or,
+
+ c) Accompany it with the information you received as to the offer
+ to distribute corresponding source code. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form with such
+ an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it. For an executable work, 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 executable. However, as a
+special exception, the source code 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.
+
+If distribution of executable or 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 counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense or distribute the Program 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.
+
+ 5. 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 Program or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program 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 to
+this License.
+
+ 7. 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 Program at all. For example, if a patent
+license would not permit royalty-free redistribution of the Program 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 Program.
+
+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.
+
+ 8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program 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.
+
+ 9. The Free Software Foundation may publish revised and/or new versions
+of the 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 Program
+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 Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+ 10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, 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
+
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "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 PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 12. 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 PROGRAM 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 PROGRAM (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 PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), 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 Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. 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 program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; 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.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) year name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU Library General
+Public License instead of this License.
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/ChangeLog b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/ChangeLog
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/ChangeLog
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/INSTALL b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/INSTALL
new file mode 100644
index 00000000..23e5f25d
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/INSTALL
@@ -0,0 +1,236 @@
+Installation Instructions
+*************************
+
+Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002, 2004, 2005 Free
+Software Foundation, Inc.
+
+This file is free documentation; the Free Software Foundation gives
+unlimited permission to copy, distribute and modify it.
+
+Basic Installation
+==================
+
+These are generic installation instructions.
+
+ The `configure' shell script attempts to guess correct values for
+various system-dependent variables used during compilation. It uses
+those values to create a `Makefile' in each directory of the package.
+It may also create one or more `.h' files containing system-dependent
+definitions. Finally, it creates a shell script `config.status' that
+you can run in the future to recreate the current configuration, and a
+file `config.log' containing compiler output (useful mainly for
+debugging `configure').
+
+ It can also use an optional file (typically called `config.cache'
+and enabled with `--cache-file=config.cache' or simply `-C') that saves
+the results of its tests to speed up reconfiguring. (Caching is
+disabled by default to prevent problems with accidental use of stale
+cache files.)
+
+ If you need to do unusual things to compile the package, please try
+to figure out how `configure' could check whether to do them, and mail
+diffs or instructions to the address given in the `README' so they can
+be considered for the next release. If you are using the cache, and at
+some point `config.cache' contains results you don't want to keep, you
+may remove or edit it.
+
+ The file `configure.ac' (or `configure.in') is used to create
+`configure' by a program called `autoconf'. You only need
+`configure.ac' if you want to change it or regenerate `configure' using
+a newer version of `autoconf'.
+
+The simplest way to compile this package is:
+
+ 1. `cd' to the directory containing the package's source code and type
+ `./configure' to configure the package for your system. If you're
+ using `csh' on an old version of System V, you might need to type
+ `sh ./configure' instead to prevent `csh' from trying to execute
+ `configure' itself.
+
+ Running `configure' takes awhile. While running, it prints some
+ messages telling which features it is checking for.
+
+ 2. Type `make' to compile the package.
+
+ 3. Optionally, type `make check' to run any self-tests that come with
+ the package.
+
+ 4. Type `make install' to install the programs and any data files and
+ documentation.
+
+ 5. You can remove the program binaries and object files from the
+ source code directory by typing `make clean'. To also remove the
+ files that `configure' created (so you can compile the package for
+ a different kind of computer), type `make distclean'. There is
+ also a `make maintainer-clean' target, but that is intended mainly
+ for the package's developers. If you use it, you may have to get
+ all sorts of other programs in order to regenerate files that came
+ with the distribution.
+
+Compilers and Options
+=====================
+
+Some systems require unusual options for compilation or linking that the
+`configure' script does not know about. Run `./configure --help' for
+details on some of the pertinent environment variables.
+
+ You can give `configure' initial values for configuration parameters
+by setting variables in the command line or in the environment. Here
+is an example:
+
+ ./configure CC=c89 CFLAGS=-O2 LIBS=-lposix
+
+ *Note Defining Variables::, for more details.
+
+Compiling For Multiple Architectures
+====================================
+
+You can compile the package for more than one kind of computer at the
+same time, by placing the object files for each architecture in their
+own directory. To do this, you must use a version of `make' that
+supports the `VPATH' variable, such as GNU `make'. `cd' to the
+directory where you want the object files and executables to go and run
+the `configure' script. `configure' automatically checks for the
+source code in the directory that `configure' is in and in `..'.
+
+ If you have to use a `make' that does not support the `VPATH'
+variable, you have to compile the package for one architecture at a
+time in the source code directory. After you have installed the
+package for one architecture, use `make distclean' before reconfiguring
+for another architecture.
+
+Installation Names
+==================
+
+By default, `make install' installs the package's commands under
+`/usr/local/bin', include files under `/usr/local/include', etc. You
+can specify an installation prefix other than `/usr/local' by giving
+`configure' the option `--prefix=PREFIX'.
+
+ You can specify separate installation prefixes for
+architecture-specific files and architecture-independent files. If you
+pass the option `--exec-prefix=PREFIX' to `configure', the package uses
+PREFIX as the prefix for installing programs and libraries.
+Documentation and other data files still use the regular prefix.
+
+ In addition, if you use an unusual directory layout you can give
+options like `--bindir=DIR' to specify different values for particular
+kinds of files. Run `configure --help' for a list of the directories
+you can set and what kinds of files go in them.
+
+ If the package supports it, you can cause programs to be installed
+with an extra prefix or suffix on their names by giving `configure' the
+option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'.
+
+Optional Features
+=================
+
+Some packages pay attention to `--enable-FEATURE' options to
+`configure', where FEATURE indicates an optional part of the package.
+They may also pay attention to `--with-PACKAGE' options, where PACKAGE
+is something like `gnu-as' or `x' (for the X Window System). The
+`README' should mention any `--enable-' and `--with-' options that the
+package recognizes.
+
+ For packages that use the X Window System, `configure' can usually
+find the X include and library files automatically, but if it doesn't,
+you can use the `configure' options `--x-includes=DIR' and
+`--x-libraries=DIR' to specify their locations.
+
+Specifying the System Type
+==========================
+
+There may be some features `configure' cannot figure out automatically,
+but needs to determine by the type of machine the package will run on.
+Usually, assuming the package is built to be run on the _same_
+architectures, `configure' can figure that out, but if it prints a
+message saying it cannot guess the machine type, give it the
+`--build=TYPE' option. TYPE can either be a short name for the system
+type, such as `sun4', or a canonical name which has the form:
+
+ CPU-COMPANY-SYSTEM
+
+where SYSTEM can have one of these forms:
+
+ OS KERNEL-OS
+
+ See the file `config.sub' for the possible values of each field. If
+`config.sub' isn't included in this package, then this package doesn't
+need to know the machine type.
+
+ If you are _building_ compiler tools for cross-compiling, you should
+use the option `--target=TYPE' to select the type of system they will
+produce code for.
+
+ If you want to _use_ a cross compiler, that generates code for a
+platform different from the build platform, you should specify the
+"host" platform (i.e., that on which the generated programs will
+eventually be run) with `--host=TYPE'.
+
+Sharing Defaults
+================
+
+If you want to set default values for `configure' scripts to share, you
+can create a site shell script called `config.site' that gives default
+values for variables like `CC', `cache_file', and `prefix'.
+`configure' looks for `PREFIX/share/config.site' if it exists, then
+`PREFIX/etc/config.site' if it exists. Or, you can set the
+`CONFIG_SITE' environment variable to the location of the site script.
+A warning: not all `configure' scripts look for a site script.
+
+Defining Variables
+==================
+
+Variables not defined in a site shell script can be set in the
+environment passed to `configure'. However, some packages may run
+configure again during the build, and the customized values of these
+variables may be lost. In order to avoid this problem, you should set
+them in the `configure' command line, using `VAR=value'. For example:
+
+ ./configure CC=/usr/local2/bin/gcc
+
+causes the specified `gcc' to be used as the C compiler (unless it is
+overridden in the site shell script). Here is a another example:
+
+ /bin/bash ./configure CONFIG_SHELL=/bin/bash
+
+Here the `CONFIG_SHELL=/bin/bash' operand causes subsequent
+configuration-related scripts to be executed by `/bin/bash'.
+
+`configure' Invocation
+======================
+
+`configure' recognizes the following options to control how it operates.
+
+`--help'
+`-h'
+ Print a summary of the options to `configure', and exit.
+
+`--version'
+`-V'
+ Print the version of Autoconf used to generate the `configure'
+ script, and exit.
+
+`--cache-file=FILE'
+ Enable the cache: use and save the results of the tests in FILE,
+ traditionally `config.cache'. FILE defaults to `/dev/null' to
+ disable caching.
+
+`--config-cache'
+`-C'
+ Alias for `--cache-file=config.cache'.
+
+`--quiet'
+`--silent'
+`-q'
+ Do not print messages saying which checks are being made. To
+ suppress all normal output, redirect it to `/dev/null' (any error
+ messages will still be shown).
+
+`--srcdir=DIR'
+ Look for the package's source code in directory DIR. Usually
+ `configure' can determine that directory automatically.
+
+`configure' also accepts some other, not widely useful, options. Run
+`configure --help' for more details.
+
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/Makefile.am b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/Makefile.am
new file mode 100644
index 00000000..d543d449
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/Makefile.am
@@ -0,0 +1,7 @@
+## Process this file with automake to produce Makefile.in
+SUBDIRS = src
+
+EXTRA_DIST = VERSION
+
+pkgconfigdir = $(datadir)/pkgconfig
+pkgconfig_DATA = bcop.pc
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/NEWS b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/NEWS
new file mode 100644
index 00000000..94941cc7
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/NEWS
@@ -0,0 +1 @@
+There is nothing here yet.
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/README b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/README
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/README
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/VERSION b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/VERSION
new file mode 100644
index 00000000..e4184f46
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/VERSION
@@ -0,0 +1 @@
+VERSION=0.8.4
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/autogen.sh b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/autogen.sh
new file mode 100755
index 00000000..80ae530c
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/autogen.sh
@@ -0,0 +1,13 @@
+#! /bin/sh
+
+srcdir=`dirname $0`
+test -z "$srcdir" && srcdir=.
+
+ORIGDIR=`pwd`
+cd $srcdir
+
+autoreconf -v --install || exit 1
+cd $ORIGDIR || exit $?
+
+$srcdir/configure "$@"
+
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/bcop.pc.in b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/bcop.pc.in
new file mode 100644
index 00000000..93d1adf0
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/bcop.pc.in
@@ -0,0 +1,13 @@
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+datarootdir=@datarootdir@
+datadir=@datadir@
+includedir=@includedir@
+bin=@exec_prefix@/bin/bcop
+xsltpath=@prefix@/share/bcop
+
+Name: bcop
+Description: Compiz option code generator
+Version: @VERSION@
+Requires:
+
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/configure.ac b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/configure.ac
new file mode 100644
index 00000000..0cf19b86
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/configure.ac
@@ -0,0 +1,27 @@
+AC_PREREQ(2.57)
+
+AC_INIT([compiz-bcop],esyscmd(. ./VERSION;echo -n $VERSION), [onestone@beryl-project.org])
+
+AC_DEFINE_UNQUOTED(VERSION,"$VERSION",[Version])
+
+AM_INIT_AUTOMAKE([1.9 dist-bzip2])
+AC_CONFIG_HEADER([config.h])
+AM_MAINTAINER_MODE
+
+AC_ISC_POSIX
+AC_PROG_CC
+AC_HEADER_STDC
+
+AC_C_BIGENDIAN
+
+PKG_CHECK_MODULES(LIBXSLT, libxslt)
+
+xsltdir=$datadir/bcop
+AC_SUBST(xsltdir)
+
+AC_OUTPUT([
+bcop.pc
+Makefile
+src/Makefile
+src/bcop
+])
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/changelog b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/changelog
new file mode 100644
index 00000000..df6afd62
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/changelog
@@ -0,0 +1,60 @@
+compiz-fusion-bcop-trinity (0.8.4-3debian11.0.0+4~a) bullseye; urgency=low
+
+ * Change debhelper compatibility level to 9
+
+ -- Slávek Banko <slavek.banko@axis.cz> Wed, 08 Apr 2020 01:25:35 +0200
+
+compiz-fusion-bcop-trinity (0.8.4-3ubuntu20.04.0+3~a) focal; urgency=low
+
+ * Change debhelper compatibility level to 7
+
+ -- Slávek Banko <slavek.banko@axis.cz> Sat, 13 Aug 2016 18:53:28 +0200
+
+compiz-fusion-bcop-trinity (0.8.4-3ubuntu16.10.0+2~a) yakkety; urgency=low
+
+ * Trinity changes pulled into a separate patch
+
+ -- Slávek Banko <slavek.banko@axis.cz> Thu, 14 Mar 2013 18:44:40 +0100
+
+compiz-fusion-bcop-trinity (0.8.4-1debian7) squeeze; urgency=low
+
+ * Hardcoded pkg-config directory to location of bcop.pc
+ * Moved KDE3 to /opt/trinity
+ * Integrated properly with KDE4.2+
+ * Added -trinity suffix
+
+ -- Timothy Pearson <kb9vqf@pearsoncomputing.net> Fri, 06 March 2009 01:35:00 -0600
+
+compiz-fusion-bcop (0.8.4-1) unstable; urgency=low
+
+ * New upstream release
+
+ -- Sean Finney <seanius@debian.org> Thu, 04 Feb 2010 18:04:13 +0100
+
+compiz-fusion-bcop (0.8.2-1) unstable; urgency=low
+
+ * New upstream release
+ * add gbp.conf for use with git-buildpackage
+ * lintian fixes:
+ - update Standards-Version to 3.8.1
+ - build binary in binary-indep, not binary-arch
+
+ -- Sean Finney <seanius@debian.org> Sun, 05 Apr 2009 22:16:11 +0200
+
+compiz-fusion-bcop (0.7.6-1) unstable; urgency=low
+
+ * New upstream release.
+
+ -- Sean Finney <seanius@debian.org> Tue, 03 Jun 2008 00:45:02 +0200
+
+compiz-fusion-bcop (0.7.4-1) unstable; urgency=low
+
+ * New upstream release.
+
+ -- Sean Finney <seanius@debian.org> Mon, 19 May 2008 19:48:56 +0200
+
+compiz-fusion-bcop (0.6.0-1) unstable; urgency=low
+
+ * Initial release (Closes: #431756).
+
+ -- Sean Finney <seanius@debian.org> Fri, 09 Nov 2007 19:04:28 +0100
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/compat b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/compat
new file mode 100644
index 00000000..ec635144
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/compat
@@ -0,0 +1 @@
+9
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/control b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/control
new file mode 100644
index 00000000..1550bef5
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/control
@@ -0,0 +1,18 @@
+Source: compiz-fusion-bcop-trinity
+Section: deps-r14/x11
+Priority: extra
+Maintainer: Timothy Pearson <kb9vqf@pearsoncomputing.net>
+Build-Depends: cdbs, debhelper (>= 9~), quilt, intltool, libtool, libglib2.0-dev, libxslt1-dev, pkg-config
+Standards-Version: 3.8.1
+
+Package: compiz-fusion-bcop-trinity
+Architecture: all
+Depends: pkg-config, xsltproc
+Description: Compiz Fusion option code generator [Trinity]
+ Compiz Fusion is the result of the re-unification of the Beryl-project
+ and the community around the Compiz Window Manager. It seeks to provide
+ an easy and fun-to-use windowing environment, allowing use of the
+ graphics hardware to provide impressive effects, amazing speed and
+ unrivalled usefulness
+ .
+ This tool is used to generate code for use with compiz-fusion plugins.
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/copyright b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/copyright
new file mode 100644
index 00000000..9b55e46e
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/copyright
@@ -0,0 +1,34 @@
+This package was debianized by sean finney <seanius@debian.org> on
+Mon, 15 Oct 2007 19:49:50 +0200.
+
+It was downloaded from: git://anongit.compiz-fusion.org/fusion/libraries/bcop
+
+Upstream Author:
+
+ Dennis Kasprzyk <onestone@beryl-project.org>
+
+Copyright:
+
+ Copyright (C) 2007 Dennis Kasprzyk
+
+License:
+
+ This package is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This package is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this package; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+
+ On Debian systems, the complete text of the GNU General
+ Public License can be found in `/usr/share/common-licenses/GPL'.
+
+ The Debian packaging is (C) 2007, sean finney <seanius@debian.org> and
+ is licensed under the GPL, see `/usr/share/common-licenses/GPL'.
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/dirs b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/dirs
new file mode 100644
index 00000000..f583045f
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/dirs
@@ -0,0 +1 @@
+opt/trinity/bin
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/docs b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/docs
new file mode 100644
index 00000000..50bd824b
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/docs
@@ -0,0 +1,2 @@
+NEWS
+README
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/099-trinity.diff b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/099-trinity.diff
new file mode 100644
index 00000000..edab4a1e
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/099-trinity.diff
@@ -0,0 +1,13 @@
+Index: b/src/bcop.in
+===================================================================
+--- a/src/bcop.in 2013-03-14 18:48:32.000000000 +0100
++++ b/src/bcop.in 2013-03-14 18:48:46.000000000 +0100
+@@ -18,7 +18,7 @@
+ # GNU General Public License for more details.
+ #
+
+-xsltdir=@prefix@/share/bcop
++xsltdir=`PKG_CONFIG_PATH=/opt/trinity/share/pkgconfig pkg-config --variable xsltpath bcop`
+
+ function usage
+ {
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/series b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/series
new file mode 100644
index 00000000..960d9805
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/patches/series
@@ -0,0 +1 @@
+099-trinity.diff
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/rules b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/rules
new file mode 100755
index 00000000..1d2eccef
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/rules
@@ -0,0 +1,19 @@
+#!/usr/bin/make -f
+
+include /usr/share/cdbs/1/class/autotools.mk
+include /usr/share/cdbs/1/rules/debhelper.mk
+
+DEB_CONFIGURE_INCLUDEDIR := /opt/trinity/include
+DEB_CONFIGURE_MANDIR := /opt/trinity/share/man
+DEB_CONFIGURE_PREFIX := /opt/trinity
+DEB_CONFIGURE_INFODIR := /opt/trinity/share/info
+
+cdbs_configure_flags := --with-qt-dir=/usr/share/qt3 --disable-rpath --with-xinerama $(cdbs_kde_enable_final) $(cdbs_kde_enable_debug)
+
+DEB_CONFIGURE_EXTRA_FLAGS := --prefix=/opt/trinity --with-extra-libs=/opt/trinity/lib --with-extra-includes=/opt/trinity/include
+
+makebuilddir:: debian/stamp-autoreconf
+debian/stamp-autoreconf:
+ dh_testdir
+ autoreconf -vi
+ touch debian/stamp-autoreconf
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/format b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/format
new file mode 100644
index 00000000..163aaf8d
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/format
@@ -0,0 +1 @@
+3.0 (quilt)
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/options b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/options
new file mode 100644
index 00000000..72f1f545
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/debian/source/options
@@ -0,0 +1,6 @@
+# Use xz instead of gzip
+compression = "xz"
+compression-level = 9
+
+# Don't run differences
+diff-ignore = .*
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/Makefile.am b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/Makefile.am
new file mode 100644
index 00000000..c311cf91
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/Makefile.am
@@ -0,0 +1,10 @@
+xmldir = $(xsltdir)
+xml_files = bcop.xslt
+xml_DATA = $(xml_files)
+
+bin_SCRIPTS = bcop
+
+DISTCLEANFILES=$(bin_SCRIPTS)
+
+EXTRA_DIST=bcop.in \
+ $(xml_files)
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.in b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.in
new file mode 100755
index 00000000..1b1b224b
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.in
@@ -0,0 +1,75 @@
+#!/bin/bash
+#
+#
+# Compiz option code generator
+#
+# Copyright : (C) 2007 by Dennis Kasprzyk
+# E-mail : onestone@beryl-project.org
+#
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+
+xsltdir=@prefix@/share/bcop
+
+function usage
+{
+ echo "Usage: $0 [options] <options file>"
+ echo "Options:"
+ echo " -h, --help display this help message"
+ echo " -v, --version print version information"
+ echo " --source=<file> source file name"
+ echo " --header=<file> header file name"
+ exit 1
+}
+
+srcfile=
+hdrfile=
+
+set -- `getopt -quo "hv" -l "help,version,source:,header:" -- "$@"`
+[ $# -lt 2 ] && usage
+
+while [ $# -gt 0 ]
+do
+ case "$1" in
+ -h) usage;;
+ --help) usage;;
+ -v) echo "@PACKAGE_STRING@"; exit 0;;
+ --version) echo "@PACKAGE_STRING@"; exit 0;;
+ --source) srcfile="$2"; shift;;
+ --header) hdrfile="$2"; shift;;
+ --) shift; break;;
+ -*) usage;;
+ *) break;; # terminate while loop
+ esac
+ shift
+done
+
+xmlfile="$1"
+
+if [ -e $xmlfile ]; then
+ if [ -n "$hdrfile" ]; then
+ xsltproc --stringparam "header" "true" $xsltdir/bcop.xslt $xmlfile > "$hdrfile"
+ RETVAL=$?
+ if [ $RETVAL -ne 0 ]; then
+ rm -f $hdrfile
+ exit $RETVAL
+ fi
+ fi
+ if [ -n "$srcfile" ]; then
+ xsltproc --stringparam "source" "true" $xsltdir/bcop.xslt $xmlfile > "$srcfile"
+ RETVAL=$?
+ if [ $RETVAL -ne 0 ]; then
+ rm -f $srcfile
+ exit $RETVAL
+ fi
+ fi
+fi
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.xslt b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.xslt
new file mode 100644
index 00000000..6976df20
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity-0.8.4/src/bcop.xslt
@@ -0,0 +1,1724 @@
+<!--
+ Compiz option code generator
+
+ Copyright : (C) 2007 by Dennis Kasprzyk
+ E-mail : onestone@beryl-project.org
+
+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License
+ as published by the Free Software Foundation; either version 2
+ of the License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+-->
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
+ <xsl:output method="text"/>
+
+<!-- String conversion helper functions -->
+
+ <xsl:template name="print">
+ <xsl:param name="text"/>
+ <xsl:value-of select="translate($text,'ABCDEFGHIJKLMNOPQRSTUVWXYZ','abcdefghijklmnopqrstuvwxyz')"/>
+ </xsl:template>
+
+ <xsl:template name="PRINT">
+ <xsl:param name="text"/>
+ <xsl:value-of select="translate($text,'abcdefghijklmnopqrstuvwxyz','ABCDEFGHIJKLMNOPQRSTUVWXYZ')"/>
+ </xsl:template>
+
+ <xsl:template name="Print">
+ <xsl:param name="text"/>
+ <xsl:call-template name="PRINT">
+ <xsl:with-param name="text">
+ <xsl:value-of select="substring($text,1,1)"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ <xsl:call-template name="print">
+ <xsl:with-param name="text">
+ <xsl:value-of select="substring($text,2)"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:template>
+
+ <xsl:template name="PrintCamel">
+ <xsl:param name="text"/>
+ <xsl:variable name="textconv">
+ <xsl:value-of select="translate($text,' +-/\','_____')"/>
+ </xsl:variable>
+ <xsl:if test="string-length($textconv)">
+ <xsl:if test="contains($textconv,'_')">
+ <xsl:call-template name="Print">
+ <xsl:with-param name="text">
+ <xsl:value-of select="substring-before($textconv,'_')"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ <xsl:call-template name="PrintCamel">
+ <xsl:with-param name="text">
+ <xsl:value-of select="substring-after($textconv,'_')"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:if>
+ <xsl:if test="not(contains($textconv,'_'))">
+ <xsl:call-template name="Print">
+ <xsl:with-param name="text">
+ <xsl:value-of select="$textconv"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:if>
+ </xsl:if>
+ </xsl:template>
+
+ <xsl:template name="saveCName">
+ <xsl:param name="text"/>
+ <xsl:variable name="textFirst">
+ <xsl:value-of select="translate(substring($text,1,1),'0123456789 +-','zottffssen___')"/>
+ </xsl:variable>
+ <xsl:value-of select="concat($textFirst,substring($text,2))"/>
+ </xsl:template>
+
+<!-- Plugin name variables -->
+
+ <xsl:variable name="pName">
+ <xsl:value-of select="/compiz/plugin[@useBcop = 'true']/@name"/>
+ </xsl:variable>
+
+ <xsl:variable name="pCName">
+ <xsl:call-template name="saveCName">
+ <xsl:with-param name="text">
+ <xsl:value-of select="$pName"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:variable>
+
+ <xsl:variable name="plugin">
+ <xsl:call-template name="print">
+ <xsl:with-param name="text">
+ <xsl:value-of select="$pCName"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:variable>
+
+ <xsl:variable name="Plugin">
+ <xsl:call-template name="Print">
+ <xsl:with-param name="text">
+ <xsl:value-of select="$pCName"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:variable>
+
+ <xsl:variable name="PLUGIN">
+ <xsl:call-template name="PRINT">
+ <xsl:with-param name="text">
+ <xsl:value-of select="$pCName"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:variable>
+
+<!-- external parameters that could be passed to this document -->
+
+ <xsl:param name="header">false</xsl:param>
+ <xsl:param name="source">false</xsl:param>
+ <xsl:param name="filename"><xsl:value-of select="$pName"/><xsl:text>_options.h</xsl:text></xsl:param>
+ <xsl:param name="metaname"><xsl:value-of select="$pName"/></xsl:param>
+
+
+<!-- global helper functions -->
+
+ <xsl:template name="license">
+<xsl:text>/*
+ * This file is autogenerated with bcop:
+ * The Compiz option code generator
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ */
+
+</xsl:text>
+ </xsl:template>
+
+ <xsl:template name="printOptionsEnumName">
+ <xsl:value-of select="$Plugin"/>
+ <xsl:call-template name="screenOrDisplay"/>
+ <xsl:text>Option</xsl:text>
+ <xsl:call-template name="PrintCamel">
+ <xsl:with-param name="text">
+ <xsl:value-of select="@name"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:template>
+
+ <xsl:template name="printOptionName">
+ <xsl:call-template name="PrintCamel">
+ <xsl:with-param name="text">
+ <xsl:value-of select="@name"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:template>
+
+ <xsl:template name="screenOrDisplay">
+ <xsl:if test="ancestor::display">
+ <xsl:text>Display</xsl:text>
+ </xsl:if>
+ <xsl:if test="ancestor::screen">
+ <xsl:text>Screen</xsl:text>
+ </xsl:if>
+ </xsl:template>
+
+ <xsl:template name="baseType">
+ <xsl:if test="ancestor::display">
+ <xsl:text>CompDisplay *d</xsl:text>
+ </xsl:if>
+ <xsl:if test="ancestor::screen">
+ <xsl:text>CompScreen *s</xsl:text>
+ </xsl:if>
+ </xsl:template>
+
+<!-- *** main block *** -->
+
+ <xsl:template match="/compiz">
+ <xsl:if test="plugin[@useBcop = 'true']">
+ <xsl:if test="$header = 'true'">
+ <xsl:call-template name="hfile"/>
+ </xsl:if>
+ <xsl:if test="$source = 'true'">
+ <xsl:call-template name="cfile"/>
+ </xsl:if>
+ </xsl:if>
+ </xsl:template>
+
+<!-- *** c source file generation *** -->
+
+ <xsl:template name="cfile">
+ <xsl:call-template name="license"/>
+ <xsl:text>#include &lt;stdio.h&gt;
+#include &lt;stdlib.h&gt;
+#include &lt;string.h&gt;
+
+#include &lt;compiz-core.h&gt;
+
+</xsl:text>
+ <xsl:text>#include "</xsl:text>
+ <xsl:value-of select="$filename"/>
+ <xsl:text>"
+
+static int </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplayPrivateIndex;
+
+static CompMetadata </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsMetadata;
+
+static CompPluginVTable *</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable = NULL;
+CompPluginVTable </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable;
+
+#define </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_DISPLAY(d) PLUGIN_DISPLAY(d, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>Options, o)
+#define </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_SCREEN(s) PLUGIN_SCREEN(s, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>Options, o)
+
+typedef struct _</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplay
+{
+ int screenPrivateIndex;
+
+</xsl:text>
+ <xsl:if test="plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:text> CompOption opt[</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum];
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>DisplayOptionChangeNotifyProc notify[</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum];
+</xsl:text>
+ <xsl:for-each select="plugin[@name=$pName]/display/descendant-or-self::option[@type = 'list' and ./desc/value and ./type/text() = 'int']">
+ <xsl:text> unsigned int </xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text>;
+</xsl:text>
+ </xsl:for-each>
+ </xsl:if>
+ <xsl:text>} </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplay;
+
+typedef struct _</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsScreen
+{
+</xsl:text>
+ <xsl:if test="plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:text> CompOption opt[</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum];
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>ScreenOptionChangeNotifyProc notify[</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum];
+</xsl:text>
+ <xsl:for-each select="plugin[@name=$pName]/screen/descendant-or-self::option[@type = 'list' and ./desc/value and ./type/text() = 'int']">
+ <xsl:text> unsigned int </xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text>;
+</xsl:text>
+ </xsl:for-each>
+ </xsl:if>
+ <xsl:text>} </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsScreen;
+
+</xsl:text>
+ <xsl:call-template name="printFunctions"/>
+ <xsl:if test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:call-template name="initDisplayOptions"/>
+ <xsl:call-template name="setDisplayOptions"/>
+ <xsl:call-template name="getDisplayOptions"/>
+ </xsl:if>
+ <xsl:if test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:call-template name="initScreenOptions"/>
+ <xsl:call-template name="setScreenOptions"/>
+ <xsl:call-template name="getScreenOptions"/>
+ </xsl:if>
+ <xsl:call-template name="initFiniScreen"/>
+ <xsl:call-template name="initFiniDisplay"/>
+ <xsl:call-template name="initFini"/>
+ <xsl:call-template name="initFiniObject"/>
+ <xsl:call-template name="getSetObject"/>
+ <xsl:call-template name="getVTable"/>
+ </xsl:template>
+
+<!-- helper functions -->
+
+ <xsl:template name="initPrivate">
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_</xsl:text>
+ <xsl:if test="ancestor::display">
+ <xsl:text>DISPLAY(d);
+</xsl:text>
+ </xsl:if>
+ <xsl:if test="ancestor::screen">
+ <xsl:text>SCREEN(s);
+</xsl:text>
+ </xsl:if>
+ </xsl:template>
+
+ <xsl:template name="privateName">
+ <xsl:if test="ancestor::display">
+ <xsl:text>od</xsl:text>
+ </xsl:if>
+ <xsl:if test="ancestor::screen">
+ <xsl:text>os</xsl:text>
+ </xsl:if>
+ </xsl:template>
+
+<!-- print get/set functions -->
+
+ <xsl:template name="printFunctions">
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/descendant-or-self::option">
+ <xsl:choose>
+ <xsl:when test="@type='int'">
+ <xsl:text>int </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.i;
+}
+
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='float'">
+ <xsl:text>float </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.f;
+}
+
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='bool'">
+ <xsl:text>Bool </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.b;
+}
+
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='string'">
+ <xsl:text>char * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.s;
+}
+
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='match'">
+ <xsl:text>CompMatch * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return &amp;</xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.match;
+}
+
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='color'">
+ <xsl:text>unsigned short * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.c;
+}
+
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Red (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.c[0];
+}
+
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Green (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.c[1];
+}
+
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Blue (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.c[2];
+}
+
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Alpha (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.c[3];
+}
+
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='action' or @type='key' or @type='button' or @type='edge' or @type='bell'">
+ <xsl:text>CompAction * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return &amp;</xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.action;
+}
+
+void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Set</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Initiate (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>, CompActionCallBackProc init)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.action.initiate = init;
+}
+
+void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Set</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Terminate (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>, CompActionCallBackProc term)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.action.terminate = term;
+}
+
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='list'">
+ <xsl:text>CompListValue * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return &amp;</xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>].value.list;
+}
+
+</xsl:text>
+ <xsl:if test="./type[text() = 'int']/../desc/value">
+ <xsl:text>unsigned int </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Mask (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>-></xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text>;
+}
+
+</xsl:text>
+ </xsl:if>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:text>CompOption * </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Option (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> return &amp;</xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>];
+}
+
+void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Set</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Notify (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>, </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:call-template name="screenOrDisplay"/>
+ <xsl:text>OptionChangeNotifyProc notify)
+{
+ </xsl:text>
+ <xsl:call-template name="initPrivate"/>
+ <xsl:text> </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->notify[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>] = notify;
+}
+
+</xsl:text>
+ </xsl:for-each>
+ <xsl:if test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:text>CompOption * </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>GetDisplayOption (CompDisplay *d, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptions num)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_DISPLAY(d);
+ return &amp;od->opt[num];
+}
+
+</xsl:text>
+ </xsl:if>
+ <xsl:if test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:text>CompOption * </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>GetScreenOption (CompScreen *s, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptions num)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_SCREEN(s);
+ return &amp;os->opt[num];
+}
+
+</xsl:text>
+ </xsl:if>
+ </xsl:template>
+
+<!-- initialze option functions generation -->
+
+ <xsl:template name="initDisplayOptions">
+ <xsl:text>static const CompMetadataOptionInfo </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsDisplayOptionInfo[] = {
+</xsl:text>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:call-template name="initOption"/>
+ </xsl:for-each>
+ <xsl:text>};
+
+</xsl:text>
+ </xsl:template>
+
+ <xsl:template name="initScreenOptions">
+ <xsl:text>static const CompMetadataOptionInfo </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsScreenOptionInfo[] = {
+</xsl:text>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:call-template name="initOption"/>
+ </xsl:for-each>
+ <xsl:text>};
+
+</xsl:text>
+ </xsl:template>
+ <xsl:template name="initOption">
+ <xsl:text> { "</xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text>", "</xsl:text>
+ <xsl:value-of select="@type"/>
+ <xsl:text>", </xsl:text>
+ <xsl:choose>
+ <xsl:when test="(@type = 'int' or @type = 'float') and (./min/text() and ./max/text())">
+ <xsl:text>"&lt;min&gt;</xsl:text>
+ <xsl:value-of select="./min/text()"/>
+ <xsl:text>&lt;/min&gt;&lt;max&gt;</xsl:text>
+ <xsl:value-of select="./max/text()"/>
+ <xsl:text>&lt;/max&gt;", </xsl:text>
+ </xsl:when>
+ <xsl:when test="@type = 'list' and ./type/text()">
+ <xsl:text>"&lt;type&gt;</xsl:text>
+ <xsl:value-of select="./type/text()"/>
+ <xsl:text>&lt;/type&gt;", </xsl:text>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:text>0, </xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+ <xsl:text>0, 0 },
+</xsl:text>
+ </xsl:template>
+
+<!-- get option functions generation -->
+
+ <xsl:template name="getDisplayOptions">
+ <xsl:text>static CompOption * </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetDisplayOptions (CompPlugin *plugin, CompDisplay *d, int *count)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_DISPLAY(d);
+ if (!od)
+ {
+ *count = 0;
+ return NULL;
+ }
+ *count = </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum;
+ return od->opt;
+}
+
+</xsl:text>
+ </xsl:template>
+
+ <xsl:template name="getScreenOptions">
+ <xsl:text>static CompOption * </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetScreenOptions (CompPlugin *plugin, CompScreen *s, int *count)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_SCREEN(s);
+ if (!os)
+ {
+ *count = 0;
+ return NULL;
+ }
+ *count = </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum;
+ return os->opt;
+}
+
+</xsl:text>
+ </xsl:template>
+
+<!-- set option function generation -->
+
+ <xsl:template name="setDisplayOptions">
+ <xsl:text>static Bool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsSetDisplayOption (CompPlugin *plugin, CompDisplay *d, const char *name, CompOptionValue *value)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_DISPLAY(d);
+ CompOption *o;
+ int index;
+
+ o = compFindOption (od->opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum, name, &amp;index);
+
+ if (!o)
+ return FALSE;
+
+ switch (index)
+ {
+</xsl:text>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:call-template name="setOption"/>
+ </xsl:for-each>
+ <xsl:text> default:
+ break;
+ }
+ return FALSE;
+}
+
+</xsl:text>
+ </xsl:template>
+
+ <xsl:template name="setScreenOptions">
+ <xsl:text>static Bool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsSetScreenOption (CompPlugin *plugin, CompScreen *s, const char *name, CompOptionValue *value)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_SCREEN(s);
+ CompOption *o;
+ int index;
+
+ o = compFindOption (os->opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum, name, &amp;index);
+
+ if (!o)
+ return FALSE;
+
+ switch (index)
+ {
+</xsl:text>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:call-template name="setOption"/>
+ </xsl:for-each>
+ <xsl:text> default:
+ break;
+ }
+ return FALSE;
+}
+
+</xsl:text>
+ </xsl:template>
+
+ <xsl:template name="setOption">
+ <xsl:text> case </xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>:
+ if (</xsl:text>
+ <xsl:choose>
+ <xsl:when test="ancestor::display">
+ <xsl:text>compSetDisplayOption (d, o, value))</xsl:text>
+ </xsl:when>
+ <xsl:when test="ancestor::screen">
+ <xsl:text>compSetScreenOption (s, o, value))</xsl:text>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:text>compSetOption (o, value))</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+ <xsl:text>
+ {
+</xsl:text>
+ <xsl:if test="@type = 'list' and ./desc/value and ./type/text() = 'int'">
+ <xsl:text> int i;
+ </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>-></xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text> = 0;
+ for (i = 0; i &lt; o->value.list.nValue; i++)
+ </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>-></xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text> |= (1 &lt;&lt; o->value.list.value[i].i);
+</xsl:text>
+ </xsl:if>
+ <xsl:text> if (</xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->notify[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>])
+ (*</xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>->notify[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>]) (</xsl:text>
+ <xsl:if test="ancestor::display">
+ <xsl:text>d</xsl:text>
+ </xsl:if>
+ <xsl:if test="ancestor::screen">
+ <xsl:text>s</xsl:text>
+ </xsl:if>
+ <xsl:text>, o, </xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>);
+ return TRUE;
+ }
+ break;
+</xsl:text>
+ </xsl:template>
+
+
+<!-- init/fini screen -->
+
+ <xsl:template name="initFiniScreen">
+ <xsl:text>static Bool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitScreen (CompPlugin *p, CompScreen *s)
+{
+ </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsScreen *os;
+ </xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option[@type = 'list']/desc/value and
+ /compiz/plugin[@name=$pName]/screen/descendant-or-self::option[@type = 'list']/type/text() = 'int'">
+ <xsl:text>CompOption *o;
+ int i;
+ </xsl:text>
+ </xsl:if>
+ <xsl:text>
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_DISPLAY (s->display);
+
+ os = calloc (1, sizeof(</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsScreen));
+ if (!os)
+ return FALSE;
+
+ s->base.privates[od->screenPrivateIndex].ptr = os;
+
+ </xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:text>if (!compInitScreenOptionsFromMetadata (s, &amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsMetadata, </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsScreenOptionInfo, os->opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum))
+ {
+ free (os);
+ return FALSE;
+ }
+</xsl:text>
+ </xsl:if>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:if test="@type = 'list' and ./desc/value and ./type/text() = 'int'">
+ <xsl:text> o = &amp;os->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>];
+ </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>-></xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text> = 0;
+ for (i = 0; i &lt; o->value.list.nValue; i++)
+ </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>-></xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text> |= (1 &lt;&lt; o->value.list.value[i].i);
+
+</xsl:text>
+ </xsl:if>
+
+ </xsl:for-each>
+
+ <xsl:text>
+ return TRUE;
+}
+
+static void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniScreen (CompPlugin *p, CompScreen *s)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_SCREEN (s);
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_DISPLAY (s->display);
+
+</xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:text>
+ compFiniScreenOptions (s, os->opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum);
+
+</xsl:text>
+ </xsl:if>
+ <xsl:text> free (os);
+ s->base.privates[od->screenPrivateIndex].ptr = NULL;
+}
+
+</xsl:text>
+ </xsl:template>
+
+<!-- init/fini display -->
+
+ <xsl:template name="initFiniDisplay">
+ <xsl:text>static Bool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitDisplay (CompPlugin *p, CompDisplay *d)
+{
+ </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplay *od;
+ </xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option[@type = 'list']/desc/value and
+ /compiz/plugin[@name=$pName]/display/descendant-or-self::option[@type = 'list']/type/text() = 'int'">
+ <xsl:text>CompOption *o;
+ int i;
+ </xsl:text>
+ </xsl:if>
+ <xsl:text>
+ </xsl:text>
+ <xsl:text>
+ od = calloc (1, sizeof(</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplay));
+ if (!od)
+ return FALSE;
+
+ od->screenPrivateIndex = allocateScreenPrivateIndex(d);
+ if (od->screenPrivateIndex &lt; 0)
+ {
+ free(od);
+ return FALSE;
+ }
+
+ d->base.privates[</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplayPrivateIndex].ptr = od;
+
+ </xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:text>if (!compInitDisplayOptionsFromMetadata (d, &amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsMetadata, </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsDisplayOptionInfo, od->opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum))
+ {
+ free (od);
+ return FALSE;
+ }
+</xsl:text>
+ </xsl:if>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:if test="@type = 'list' and ./desc/value and ./type/text() = 'int'">
+ <xsl:text> o = &amp;od->opt[</xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>];
+ </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>-></xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text> = 0;
+ for (i = 0; i &lt; o->value.list.nValue; i++)
+ </xsl:text>
+ <xsl:call-template name="privateName"/>
+ <xsl:text>-></xsl:text>
+ <xsl:value-of select="@name"/>
+ <xsl:text> |= (1 &lt;&lt; o->value.list.value[i].i);
+
+</xsl:text>
+ </xsl:if>
+
+ </xsl:for-each>
+ <xsl:text>
+ return TRUE;
+}
+
+static void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniDisplay (CompPlugin *p, CompDisplay *d)
+{
+ </xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_DISPLAY (d);
+
+ freeScreenPrivateIndex(d, od->screenPrivateIndex);
+</xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:text>
+ compFiniDisplayOptions (d, od->opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum);
+
+</xsl:text>
+ </xsl:if>
+ <xsl:text> free (od);
+ d->base.privates[</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplayPrivateIndex].ptr = NULL;
+}
+
+</xsl:text>
+ </xsl:template>
+
+<!-- init/fini plugin -->
+
+ <xsl:template name="initFini">
+ <xsl:text>static Bool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInit (CompPlugin *p)
+{
+ </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplayPrivateIndex = allocateDisplayPrivateIndex();
+ if (</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplayPrivateIndex &lt; 0)
+ return FALSE;
+
+ if (!compInitPluginMetadataFromInfo (&amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsMetadata, "</xsl:text>
+ <xsl:value-of select="$pName"/>
+ <xsl:text>",</xsl:text>
+ <xsl:choose>
+ <xsl:when test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsDisplayOptionInfo, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum, </xsl:text>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:text>0, 0, </xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+ <xsl:choose>
+ <xsl:when test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsScreenOptionInfo, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum</xsl:text>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:text>0, 0</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+<xsl:text>))
+ return FALSE;
+
+ compAddMetadataFromFile (&amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsMetadata, "</xsl:text>
+ <xsl:value-of select="$metaname"/>
+ <xsl:text>");
+ if (</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable &amp;&amp; </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->init)
+ return </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->init (p);
+ return TRUE;
+}
+
+static void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFini (CompPlugin *p)
+{
+ if (</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable &amp;&amp; </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->fini)
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->fini (p);
+
+ if (</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplayPrivateIndex >= 0)
+ freeDisplayPrivateIndex (</xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>OptionsDisplayPrivateIndex);
+
+ compFiniMetadata (&amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsMetadata);
+}
+
+</xsl:text>
+ </xsl:template>
+
+<!-- init/fini object plugin -->
+
+ <xsl:template name="initFiniObject">
+ <xsl:text>static CompBool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitObject (CompPlugin *p, CompObject *o)
+{
+ static InitPluginObjectProc dispTab[] = {
+ (InitPluginObjectProc) 0,
+ (InitPluginObjectProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitDisplay,
+ (InitPluginObjectProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitScreen
+ };
+
+ RETURN_DISPATCH (o, dispTab, ARRAY_SIZE (dispTab), TRUE, (p, o));
+}
+
+static void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniObject (CompPlugin *p, CompObject *o)
+{
+ static FiniPluginObjectProc dispTab[] = {
+ (FiniPluginObjectProc) 0,
+ (FiniPluginObjectProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniDisplay,
+ (FiniPluginObjectProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniScreen
+ };
+
+ DISPATCH (o, dispTab, ARRAY_SIZE (dispTab), (p, o));
+}
+
+static CompBool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitObjectWrapper (CompPlugin *p, CompObject *o)
+{
+ CompBool rv = TRUE;
+ rv = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitObject (p, o);
+ if (</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->initObject)
+ rv &amp;= </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->initObject (p, o);
+ return rv;
+}
+
+static void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniObjectWrapper (CompPlugin *p, CompObject *o)
+{
+ if (</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->finiObject)
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable->finiObject (p, o);
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniObject (p, o);
+}
+
+</xsl:text>
+ </xsl:template>
+
+<!-- get/set object options -->
+
+ <xsl:template name="getSetObject">
+ <xsl:text>static CompOption * </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetObjectOptions (CompPlugin *p, CompObject *o, int *count)
+{
+ static GetPluginObjectOptionsProc dispTab[] = {
+ (GetPluginObjectOptionsProc) 0,
+ </xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:text> (GetPluginObjectOptionsProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetDisplayOptions,
+ </xsl:text>
+ </xsl:if>
+ <xsl:if test="not(/compiz/plugin[@name=$pName]/display/descendant-or-self::option)">
+ <xsl:text> (GetPluginObjectOptionsProc) 0,
+ </xsl:text>
+ </xsl:if>
+ <xsl:if test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:text> (GetPluginObjectOptionsProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetScreenOptions
+ </xsl:text>
+ </xsl:if>
+ <xsl:text>};
+
+ *count = 0;
+ RETURN_DISPATCH (o, dispTab, ARRAY_SIZE (dispTab),
+ NULL, (p, o, count));
+}
+
+static CompBool </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsSetObjectOption (CompPlugin *p, CompObject *o, const char *name, CompOptionValue *value)
+{
+ static SetPluginObjectOptionProc dispTab[] = {
+ (SetPluginObjectOptionProc) 0,
+ </xsl:text>
+ <xsl:if test="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:text> (SetPluginObjectOptionProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsSetDisplayOption,
+ </xsl:text>
+ </xsl:if>
+ <xsl:if test="not(/compiz/plugin[@name=$pName]/display/descendant-or-self::option)">
+ <xsl:text> (SetPluginObjectOptionProc) 0,
+ </xsl:text>
+ </xsl:if>
+ <xsl:if test="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:text> (SetPluginObjectOptionProc) </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsSetScreenOption
+ </xsl:text>
+ </xsl:if>
+ <xsl:text>};
+
+ RETURN_DISPATCH (o, dispTab, ARRAY_SIZE (dispTab), FALSE,
+ (p, o, name, value));
+}
+
+</xsl:text>
+ </xsl:template>
+
+<!-- vtable generation -->
+
+ <xsl:template name="getVTable">
+ <xsl:text>static CompMetadata *
+</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetMetadata (CompPlugin *plugin)
+{
+ return &amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsMetadata;
+}
+
+</xsl:text>
+ <xsl:text>CompPluginVTable *getCompPluginInfo20070830 (void)
+{
+ if (!</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable)
+ {
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable = </xsl:text>
+ <xsl:text>getCompPluginInfo ();
+ memcpy(&amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable, </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>PluginVTable, sizeof(CompPluginVTable));
+ </xsl:text>
+
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable.getMetadata = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetMetadata;
+ </xsl:text>
+
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable.init = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInit;
+ </xsl:text>
+
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable.fini = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFini;
+ </xsl:text>
+
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable.initObject = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsInitObjectWrapper;
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable.finiObject = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsFiniObjectWrapper;
+ </xsl:text>
+
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable.getObjectOptions = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsGetObjectOptions;
+ </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable.setObjectOption = </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsSetObjectOption;
+ </xsl:text>
+ <xsl:text>
+ }
+ return &amp;</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>OptionsVTable;
+}
+
+</xsl:text>
+ </xsl:template>
+
+
+<!-- *** header file generation *** -->
+
+ <xsl:template name="hfile">
+ <xsl:call-template name="license"/>
+ <xsl:text>#ifndef _</xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_H
+#define _</xsl:text>
+ <xsl:value-of select="$PLUGIN"/>
+ <xsl:text>_OPTIONS_H
+
+#include &lt;compiz-common.h&gt;
+
+COMPIZ_BEGIN_DECLS
+
+CompPluginVTable * getCompPluginInfo (void);
+
+</xsl:text>
+ <xsl:call-template name="printDisplayOptionsEnum"/>
+ <xsl:call-template name="printScreenOptionsEnum"/>
+ <xsl:call-template name="printOptionEnums"/>
+ <xsl:call-template name="printOptionMasks"/>
+ <xsl:call-template name="printFunctionDefinitions"/>
+ <xsl:text>#ifndef GENERIC_PRIVATE_DEFINES
+#define GENERIC_PRIVATE_DEFINES
+
+#define GET_PLUGIN_CORE(object, plugin) \
+ ((plugin##Core *) (object)->base.privates[plugin##CorePrivateIndex].ptr)
+#define PLUGIN_CORE(object, plugin, prefix) \
+ plugin##Core * prefix##c = GET_PLUGIN_CORE (object, plugin)
+
+#define GET_PLUGIN_DISPLAY(object, plugin) \
+ ((plugin##Display *) \
+ (object)->base.privates[plugin##DisplayPrivateIndex].ptr)
+#define PLUGIN_DISPLAY(object, plugin, prefix) \
+ plugin##Display * prefix##d = GET_PLUGIN_DISPLAY (object, plugin)
+
+#define GET_PLUGIN_SCREEN(object, parent, plugin) \
+ ((plugin##Screen *) \
+ (object)->base.privates[(parent)->screenPrivateIndex].ptr)
+#define PLUGIN_SCREEN(object, plugin, prefix) \
+ plugin##Screen * prefix##s = \
+ GET_PLUGIN_SCREEN (object, \
+ GET_PLUGIN_DISPLAY ((object)->display, plugin), plugin)
+
+#define GET_PLUGIN_WINDOW(object, parent, plugin) \
+ ((plugin##Window *) \
+ (object)->base.privates[(parent)->windowPrivateIndex].ptr)
+#define PLUGIN_WINDOW(object, plugin, prefix) \
+ plugin##Window * prefix##w = \
+ GET_PLUGIN_WINDOW (object, \
+ GET_PLUGIN_SCREEN ((object)->screen, \
+ GET_PLUGIN_DISPLAY ((object)->screen->display, plugin), plugin), plugin)
+
+#endif
+
+COMPIZ_END_DECLS
+
+#endif
+</xsl:text>
+ </xsl:template>
+
+<!-- enums for screen/display options -->
+
+ <xsl:template name="printDisplayOptionsEnum">
+<xsl:text>typedef enum
+{
+</xsl:text>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/display/descendant-or-self::option">
+ <xsl:text> </xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>,
+</xsl:text>
+ </xsl:for-each>
+ <xsl:text> </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptionNum
+</xsl:text>
+<xsl:text>} </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+<xsl:text>DisplayOptions;
+
+typedef void (*</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>DisplayOptionChangeNotifyProc) (CompDisplay *display, CompOption *opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptions num);
+
+CompOption *</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>GetDisplayOption (CompDisplay *d, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>DisplayOptions num);
+
+</xsl:text>
+ </xsl:template>
+
+ <xsl:template name="printScreenOptionsEnum">
+<xsl:text>typedef enum
+{
+</xsl:text>
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/screen/descendant-or-self::option">
+ <xsl:text> </xsl:text>
+ <xsl:call-template name="printOptionsEnumName"/>
+ <xsl:text>,
+</xsl:text>
+ </xsl:for-each>
+ <xsl:text> </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptionNum
+</xsl:text>
+<xsl:text>} </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+<xsl:text>ScreenOptions;
+
+typedef void (*</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>ScreenOptionChangeNotifyProc) (CompScreen *screen, CompOption *opt, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptions num);
+
+CompOption *</xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>GetScreenOption (CompScreen *s, </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:text>ScreenOptions num);
+
+</xsl:text>
+ </xsl:template>
+
+<!-- generate enums/masks for restricted string options -->
+
+ <xsl:template name="printOptionEnums">
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/descendant-or-self::option[(@type = 'int' or (@type = 'list' and ./type/text() = 'int')) and ./desc/value]">
+ <xsl:text>typedef enum
+{
+</xsl:text>
+ <xsl:for-each select="desc/*[(name() = 'name' and not(@xml:lang)) or name() = '_name']">
+ <xsl:text> </xsl:text>
+ <xsl:call-template name="PrintCamel">
+ <xsl:with-param name="text">
+ <xsl:value-of select="../../@name"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ <xsl:call-template name="PrintCamel">
+ <xsl:with-param name="text">
+ <xsl:value-of select="text()"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ <xsl:text> = </xsl:text>
+ <xsl:value-of select="../value/text()"/>
+ <xsl:text>,
+</xsl:text>
+ </xsl:for-each>
+ <xsl:text>} </xsl:text>
+ <xsl:value-of select="$Plugin"/>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Enum;
+
+</xsl:text>
+ </xsl:for-each>
+ </xsl:template>
+
+ <xsl:template name="printOptionMasks">
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/descendant-or-self::option[@type = 'list' and ./desc/value and ./type/text() = 'int']">
+ <xsl:for-each select="desc/*[(name() = 'name' and not(@xml:lang)) or name() = '_name']">
+ <xsl:text>#define </xsl:text>
+ <xsl:call-template name="PrintCamel">
+ <xsl:with-param name="text">
+ <xsl:value-of select="../../@name"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ <xsl:call-template name="PrintCamel">
+ <xsl:with-param name="text">
+ <xsl:value-of select="text()"/>
+ </xsl:with-param>
+ </xsl:call-template>
+ <xsl:text>Mask (1 &lt;&lt; </xsl:text>
+ <xsl:value-of select="../value/text()"/>
+ <xsl:text>)
+</xsl:text>
+ </xsl:for-each>
+ <xsl:text>
+
+</xsl:text>
+ </xsl:for-each>
+ </xsl:template>
+
+<!-- generate get/set function definitions -->
+
+ <xsl:template name="printFunctionDefinitions">
+ <xsl:for-each select="/compiz/plugin[@name=$pName]/descendant-or-self::option">
+ <xsl:choose>
+ <xsl:when test="@type='int'">
+ <xsl:text>int </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='float'">
+ <xsl:text>float </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='bool'">
+ <xsl:text>Bool </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='string'">
+ <xsl:text>char * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='match'">
+ <xsl:text>CompMatch * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='color'">
+ <xsl:text>unsigned short * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Red (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>);
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Green (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>);
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Blue (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>);
+unsigned short </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Alpha (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>);
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='action' or @type='key' or @type='button' or @type='edge' or @type='bell'">
+ <xsl:text>CompAction * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Set</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Initiate (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>, CompActionCallBackProc init);
+void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Set</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Terminate (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>, CompActionCallBackProc term);
+</xsl:text>
+ </xsl:when>
+ <xsl:when test="@type='list'">
+ <xsl:text>CompListValue * </xsl:text>
+ <xsl:call-template name="printGetFunctionDef"/>
+ <xsl:text>;
+</xsl:text>
+ <xsl:if test="./type[text() = 'int']/../desc/value">
+ <xsl:text>unsigned int </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Mask (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>);
+</xsl:text>
+ </xsl:if>
+ </xsl:when>
+ </xsl:choose>
+ <xsl:text>CompOption * </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Option (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>);
+void </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Set</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text>Notify (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>, </xsl:text>
+ <xsl:value-of select="$plugin"/>
+ <xsl:call-template name="screenOrDisplay"/>
+ <xsl:text>OptionChangeNotifyProc notify);
+
+</xsl:text>
+ </xsl:for-each>
+ </xsl:template>
+
+ <xsl:template name="printGetFunctionDef">
+ <xsl:value-of select="$plugin"/>
+ <xsl:text>Get</xsl:text>
+ <xsl:call-template name="printOptionName"/>
+ <xsl:text> (</xsl:text>
+ <xsl:call-template name="baseType"/>
+ <xsl:text>)</xsl:text>
+ </xsl:template>
+
+</xsl:stylesheet>
diff --git a/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity_0.8.4.orig.tar.xz b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity_0.8.4.orig.tar.xz
new file mode 100644
index 00000000..2e7fbe84
--- /dev/null
+++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity_0.8.4.orig.tar.xz
Binary files differ