Revision history for UR

0.39    2013-01-30
        Better support for PostgreSQL.  It is now on par with Oracle.
        New datasource UR::DataSource::Filesystem.  It obsoletes UR::DataSource::File
         and UR::DataSource::FileMux, and is more flexible.
        Classes can specify a query hint when they are used as the primary
         class of a get() or when they are involved in a join.  
        BoolExprs with an or-clause now support hints and order-by correctly..
        Messaging methods (error_message(), status_message(), etc) now trigger
         observers of the same name.  This means any number of message
         observers can be attached at any point in the class hierarchy.
        Using chained delegated properties with the dot-syntax (object.deledate.prop)
         is accepted in more places.
        Better support for queries using direct SQL.
        Many fixes for the Boolean Expression syntax parser.  Besides fixing
         bugs, it now supports more operators and understands 'offset' and
         'limit'.
        Support for defining a property that is an alias for another.
        Fixes for remaining connected to databases after fork().
        Optimization for the case where a delegation goes through an abstract
         class with no data source and back to the original data source. It
         now does one query instead of many.
        Improvements to the Command API documentation.
        Removed some deps on XML-related modules.
 
0.38    2012-03-28
        Bug fixes to support C3 inheritance on the Mac correctly.
        Rich extensions to primitive/value data-types for files, etc.
        Optimization for very large in-clauses.
        Database updates now infer table structure from class meta-data instead of leaning on database metadata when inserting (update and delete already do this).  
        Bug fixes to the new boolean expression parser.  
        Fixes to complex inheritance in RDBMS data.
        Fix to sorting issues in older Perl 5.8.
        Bug fixes to boolean expressions with values which are non-UR objects
        Smarter query plans when the join table is variable (not supported in SQL, but in the API), leading to multiple database queries where necessary.

0.37    2012-02-03
        Added a proper parser for generating Boolean Expressions from text
            strings.  The object lister commands (UR::Object::Command::List)
            use it to process the --filter, and it can be used directly
            through the method UR::BoolExpr::resolve_for_string().  See the
            UR::BoolExpr pod for more info.
        Or-type Boolean Expressions now support -order, and can be the filter
            for iterators.
        Important Bugfixes:
            * Better error messages when a module fails to load properly
              during autoloading.
            * Class methods called on Set instances are dispatched to the
              proper class instead of called on the Set's members.
            * Values in an SQL in-clause are escaped using DBI's quote() method.

0.36    2012-01-05
        Fix for 'like' clause's escape string on PostgreSQL
        Speed improvement for class initialization by normalizing metadata
           more efficiently and only calculating the cached data for
           property_meta_for_name() once.
        Workaround for a bug in Perl 5.8 involving sorters by avoiding method
            calls inside some sort subs
        Fully deprecate the old Subscription API in favor of the new Observer api
        UR::Value classes use UR::DataSource::Default and the normal loading
            mechanism.  Previously, UR::Values used a special codepath to get
            loaded into memory
        Add a json perspective for available views
        Allow descending sorts in order-by.  For example:
            my @o = Some::Class->get(prop => 'value', -order => ['field1','-field2']
            To get all objects where prop is equal to the string 'value', first
            sorted by field1 in ascending order, then by field2 in descending
            order
        Standardize sorting results on columns with NULLs by having NULL/undef
            always appears at the end for ascending sorts.  Previously, the
            order depended on the data source's behavior.  Oracle and
            PostgreSQL put them at the end, while MySQL, SQLite and cached
            get()s put them at the beginning.
        Fix exit code for 'ur test run' when the --lsf arg is used.  It used
            always return a false value (1).  Now it returns true (0) if all
            tests pass, and false (1) if any one test fails.
        UR::Object now implements the messaging API that used to be in Command
            (error_message, dump_error_messages, etc).  The old messaging API
            is now deprecated.

0.35    2011-10-28
        Queries with the -recurse option are suppored for all datasources, not
            just those that support recursive queries directly
        Make the object listers more user-friendly by implicitly putting '%'
            wildcards on either side of the user-supplied 'like' filter
        Update to the latest version of Getopt::Complete for command-line completion
        Object Set fixes (non-datasource expressable filters)
        Bugfixes for queries involving multiple joins to the same table with
            different join conditions
        Queries with -offset/-limit and -page are now supported.
        Query efficiency improvements:
            * id_by properties with a know data_type have special code in
                the bridging logic to handle them more efficiently
            * large in-clause testing uses a binary search instead of linear
                for cached objects
            * no longer indexing delegated properties results in fewer unnecessary
                queries during loading
            * remove unnecessary rule evaluations against loaded objects
            * When a query includes a filter or -hints for a calculated property,
                implicitly add its calculate_from properties to the -hints list
            * Rules in the query cache are always normalized, which makes
                many lookups faster
            * Fix a bug where rules in the query cache related to in-clause
                queries were malformed, resulting in fewer queries to the data source
        Command module fixes:
            * running with --help no longer emits error messages about other
                missing params
            * Help output only lists properties that are is_input or is_param
        Deleted objects hanging around as UR::DeletedRefs are recycled if the
            original object gets re-created
        
0.34    2011-07-26
        New class (Command::SubCommandFactory) which can act as a factory for a
            tree of sub-commands
        Remove the distinction between older and newer versions of DBD::SQLite
            installed on the system.  If you have SQLite databases (including
            MetaDBs) with names like "*sqlite3n*", they will need to be
            renamed to "*sqlite3*".
        Make the tests emit fewer messages to the terminal when run in the
            harness; improve coverage on non-Intel/Linux systems.

0.33    2011-06-30
        New environment variable (UR_DBI_SUMMARIZE_SQL) to help find query
            optimization targets
        View aspects for objects' primitive values use the appropriate UR::Value
            View classes
        Query engine remembers cases where a left join matches nothing, and skips
            asking the datasource on subsequent similar queries
        Committing a software transaction now performs the same data consistancy
            checking as the top-level transaction.
        Improved document auto-generation for Command classes
        Improved SQLite Data Source schema introspection
        Updated database handling for Pg and mysql table case sensitivity
        UR's developer tools (ur command-line tool) can operate on non-standard
            source tree layouts, and can be forced to operate on a namespace
            with a command-line option
        Support for using a chain of properties in queries ('a.b.c like' => $v)
        Set operations normalized: min, max, sum, count
        Set-to-set relaying is now correctly lazy
        Objects previously loaded from the database, and later deleted from the
            database, are now detected as deleted and handled as another type of
            change to be merged with in-memory changes.

0.32    (skipped)

0.31    (skipped)

0.30    2011-03-07
        re-package 0.29 with versions correctly set

0.29    2011-03-07
        query/iteration engine now solves n+1 in the one-to-many case as well as many-to-one
        query optimization where the join table is variable across rows in a single resultset 
        automated manual page creation for commands
        reduced deps (removed UR::Time)

0.28    2011-01-23
        fix to the installer which caused a failure during docs generation
        improvements to man page generation

0.27    2011-01-22
        updated build process autogenerates man pages
        
0.26    2011-01-16
        yet another refactoring to ensure VERSION appears on all modules
        fixes for tests which fail only in the install harness

0.25    2011-01-15
        Updated docs.

0.24    2011-01-15
        Updated deps to compile fully on a new OSX installation (requires XCode).  

0.22    2011-01-12
        VERSION refactoring for cleaner uploads

0.20    2011-01-11
        faster compile (<.5s)
        faster object creation
        faster install
        documentation polish

0.19    2010-12-24
        faster compile
        faster query cache resolution
        leaner meta-data
        less build deps, build dep fixes
        hideable commands
        fixes for newer sqlite API
        revamped UR::BoolExpr API
        new command tree

0.18	2010-12-10
        Bugfix for queries involving subclasses without tables
        Preliminary support for building debian packages
        Bugfixes for queries with the 'in' and 'not in' operators
        Object cache indexing sped up by replacing regexes with direct string comparisons

0.17    2010-11-10
        Fixed bug with default datasources dumping debug info during queries.
        Deprecated old parts of the UR::Object API.
        Bugfixes for MySQL data sources with handling of between and like operators, and table/column name case sensitivity
        MySQL data sources will complain if the 'lower_case_table_names' setting is not set to 1
        Bugfixes for FileMux data sources to return objects from iterators in correct sorted order
        File data sources remember their file offsets more often to improve seeking
        Bugfixes for handling is_many values passed in during create()
        New class for JSON-formatted Set views 
        More consistent behavior during evaluation of BoolExprs with is_many values and undef/NULL values
        Bugfixes for handling observers during software transaction commit and rollback
        Addition of a new UR::Change type (external_change) to track non-UR entities that need undo-ing during a rollback

0.16	2010-09-27
        File datasources build an on-the-fly index to improve its ability to seek within the file
        Initial support for classes to supply custom logic for loading data
        Compile-time speed improvements
        Bug fixes for SQL generation with indirect properties, and the object cache pruner

0.15	2010-08-03
        Improved 'ur update classes' interaction with MySQL databases
        Integration with Getopt::Complete for bash command-line tab completion
	
0.14	2010-07-26
        Metadata about data source entities (tables, columns, etc) is autodiscovered within commit() if it doesn't already exist in the MetaDB
        The new View API now has working default toolkits for HTML, Text, XML and XSL.  The old Viewer API has been removed.
        Smarter property merging when the Context reloads an already cached object and the data in the data source has changed
        Added a built-in 'product' calculation property type
        Calculated properties can now be memoized
        subclassify_by for an abstract class can now be a regular, indirect or calculated property
        New environment variable UR_CONTEXT_MONITOR_QUERY for printing Context/query info to stdout
        SQLite data sources can initialize themselves even if the sqlite3 executable cannot be found
        Test harness improvements: --junit and --color options, control-C stops tests and reports results
        'use lib' within an autoloaded module stays in effect after the module is loaded
	
0.13    2010-02-21
        Circular foreign key constraints between tables are now handled smartly handled in UR::DataSource::RDBMS. 
        New meta-property properties: id_class_by, order_by, specify_by.
        Updated autogenerated Command documentation.
        Formalized the __extend_namespace__ callback for dynamic class creation.
        New Command::DynamicSubCommands class makes command trees for a group of classes easy.
        The new view API is available.  The old "viewer" API is still available in this release, but is deprecated.

0.12	2009-09-09
        'ur test run' can now run tests in parallel and can submit tests as jobs to LSF
        Command modules now have support for Getopt::Complete for bash tab-completion
        Bugfixes related to saving objects to File data sources.
        Several more fixes for merging between database and in-memory objects.
        Property names beginning with an underscore are now handled properly during rule
        and object creation

0.11    2009-07-30
        Fix bug in merge between database/in-memory data sets with changes.

0.10    2009-07-22
        Updates to the UR::Object::Type MOP documentation.
        Other documentation cleanup and file cleanup.

0.9     2009-06-19
        Additional build fixes.

0.8     2009-06-17
        David's build fixes.

0.7     2009-06-10
        Fix to build process: the distribution will work if you do not have Module::Install installed.

0.6     2009-06-07
        Fixed to build process: actually install the "ur" executable.

0.5     2009-06-06 
        Updates to POD.  Additional API updates to UR::Object.

0.4     2009-06-04
        Updates to POD.  Extensive API updates to UR::Object.

0.3     2009-05-29
        Fixed memory leak in cache pruner, and added additional debugging environment variable.
        Additional laziness on file-based data-sources.
        Updated lots of POD.
        Switched to version numbers without zero padding!

0.02    2009-05-23
        Cleanup of initial deployment issues.
        UR uses a non-default version of Class::Autouse.  This is now a special file to prevent problems with the old version.
        Links to old DBIx::Class modules are now gone.
        Updated boolean expression API.

0.01    2009-05-07 
        First public release for Lambda Lounge language shootout.