Big Fast Class Generator for C++, initial check-in to git (from CVS, no less).
This commit is contained in:
commit
7d1fbc4930
|
@ -0,0 +1,6 @@
|
||||||
|
*.pyc
|
||||||
|
*.pyo
|
||||||
|
*#
|
||||||
|
.#*
|
||||||
|
.DS_Store
|
||||||
|
*~
|
|
@ -0,0 +1,5 @@
|
||||||
|
Elf M. Sternberg <elf@drizzle.com>
|
||||||
|
|
||||||
|
Thanks to John F. Hubbard for the initial design and C++ implementation,
|
||||||
|
and special thanks for his permission to release the Python version
|
||||||
|
under the GPL.
|
|
@ -0,0 +1,340 @@
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 2, June 1991
|
||||||
|
|
||||||
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
||||||
|
59 Temple Place, Suite 330, Boston, MA 02111-1307 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 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.
|
|
@ -0,0 +1,6 @@
|
||||||
|
Basic Installation
|
||||||
|
==================
|
||||||
|
|
||||||
|
bigfcc.py is a simple python script. Just put it somewhere in your path
|
||||||
|
and run it. You may have to modify the first line to point to your
|
||||||
|
python executable.
|
|
@ -0,0 +1,18 @@
|
||||||
|
FILES = AUTHORS COPYING INSTALL README TODO \
|
||||||
|
bigfcc.py bigfcc_man.tex Makefile
|
||||||
|
|
||||||
|
TARFILES = ${FILES} bigfcc_man.html bigfcc.1 bigfcc.man
|
||||||
|
|
||||||
|
bigfcc_man.html: bigfcc_man.tex
|
||||||
|
latex2man -H bigfcc_man.tex bigfcc_man.html
|
||||||
|
|
||||||
|
bigfcc.1: bigfcc_man.tex
|
||||||
|
latex2man bigfcc_man.tex bigfcc.1
|
||||||
|
|
||||||
|
bigfcc.man: bigfcc.1
|
||||||
|
nroff -Tascii -man bigfcc.1 > bigfcc.man
|
||||||
|
|
||||||
|
all: ${TARFILES}
|
||||||
|
|
||||||
|
archive: all
|
||||||
|
tar cvf - ${TARFILES} | gzip -9c > bigfcc.tar.gz
|
|
@ -0,0 +1,14 @@
|
||||||
|
This is a distribution of bigfcc.py, a C++ Class Framework generator
|
||||||
|
|
||||||
|
* Licensing
|
||||||
|
|
||||||
|
This program is released under the terms of the GNU General Public
|
||||||
|
License (GNU GPL).
|
||||||
|
|
||||||
|
You can find a copy of the license in the file COPYING.
|
||||||
|
|
||||||
|
* Using:
|
||||||
|
|
||||||
|
Bigfcc comes with a complete list of commands that can be seen by
|
||||||
|
running the command with no arguments. See the man page that comes
|
||||||
|
with it.
|
|
@ -0,0 +1,229 @@
|
||||||
|
'\" t
|
||||||
|
.\" Manual page created with latex2man on Thu Oct 11 15:40:18 PDT 2001
|
||||||
|
.\" NOTE: This file is generated, DO NOT EDIT.
|
||||||
|
.de Vb
|
||||||
|
.ft CW
|
||||||
|
.nf
|
||||||
|
..
|
||||||
|
.de Ve
|
||||||
|
.ft R
|
||||||
|
|
||||||
|
.fi
|
||||||
|
..
|
||||||
|
.TH "FCC" "1" "11 October 2001" "C++ Development Tools "
|
||||||
|
.SH NAME
|
||||||
|
|
||||||
|
.PP
|
||||||
|
fcc
|
||||||
|
is a tool to rapidly generate the basic framework of C++
|
||||||
|
class and components. fcc
|
||||||
|
can generate inline files, testing
|
||||||
|
components, and basic copyright notices.
|
||||||
|
.PP
|
||||||
|
.SH SYNOPSIS
|
||||||
|
|
||||||
|
.PP
|
||||||
|
fcc
|
||||||
|
\fB\-class \fP\fIlist of class names\fP
|
||||||
|
\fB\-author \fP\fIauthor\&'s name\fP
|
||||||
|
[\fB\-namespace \fP\fInamespace_name\fP]
|
||||||
|
[\fB\-overwrite\fP]
|
||||||
|
[\fB\-verbose\fP]
|
||||||
|
[\fB\-no_unit_test\fP]
|
||||||
|
[\fB\-no_makefile\fP]
|
||||||
|
[\fB\-project \fP\fIproject_name\fP]
|
||||||
|
[\fB\-sccs_keywords\fP]
|
||||||
|
[\fB\-continuus_keywords\fP]
|
||||||
|
[\fB\-open_source_notice\fP]
|
||||||
|
[\fB\-copyright \fP[\fIcopyright\fP]]
|
||||||
|
[\fB\-base_filename \fP\fIbase_filename\fP]
|
||||||
|
[\fB\-no_copy_ctor\fP]
|
||||||
|
[\fB\-no_assignment_operator\fP]
|
||||||
|
[\fB\-no_ctor\fP]
|
||||||
|
[\fB\-no_dtor\fP]
|
||||||
|
[\fB\-public_copy_ctor\fP]
|
||||||
|
[\fB\-public_assignment_operator\fP]
|
||||||
|
[\fB\-no_dump_diagnostics\fP]
|
||||||
|
[\fB\-no_check_valid\fP]
|
||||||
|
[\fB\-no_icc\fP]
|
||||||
|
[\fB\-settings_file \fP\fIfilename\fP]
|
||||||
|
.PP
|
||||||
|
.SH DESCRIPTION
|
||||||
|
|
||||||
|
fcc
|
||||||
|
takes the name of one or more classes and generates the
|
||||||
|
appropriate code and header files for those classes. By default, it
|
||||||
|
includes a constructor, destructor, private copy constructor, private
|
||||||
|
assignment operator, unit testing, and appropriate inlines. It also
|
||||||
|
generates a raw BSD\-style makefile.
|
||||||
|
.PP
|
||||||
|
.SH OPTIONS
|
||||||
|
|
||||||
|
.TP
|
||||||
|
\fB\-class \fP\fIlist of class names\fP
|
||||||
|
Names of classes to be
|
||||||
|
generated. The files will be named after the first class name on the
|
||||||
|
list. Class names must be separated by whitespace.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-author \fP\fIauthor\&'s name\fP
|
||||||
|
Your name here.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-namespace \fP\fInamespace name\fP
|
||||||
|
Wrap the output in a
|
||||||
|
specified namespace.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-verbose\fP
|
||||||
|
Explain in excruciating detail what the program
|
||||||
|
is doing.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_unit_test\fP
|
||||||
|
Do not generate unit\-testing definitions in
|
||||||
|
the source files. This is an empty method; it\&'s up to the user to
|
||||||
|
define appropriate tests.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_makefile\fP
|
||||||
|
Do not generate a makefile for this code.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-project \fP\fIproject_name\fP
|
||||||
|
Define a project for this makefile. Right now
|
||||||
|
this option does nothing.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-sccs_keywords\fP
|
||||||
|
Generate IDs appropriate to SCCS.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-continuus_keywords\fP
|
||||||
|
Generate keywords for the Continuus
|
||||||
|
Version System.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-open_source_notice\fP
|
||||||
|
Add some comments about how this code
|
||||||
|
is open source and permission to copy in granted yadda yadda...
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-copyright \fP[\fIcopyright\fP]
|
||||||
|
Adds your copyright notice to the
|
||||||
|
code.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-base_filename \fP\fIbase_filename\fP
|
||||||
|
Set the name of the
|
||||||
|
files output. Defaults to first class name listed if not set.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_copy_ctor\fP
|
||||||
|
Do not provide a copy constructor in the
|
||||||
|
output code.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_assignment_operator\fP
|
||||||
|
Do not provide an assignment
|
||||||
|
operator in the output code.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_ctor\fP
|
||||||
|
Do not provide a default constructor in the
|
||||||
|
output code.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_dtor\fP
|
||||||
|
Do not provide a destructor in the output code.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-public_copy_ctor\fP
|
||||||
|
Put the copy constructor in the public
|
||||||
|
section instead of the private section.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-public_assignment_operator\fP
|
||||||
|
Put the assignment operator in
|
||||||
|
the public section instead of the private section.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_dump_diagnostics\fP
|
||||||
|
Do not provide a debugging method.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_check_valid\fP
|
||||||
|
Do not provide a Programming By Contract
|
||||||
|
style method to check for invariants.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-no_icc\fP
|
||||||
|
Do not provide a file for class inlines.
|
||||||
|
.PP
|
||||||
|
.TP
|
||||||
|
\fB\-settings_file \fP\fIfilename\fP
|
||||||
|
Get options from a settings
|
||||||
|
file. Right now this option does nothing.
|
||||||
|
.PP
|
||||||
|
.SH REQUIREMENTS
|
||||||
|
|
||||||
|
.PP
|
||||||
|
.RS
|
||||||
|
.TP
|
||||||
|
Python
|
||||||
|
fcc
|
||||||
|
requires Python version >= 2.0
|
||||||
|
.RE
|
||||||
|
.RS
|
||||||
|
.PP
|
||||||
|
.SH VERSION
|
||||||
|
|
||||||
|
Version: 0.8a of May 5, 2001
|
||||||
|
.PP
|
||||||
|
.SH LICENSE AND COPYRIGHT
|
||||||
|
|
||||||
|
.PP
|
||||||
|
.RS
|
||||||
|
.RE
|
||||||
|
.TP
|
||||||
|
Copyright
|
||||||
|
(C)2001, Elf M. Sternberg
|
||||||
|
.br
|
||||||
|
\fBelf@drizzle.com\fP
|
||||||
|
.br
|
||||||
|
\fBhttp://www.drizzle.com/ elf\fP
|
||||||
|
.RS
|
||||||
|
.PP
|
||||||
|
.RE
|
||||||
|
.TP
|
||||||
|
License
|
||||||
|
This program can be redistributed and/or modified under the
|
||||||
|
terms of the GNU Public License. See the file COPYING or visit
|
||||||
|
\fBhttp://www.gnu.org/copyleft/gpl.html\fP
|
||||||
|
for terms of use and
|
||||||
|
distribution.
|
||||||
|
.RS
|
||||||
|
.PP
|
||||||
|
.RE
|
||||||
|
.TP
|
||||||
|
Misc
|
||||||
|
If you find this software useful, please drop me some email
|
||||||
|
.RS
|
||||||
|
.PP
|
||||||
|
.RE
|
||||||
|
.TP
|
||||||
|
Misc
|
||||||
|
This man page was generated using latex2man by Dr. Jurgen
|
||||||
|
Vollmer, and is available from the CTAN archives.
|
||||||
|
.RE
|
||||||
|
.RS
|
||||||
|
.PP
|
||||||
|
.SH AUTHOR
|
||||||
|
|
||||||
|
.PP
|
||||||
|
Elf M. Sternberg
|
||||||
|
.br
|
||||||
|
Email: \fBelf@drizzle.com\fP
|
||||||
|
.br
|
||||||
|
WWW: \fBhttp://www.drizzle.com/ elf\fP\&.
|
||||||
|
.\" NOTE: This file is generated, DO NOT EDIT.
|
|
@ -0,0 +1,264 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FCC(1) FCC(1)
|
||||||
|
|
||||||
|
|
||||||
|
NNAAMMEE
|
||||||
|
fcc is a tool to rapidly generate the basic framework of
|
||||||
|
C++ class and components. fcc can generate inline files,
|
||||||
|
testing components, and basic copyright notices.
|
||||||
|
|
||||||
|
|
||||||
|
SSYYNNOOPPSSIISS
|
||||||
|
fcc --ccllaassss _l_i_s_t _o_f _c_l_a_s_s _n_a_m_e_s --aauutthhoorr _a_u_t_h_o_r_'_s _n_a_m_e
|
||||||
|
[--nnaammeessppaaccee _n_a_m_e_s_p_a_c_e___n_a_m_e] [--oovveerrwwrriittee] [--vveerrbboossee]
|
||||||
|
[--nnoo__uunniitt__tteesstt] [--nnoo__mmaakkeeffiillee] [--pprroojjeecctt _p_r_o_j_e_c_t___n_a_m_e]
|
||||||
|
[--ssccccss__kkeeyywwoorrddss] [--ccoonnttiinnuuuuss__kkeeyywwoorrddss]
|
||||||
|
[--ooppeenn__ssoouurrccee__nnoottiiccee] [--ccooppyyrriigghhtt [_c_o_p_y_r_i_g_h_t]]
|
||||||
|
[--bbaassee__ffiilleennaammee _b_a_s_e___f_i_l_e_n_a_m_e] [--nnoo__ccooppyy__ccttoorr]
|
||||||
|
[--nnoo__aassssiiggnnmmeenntt__ooppeerraattoorr] [--nnoo__ccttoorr] [--nnoo__ddttoorr] [--ppuubb--
|
||||||
|
lliicc__ccooppyy__ccttoorr] [--ppuubblliicc__aassssiiggnnmmeenntt__ooppeerraattoorr]
|
||||||
|
[--nnoo__dduummpp__ddiiaaggnnoossttiiccss] [--nnoo__cchheecckk__vvaalliidd] [--nnoo__iicccc] [--sseett--
|
||||||
|
ttiinnggss__ffiillee _f_i_l_e_n_a_m_e]
|
||||||
|
|
||||||
|
|
||||||
|
DDEESSCCRRIIPPTTIIOONN
|
||||||
|
fcc takes the name of one or more classes and generates
|
||||||
|
the appropriate code and header files for those classes.
|
||||||
|
By default, it includes a constructor, destructor, private
|
||||||
|
copy constructor, private assignment operator, unit test-
|
||||||
|
ing, and appropriate inlines. It also generates a raw
|
||||||
|
BSD-style makefile.
|
||||||
|
|
||||||
|
|
||||||
|
OOPPTTIIOONNSS
|
||||||
|
--ccllaassss _l_i_s_t _o_f _c_l_a_s_s _n_a_m_e_s
|
||||||
|
Names of classes to be generated. The files will
|
||||||
|
be named after the first class name on the list.
|
||||||
|
Class names must be separated by whitespace.
|
||||||
|
|
||||||
|
|
||||||
|
--aauutthhoorr _a_u_t_h_o_r_'_s _n_a_m_e
|
||||||
|
Your name here.
|
||||||
|
|
||||||
|
|
||||||
|
--nnaammeessppaaccee _n_a_m_e_s_p_a_c_e _n_a_m_e
|
||||||
|
Wrap the output in a specified namespace.
|
||||||
|
|
||||||
|
|
||||||
|
--vveerrbboossee
|
||||||
|
Explain in excruciating detail what the program is
|
||||||
|
doing.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__uunniitt__tteesstt
|
||||||
|
Do not generate unit-testing definitions in the
|
||||||
|
source files. This is an empty method; it's up to
|
||||||
|
the user to define appropriate tests.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
C++ Development Tools 11 October 2001 1
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FCC(1) FCC(1)
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__mmaakkeeffiillee
|
||||||
|
Do not generate a makefile for this code.
|
||||||
|
|
||||||
|
|
||||||
|
--pprroojjeecctt _p_r_o_j_e_c_t___n_a_m_e
|
||||||
|
Define a project for this makefile. Right now this
|
||||||
|
option does nothing.
|
||||||
|
|
||||||
|
|
||||||
|
--ssccccss__kkeeyywwoorrddss
|
||||||
|
Generate IDs appropriate to SCCS.
|
||||||
|
|
||||||
|
|
||||||
|
--ccoonnttiinnuuuuss__kkeeyywwoorrddss
|
||||||
|
Generate keywords for the Continuus Version Sys-
|
||||||
|
tem.
|
||||||
|
|
||||||
|
|
||||||
|
--ooppeenn__ssoouurrccee__nnoottiiccee
|
||||||
|
Add some comments about how this code is open
|
||||||
|
source and permission to copy in granted yadda
|
||||||
|
yadda...
|
||||||
|
|
||||||
|
|
||||||
|
--ccooppyyrriigghhtt [_c_o_p_y_r_i_g_h_t]
|
||||||
|
Adds your copyright notice to the code.
|
||||||
|
|
||||||
|
|
||||||
|
--bbaassee__ffiilleennaammee _b_a_s_e___f_i_l_e_n_a_m_e
|
||||||
|
Set the name of the files output. Defaults to
|
||||||
|
first class name listed if not set.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__ccooppyy__ccttoorr
|
||||||
|
Do not provide a copy constructor in the output
|
||||||
|
code.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__aassssiiggnnmmeenntt__ooppeerraattoorr
|
||||||
|
Do not provide an assignment operator in the out-
|
||||||
|
put code.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__ccttoorr
|
||||||
|
Do not provide a default constructor in the output
|
||||||
|
code.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__ddttoorr
|
||||||
|
Do not provide a destructor in the output code.
|
||||||
|
|
||||||
|
|
||||||
|
--ppuubblliicc__ccooppyy__ccttoorr
|
||||||
|
Put the copy constructor in the public section
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
C++ Development Tools 11 October 2001 2
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FCC(1) FCC(1)
|
||||||
|
|
||||||
|
|
||||||
|
instead of the private section.
|
||||||
|
|
||||||
|
|
||||||
|
--ppuubblliicc__aassssiiggnnmmeenntt__ooppeerraattoorr
|
||||||
|
Put the assignment operator in the public section
|
||||||
|
instead of the private section.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__dduummpp__ddiiaaggnnoossttiiccss
|
||||||
|
Do not provide a debugging method.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__cchheecckk__vvaalliidd
|
||||||
|
Do not provide a Programming By Contract style
|
||||||
|
method to check for invariants.
|
||||||
|
|
||||||
|
|
||||||
|
--nnoo__iicccc
|
||||||
|
Do not provide a file for class inlines.
|
||||||
|
|
||||||
|
|
||||||
|
--sseettttiinnggss__ffiillee _f_i_l_e_n_a_m_e
|
||||||
|
Get options from a settings file. Right now this
|
||||||
|
option does nothing.
|
||||||
|
|
||||||
|
|
||||||
|
RREEQQUUIIRREEMMEENNTTSS
|
||||||
|
Python fcc requires Python version >= 2.0
|
||||||
|
|
||||||
|
|
||||||
|
VVEERRSSIIOONN
|
||||||
|
Version: 0.8a of May 5, 2001
|
||||||
|
|
||||||
|
|
||||||
|
LLIICCEENNSSEE AANNDD CCOOPPYYRRIIGGHHTT
|
||||||
|
Copyright
|
||||||
|
(C)2001, Elf M. Sternberg
|
||||||
|
eellff@@ddrriizzzzllee..ccoomm
|
||||||
|
hhttttpp::////wwwwww..ddrriizzzzllee..ccoomm// eellff
|
||||||
|
|
||||||
|
|
||||||
|
License
|
||||||
|
This program can be redistributed and/or modified
|
||||||
|
under the terms of the GNU Public License. See the
|
||||||
|
file COPYING or visit hhttttpp::////wwwwww..ggnnuu..oorrgg//ccooppyy--
|
||||||
|
lleefftt//ggppll..hhttmmll for terms of use and distribution.
|
||||||
|
|
||||||
|
|
||||||
|
Misc If you find this software useful, please drop me
|
||||||
|
some email
|
||||||
|
|
||||||
|
|
||||||
|
Misc This man page was generated using latex2man by Dr.
|
||||||
|
Jurgen Vollmer, and is available from the CTAN
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
C++ Development Tools 11 October 2001 3
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FCC(1) FCC(1)
|
||||||
|
|
||||||
|
|
||||||
|
archives.
|
||||||
|
|
||||||
|
|
||||||
|
AAUUTTHHOORR
|
||||||
|
Elf M. Sternberg
|
||||||
|
Email: eellff@@ddrriizzzzllee..ccoomm
|
||||||
|
WWW: hhttttpp::////wwwwww..ddrriizzzzllee..ccoomm// eellff.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
C++ Development Tools 11 October 2001 4
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,596 @@
|
||||||
|
#!/usr/local/bin/python
|
||||||
|
|
||||||
|
from StringIO import StringIO
|
||||||
|
import string
|
||||||
|
import sys
|
||||||
|
import time
|
||||||
|
|
||||||
|
class WriteSentry:
|
||||||
|
'''
|
||||||
|
Purpose: WriteSentry encapsulates the way an output file is written
|
||||||
|
to. It also provides a convenient way to open, write to, and close
|
||||||
|
a file, merely by declaring a WriteSentry object in a given Python
|
||||||
|
scope. When the WriteSentry object goes out of scope, the __del__
|
||||||
|
method is called, and the file is flushed and closed.
|
||||||
|
'''
|
||||||
|
|
||||||
|
VERBOSE = 1;
|
||||||
|
OVERWRITE = 2;
|
||||||
|
|
||||||
|
def __init__( self, fileName, mode, reallyCreate = 1 ):
|
||||||
|
mode = mode or self.VERBOSE
|
||||||
|
self.outputFile = None
|
||||||
|
if reallyCreate:
|
||||||
|
bCreateTheFile = ( mode & self.OVERWRITE ) != 0
|
||||||
|
if not bCreateTheFile:
|
||||||
|
try:
|
||||||
|
fd = open( fileName, "r" );
|
||||||
|
self.outputFile = open( "/dev/null", "w" )
|
||||||
|
if ( mode & self.VERBOSE ):
|
||||||
|
print "Did NOT create " + fileName + " because it already exists."
|
||||||
|
fd.close
|
||||||
|
except:
|
||||||
|
bCreateTheFile = 1;
|
||||||
|
|
||||||
|
if bCreateTheFile:
|
||||||
|
try:
|
||||||
|
self.outputFile = open( fileName, "w" )
|
||||||
|
if ( mode & self.VERBOSE ):
|
||||||
|
print "Created " + fileName + "\n"
|
||||||
|
except IOError, e:
|
||||||
|
print "Could not create file " + str( e )
|
||||||
|
raise
|
||||||
|
|
||||||
|
def __del__( self ):
|
||||||
|
if self.outputFile != None:
|
||||||
|
self.outputFile.close()
|
||||||
|
|
||||||
|
def getStream( self ):
|
||||||
|
return self.outputFile
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class DigestedCommands:
|
||||||
|
|
||||||
|
usage = \
|
||||||
|
"*******************************************************************************\n" + \
|
||||||
|
"Fast Class Creator Version 2.35b, Created by John F. Hubbard, 20 April 2001\n" + \
|
||||||
|
"Ported to Python 13 May 2001 by Elf M. Sternberg\n\n" + \
|
||||||
|
"Usage: fcc -class <list_of_class_names> (see example below)\n" + \
|
||||||
|
" -author <authors_name> \n" + \
|
||||||
|
" [-namespace <namespace_name> | -ns <namespace_name>]\n" + \
|
||||||
|
" [-overwrite | -ow]\n" + \
|
||||||
|
" [-verbose | -v]\n" + \
|
||||||
|
" [-no_unit_test | -no_ut]\n" + \
|
||||||
|
" [-no_makefile | -no_mf]\n" + \
|
||||||
|
" [-project <project_name>]\n" + \
|
||||||
|
" [-sccs_keywords | -sccs]\n" + \
|
||||||
|
" [-continuus_keywords | -ct]\n" + \
|
||||||
|
" [-open_source_notice | -os]\n" + \
|
||||||
|
" [-copyright <copyright> | -c <copyright>]\n" + \
|
||||||
|
" [-base_filename <base_filename> | -file <base_filename>]\n" + \
|
||||||
|
" [-no_copy_ctor]\n" + \
|
||||||
|
" [-no_assignment_operator | -no_op =]\n" + \
|
||||||
|
" [-no_ctor]\n" + \
|
||||||
|
" [-no_dtor]\n" + \
|
||||||
|
" [-public_copy_ctor]\n" + \
|
||||||
|
" [-public_assignment_operator | -pub_op =]\n" + \
|
||||||
|
" [-no_dump_diagnostics | -no_dd]\n" + \
|
||||||
|
" [-no_check_valid | -no_cv]\n" + \
|
||||||
|
" [-no_icc]\n" + \
|
||||||
|
" [-settings_file <filename>]\n\n" + \
|
||||||
|
"Abbreviations: ctor = constructor, dtor = destructor\n\n" + \
|
||||||
|
"A simple example:\n\n" + \
|
||||||
|
" fcc -verbose -class Airplane -namespace airport -author \"John F. Hubbard\"\n\n" + \
|
||||||
|
"This example generates several classes in the same set of FruitFiles.xxx files:\n\n" + \
|
||||||
|
" fcc -file FruitFiles -class Apple Orange Pear " + \
|
||||||
|
"-ns fruits -author \"John F. Hubbard\"\n\n" + \
|
||||||
|
"*******************************************************************************\n\n"
|
||||||
|
|
||||||
|
def __init__( self, arglist = sys.argv[1:] ):
|
||||||
|
j = 0
|
||||||
|
self.arglist = arglist
|
||||||
|
self.argkeys = {}
|
||||||
|
for i in arglist:
|
||||||
|
self.argkeys[i] = j
|
||||||
|
j = j + 1
|
||||||
|
|
||||||
|
if not ( self.argkeys.has_key( "-class" ) and self.argkeys.has_key( "-author" ) ):
|
||||||
|
raise self.usage
|
||||||
|
|
||||||
|
self.classList = self.getArgument( "-class" )
|
||||||
|
self.author = self.getArgument( "-author" )
|
||||||
|
|
||||||
|
# Added to support multiple classes per file, and control of copy/assignment:
|
||||||
|
self.sccsKeywords = ( self.argkeys.has_key( "-sccs_keywords" ) or
|
||||||
|
self.argkeys.has_key( "-sccs" ) )
|
||||||
|
self.continuousKeywords = ( self.argkeys.has_key( "-continuus_keywords" ) or
|
||||||
|
self.argkeys.has_key( "-ct" ) )
|
||||||
|
self.openSourceNotice = ( self.argkeys.has_key( "-open_source_notice" ) or
|
||||||
|
self.argkeys.has_key( "-os" ) )
|
||||||
|
|
||||||
|
if self.argkeys.has_key( "-copyright" ):
|
||||||
|
self.copyright = self.getArgument( "-copyright" )
|
||||||
|
|
||||||
|
elif self.argkeys.has_key( "-c" ):
|
||||||
|
self.copyright = self.getArgument( "-c" )
|
||||||
|
else:
|
||||||
|
self.copyright = \
|
||||||
|
" * Put Your Copyright Notice here\n"
|
||||||
|
|
||||||
|
self.createUnitTestFile = not ( self.argkeys.has_key( "-no_unit_test" ) or
|
||||||
|
self.argkeys.has_key( "-no_ut" ) )
|
||||||
|
self.createMakefile = not ( self.argkeys.has_key( "-no_makefile" ) or
|
||||||
|
self.argkeys.has_key( "-no_mf" ) )
|
||||||
|
self.ctor = not self.argkeys.has_key( "-no_ctor" )
|
||||||
|
self.dtor = not self.argkeys.has_key( "-no_dtor" )
|
||||||
|
self.iccFile = not self.argkeys.has_key( "-no_icc" )
|
||||||
|
self.checkValid = not ( self.argkeys.has_key( "-no_check_valid" ) or
|
||||||
|
self.argkeys.has_key( "-no_cv" ) )
|
||||||
|
self.dumpDiagnostics = not ( self.argkeys.has_key( "-no_dump_diagnostics" ) or
|
||||||
|
self.argkeys.has_key( "-no_dd" ) )
|
||||||
|
self.useNamespace = self.argkeys.has_key( "-namespace" ) or self.argkeys.has_key( "-ns" )
|
||||||
|
self.dtor = not self.argkeys.has_key( "-no_dtor" )
|
||||||
|
self.copyCtor = self.ctor and not self.argkeys.has_key( "-no_copy_ctor" )
|
||||||
|
self.assignmentOperator = not ( self.argkeys.has_key( "-no_assignment_operator" ) or
|
||||||
|
self.argkeys.has_key( "-no_op =" ) )
|
||||||
|
self.publicCopyCtor = self.argkeys.has_key( "-public_copy_ctor" ) and self.copyCtor
|
||||||
|
self.publicAssignmentOperator = self.assignmentOperator and \
|
||||||
|
( self.argkeys.has_key( "-public_assignment_operator" ) or
|
||||||
|
self.argkeys.has_key( "-pub_op =" ) )
|
||||||
|
|
||||||
|
self.writeSentryMode = 0
|
||||||
|
|
||||||
|
if ( self.argkeys.has_key( "-verbose" ) or self.argkeys.has_key( "-v" ) ):
|
||||||
|
self.writeSentryMode = self.writeSentryMode | WriteSentry.VERBOSE
|
||||||
|
|
||||||
|
if ( self.argkeys.has_key( "-overwrite" ) or self.argkeys.has_key( "-ow" ) ):
|
||||||
|
self.writeSentryMode = self.writeSentryMode | WriteSentry.OVERWRITE
|
||||||
|
|
||||||
|
if self.argkeys.has_key( "-project" ):
|
||||||
|
self.projectName = self.getArgument( "-project" );
|
||||||
|
|
||||||
|
if self.argkeys.has_key( "-namespace" ):
|
||||||
|
self.namespace = self.getArgument( "-namespace" );
|
||||||
|
elif self.argkeys.has_key( "-ns" ):
|
||||||
|
self.namespace = self.getArgument( "-ns" );
|
||||||
|
|
||||||
|
self.classNames = self.getArglist( "-class" )
|
||||||
|
|
||||||
|
if self.argkeys.has_key( "-base_filename" ):
|
||||||
|
self.baseFilename = self.getArgument( "-base_filename" );
|
||||||
|
elif self.argkeys.has_key( "-file" ):
|
||||||
|
self.baseFilename = self.getArgument( "-file" )
|
||||||
|
else:
|
||||||
|
self.baseFilename = self.classNames[0]
|
||||||
|
|
||||||
|
self.headerFile = self.baseFilename + ".h"
|
||||||
|
self.implFile = self.baseFilename + ".cpp"
|
||||||
|
self.inlineFile = self.baseFilename + ".icc"
|
||||||
|
self.makefile = "makefile"
|
||||||
|
self.unitTestFile = "ut" + self.baseFilename + ".cpp"
|
||||||
|
|
||||||
|
|
||||||
|
def getArgument( self, arg ):
|
||||||
|
loc = self.argkeys[ arg ] + 1
|
||||||
|
rep = self.arglist[ loc ]
|
||||||
|
if string.find( rep, "-" ) == 0:
|
||||||
|
raise self.usage
|
||||||
|
return rep
|
||||||
|
|
||||||
|
def getArglist( self, arg ):
|
||||||
|
loc = self.argkeys[ arg ] + 1
|
||||||
|
rep = []
|
||||||
|
while( ( loc < len( self.arglist ) ) and
|
||||||
|
( string.find( self.arglist[ loc ], "-" ) == -1 ) ):
|
||||||
|
rep.append( self.arglist[ loc ] )
|
||||||
|
loc = loc + 1
|
||||||
|
if ( len( rep ) == 0 ):
|
||||||
|
raise self.usage
|
||||||
|
return rep
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class CodeGenerator:
|
||||||
|
|
||||||
|
def __init__( self, commands ):
|
||||||
|
self.commands = commands
|
||||||
|
|
||||||
|
def genCommentHeader( self ):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def genPreface( self ):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def genCodeBody( self, className ):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def genEpilogue( self ):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def generateDefaultCommentHeader( self, fileName, io_str ):
|
||||||
|
print >> self.getStream(), \
|
||||||
|
"/*****************************************************************************\n" + \
|
||||||
|
" *\n" + \
|
||||||
|
" * " + fileName + "\n" + \
|
||||||
|
" * Created by " + self.commands.author + ", on " + dateStamp() + "\n" + \
|
||||||
|
" *\n" + \
|
||||||
|
" * " + self.commands.copyright + "\n" + \
|
||||||
|
" *\n",
|
||||||
|
|
||||||
|
if self.commands.openSourceNotice:
|
||||||
|
print >> self.getStream(), \
|
||||||
|
" * Permission is granted to use this code without restriction,\n" + \
|
||||||
|
" * as long as this copyright notice appears in all source files.\n" + \
|
||||||
|
" *\n",
|
||||||
|
|
||||||
|
print >> self.getStream(), io_str.getvalue(),
|
||||||
|
|
||||||
|
if self.commands.continuousKeywords:
|
||||||
|
print >> self.getStream(), \
|
||||||
|
" * %version: 1 %\n" + \
|
||||||
|
" * %date_modified: " + dateStamp() + " %\n" + \
|
||||||
|
" * %created_by: " + self.commands.author + " %\n",
|
||||||
|
|
||||||
|
if self.commands.sccsKeywords:
|
||||||
|
print >> self.getStream(), \
|
||||||
|
" * Version: %I%\n" + \
|
||||||
|
" * Date modified: %G%\n" + \
|
||||||
|
" *\n"
|
||||||
|
print >> self.getStream(), \
|
||||||
|
" *****************************************************************************\n" + \
|
||||||
|
" */\n\n",
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def generateDefaultPreface( self, fileName, io_str ):
|
||||||
|
print >> self.getStream(), \
|
||||||
|
"#include <string>\n" + \
|
||||||
|
"#include <iostream>\n" + \
|
||||||
|
"#include \"" + self.commands.headerFile + "\"\n",
|
||||||
|
|
||||||
|
print >> self.getStream(), io_str.getvalue()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def createUniqueName( self ):
|
||||||
|
if self.commands.useNamespace:
|
||||||
|
return string.upper(self.commands.namespace) + "_" + \
|
||||||
|
string.upper(self.commands.baseFilename) + "_H"
|
||||||
|
else:
|
||||||
|
return string.upper(self.commands.baseFilename) + "_H"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def dateStamp():
|
||||||
|
return time.asctime( time.localtime( time.time() ) )
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class HeaderFileGen( CodeGenerator ):
|
||||||
|
|
||||||
|
def __init__( self, commands ):
|
||||||
|
self.commands = commands
|
||||||
|
self.writer = WriteSentry( self.commands.headerFile,
|
||||||
|
self.commands.writeSentryMode )
|
||||||
|
|
||||||
|
def getStream( self ):
|
||||||
|
return self.writer.getStream()
|
||||||
|
|
||||||
|
|
||||||
|
def genCommentHeader( self ):
|
||||||
|
io_str = StringIO()
|
||||||
|
print >> io_str, " *\n" + \
|
||||||
|
" * File Contents: Interface and documentation of the " + \
|
||||||
|
self.commands.baseFilename + " component.\n" + \
|
||||||
|
" *\n",
|
||||||
|
self.generateDefaultCommentHeader( self.commands.headerFile, io_str )
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def genPreface( self ):
|
||||||
|
print >> self.getStream(), \
|
||||||
|
"#ifndef " + self.createUniqueName() + "\n" + \
|
||||||
|
"#define " + self.createUniqueName() + "\n\n",
|
||||||
|
|
||||||
|
if self.commands.useNamespace:
|
||||||
|
print >> self.getStream(), \
|
||||||
|
"namespace " + self.commands.namespace + "\n" + \
|
||||||
|
"{\n" + \
|
||||||
|
" \n",
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def genCodeBody(self, className ):
|
||||||
|
print >> self.getStream(), "/** Purpose: TODO: Describe the purpose of the class.\n" + \
|
||||||
|
" * (Everything that you write here will show up in the\n" + \
|
||||||
|
" * doc++ generated documentation.)\n" + \
|
||||||
|
" */\n" + \
|
||||||
|
"class " + className + "\n" + \
|
||||||
|
"{\n" + \
|
||||||
|
"public:\n",
|
||||||
|
|
||||||
|
if self.commands.ctor:
|
||||||
|
print >> self.getStream(), " /// Constructor.\n" + \
|
||||||
|
" " + className + "();\n\n",
|
||||||
|
|
||||||
|
if self.commands.dtor:
|
||||||
|
print >> self.getStream(), " /// Destructor.\n" + \
|
||||||
|
" virtual ~" + className + "();\n",
|
||||||
|
|
||||||
|
if self.commands.checkValid:
|
||||||
|
print >> self.getStream(), " \n" + \
|
||||||
|
" /// CheckValid() is designed to check the class invariants.\n" + \
|
||||||
|
" inline CheckValid() const;\n",
|
||||||
|
|
||||||
|
if self.commands.dumpDiagnostics:
|
||||||
|
print >> self.getStream(), " \n" + \
|
||||||
|
" /// DumpDiagnostics() dumps the object's state to standard output.\n" + \
|
||||||
|
" DumpDiagnostics() const;\n" + \
|
||||||
|
" \n",
|
||||||
|
|
||||||
|
if self.commands.publicCopyCtor:
|
||||||
|
print >> self.getStream(), "public:\n" + \
|
||||||
|
" // TODO: Provide an implementation for the copy constructor:\n" + \
|
||||||
|
" " + className + "(const " + className + "&);\n\n",
|
||||||
|
|
||||||
|
elif self.commands.copyCtor:
|
||||||
|
print >> self.getStream(), "private:\n" + \
|
||||||
|
" // Copying of this class is prohibited:\n" + \
|
||||||
|
" " + className + "(const " + className + "&);\n\n",
|
||||||
|
|
||||||
|
if self.commands.publicAssignmentOperator:
|
||||||
|
print >> self.getStream(), "public:\n" + \
|
||||||
|
" // TODO: Provide an implementation for the assignment operator:\n" + \
|
||||||
|
" " + className + "& operator=(const " + className + "&);\n\n",
|
||||||
|
|
||||||
|
elif self.commands.assignmentOperator:
|
||||||
|
print >> self.getStream(), "private:\n" + \
|
||||||
|
" // Assignment to this class is prohibited:\n" + \
|
||||||
|
" " + className + "& operator=(const " + className + "&);\n\n",
|
||||||
|
|
||||||
|
print >> self.getStream(), "};\n",
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def genEpilogue( self ):
|
||||||
|
if self.commands.iccFile:
|
||||||
|
print >> self.getStream(), " \n" + \
|
||||||
|
"#include \"" + self.commands.inlineFile + "\"\n",
|
||||||
|
|
||||||
|
if self.commands.useNamespace:
|
||||||
|
print >> self.getStream(), "} // end of the " + self.commands.namespace + " namespace\n\n",
|
||||||
|
|
||||||
|
print >> self.getStream(), "#endif /* " + self.createUniqueName() + " */\n\n",
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class ImplFileGen( CodeGenerator ):
|
||||||
|
|
||||||
|
def __init__( self, commands ):
|
||||||
|
self.commands = commands
|
||||||
|
self.writer = WriteSentry( self.commands.implFile,
|
||||||
|
self.commands.writeSentryMode)
|
||||||
|
|
||||||
|
def getStream( self ):
|
||||||
|
return self.writer.getStream()
|
||||||
|
|
||||||
|
def genCommentHeader( self ):
|
||||||
|
io_str = StringIO()
|
||||||
|
print >> io_str, " *\n" + \
|
||||||
|
" * File Contents: Implementation of the " + self.commands.baseFilename + " component.\n" + \
|
||||||
|
" * Please see " + self.commands.headerFile + " for full documentation of this system.\n" + \
|
||||||
|
" *\n",
|
||||||
|
self.generateDefaultCommentHeader( self.commands.implFile, io_str )
|
||||||
|
|
||||||
|
def genPreface( self ):
|
||||||
|
io_str = StringIO()
|
||||||
|
self.generateDefaultPreface( self.commands.implFile, io_str )
|
||||||
|
if ( self.commands.useNamespace ):
|
||||||
|
print >> self.getStream(), "namespace " + self.commands.namespace + "\n" + \
|
||||||
|
"{\n" + \
|
||||||
|
" \n"
|
||||||
|
|
||||||
|
|
||||||
|
def genCodeBody( self, className ):
|
||||||
|
if self.commands.ctor :
|
||||||
|
print >> self.getStream(), \
|
||||||
|
className + "::" + className + "()\n" + \
|
||||||
|
"{\n" + \
|
||||||
|
"}\n"
|
||||||
|
|
||||||
|
if self.commands.dtor:
|
||||||
|
print >> self.getStream(), className + "::~" + \
|
||||||
|
className + "()\n" + \
|
||||||
|
"{\n" + \
|
||||||
|
"}\n"
|
||||||
|
|
||||||
|
if self.commands.dumpDiagnostics:
|
||||||
|
print >> self.getStream(), "void\n" + \
|
||||||
|
className + "::DumpDiagnostics() const\n" + \
|
||||||
|
"{\n",
|
||||||
|
|
||||||
|
print >> self.getStream(), ' std::cout << std::endl << std::endl << \n' + \
|
||||||
|
" \"" + className + \
|
||||||
|
" Diagnostics dump \"<< std::endl << std::endl;\n",
|
||||||
|
|
||||||
|
print >> self.getStream(), "}\n"
|
||||||
|
|
||||||
|
def genEpilogue( self ):
|
||||||
|
if self.commands.useNamespace:
|
||||||
|
print >> self.getStream(), \
|
||||||
|
" \n" + \
|
||||||
|
"} // end of the " + self.commands.namespace + " namespace"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class InlineFileGen( CodeGenerator ):
|
||||||
|
|
||||||
|
def __init__( self, commands ):
|
||||||
|
self.commands = commands
|
||||||
|
self.writer = WriteSentry( commands.inlineFile, commands.writeSentryMode )
|
||||||
|
|
||||||
|
def getStream( self ):
|
||||||
|
return self.writer.getStream()
|
||||||
|
|
||||||
|
def genCommentHeader( self ):
|
||||||
|
io_str = StringIO()
|
||||||
|
print >> io_str, " *\n" + \
|
||||||
|
" * File Contents: Inline definitions for the " + self.commands.baseFilename + \
|
||||||
|
" component.\n" + \
|
||||||
|
" * Please see " + self.commands.headerFile + " for full documentation of this class.\n" + \
|
||||||
|
" *\n",
|
||||||
|
self.generateDefaultCommentHeader( self.commands.inlineFile, io_str );
|
||||||
|
|
||||||
|
def genCodeBody( self, className ):
|
||||||
|
if self.commands.checkValid:
|
||||||
|
print >> self.getStream(), "inline void\n" + \
|
||||||
|
className + "::CheckValid() const\n" + \
|
||||||
|
"{\n" + \
|
||||||
|
" // TODO: Fill in with class invariant assertions for " + \
|
||||||
|
className + ".\n" + \
|
||||||
|
"}\n"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class MakefileGen( CodeGenerator ):
|
||||||
|
|
||||||
|
def __init__( self, commands ):
|
||||||
|
self.commands = commands
|
||||||
|
self.writer = WriteSentry( self.commands.makefile,
|
||||||
|
self.commands.writeSentryMode,
|
||||||
|
self.commands.createMakefile )
|
||||||
|
|
||||||
|
def getStream( self ):
|
||||||
|
return self.writer.getStream()
|
||||||
|
|
||||||
|
|
||||||
|
def genCommentHeader( self ):
|
||||||
|
print >> self.getStream(), \
|
||||||
|
"#########################################################################\n" + \
|
||||||
|
"# " + self.commands.makefile + "\n" + \
|
||||||
|
"# Created by " + self.commands.author + " on " + dateStamp() + "\n" + \
|
||||||
|
"#\n" + \
|
||||||
|
"# File Contents: makefile for the " + self.commands.baseFilename + " component.\n" + \
|
||||||
|
"#\n" + \
|
||||||
|
"#########################################################################\n\n"
|
||||||
|
|
||||||
|
def genPreface( self ):
|
||||||
|
print >> self.getStream(), "NAME=" + self.commands.baseFilename
|
||||||
|
|
||||||
|
print >> self.getStream(), "INCLUDES=\n" + \
|
||||||
|
"LIBS=\n" + \
|
||||||
|
"CC=gcc\n" + \
|
||||||
|
"CXX=g++\n" + \
|
||||||
|
"LD=g++\n" + \
|
||||||
|
"LD_FLAGS=\n\n" + \
|
||||||
|
"all: ut${NAME} html\n\n" + \
|
||||||
|
"html: ${NAME}.h \n" + \
|
||||||
|
"\tdoc++ -d html *.h\n" + \
|
||||||
|
"\ttouch html\n\n" + \
|
||||||
|
"CXX_FLAGS=-DLINUX -g -c -fhonor-std \\\n" + \
|
||||||
|
" -fno-builtin -D_REENTRANT -Wall -Wno-unknown-pragmas -Wno-unused\n\n" + \
|
||||||
|
"ut${NAME} : ut${NAME}.o ${NAME}.o\n" + \
|
||||||
|
"\t${LINK} ${LINK_FLAGS} -o ut${NAME} ut${NAME}.o ${NAME}.o ${LIBS}\n\n" + \
|
||||||
|
"${NAME}.o : ${NAME}.cpp ${NAME}.h",
|
||||||
|
|
||||||
|
if self.commands.iccFile:
|
||||||
|
print >> self.getStream(), " ${NAME}.icc",
|
||||||
|
|
||||||
|
print >> self.getStream(), "\n" + \
|
||||||
|
"\t${CXX} ${CXX_FLAGS} ${INCLUDES} -c -o ${NAME}.o ${NAME}.cpp\n\n" + \
|
||||||
|
"ut${NAME}.o : ut${NAME}.cpp ${NAME}.h",
|
||||||
|
|
||||||
|
if self.commands.iccFile:
|
||||||
|
print >> self.getStream(), " ${NAME}.icc",
|
||||||
|
|
||||||
|
print >> self.getStream(), "\n" + \
|
||||||
|
"\t${CXX} ${CXX_FLAGS} ${INCLUDES} -c -o ut${NAME}.o ut${NAME}.cpp\n\n" + \
|
||||||
|
"clean:\n" + \
|
||||||
|
"\trm *.o ut${NAME} html/" "*\n" + \
|
||||||
|
"\trmdir html"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class UnitTestFileGen(CodeGenerator):
|
||||||
|
|
||||||
|
def __init__( self, commands ):
|
||||||
|
self.commands = commands
|
||||||
|
self.writer = WriteSentry( self.commands.unitTestFile,
|
||||||
|
self.commands.writeSentryMode,
|
||||||
|
self.commands.createUnitTestFile )
|
||||||
|
|
||||||
|
def genCommentHeader( self ):
|
||||||
|
io_str = StringIO()
|
||||||
|
print >> io_str, " *\n" + \
|
||||||
|
" * File Contents: Unit test for the the " + self.commands.baseFilename +" component.\n" + \
|
||||||
|
" * Please see " + self.commands.headerFile +" for full documentation of this class.\n" + \
|
||||||
|
" *\n"
|
||||||
|
self.generateDefaultCommentHeader( self.commands.unitTestFile, io_str )
|
||||||
|
|
||||||
|
def genPreface( self ):
|
||||||
|
io_str = StringIO()
|
||||||
|
self.generateDefaultPreface( self.commands.unitTestFile, io_str )
|
||||||
|
print >> self.getStream(), "int main(int argc, char* argv[])\n" + \
|
||||||
|
"{\n"
|
||||||
|
|
||||||
|
|
||||||
|
def genCodeBody( self, className ):
|
||||||
|
if self.commands.useNamespace:
|
||||||
|
print >> self.getStream(), " " + self.commands.namespace +"::"
|
||||||
|
|
||||||
|
print >>self.getStream(), className +" obj" + className +";\n"
|
||||||
|
|
||||||
|
if self.commands.dumpDiagnostics:
|
||||||
|
print >> self.getStream(), " obj" + className +".DumpDiagnostics();\n"
|
||||||
|
|
||||||
|
print >> self.getStream(), "\n"
|
||||||
|
|
||||||
|
def genEpilogue( self ):
|
||||||
|
print >> self.getStream(), " return 0;\n" + \
|
||||||
|
"}\n"
|
||||||
|
|
||||||
|
def getStream( self ):
|
||||||
|
return self.writer.getStream()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class ClassCreator:
|
||||||
|
|
||||||
|
def __init__( self, commands ):
|
||||||
|
self.commands = commands
|
||||||
|
|
||||||
|
def generateCode( self ):
|
||||||
|
self.generateFile( HeaderFileGen )
|
||||||
|
self.generateFile( ImplFileGen )
|
||||||
|
|
||||||
|
if self.commands.iccFile:
|
||||||
|
self.generateFile( InlineFileGen )
|
||||||
|
|
||||||
|
if self.commands.createMakefile:
|
||||||
|
self.generateFile( MakefileGen )
|
||||||
|
|
||||||
|
if self.commands.createUnitTestFile:
|
||||||
|
self.generateFile( UnitTestFileGen )
|
||||||
|
|
||||||
|
def generateFile( self, inclass ):
|
||||||
|
generator = inclass( self.commands )
|
||||||
|
|
||||||
|
generator.genCommentHeader(); # The comment header with author, description, etc.
|
||||||
|
generator.genPreface(); # #ifdef directives, for example.
|
||||||
|
|
||||||
|
for i in self.commands.classNames:
|
||||||
|
generator.genCodeBody( i ); # generate each class.
|
||||||
|
|
||||||
|
generator.genEpilogue();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
commands = DigestedCommands( )
|
||||||
|
creator = ClassCreator( commands )
|
||||||
|
creator.generateCode()
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,232 @@
|
||||||
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
|
||||||
|
<!-- Manual page created with latex2man on Thu Oct 11 15:40:11 PDT 2001 --
|
||||||
|
-- Author of latex2man: Juergen.Vollmer@acm.org --
|
||||||
|
-- NOTE: This file is generated, DO NOT EDIT. -->
|
||||||
|
<html>
|
||||||
|
<head><title>FCC</title></head>
|
||||||
|
<body bgcolor="white">
|
||||||
|
<h1 align=center>
|
||||||
|
fcc -<br>
|
||||||
|
Fast Class Generator
|
||||||
|
</h1>
|
||||||
|
<h4 align=center>Elf M. Sternberg </h4>
|
||||||
|
<h4 align=center>11 October 2001</h4>
|
||||||
|
<h4 align=center>Version 0.8a</h4>
|
||||||
|
<p>
|
||||||
|
<tt>fcc</tt>
|
||||||
|
is a tool to rapidly generate the basic framework of C++
|
||||||
|
class and components. <tt>fcc</tt>
|
||||||
|
can generate inline files, testing
|
||||||
|
components, and basic copyright notices.
|
||||||
|
<p>
|
||||||
|
<h3>Table of Contents</h3>
|
||||||
|
<ul>
|
||||||
|
<li><a href="#section_1">Synopsis </a></li>
|
||||||
|
<li><a href="#section_2">Description </a></li>
|
||||||
|
<li><a href="#section_3">Options </a></li>
|
||||||
|
<li><a href="#section_4">Requirements </a></li>
|
||||||
|
<li><a href="#section_5">Version </a></li>
|
||||||
|
<li><a href="#section_6">License and Copyright </a></li>
|
||||||
|
<li><a href="#section_7">Author </a>
|
||||||
|
</li></ul>
|
||||||
|
<p>
|
||||||
|
<h2><a name="section_1">Synopsis</a></h2>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<tt>fcc</tt>
|
||||||
|
<b>-class </b><i>list of class names</i>
|
||||||
|
<b>-author </b><i>author's name</i>
|
||||||
|
[<b>-namespace </b><i>namespace_name</i>]
|
||||||
|
[<b>-overwrite</b>]
|
||||||
|
[<b>-verbose</b>]
|
||||||
|
[<b>-no_unit_test</b>]
|
||||||
|
[<b>-no_makefile</b>]
|
||||||
|
[<b>-project </b><i>project_name</i>]
|
||||||
|
[<b>-sccs_keywords</b>]
|
||||||
|
[<b>-continuus_keywords</b>]
|
||||||
|
[<b>-open_source_notice</b>]
|
||||||
|
[<b>-copyright </b>[<i>copyright</i>]]
|
||||||
|
[<b>-base_filename </b><i>base_filename</i>]
|
||||||
|
[<b>-no_copy_ctor</b>]
|
||||||
|
[<b>-no_assignment_operator</b>]
|
||||||
|
[<b>-no_ctor</b>]
|
||||||
|
[<b>-no_dtor</b>]
|
||||||
|
[<b>-public_copy_ctor</b>]
|
||||||
|
[<b>-public_assignment_operator</b>]
|
||||||
|
[<b>-no_dump_diagnostics</b>]
|
||||||
|
[<b>-no_check_valid</b>]
|
||||||
|
[<b>-no_icc</b>]
|
||||||
|
[<b>-settings_file </b><i>filename</i>]
|
||||||
|
<p>
|
||||||
|
<h2><a name="section_2">Description</a></h2>
|
||||||
|
|
||||||
|
<tt>fcc</tt>
|
||||||
|
takes the name of one or more classes and generates the
|
||||||
|
appropriate code and header files for those classes. By default, it
|
||||||
|
includes a constructor, destructor, private copy constructor, private
|
||||||
|
assignment operator, unit testing, and appropriate inlines. It also
|
||||||
|
generates a raw BSD-style makefile.
|
||||||
|
<p>
|
||||||
|
<h2><a name="section_3">Options</a></h2>
|
||||||
|
|
||||||
|
<dl compact>
|
||||||
|
<dt><b>-class </b><i>list of class names</i>
|
||||||
|
<dd> Names of classes to be
|
||||||
|
generated. The files will be named after the first class name on the
|
||||||
|
list. Class names must be separated by whitespace.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-author </b><i>author's name</i>
|
||||||
|
<dd> Your name here.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-namespace </b><i>namespace name</i>
|
||||||
|
<dd> Wrap the output in a
|
||||||
|
specified namespace.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-verbose</b>
|
||||||
|
<dd> Explain in excruciating detail what the program
|
||||||
|
is doing.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_unit_test</b>
|
||||||
|
<dd> Do not generate unit-testing definitions in
|
||||||
|
the source files. This is an empty method; it's up to the user to
|
||||||
|
define appropriate tests.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_makefile</b>
|
||||||
|
<dd> Do not generate a makefile for this code.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-project </b><i>project_name</i>
|
||||||
|
<dd> Define a project for this makefile. Right now
|
||||||
|
this option does nothing.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-sccs_keywords</b>
|
||||||
|
<dd> Generate IDs appropriate to SCCS.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-continuus_keywords</b>
|
||||||
|
<dd> Generate keywords for the Continuus
|
||||||
|
Version System.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-open_source_notice</b>
|
||||||
|
<dd> Add some comments about how this code
|
||||||
|
is open source and permission to copy in granted yadda yadda...
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-copyright </b>[<i>copyright</i>]
|
||||||
|
<dd> Adds your copyright notice to the
|
||||||
|
code.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-base_filename </b><i>base_filename</i>
|
||||||
|
<dd> Set the name of the
|
||||||
|
files output. Defaults to first class name listed if not set.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_copy_ctor</b>
|
||||||
|
<dd> Do not provide a copy constructor in the
|
||||||
|
output code.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_assignment_operator</b>
|
||||||
|
<dd> Do not provide an assignment
|
||||||
|
operator in the output code.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_ctor</b>
|
||||||
|
<dd> Do not provide a default constructor in the
|
||||||
|
output code.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_dtor</b>
|
||||||
|
<dd> Do not provide a destructor in the output code.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-public_copy_ctor</b>
|
||||||
|
<dd> Put the copy constructor in the public
|
||||||
|
section instead of the private section.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-public_assignment_operator</b>
|
||||||
|
<dd> Put the assignment operator in
|
||||||
|
the public section instead of the private section.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_dump_diagnostics</b>
|
||||||
|
<dd> Do not provide a debugging method.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_check_valid</b>
|
||||||
|
<dd> Do not provide a Programming By Contract
|
||||||
|
style method to check for invariants.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-no_icc</b>
|
||||||
|
<dd> Do not provide a file for class inlines.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt><b>-settings_file </b><i>filename</i>
|
||||||
|
<dd> Get options from a settings
|
||||||
|
file. Right now this option does nothing.
|
||||||
|
<p>
|
||||||
|
<h2><a name="section_4">Requirements</a></h2>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<dl compact>
|
||||||
|
<dt>Python
|
||||||
|
<dd> <tt>fcc</tt>
|
||||||
|
requires Python version >= 2.0
|
||||||
|
</dd>
|
||||||
|
</dl>
|
||||||
|
<p>
|
||||||
|
<h2><a name="section_5">Version</a></h2>
|
||||||
|
|
||||||
|
Version: 0.8a of May 5, 2001
|
||||||
|
<p>
|
||||||
|
<h2><a name="section_6">License and Copyright</a></h2>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<dl compact>
|
||||||
|
<dt>Copyright
|
||||||
|
<dd> © 2001, Elf M. Sternberg <br>
|
||||||
|
|
||||||
|
<a href ="mailto:elf@drizzle.com"><tt>elf@drizzle.com</tt></a>
|
||||||
|
<br>
|
||||||
|
<a href ="http://www.drizzle.com/ elf"><tt>http://www.drizzle.com/ elf</tt></a>
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt>License
|
||||||
|
<dd> This program can be redistributed and/or modified under the
|
||||||
|
terms of the GNU Public License. See the file COPYING or visit
|
||||||
|
<a href ="http://www.gnu.org/copyleft/gpl.html"><tt>http://www.gnu.org/copyleft/gpl.html</tt></a>
|
||||||
|
for terms of use and
|
||||||
|
distribution.
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt>Misc
|
||||||
|
<dd> If you find this software useful, please drop me some email
|
||||||
|
<p>
|
||||||
|
</dd>
|
||||||
|
<dt>Misc
|
||||||
|
<dd> This man page was generated using latex2man by Dr. Jurgen
|
||||||
|
Vollmer, and is available from the CTAN archives.
|
||||||
|
</dd>
|
||||||
|
</dl>
|
||||||
|
<p>
|
||||||
|
<h2><a name="section_7">Author</a></h2>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
Elf M. Sternberg <br>
|
||||||
|
|
||||||
|
Email: <a href ="mailto:elf@drizzle.com"><tt>elf@drizzle.com</tt></a>
|
||||||
|
<br>
|
||||||
|
WWW: <a href ="http://www.drizzle.com/ elf"><tt>http://www.drizzle.com/ elf</tt></a>.
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
<!-- NOTE: This file is generated, DO NOT EDIT. -->
|
|
@ -0,0 +1,167 @@
|
||||||
|
\documentclass[english]{article}
|
||||||
|
\usepackage[latin1]{inputenc}
|
||||||
|
\usepackage{babel}
|
||||||
|
|
||||||
|
\IfFileExists{fancyhdr.sty}{
|
||||||
|
\usepackage[fancyhdr,pdf]{latex2man}
|
||||||
|
}{
|
||||||
|
|
||||||
|
\IfFileExists{fancyheadings.sty}{
|
||||||
|
\usepackage[fancy,pdf]{latex2man}
|
||||||
|
}{
|
||||||
|
\usepackage[nofancy,pdf]{latex2man}
|
||||||
|
\message{no fancyhdr or fancyheadings package present, discard it}
|
||||||
|
}}
|
||||||
|
|
||||||
|
\setVersionWord{Version:}
|
||||||
|
\setVersion{0.8a}
|
||||||
|
|
||||||
|
\begin{document}
|
||||||
|
|
||||||
|
\begin{Name}{1}{fcc}{Elf M. Sternberg}{C++ Development Tools}{fcc\\--\\ Fast Class Generator}
|
||||||
|
|
||||||
|
\Prog{fcc} is a tool to rapidly generate the basic framework of C++
|
||||||
|
class and components. \Prog{fcc} can generate inline files, testing
|
||||||
|
components, and basic copyright notices.
|
||||||
|
|
||||||
|
\end{Name}
|
||||||
|
|
||||||
|
\section{Synopsis}
|
||||||
|
%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
\Prog{fcc} \OptArg{-class }{list of class names}
|
||||||
|
\OptArg{-author }{author's name}
|
||||||
|
\oOptArg{-namespace }{namespace_name}
|
||||||
|
\oOpt{-overwrite}
|
||||||
|
\oOpt{-verbose}
|
||||||
|
\oOpt{-no_unit_test}
|
||||||
|
\oOpt{-no_makefile}
|
||||||
|
\oOptArg{-project }{project_name}
|
||||||
|
\oOpt{-sccs_keywords}
|
||||||
|
\oOpt{-continuus_keywords}
|
||||||
|
\oOpt{-open_source_notice}
|
||||||
|
\oOptoArg{-copyright }{copyright}
|
||||||
|
\oOptArg{-base_filename }{base_filename}
|
||||||
|
\oOpt{-no_copy_ctor}
|
||||||
|
\oOpt{-no_assignment_operator}
|
||||||
|
\oOpt{-no_ctor}
|
||||||
|
\oOpt{-no_dtor}
|
||||||
|
\oOpt{-public_copy_ctor}
|
||||||
|
\oOpt{-public_assignment_operator}
|
||||||
|
\oOpt{-no_dump_diagnostics}
|
||||||
|
\oOpt{-no_check_valid}
|
||||||
|
\oOpt{-no_icc}
|
||||||
|
\oOptArg{-settings_file }{filename}
|
||||||
|
|
||||||
|
\section{Description}
|
||||||
|
%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
\Prog{fcc} takes the name of one or more classes and generates the
|
||||||
|
appropriate code and header files for those classes. By default, it
|
||||||
|
includes a constructor, destructor, private copy constructor, private
|
||||||
|
assignment operator, unit testing, and appropriate inlines. It also
|
||||||
|
generates a raw BSD-style makefile.
|
||||||
|
|
||||||
|
\section{Options}
|
||||||
|
%%%%%%%%%%%%%%%%%
|
||||||
|
\begin{Description}
|
||||||
|
\item[\OptArg{-class }{list of class names}] Names of classes to be
|
||||||
|
generated. The files will be named after the first class name on the
|
||||||
|
list. Class names must be separated by whitespace.
|
||||||
|
|
||||||
|
\item[\OptArg{-author }{author's name}] Your name here.
|
||||||
|
|
||||||
|
\item[\OptArg{-namespace }{namespace name}] Wrap the output in a
|
||||||
|
specified namespace.
|
||||||
|
|
||||||
|
\item[\Opt{-verbose}] Explain in excruciating detail what the program
|
||||||
|
is doing.
|
||||||
|
|
||||||
|
\item[\Opt{-no_unit_test}] Do not generate unit-testing definitions in
|
||||||
|
the source files. This is an empty method; it's up to the user to
|
||||||
|
define appropriate tests.
|
||||||
|
|
||||||
|
\item[\Opt{-no_makefile}] Do not generate a makefile for this code.
|
||||||
|
|
||||||
|
\item[\OptArg{-project }{project_name}] Define a project for this makefile. Right now
|
||||||
|
this option does nothing.
|
||||||
|
|
||||||
|
\item[\Opt{-sccs_keywords}] Generate IDs appropriate to SCCS.
|
||||||
|
|
||||||
|
\item[\Opt{-continuus_keywords}] Generate keywords for the Continuus
|
||||||
|
Version System.
|
||||||
|
|
||||||
|
\item[\Opt{-open_source_notice}] Add some comments about how this code
|
||||||
|
is open source and permission to copy in granted yadda yadda...
|
||||||
|
|
||||||
|
\item[\OptoArg{-copyright }{copyright}] Adds your copyright notice to the
|
||||||
|
code.
|
||||||
|
|
||||||
|
\item[\OptArg{-base_filename }{base_filename}] Set the name of the
|
||||||
|
files output. Defaults to first class name listed if not set.
|
||||||
|
|
||||||
|
\item[\Opt{-no_copy_ctor}] Do not provide a copy constructor in the
|
||||||
|
output code.
|
||||||
|
|
||||||
|
\item[\Opt{-no_assignment_operator}] Do not provide an assignment
|
||||||
|
operator in the output code.
|
||||||
|
|
||||||
|
\item[\Opt{-no_ctor}] Do not provide a default constructor in the
|
||||||
|
output code.
|
||||||
|
|
||||||
|
\item[\Opt{-no_dtor}] Do not provide a destructor in the output code.
|
||||||
|
|
||||||
|
\item[\Opt{-public_copy_ctor}] Put the copy constructor in the public
|
||||||
|
section instead of the private section.
|
||||||
|
|
||||||
|
\item[\Opt{-public_assignment_operator}] Put the assignment operator in
|
||||||
|
the public section instead of the private section.
|
||||||
|
|
||||||
|
\item[\Opt{-no_dump_diagnostics}] Do not provide a debugging method.
|
||||||
|
|
||||||
|
\item[\Opt{-no_check_valid}] Do not provide a Programming By Contract
|
||||||
|
style method to check for invariants.
|
||||||
|
|
||||||
|
\item[\Opt{-no_icc}] Do not provide a file for class inlines.
|
||||||
|
|
||||||
|
\item[\OptArg{-settings_file }{filename}] Get options from a settings
|
||||||
|
file. Right now this option does nothing.
|
||||||
|
|
||||||
|
\section{Requirements}
|
||||||
|
%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
\begin{description}\setlength{\itemsep}{1cm}
|
||||||
|
\item[Python] \Prog{fcc} requires Python version $>=$ 2.0
|
||||||
|
\end{description}
|
||||||
|
|
||||||
|
\section{Version}
|
||||||
|
%%%%%%%%%%%%%%%%%
|
||||||
|
Version: 0.8a of May 5, 2001
|
||||||
|
|
||||||
|
\section{License and Copyright}
|
||||||
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
\begin{description}
|
||||||
|
\item[Copyright] \copyright\ 2001, Elf M. Sternberg \\
|
||||||
|
\Email{elf@drizzle.com} \\
|
||||||
|
\URL{http://www.drizzle.com/~elf}
|
||||||
|
|
||||||
|
\item[License] This program can be redistributed and/or modified under the
|
||||||
|
terms of the GNU Public License. See the file COPYING or visit
|
||||||
|
\URL{http://www.gnu.org/copyleft/gpl.html} for terms of use and
|
||||||
|
distribution.
|
||||||
|
|
||||||
|
\item[Misc] If you find this software useful, please drop me some email
|
||||||
|
|
||||||
|
\item[Misc] This man page was generated using latex2man by Dr. Jurgen
|
||||||
|
Vollmer, and is available from the CTAN archives.
|
||||||
|
\end{description}
|
||||||
|
|
||||||
|
\section{Author}
|
||||||
|
%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
|
\noindent
|
||||||
|
Elf M. Sternberg \\
|
||||||
|
Email: \Email{elf@drizzle.com} \\
|
||||||
|
WWW: \URL{http://www.drizzle.com/~elf}.
|
||||||
|
\LatexManEnd
|
||||||
|
\end{document}
|
Loading…
Reference in New Issue