diff options
author | Michele Calgaro <michele.calgaro@yahoo.it> | 2020-09-11 14:38:47 +0900 |
---|---|---|
committer | Michele Calgaro <michele.calgaro@yahoo.it> | 2020-09-11 14:38:47 +0900 |
commit | 884c8093d63402a1ad0b502244b791e3c6782be3 (patch) | |
tree | a600d4ab0d431a2bdfe4c15b70df43c14fbd8dd0 /debian/compiz-fusion-bcop-trinity | |
parent | 14e1aa2006796f147f3f4811fb908a6b01e79253 (diff) | |
download | extra-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')
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 <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include <compiz-core.h> + +</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 &</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 &</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 &</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 &</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 &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 &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>"<min></xsl:text> + <xsl:value-of select="./min/text()"/> + <xsl:text></min><max></xsl:text> + <xsl:value-of select="./max/text()"/> + <xsl:text></max>", </xsl:text> + </xsl:when> + <xsl:when test="@type = 'list' and ./type/text()"> + <xsl:text>"<type></xsl:text> + <xsl:value-of select="./type/text()"/> + <xsl:text></type>", </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, &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, &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 < o->value.list.nValue; i++) + </xsl:text> + <xsl:call-template name="privateName"/> + <xsl:text>-></xsl:text> + <xsl:value-of select="@name"/> + <xsl:text> |= (1 << 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, &</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 = &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 < o->value.list.nValue; i++) + </xsl:text> + <xsl:call-template name="privateName"/> + <xsl:text>-></xsl:text> + <xsl:value-of select="@name"/> + <xsl:text> |= (1 << 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 < 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, &</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 = &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 < o->value.list.nValue; i++) + </xsl:text> + <xsl:call-template name="privateName"/> + <xsl:text>-></xsl:text> + <xsl:value-of select="@name"/> + <xsl:text> |= (1 << 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 < 0) + return FALSE; + + if (!compInitPluginMetadataFromInfo (&</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 (&</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 && </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 && </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 (&</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 &= </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 &</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(&</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 &</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 <compiz-common.h> + +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 << </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 Binary files differnew file mode 100644 index 00000000..2e7fbe84 --- /dev/null +++ b/debian/compiz-fusion-bcop-trinity/compiz-fusion-bcop-trinity_0.8.4.orig.tar.xz |