This is the README file for Class::Generate, version 1.08. Class::Generate is a Perl5 module to simplify creating class hierarchies. It offers typed or untyped scalar, array, and hash members, required members, private members, methods (both instance and class), and other common features of object- oriented software development. Of course, you can implement all these things without a special module, but doing it via Class::Generate is much, much more concise. And futhermore, it's much less error prone: if you are using Perl's -w flag, Class::Generate will catch many class specification and usage errors. After unpacking this module, type the commands: % perl Makefile.PL PREFIX=<dir> % make install where <dir> is the root of your Perl library directory. The commands will install 2 files: -- Generate.pm, which is the file containing the Class::Generate module. -- Generate.pod, which contains the documentation, in POD format. It is sufficiently large that I decided to place it in a separate file. Copyright (c) 1999,2000,2007 Steven Wartik. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. CHANGES IN VERSION 1.01 Parameter passing from a subclass to its superclass constructor is greatly improved. Several bugs were detected and corrected. The algorithms are smarter. Superclasses not declared via class() or subclass() are handled better. In 1.00, class() and subclass() sometimes modified their parameters. They no longer do. Array members have a new accessor, last_<name>, which is a convenient abbreviation for the oft-used $obj-><name>($obj-><name>_size). Each class now has two methods that operate on instances: copy(), to copy an object instance, and equals(), to test the equality of two instances. New options: -- "class_var", which lets you choose an identifer other than "$class" as the class variable within a class method. -- "instance_var", which lets you choose an identifier other than "$self" as the instance variable within an object method. -- "check_code", which lets you control whether user-defined code is checked for correctness. -- "check_default", which does the same thing for default values of members. Some bug fixes: -- A bug in checking for duplicate member/method names has been corrected. -- A bug wherein class variables with default values were not always being properly declared has been corrected. -- List members were not checking for attempts to set read-only members. They do now. -- The error message emitted regarding an incorrect number of parameters reported the wrong number. It now reports the right number. -- Code checking in "post" code did not have the context of "pre" code. It now does. -- A member's "pre" code needs a trailing semicolon. The error message in 1.00 was not informative. It is improved in 1.01. -- Private members, and members in the own style, were not being assigned their default values in constructors. They are now. CHANGES IN VERSION 1.02 New option "nfi" (New From Instance) lets the constructor be invoked via a reference as well as a class name. New "-exclude" flag permits method exclusion. You get more control over how users can access a class. "parent" is deprecated in favor of "-parent". Values of -instance_var and -class_var flags are now checked to make sure they're valid identifiers. Generation of the base form is more (though not optimally) intelligent. Some bug fixes: -- The use of the -class_var flag wasn't checked in several places. -- In "mix" style, there was a reference to "pp" that should have been to "{pp}". CHANGES IN VERSION 1.03 Bug fixes: -- The -comment flag wasn't recognized. -- The conditions under which a constructor is needed have been expanded. Enhancements: -- Parent members may now be accessed from user-defined code in subclasses as regular variables. -- The key/value style is a little smarter about catching parameters that aren't members. CHANGES IN VERSION 1.04 The big change is the addition of protected members and methods to the object model. Other things: Bug fixes: -- The regexps for testing the validity of a member name let some erroneous names slip by. They have been corrected. -- A test for whether a subroutine name is known in a package was incorrectly implemented and sometimes resulted in a warning about an undefined value. It's been fixed. -- The MIX parameter passing style wasn't implementing the checks for extraneous parameters correctly. Enhancements: -- Hash-based members have a new accessor: $o->delete_x(k) deletes key k from hash-based member x of instance o. -- Added the nocopy option for members that should be assigned rather than copied during instance copying. -- The base type of a class is now saved in a variable _cginfo contained in the package implementing the class. This improves handling of classes saved to files. It simplifies the code for all classes to boot! CHANGES IN VERSION 1.05 Enhancements: -- The class() function now accepts the -parent flag. Classes can be specified in a style closer to C++, should you prefer. -- _cginfo (see version 1.04) now holds much more information than just a class' base type. Classes saved to files are almost completely identical to classes generated dynamically. CHANGES IN VERSION 1.06 Enhancements: -- Trailing semicolons are automatically appended to pre/post code if they were missing ("Do what I mean"). -- Diagnostics have been improved. -- A subroutine delete_class() has been added, to encapsulate the operation of deleting a class. CHANGES IN VERSION 1.07 Enhancements: -- Class::Generate now uses the warnings pragma added to Perl in version 5.6. CHANGES IN VERSION 1.08 Maintenance: -- The "require 5.8" statement has been changed to "use 5.008". CHANGES IN VERSION 1.09 Bug fixes: -- If a class method declares a subclass, then code-checking in the subclass didn't set up a framework that declared @ISA. This has been fixed. -- Constructor styles were not being properly recorded in classes that had no members. This caused saved classes to be incompletely specified when reloaded, so subclass declarations sometimes failed. This has been fixed. CHANGES IN VERSION 1.10 Bug fixes: -- A class that uses the "own" parameter style can pass a constant to a superclass. If this constant contains a single quote, that quote will appear in %_cginfo. Class::Generate was not escaping such quotes, so the code would fail. This has been fixed. Documentation: -- Two additional explanations have been added. One clarifies how default member values work. The other adds to the description of the "own" parameter style.