Bio::SeqIO::agave: move to its own distribution
[bioperl-live.git] / Changes
blob10f515abad1b6174b787a5dc8050189c631680f4
1 ---------------------------------------------------------
2 Revision history for BioPerl core modules
3 ---------------------------------------------------------
4 The comprehensive history and ongoing development of BioPerl:
6    http://github.com/bioperl/bioperl-live
8 Some of that history is also highlighted on our wiki:
10    http://www.bioperl.org/wiki/Change_log
11    http://www.bioperl.org/wiki/History_of_BioPerl
13 Bugs and requested features list:
15    https://github.com/bioperl/bioperl-live/issues
17 CPAN releases are branched from 'master'.
18 ---------------------------------------------------------
20 Philosophy for 1.7.x:
22 In order to reduce the number of dependencies, we are actively encouraging
23 developers wanting to submit new code with additional dependencies to release
24 code in a separate repository and release it on CPAN. We can help assist in this
25 process and can also place this under the 'bioperl' Github organization (and
26 similarly under the bioperl umbrella account in CPAN), though this is not
27 required.
29 We will also be moving additonal code to other repositories and will release
30 them separately on CPAN. Modules considered obsolute (relies on a dead web
31 service or utilizes strict dependencies that are also considered obsolete) will
32 be removed.
34 1.7.3 - "To Be Named"
36     * The following modules have been moved here from the BioPerl-Run
37       distribution:
39           Bio::Tools::Run::Analysis
40           Bio::Tools::Run::AnalysisFactory
41           Bio::Tools::Run::Phylo::PhyloBase
42           Bio::Tools::Run::WrapperBase
43           Bio::Tools::Run::WrapperBase::CommandExts
45     * The following modules have been removed from the BioPerl
46       distribution to be part of a separate distribution also
47       on CPAN:
49           Bio::AlignIO::stockholm
50           Bio::Cluster::*
51           Bio::ClusterI
52           Bio::ClusterIO::*
53           Bio::DB::CUTG
54           Bio::DB::EMBL
55           Bio::DB::EntrezGene
56           Bio::DB::Expression
57           Bio::DB::Expression::geo
58           Bio::DB::GFF
59           Bio::DB::GFF::Adaptor::*
60           Bio::DB::GFF::Aggregator::*
61           Bio::DB::GFF::Featname
62           Bio::DB::GFF::Feature
63           Bio::DB::GFF::Homol
64           Bio::DB::GFF::RelSegment
65           Bio::DB::GFF::Segment
66           Bio::DB::GFF::Typename
67           Bio::DB::GenBank
68           Bio::DB::GenPept
69           Bio::DB::NCBIHelper
70           Bio::DB::Query::GenBank
71           Bio::DB::RefSeq
72           Bio::DB::SeqFeature::*
73           Bio::DB::SeqVersion::*
74           Bio::DB::Taxonomy::entrez
75           Bio::DB::Taxonomy::sqlite
76           Bio::Index::Stockholm
77           Bio::LiveSeq::*
78           Bio::Phenotype::*
79           Bio::Root::Build
80           Bio::SearchDist
81           Bio::SeqFeature::SiRNA::*
82           Bio::SeqIO::abi
83           Bio::SeqIO::agave
84           Bio::SeqIO::alf
85           Bio::SeqIO::chadoxml
86           Bio::SeqIO::chaos
87           Bio::SeqIO::chaosxml
88           Bio::SeqIO::ctf
89           Bio::SeqIO::exp
90           Bio::SeqIO::flybase_chadoxml
91           Bio::SeqIO::pln
92           Bio::SeqIO::strider
93           Bio::SeqIO::ztr
94           Bio::Taxonomy::*
95           Bio::Tools::AlignFactory
96           Bio::Tools::Analysis::DNA::*
97           Bio::Tools::Analysis::Protein::*
98           Bio::Tools::Phylo::Gumby
99           Bio::Tools::Protparam
100           Bio::Tools::SiRNA::*
101           Bio::Tools::dpAlign
102           Bio::Tools::pSW
103           Bio::Variation::*
105     * The following programs have been removed:
107           bp_bulk_load_gff
108           bp_das_server
109           bp_download_query_genbank
110           bp_fast_load_gff
111           bp_flanks
112           bp_genbank2gff
113           bp_generate_histogram
114           bp_load_gff
115           bp_meta_gff
116           bp_netinstall
117           bp_process_wormbase
118           bp_query_entrez_taxa
119           bp_seqfeature_delete
120           bp_seqfeature_gff3
121           bp_seqfeature_load
123     * The following modules are no longer dependencies:
125           Bio::SeqIO::staden::read
126           Convert::Binary::C
127           DBD::Pg
128           DBD::SQLite
129           Data::Stag::XMLWriter
130           English
131           HTML::HeadParser
132           HTML::TableExtract
133           MIME::Base64
134           Memoize
135           Text::ParseWords
136           URI::Escape
138     [Code changes]
140     * The deobfuscator has been removed.
142     * The script `bp_blast2tree` has been moved to the BioPerl-Run
143       distribution since it's mainly a wrapper to modules in there.
145     * The entire Bio::PopGen namespace, Bio::Tree::AlleleNode
146       module, and scripts bp_composite_LD and bp_heterogeneity_test
147       have been moved into a separate distribution named Bio-PopGen.
149     * All modules related to the NeXML format have been moved into a
150       separate distribution named Bio-NeXMLIO.  These are:
152           * Bio::AlignIO::nexml
153           * Bio::Nexml::Factory
154           * Bio::NexmlIO
155           * Bio::SeqIO::nexml
156           * Bio::TreeIO::nexml
158       This also means BioPerl is no longer dependent on Bio-Phylo.
160     * All modules interfacing to ACeDB servers have been moved into a
161       separate distribution named Bio-DB-Ace.  These are:
163           * Bio::DB::Ace
164           * Bio::DB::GFF::Adaptor::ace
165           * Bio::DB::GFF::Adaptor::dbi::mysqlace
166           * Bio::DB::GFF::Adaptor::dbi::oracleace
168       This also means BioPerl is no longer dependent on AcePerl.
170     * The module Bio::Draw::Pictogram has been moved to a separate
171       distribution named Bio-Draw-Pictogram.  This also means BioPerl
172       is no longer dependent on SVG.
174     * The module Bio::Tree::Draw::Cladogram has been moved to a
175       separate distribution named Bio-Tree-Draw-Cladogram.  This also
176       means BioPerl is no longer dependent on PostScript.
178     * The module Bio::TreeIO::svggraph has been moved to a separate
179       distribution named Bio-TreeIO-svggraph.  This also means that
180       BioPerl is no longer dependent on SVG-Graph and Tree-DAG_Node.
182     * The module Bio::SeqIO::excel has been moved to a separate
183       distribution named Bio-SeqIO-excel.  This also means that
184       BioPerl is no longer dependent on Spreadsheet-ParseExcel.
186     * The entire Bio::PhyloNetwork namespace has been moved to a
187       separate distribution named Bio-PhyloNetwork.  This also means
188       that BioPerl is no longer dependent on Algorithm::Munkres,
189       GraphViz, and Array::Compare.
191     * The entire Bio::Asembly namespace has been moved to a separate
192       distribution named Bio-Assembly.  This also means that BioPerl
193       is no longer dependent on Bio-SamTools and Sort-Naturally.
195     * The entire Bio::Structure namespace has been moved to a
196       separate distribution named Bio-Structure.
198     * The entire Bio::SeqEvolution namespace has been moved to a
199       separate distribution named Bio-SeqEvolution.
201     * The Bio::Tools::Gel module has been moved into its own
202       distribution named Bio-Tools-Gel.
204     * The entire Bio::Restriction namespace has been moved to a
205       separate distribution named Bio-Restriction.
207     * The module Bio::SeqIO::entrezgene has been moved to the
208       Bio-ASN1-EntrezGene distribution.
210     * The module Bio::MolEvol::CodonModel has moved to a distribution
211       of its own, named after itself.
213     * The module Bio::Perl has moved to a new distribution named
214       Bio-Procedural.
216     * The module Bio::Tools::Run::RemoteBlast has moved to a new
217       distribution named after itself.
219     * The module Bio::Align::Graphics has been moved to a new distribution
220       named after itself.  This also means that BioPerl is no longer
221       dependent on GD.
223     * The entire Bio::DB::HIV namespace, the Bio::DB::Query::HIVQuery
224       module, and the the bp_hivq program have been moved to their
225       own distribution named Bio-DB-HIV.  This also drops the bioperl
226       dependency on XML-Simple and Term-ReadLine.
228     * The entire Bio::DB::TFBS namespace has been moved to its own
229       distribution named after itself.
231     * All modules to handle HMMER programs output have been moved to their
232       own distribution named Bio-SearchIO-hmmer.  This also includes the
233       programs bp_hmmer_to_table and bp_parse_hmmsearch.
235     * Bio::DB::MeSH and related Bio::Phenotype::MeSH modules have moved
236       to their own distribution Bio-DB-MeSH.
238     * The Bio::DB::Universal module has been moved to its own distribution.
240     * The emacs bioperl minor mode is no longer distributed as part of the
241       perl module distributions.  See
242       https://github.com/bioperl/emacs-bioperl-mode
244 1.7.2 - "Entebbe"
246     [Bugs]
247     
248     * #247 - Omit unnecessary parent_id attribute added by GFF3Loader [nathanweeks]
249     * #245 - Code coverage fixes [zmughal,cjfields]
250     * #237 - Fix warning in Bio::DB::IndexedBase [willmclaren,bosborne]
251     * #238 - Use a Travis cron job for network tests [zmughal,cjfields]
252     * #218 - Bio::DB::Flat::BinarySearch should use _fh() instead of fh() as fh() does not take arguments in [thibauthourlier,bosborne]
253     * #227 - Bio::SeqIO Ignores first line of sequence [VAR121,bosborne]
254     * #223 - Use Travis Perl helper script and enable coverage [zmughal,cjfields]
255     * #222 - Fix test RemoteDB/Taxonomy.t: requires networking [zmughal,cjfields]
256     * #216 - Apply carsonhh's patch (Inline::C fixes) [carsonh,bosborne]
257     * #213 - Support FTS5 in Bio::DB::SeqFeature::Store::DBI::SQLite [nathanweeks,bosborne]
258     * #210 - Sorting qualifiers while write embl files [hdevillers,cjfields]
259     * #209 - Fixed bug in _toDsspKey() [jvolkening,hlapp]
260     
261     [Code changes]
262     
263     * PAML-related code from bioperl and bioperl-run are now in a separate distribution on CPAN [carandraug]
265 1.7.1 - "Election"
267     [Bugs]
268     
269     * Minor release to incorporate fix for CPAN indexing, which
270       prevented proper updates [cjfields]
271     * Fix problem in managing Target attribute for gff3 [Jukes34]
272     * Minor bug fixes related to NCBI HTTPS support [cjfields]
274 1.7.0 - "Disney"
276     [New site]
277     
278     * We have migrated to Github Pages. This was actually planned, but the
279       recent OBF server compromise forced our hand.
280       
281       Brian Osborne [bosborne] took this under his wing to move docs and has
282       done a tremendous amount of work formatting the site and working out some
283       of the idiosyncracies with the new Jekyll-based design.  Mark Jensen, Paul
284       Cantalupo and Franscison Ossandon also helped.  Kudos!!
285       
286     * Similarly, the official issue tracker is now Github Issues.  This has
287       been updated in the relevant documentation bits (we hope!) 
289     [Code changes]
290     
291     * Previously deprecated modules removed
292       * Bio::Tools::Infernal, Bio::Tools::ERPIN, Bio::Tools::RNAMotif
293     * Bio::DB::SeqHound has been removed due to the service no longer being
294       available
295     * Bio::Tools::Analysis::Protein::Mitoprot has been removed for security
296       reasons due to the server no longer having a valid cert
297     * Bio::EUtilities, Bio::Biblio are now separate releases on CPAN
298     * Bio::Coordinate, Bio::SearchIO::blastxml,
299       Bio::SearchIO::Writer::BSMLResultWriter are now separate releases to be
300       added on CPAN
302     [New features]
304     * Docker instances of tagged releases are available! [hlapp]
305     * NCBI HTTPS support [mjohnson and others]
306     * Bio::SearchIO::infernal
307       - Issue #131: added CMSEARCH parsing support for Infernal 1.1 [pcantalupo]
308     * Bio::Search::HSP::ModelHSP
309       - Added a 'noncanonical_string' method to retrieve the NC line from CMSEARCH
310         reports [pcantalupo]
311     * Bio::Search::Result::INFERNALResult
312       - Added new module to represent features of Infernal reports [pcantalupo]
313     * Bio::DB::Taxonomy SQLite option [cjfields]
314     * WrapperBase quoted option values [majensen]
315     * Various documentation fixes and updates [bosborne]
316     
317    [Bug Fixes]
318    
319     * Fixes in Bio::Root::Build to deal with META.json/yml for CPAN indexing [cjfields]
320     * Bio::SeqFeature::Generic spliced_seq() bug fix [Eric Snyder, via bosborne]
321     * NeXML parser fixes [fjossandon]
322     * Bug fix for Bio::DB::SeqFeature memory adapter [lstein]
323     * RT 103272 : SeqFeature database deletion skipped features with a decimal -
324       Joshua Fortriede (Xenbase)
325     * RT 98374: AlignIO issues with sequence names not correctly parsing - Xiaoyu Zhuo
326     * Issue #70: CONTIG parsing in GenBank output fixed [fjossandon]
327     * Issue #76: Circular genome fixes with Bio::Location::Split [fjossandon]
328     * Issue #80: Fix lack of caching issue with Bio::DB::Taxonomy [fjossandon]
329     * Issue #81: Small updates to make sure possible memory leaks are detected [cjfields]
330     * Issue #84: EMBL format wrapping problem [nyamned]
331     * Issue #90: Missing entries for translation tables 24 and 25 [fjossandon]
332     * Issue #95: Speed up of Bio::DB::Fasta::subseq by using a compiled regex
333       or compiled C code (when Inline::C is installed) [rocky]
334     * Fix various Bio::Tools::Analysis remote server config problems [cjfields]
335     * Added several missing 'Data::Stag' and 'LWP::UserAgent' requirements [fjossandon]
336     * Added a workaround in Bio::DB::Registry to get Username in Windows [fjossandon]
337     * For HMMer report parsing, changed "$hsp->bits" to return 0 instead of undef
338       to be consistent with "$hit->bits" behaviour [fjossandon]
339     * Fixed a bug in HMMer3 parsing, where an homology line ending in CS or RF
340       aminoacids made "next_seq" confused and broke the parser [fjossandon]
341     * Adjusted FTLocationFactory.pm to comply with current GenBank Feature Table
342       Definition, so now "join(complement(C..D),complement(A..B))" is equivalent
343       to "complement(join(A..B,C..D))" [fjossandon]
344     * For the many many many fixes that weren't mentioned - blame the release guy!
346 1.6.924
348     [Significant changes]
350     * Bug/feature issue tracking has moved to GitHub Issues:
351           https://github.com/bioperl/bioperl-live/issues
352     * DB_File has been demoted from "required" to "recommended",
353       which should make easier for Windows users to install BioPerl
354       if they don't need that module.
356     [New features]
358     * Bio::Search::HSP::GenericHSP
359         - Bug #3370, added a "posterior_string" method to retrieve the
360           posterior probability lines (PP) from HMMER3 reports [fjossandon]
361         - Added a "consensus_string" method to retrieve the consensus
362           structure lines (CS|RF) from HMMER2 and HMMER3 reports when available [fjossandon]
363     * Bio::SearchIO::hmmer2
364         - The number of identical and conserved residues are now calculated
365           directly from the homology line [fjossandon]
366         - Now the Query Length and Hit Length are reported when the alignment
367           runs until the end of the sequence/model ('.]' or '[]') [fjossandon]
368         - Implemented the capture of the consensus structure lines [fjossandon]
369     * Bio::SearchIO::hmmer3
370         - The number of identical and conserved residues are now calculated
371           directly from the homology line [fjossandon]
372         - Now the Hit Length is reported when the alignment runs until the end
373           of the sequence/model ('.]' or '[]') [fjossandon]
374         - Implemented the capture of the consensus structure lines [fjossandon]
375         - Implemented the capture of the posterior probability lines [fjossandon]
376         - Completed the development of NHMMER parsing, including alignments [fjossandon]
377     * Bio::SearchIO::SearchResultEventBuilder & Bio::SearchIO::IteratedSearchResultEventBuilder
378         - Feature #2615, moved "_init_parse_params", "max_significance, "signif",
379           "min_score", "min_bits, and "hit_filter" methods from
380           'IteratedSearchResultEventBuilder' to parent 'SearchResultEventBuilder'.
381           This means that the Bio::SearchIO->new() parameters '-signif', '-score',
382           '-bits' and '-hit_filter' will now work with other Bio::SearchIO formats
383           besides Blast, instead of being ignored. Added tests for all moved methods
384           using HMMER outputs and run the full test suite and everything pass [fjossandon]
385     * Bio::SeqIO::MultiFile
386         - Autodetection of file format [fangly]
387     * Bio::Tools::GuessSeqFormat:
388         - Format detection from non-seekable filehandles such as STDIN [fangly]
390     [Bug fixes]
392     * Fix problems when using Storable as backend for cloning [v1.6.x branch, tsibley]
393     * Fix potential problems with Storable in Bio::DB::SeqFeature::Store [tsibley]
394     * SeqFeature::Lite: Fixed wrong strand when using "+", "-", or "." [nathanweeks]
395     * Abstract: Fixed ActivePerl incapability of removing temporary files
396       because of problems closing tied filehandles [fjossandon]
397     * IndexedBase: For Windows' ActivePerl, several LocalDB tests were failing
398       because ActivePerl were producing a ".index.pag" and ".index.dir"
399       files instead of a single ".index" file (like Strawberry Perl).
400       Now those temporary files are correctly considered and deleted. [fjossandon]
401     * Test files: Added missing module requirements (DB_File and Data::Stag)
402       to several tests files that were failing because those modules were
403       not present. Now those test files are correctly skipped instead. [fjossandon]
404     * Blast: Added support to changes in bl2seq from BLAST+ output, which
405       now uses "Subject=" instead of ">" to start hit lines [yschensandiego]
406     * Phylip: Return undef in "next_aln" at file end to avoid
407       an infinite loop [yschensandiego]
408     * HMMER3: When a hit description is too long, it is truncated in
409       the Scores table. In those cases, the more complete description from
410       the Annotation line (>>) will be used [fjossandon]
411     * GenericHSP: Added '.' to gap symbols in "_pre_gaps" (except for ERPIN),
412       since it is now used by HMMER3 format in alignments [fjossandon]
413     * GenericHit: Changed "frac_aligned_query" and "frac_aligned_hit"
414       to return undef if the query/hit length is unknown (like in some
415       HMMER outputs), to avoid division by 0 crashes. Also "query_length"
416       now is set to 0 if its undefined, to be consistent with hit "length" [fjossandon]
417     * HMMER: fixed many bugs in the parsing of Hmmer2 and Hmmer3 outputs,
418       added support to multi-query reports, reduced code redundancy,
419       and eliminated the automatic removal of hits below "inclusion threshold" [fjossandon]
420     * [3369] - Fixed reported bugs in parse from HMMSEARCH3 reports [fjossandon]
421     * [3446] - Fixed wrong marker position in Bio::Map::Physical [fjossandon]
422     * [3455] - Fixed wrong print of DBLink in Genbank file [bosborne]
423     * Fixed some Bio::Root::Utilities subroutines [fjossandon]
424     * Double-quotes on paths are needed in some places [fjossandon]
425     * [3453] - Allow multiple homologies and products in Entrezgene [fjossandon]
426     * Use "NUL" instead of"/dev/null" when running in Windows [fjossandon]
427     * Updated all files from Bio-Root, Bio-Coordinate and Bio-SearchIO-blastxml
428       with the latest changes made in their own repositories [fjossandon]
429     * General synching of files with the master branch [fjossandon]
430     * Fixed tests failing in Windows because of using Linux commands [fjossandon]
431     * Closed many open filehandles that prevented temporary files deletion [fjossandon]
432     * Fixed broken MeSH parser [fjossandon]
433     * Fixed missing detection of format in SeqIO when given a -string [fangly]
435 1.6.923
436     
437     * Major Windows support updates! [fjossandon]
438     * MAKER update to allow for stricter standard codon table [cjfields]
439     * Better support for circular sequences [fjossandon]
440     * Fixes for some complex location types [fjossandon]
441     * Address CONTIG bug in GenBank format, bug #3448 [cjfields]
442     * Fix bug #2978 related to BLAST report type [fjossandon]
443     * Deobfuscator fixes [DaveMessina]
445 1.6.922
447     * Address CPAN test failures [cjfields]
448     * Add BIOPROJECT support for Genbank files [hyphaltip]
449     * Better regex support for HMMER3 output [bosborne]
451 1.6.921
453     * Minor update to address CPAN test failures
455 1.6.920
457     * Remove Bio::Biblio and related files [carandraug]
458       - this cause version clashes with an independently-released
459         version of Bio::Biblio
461 1.6.910
463     [New features]
465     * Hash randomization fixes for perl 5.18.x
466       - Note: at least one module (Bio::Map::Physical) still has a failing test;
467         this is documented in bug #3446 and has been TODO'd; we will be pulling
468         Bio::Map and similar modules out of core into separate distributions in the
469         1.7.x release series [cjfields]
471     [New features]
473     * Bio::Seq::SimulatedRead
474         - New module to represent reads taken from other sequences [fangly]
475     * Bio::Root::Root
476         - Support of Clone::Fast as a faster cloning alternative [fangly]
477     * Bio::Root::IO
478         - Moved the format() and variant() methods from Bio::*IO modules to
479           Bio::Root::IO [fangly]
480         - Can now use format() to get the type of IO format in use [fangly]
481     * Bio::Tools::IUPAC
482         - New regexp() method to create regular expressions from IUPAC sequences
483           [fangly]
484     * Bio::SeqFeature::Primer and Bio::Seq::PrimedSeq:
485         - Code refresh [fangly]
486     * Bio::DB::Taxonomy
487         - Added support for the Greengenes and Silva taxonomies [fangly]
488     * Bio::Tree::TreeFunctionsI
489         - get_lineage_string() represents a lineage as a string [fangly]
490         - add_trait() returns instead of reporting an error when the column
491           number is exceeded in add_trait() [fangly]
492         - Option to support tree leaves without trait [fangly]
493         - Allow ID of 0 in trait files [fangly]
494     * Bio::DB::Taxonomy::list
495         - Misc optimizations [fangly]
496         - Option -names of get_taxon() to help with ambiguous taxa [fangly]
497     * Bio::DB::Taxonomy::*
498         - get_num_taxa() returns the number of taxa in the database [fangly]
499     * Bio::DB::Fasta and Bio::DB::Qual
500         - support indexing an arbitrary list of files [fangly]
501         - user can supply an arbitrary index file name [fangly]
502         - new option to remove index file at the end [fangly]
503     * Bio::DB::Fasta
504         - now handles IUPAC degenerate residues [fangly]
505     * Bio::PrimarySeq and Bio::PrimarySeqI
506         - speed improvements for large sequences [Ben Woodcroft, fangly]
507     * Bio::PrimaryQual
508         - tightened and optimized quality string validation [fangly]
509     * Bio::SeqIO::fasta
510         - new method and option 'block', to create FASTA output with space
511           intervaled blocks (similar to genbank or EMBL) has been implemented.
512         - package variables $WIDTH and $DEFAULT_SEQ_ID_TYPE have been removed
513           in favour of the methods 'width' and 'preferred_id_type` respectively.
514     * Bio::FeatureIO::*
515         - moved from bioperl-live into the separate distribution Bio-FeatureIO
516     * Bio::SeqFeature::Annotated
517         - moved from bioperl-live into the separate distribution Bio-FeatureIO
518     * Bio::Cluster::SequenceFamily
519         - improved performance when using get_members with overlapping multiple
520           criteria
521     * Bio::SearchIO::hmmer3
522         - now supports nhmmer [bosborne]
524     [Bug fixes]
526     * [3302] Fixes bug in Bio::SearchIO::hmmer2.pm to correctly parse
527       multi-query hmmer output [Francisco J. Ossandon, Paul Cantalupo]
528     * [3421] Fixes bug in Bio::SearchIO::hmmer2.pm to correctly parse an HSP
529       with a line full of dashes [Francisco J. Ossandon, Paul Cantalupo]
530     * [3298] Fix bug in Bio::SearchIO::blast.pm where algorithm version
531       information was lost in a multi-result blast file [Paul Cantalupo]
532     * [3343] Fix bug in Bio::SearchIO::blasttable.pm to correctly calculate
533       total gaps [Paul Cantalupo]
534     * [3375] Fix DBLINK parsing bug in Bio::SeqIO::genbank.pm [Paul Cantalupo]
535     * [3376] Fix bug in Bio::SearchIO::hmmer2.pm to correctly handle case
536       when end of domain indicator is split across lines [Paul Cantalupo]
537     * [3240] Bio::AlignIO::stockholm now parses simple sequences [Bernd Web,
538       cjfields]
539     * [3237] Bio::DB::Fasta now allows blank lines between sequences, catches
540       instances where blank lines are within sequences [cjfields]
541     * Bio::DB::Fasta reports correct alphabet for files with multiple sequence
542       types [fangly]
543     * Bio::DB::Fasta rev-comps sequences other than DNA properly [fangly]
544     * [3238] Fixes for Bio::DB::SeqFeature::Store::DBI::Pg [Thomas Burkhard,
545       cjfields]
546     * Various fixes for Stockholm file indexing and processing [bosborne]
547     * Fix edge case in FASTQ parsing where sequence of length 1 and qual of 0
548       breaks parsing [cjfields]
549     * Fix case where Bio::Seq::Meta* objects with no meta information could not
550       be reverse-complemented [fangly]
551     * Fix bug for fields without aliases in Bio::DB::Query::HIVQuery [fangly]
552     * Fix Bio::PopGen::IO::phase: sort values lexically instead of numerically
553       when unsure that values will be numerical [fangly]
554     * Fix undef warnings in Bio::SeqIO::embl [fangly]
555     * Fix undef warnings in Bio::DB::Fasta and Bio::DB::Qual [fangly]
556     * Fix Bio::Tools::IUPAC should accept any sequence object [fangly]
557     * Fix for 'Inappropriate ioctl' in Bio::DB::Store::berkeleydb3 [Olivier
558       Sallou]
559     * Bio::SeqFeature::Generic SeqfeatureI compliance: methods primary_tag,
560       source_tag and display_name must return a string, not undef [fangly]
561     * Bio::SimpleAlign and Bio::Seq compliance with Bio::FeatureHolderI
562       add_SeqFeature takes a single argument [fangly]
563     * Use cross-platform filenames and temporary directory in
564       Bio::DB::Taxonomy::flatfile [fangly]
565     * Fix bug in Bio::DB::Taxonomy::list where taxa with no ancestors were not
566       properly identified as existing taxa in the database [fangly]
567     * Fix issue where a Bio::DB::Taxonomy::list object could not be created
568       without also passing a lineage to store [fangly]
569     * Prevent passing a directory to the gi2taxid option (-g) of
570       bp_classify_hits_kingdom.pl and remove an 'earlier declaration' warning
571       [fangly]
572     * Fixed bp_genbank2gff3.pl crash when missing source feature date [fangly]
573     * Bio::PrimarySeq constructor -direct works for -seq or -ref_to_seq [fangly]
574     * Bio::Cluster::SequenceFamily - checks if the sequence has a Bio::Species
575       object before trying to access, and no longer returns repeated sequences.
578 1.6.901 May 18, 2011
580     [Notes]
582     * Use of AcePerl is deprecated; Ace.pm isn't actively maintained, and
583       modules using Ace will also be deprecated [lds, cjfields]
584     * Minor bug fix release
585     * Bio::SeqIO::gbxml tests require XML::SAX [hartzell]
586     * Address Build.PL issues when DBI is not present [hartzell]
587     * Skip gbxml.t and Interpro tests when modules not installed [cjfields]
588     * Remove deprecated code for perl 5.14.0 compat [cjfields]
589     * Due to schema changes and lack of support for older versions, support
590       for NeXML 0.9 is only (very) partially implemented.
591       See: https://redmine.open-bio.org/issues/3207
593     [Bug fixes]
595     * [3205] - small fix to Bio::Perl blast_sequence() to make compliant with
596       docs [genehack, cjfields]
597     * $VERSION for CPAN/cpanm-based installs was broken; force setting of
598       module version from dist_version (probably not the best way to do this,
599       but it seems to work) [rbuels, cjfields]
602 1.6.900 April 14, 201
604     [Notes]
606     * This will probably be the last release to add significant features to
607       core modules; subsequent releases will be for bug fixes alone.
608       We are planning on a restructuring of core for summer 2011, potentially
609       as part of the Google Summer of Code.  This may become BioPerl 2.0.
610     * Version bump represents 'just prior to v 1.7'.  We may have point
611       releases to deal with bugs, with increments of 1.6.901, 1.6.902, etc.
612       This code essentially is what is on the github master branch.
614     [New features]
616     * Core code updated for perl 5.12.x [cjfields, Charle Tilford]
617     * Bio::Tree refactor
618         - major overhaul of Bio::Tree code by Greg Jordan, fixes several bugs
619         - removal of Scalar::Util::weaken code, which was causing odd headaches
620           with premature GC, memory leaks with perl 5.10.0, etc [cjfields]
621     * Bio::DB::SeqFeature bug fixes for GBrowse2 compatibility [lds, scottcain,
622           many others]
623     * Bio::SeqIO::msout, Bio::SeqIO::mbsout - parsers for ms and mbs
624           [Warren Kretzschmar]
625     * Bio::SeqIO::gbxml
626         - bug 2515 - new contribution [Ryan Golhar, jhannah]
627     * Bio::Assembly::IO
628         - support for reading Maq, Sam and Bowtie files [maj]
629         - support for reading 454 GS Assembler (Newbler) ACE files [fangly]
630         - bug 2483: support for writing ACE files [Joshua Udall, fangly]
631         - bug 2599: support DBLINK annotation in GenBank files [cjfields]
632         - bug 2726: reading/writing granularity: whole scaffold or one contig
633           at a time [Joshua Udall, fangly]
634     * Bio::OntologyIO
635         - Added parsing of xrefs to OBO files, which are stored as secondary
636             dbxrefs of the cvterm [Naama Menda]
637         - General Interpro-related code refactors [dukeleto, rbuels, cjfields]
638     * PAML code updated to work with PAML 4.4d [DaveMessina]
640     [Bug fixes]
642     * [3198] - sort tabular BLAST hits by score [DaveMessina]
643     * [3196] - fix invalid metadata produced by latest Module::Build [cjfields]
644     * [3190] - RemoteBlast GAPCOSTS regex fix [Ali Walsh, cjfields]
645     * [3185] - Bio::Tools::SeqStats->get_mol_wt now gives correct MW
646                [cjfields]
647     * [3178] - fix tr/// issue in Bio::Range [Andrew Conley, cjfields]
648     * [3172] - Bio::DB::Fasta - catch possibly bad FASTA files [cjfields]
649     * [3164] - TreeFunctionsI syntax  bug [gjuggler]
650     * [3163] - AssemblyIO speedup [fangly]
651     * [3160] - Bio::SearchIO::Writer::TextResultWriter output [Paul Cantalupo,
652                hyphaltip]
653     * [3159] - add SwissPfam support to bp_index.PLS [hyphaltip]
654     * [3158] - fix EMBL file mis-parsing [cjfields]
655     * [3157] - Bio::Restriction::Analysis 'sizes' method fixed [Marc Perry,
656                cjfields]
657     * [3153] - fix SeqIO::swiss TagTree issues [Charles Tilford, cjfields]
658     * [3148] - URL change for UniProt [cjfields]
659     * [3145] - AXT off-by-1 error [Aaron Goodman, cjfields]
660     * [3136] - HMMer3 parser fixes [kblin]
661     * [3126] - catch description [Toshihiko Akiba]
662     * [3122] - Catch instances where non-seekable filehandles were being
663                seek'd w/o checking for status [Stefan Kirov, Roy Chaudhuri]
664     * [3121] - Bio::OntologyIO cannot parse the full InterPro XML file
665                [dukeleto, rbuels, cjfields]
666     * [3120] - bp_seqfeature_gff3.pl round-trip fixes [genehack, David Breimann,
667                jhannah]
668     * [3116,3117] - perl 5.12.x warnings fixed [cjfields, Charles Tilford]
669     * [3110] - Better 'namespace' support for bp_seqfeature_load.PLS [dbolser,
670                cjfields]
671     * [3107] - BLAST alignment column_from_residue_number() [cjfields]
672     * [3104] - Bio::Species single node hierarchies [Charles Tilford, cjfields]
673     * [3092, 3090] - parsing of BLAST HSP stats [Razi Khaja, cjfields]
674     * [3089] - HSPTableWriter missing methods [Robson de Souza, cjfields]
675     * [3086] - EMBL misparsing long tags [kblin, cjfields]
676     * [3085] - CommandExts and array of files [maj, hyphaltip]
677     * [3077] - Bio::SimpleAlign slice() now correctly computes seq coordinates
678                for alignment slices [Ha X. Dang, cjfields]
679     * [3076] - XMFA alignment strand wrong [Ha X., cjfields]
680     * [3073] - fix parsing of GenBank files from RDP [cjfields]
681     * [3068] - FASTQ parse failure with trailing 0 [cjfields]
682     * [3064] - All-gap midline BLAST report issues [cjfields]
683     * [3063] - BLASt report RID [Razi Khaja, cjfields]
684     * [3058] - SearchIO::fasta parsing [DaveMessina, cjfields]
685     * [3053] - LOCUS line formatting [M. Wayne, cjfields]
686     * [3039] - correct Newick output root node branch length [gjuggler,
687                DaveMessina]
688     * [3038] - SELEX alignment error [Bernd, cjfields]
689     * [3033] - PrimarySeq ID setting [Bernd, maj]
690     * [3032] - Fgenesh errors [Wes Barris, hyphaltip]
691     * [3034] - AlignIO::clustal output [Bernd, DaveMessina]
692     * [3031] - Parse algorithm ref for BLAST [Razi Khaja, cjfields]
693     * [3028] - Bio::TreeIO::nexus and FigTree compat [Kevin Balbi, cjfields]
694     * [3025] - Bio::SeqIO::embl infinite loop [Adam Sjøgren, cjfields]
695     * [3040, 3023, 2974, 2921, 2753, 2636, 2482] - PAML parser fixed, works with
696                PAML 4.4d [DaveMessina]
697     * [3015, 3022] - Bio::Restriction withrefm regexp [Emmanuel Quevillon,
698                DaveMessina]
699     * [3020] - GFF3Loader alias attribute [Nathan Weeks, cjfields]
700     * [3018, 3019, 3021] - gmap_f9 parsing [Kiran Mukhyala, cjfields]
701     * [3017] - using threads with Bio::DB::GenBank [cjfields]
702     * [3012] - Bio::Root::HTTPget fixes [maj, cjfields]
703     * [3011] - namespace support for SF::Store::DBI::Pg [Adam Witney, cjfields]
704     * [3002] - Bio::DB::EUtilities NCBI policy updates [cjfields]
705     * [3001] - seq identifier '0' dropped with FASTA [Michael Kuhn, maj]
706     * [2984] - let LocatableSeq decide on length of phylip aln [Adam Witney,
707                cjfields]
708     * [2983] - fix score/percent ID mixup [Alexie Papanicolaou]
709     * [2977] - TreeIO issues [DaveMessina]
710     * [2959] - Bio::SeqUtils->revcom_with_features [Roy Chaudhuri, maj]
711     * [2944] - Bio::Tools::GFF score [cjfields]
712     * [2942] - correct MapTiling output [maj]
713     * [2939] - PDB residue insertion codes [John May, maj]
714     * [2930] - PrimarySeqI term symbol [Adam Sjøgren, maj]
715     * [2928] - GuessSeqFormat raw [maj]
716     * [2926] - Bio:Tools::TandemRepeatsFinder seq_id [takadonet, cjfields]
717     * [2922] - open() directive issue [cjfields]
718     * [2915] - GenBank parser infinite loop [Francisco Ossandon, cjfields]
719     * [2901] - DNAStatistics div by zero error [Janet Young, cjfields]
720     * [2899] - SeqFeature::Store host issues [lstein, dbolser]
721     * [2897] - Add a "mask_below_threshold" method to Seq::Quality [dbolser,
722                cjfields]
723     * [2881] - .scf files don't' roundtrip [Adam Sjøgren, cjfields]
724     * [2876] - CDD search with RemoteBlast [Malcolm Cook]
725     * [2863] - Root::IO::_initialize_io causes crash [rbuels, maj, DaveMessina]
726     * [2845] - Bio::Seq::Quality gives seq with no ID [Tristan Lefebure, cjfields]
727     * [2843] - FeatureIO BED to GFF fails w/ no phase [cassjm cjfields]
728     * [2773] - Bio::Tree::Node premature GC [Morgan Price, cjfields]
729     * [2764] - add ID Tracker helper for SwissProt [heikki, cjfields]
730     * [2758] - Bio::AssemblyIO ace problems [fangly]
731     * [2744] - Bio::LocatableSeq::end [Bernd, cjfields]
732     * [2726] - ace file IO [Josh, fangly]
733     * [2700] - Refactor Build.PL [cjfields]
734     * [2673] - addition of simple Root-based clone() method [cjfields]
735     * [2648] - Bio::Assembly::Scaffold->get_all_seq_ids [dbolser, fangly]
736     * [2599] - support for DBLINK annotation in GenBank files [cjfields]
737     * [2594] - Bio::Species memory leak [cjfields]
738     * [2515] - GenBank XML parser [jhannah]
739     * [2499] - Method "pi" in package Bio::PopGen::Statistics [hyphaltip]
740     * [2483] - Bio::Assembly::IO::ace write_assembly implemented [fangly]
741     * [2350] - ID consistency btwn Bio::SeqI, Bio::Align::AlignI [fangly,
742                cjfields]
743     * [1572] - no docs Bio::Location::Simple/Atomic::trunc [hyphaltip]
745     [Deprecated]
747     * Bio::Expression modules - these were originally designed to go with the
748       bioperl-microarray suite of tools, however they have never been completed
749       and so have been removed from the distribution.  The original code has
750       been moved into the inactive bioperl-microarray suite. [cjfields]
752     [Other]
754     * Repository moved from Subversion (SVN) to
755       http://github.com/bioperl/bioperl-live [cjfields]
756     * Bug database has moved to Redmine (https://redmine.open-bio.org)
757     * Bio::Micrarray - the tools developed for ReSeq chip analysis by Marian
758       Thieme have been moved to their own distribution (Bio-Microarray).
759       [cjfields]
761 1.6.1   Sept. 29, 2009 (point release)
762     * No change from last alpha except VERSION and doc updates [cjfields]
764 1.6.0_6 Sept. 27, 2009 (sixth 1.6.1 alpha)
765     * Fix for silent OBDA bug related to FASTA validation [cjfields]
767 1.6.0_5 Sept. 27, 2009 (fifth 1.6.1 alpha)
768     * Possible fix for RT 49950 (Strawberry Perl installation) [cjfields]
769     * [RT 50048] - removed redundant VERSION, which was borking CPANPLUS
770       [cjfields]
771     * BioPerl.pod -> BioPerl.pm (Perl Best Practices) [cjfields]
773 1.6.0_4 Sept. 25, 2009 (fourth 1.6.1 alpha)
774     * WinXP test fixes [cjfields, maj]
775     * BioPerl.pod added for descriptive information, fixes CPAN indexing
776       [cjfields]
777     * Minor doc fixes [cjfields]
779 1.6.0_3 Sept. 22, 2009 (third 1.6.1 alpha)
780     * Fix tests failing due to merging issues [cjfields]
781     * More documentation updates for POD parsing [cjfields]
783 1.6.0_2 Sept. 22, 2009 (second 1.6.1 alpha)
784     * Bio::Root::Build
785         - fix YAML meta data generation [cjfields]
787 1.6.0_1 Sept. 15, 2009 (first 1.6.1 alpha)
788     * Bio::Align::DNAStatistics
789         - fix divide by zero problem [jason]
790     * Bio::AlignIO::*
791         - bug 2813 - fix faulty logic to detect end-of-stream [cjfields]
792     * Bio::AlignIO::stockholm
793         - bug 2796 - fix faulty logic to detect end-of-stream [cjfields]
794     * Bio::Assembly::Tools::ContigSpectrum
795         - function to score contig spectrum [fangly]
796     * Bio::DB::EUtilities
797         - small updates [cjfields]
798     * Bio::DB::Fasta
799         - berkeleydb database now autoindexes wig files and locks correctly
800           [lstein]
801     * Bio::DB::HIV
802         - various small updates for stability; tracking changes to LANL
803           database interface [maj]
804     * Bio::DB::SeqFeature (lots of updates and changes)
805         - add Pg, SQLite, and faster BerkeleyDB implementations [lstein, scain]
806         - bug 2835 - patch [Dan Bolser]
807         - bug RT 44535 - patch FeatureFileLoader [Cathy Gresham]
808     * Bio::DB::SwissProt
809         - bug 2764 - idtracker() method [cjfields, courtesy Neil Saunders]
810     * Bio::Factory::FTLocationFactory
811         - mailing list bug fix [cjfields]
812     * Bio::LocatableSeq
813         - performance work on column_from_residue_number [hartzell]
814     * Bio::Matrix::IO::phylip
815         - bug 2800 - patch to fix phylip parsing [Wei Zou]
816     * Bio::Nexml
817         - Google Summer of Code project from Chase Miller - parsers for Nexml
818           file format [maj, chmille4]
819     * Bio::PopGen
820         - Make Individual, Population, Marker objects AnnotatableI [maj]
821         - simplify LD code [jason]
822     * Bio::RangeI
823         - deal with empty intersection [jason]
824     * Bio::Restriction
825         - significant overhaul of Bio::Restriction system: complete support for
826           external and non-palindromic cutters. [maj]
827     * Bio::Root::Build
828         - CPANPLUS support, no automatic installation [sendu]
829     * Bio::Root::IO
830         - allow IO::String (regression fix) [cjfields]
831         - catch unintentional undef values [cjfields]
832         - throw if non-fh is passed to -fh [maj]
833     * Bio::Root::Root/RootI
834         - small debugging and core fixes [cjfields]
835     * Bio::Root::Test
836         - bug RT 48813 - fix for Strawberry Perl bug [kmx]
837     * Bio::Root::Utilities
838         - bug 2737 - better warnings [cjfields]
839     * Bio::Search
840         - tiling completely refactored, HOWTO added [maj]
841           NOTE : Bio::Search::Hit::* classes do not use this code directly; we
842           will deprecate usage of the older tiling code in the next BioPerl
843           release
844         - small fixes [cjfields]
845     * Bio::SearchIO
846         - Infernal 1.0 output now parsed [cjfields]
847         - new parser for gmap -f9 output [hartzell]
848         - bug 2852 - fix infinite loop in some output [cjfields]
849         - blastxml output now passes all TODO tests [cjfields]
850         - bug 2346, 2850 - psl and exonerate parsing fixes [rbuels, jhannah, bvecchi, YAPC hackathon]
851         - RT 44782 - GbrowseGFF writer now catches evalues [Allen Day]
852         - bug 2575 - add two columns of additional output to HSPTableWriter [cjfields]
853     * Bio::Seq::LargePrimarySeq
854         - delete tempdirs [cjfields]
855         - bug fixes [rbuels, jhannah, bvecchi, YAPC hackathon]
856     * Bio::Seq::Quality
857         - extract regions based on quality threshold value [Dan Bolser, heikki]
858         - bug 2847 - resolve threshold issue (rbuels, jhannah, bvecchi)
859     * Bio::SeqFeature::Lite
860         - various Bio::DB::SeqFeature-related fixes [lstein]
861     * Bio::SeqFeature::Tools::TypeMapper
862         - additional terms for GenBank to SO map [scain]
863     * Bio::SeqIO::chadoxml
864         - bug 2785 - patch to get this working for bp_seqconvert [cjfields]
865     * Bio::SeqIO::embl
866         - support for CDS records [dave_messina, Sylvia]
867     * Bio::SeqIO::fastq
868         - complete refactoring to handle all FASTQ variants, perform validation,
869           write output. API now conforms with other Bio* parsers and the rest of
870           Bio::SeqIO (e.g. write_seq() creates fastq output, not fasta output).
871           [cjfields]
872     * Bio::SeqIO::genbank
873         - bug 2784 - fix DBSOURCE issue [Phillip Garland]
874         - bug RT 44536 - support for UniProt/UniProtKB tests [cjfields]
875     * Bio::SeqIO::largefasta
876         - parser returns a Bio::Seq::LargePrimarySeq [jhannah]
877     * Bio::SeqIO::raw
878         - add option for 'single' and 'multiple'
879     * Bio::SeqIO::scf
880         - bug 2881 - fix scf round-tripping [Adam Søgren]
881     * Bio::SeqUtils
882         - bug 2766, 2810 - copy over tags from features, doc fixes [David
883           Jackson]
884     * Bio::SimpleAlign
885         - bug 2793 - patch for add_seq index issue [jhannah, maj]
886         - bug 2801 - throw if args are required [cjfields]
887         - bug 2805 - uniq_seq returns SimpleAlign and hash ref of sequence types
888           [Tristan Lefebure, maj]
889         - bug fixes from YAPC hackathon [rbuels, jhannah, bvecchi]
890         - fix POD and add get_SeqFeatures filter [maj]
891     * Bio::Tools::dpAlign
892         - add support for LocatableSeq [ymc]
893         - to be moved to a separate distribution [cjfields, rbuels]
894     * Bio::Tools::EUtilities
895         - fix for two bugs from mail list [Adam Whitney, cjfields]
896         - add generic ItemContainerI interface for containing same methods
897           [cjfields]
898     * Bio::Tools::HMM
899         - fix up code, add more warnings [cjfields]
900         - to be moved to a separate distribution [cjfields, rbuels]
901     * Bio::Tools::Primer3
902         - bug 2862 - fenceposting issue fixed [maj]
903     * Bio::Tools::Run::RemoteBlast
904         - tests for remote RPS-BLAST [mcook]
905     * Bio::Tools::SeqPattern
906         - bug 2844 - backtranslate method [rbuels, jhannah, bvecchi]
907     * Bio::Tools::tRNAscanSE
908         - use 'gene' and 'exon' for proper SO, ensure ID is unique [jason]
909     * Bio::Tree::*
910         - bug 2456 - fix reroot_tree(), added create_node_on_branch() [maj]
911     * Bio::Tree::Statistics
912         - several methods for calculating Fitch-based score, internal trait
913           values, statratio(), sum of leaf distances [heikki]
914     * Bio::Tree::Tree
915         - bug 2869 - add docs indicating edge case where nodes can be
916           prematurely garbage-collected [cjfields]
917         - add as_text() function to create Tree as a string in specified format
918           [maj]
919     * Bio::Tree::TreeFunctionsI
920         - bug 2877 - fix bug where bootstrap assigned to the wrong node [Tristan
921           Lefebure, maj]
922     * Bio::TreeIO::newick
923         - fix small semicolon issue [cjfields]
924     * scripts
925         - update to bp_seqfeature_load for SQLite [lstein]
926         - hivq.pl - commmand-line interface to Bio::DB::HIV [maj]
927         - fastam9_to_table - fix for MPI output [jason]
928         - gccalc - total stats [jason]
929     * General Stuff
930         - POD cleanup re: FEEDBACK section [maj, cjfields]
931         - cleanup or fix dead links [cjfields]
932         - Use of no_* methods (indicating 'number of something') is deprecated
933           in favor of num_* [cjfields]
934         - lots of new tests for the above bugs and refactors [everyone!]
935         - new template for Komodo text editor [cjfields]
937 1.6.0 Winter 2009
938     * Feature/Annotation rollback
939         - Problematic changes introduced prior to the 1.5 release have been
940           rolled back. These changes led to subtle bugs involving operator
941           overloading and interface methods.
942         - Behavior is very similar to that for BioPerl 1.4, with tag values
943           being stored generically as simple scalars. Results in a modest
944           speedup.
945     * Bio::Graphics
946         - Split into a separate distribution on CPAN, primarily so development
947           isn't reliant on a complete BioPerl release.
948         - Bio::Graphics::Pictogram has been renamed to Bio::Draw::Pictogram but
949           is only available via Subversion (via bioperl-live main trunk)
950     * Bio::Root::Test
951         - Common test bed for all BioPerl modules
952     * Bio::Root::Build
953         - Common Module::Build-based subclass for all BioPerl modules
954     * Bio::DB::EUtilities
955         - Complete refactoring to split up parsing (Bio::Tools::EUtilities),
956           parameter handling (Bio::Tools::EUtilities::EUtilParameters),
957           and user agent request posting and retrieval
958     * Test implementation and reorganization
959         - Tests have been reorganized into groups based on classes or use
960           cases.
961         - Automated test coverage is now online:
962           http://www.bioperl.org/wiki/Test_Coverage
963         - After this release, untested modules will be moved into a
964           separate developer distribution until tests can be derived.
965           Also, new modules to be added are expected to have a test suite
966           and adequate test coverage.
968 1.5.2 Developer release
970     Full details of changes since 1.5.1 are available online at:
971     http://www.bioperl.org/wiki/Change_log
972     The following represents a brief overview of the most important changes.
974     o Bio::Map
975       - Overhaul. Brand new system fully allows markers to have multiple
976         positions on multiple maps, and to have relative positions. Should be
977         backward compatible.
979     o Bio::Taxonomy
980       - This module and all the modules in the Taxonomy directory now
981         deprecated in favour of Bio::Taxon and Bio::Tree::Tree
983     o Bio::DB::Taxonomy
985       - Taxonomy.pm
986         * get_Taxonomy_Node() eventually to be deprecated, renamed get_taxon().
988         * New methods ancestor(), each_Descendent() and _handle_internal_id().
990         * Allows for different database modules to create Bio::Taxon objects
991           with the same internal id when the same taxon is requested from each.
993       - flatfile.pm
994         * get_Children_Taxids() is deprecated, superceded by each_Descendent().
996         * No longer includes the fake root node 'root'; there are multiple roots
997           now (10239, 12884, 12908, 29384 and 131567). Consistent with entrez.pm
999       - entrez.pm
1000         * get_node() has new option -full
1002         * Caches data retrieved from website
1004     o Bio::Species
1005       - Now a Bio::Taxon. Carries out the species name -> specific name munging
1006         that Bio::DB::Taxonomy modules and SeqIO modules used to do, for
1007         backward compatability in species() method.
1009     o Bio::Search and Bio::SearchIO
1010       - Overhaul. The existing system has been sped up via some minor changes
1011         (mostly gain-of-function to the API). Bio::PullParserI is introduced
1012         as a potential eventual replacment for the existing system, though as
1013         yet only a Hmmpfam parser exists written using it.
1016 1.5.1 Developer release
1018     o Major problem with how Annotations were written out with
1019       Bio::Seq is fixed by reverting to old behavior for
1020       Bio::Annotation objects.
1022     o Bio::SeqIO
1024      - genbank.pm
1025        * bug #1871; REFLOOP' parsing loop, I changed the pattern to
1026          expect at l east 9 spaces at the beginning of a line to
1027          indicate line wrapping.
1029        * Treat multi-line SOURCE sections correctly, this defect broke
1030          both common_name() and classification()
1032        * parse swissprot fields in genpept file
1034        * parse WGS genbank records
1036      - embl.pm
1037         * Changed regexp for ID line. The capturing parentheses are
1038           the same, the difference is an optional repeated-not-semi-
1039           colon expression following the captured \S+. This means the
1040           regexp works when the division looks like /PRO;/ or when the
1041           division looks like /ANG ;/ - the latter is from EMBL
1042           repbase
1044         * fix ID line parsing: the molecule string can have spaces in
1045           it. Like: "genomic DNA"
1047      - swiss.pm: bugs  #1727, #1734
1049      - entrezgene.pm
1050         * Added parser for entrezgene ASN1 (text format) files.
1051           Uses Bio::ASN1::EntrezGene as a low level parser (get it from CPAN)
1053     o Bio::AlignIO
1055      -  maf.pm coordinate problem fixed
1057     o Bio::Taxonomy and Bio::DB::Taxonomy
1059      - Parse NCBI XML now so that nearly all the taxonomy up-and-down
1060        can be done via Web without downloading all the sequence.
1062     o Bio::Tools::Run::RemoteBlast supports more options and complies
1063       to changes to the NCBI interface. It is reccomended that you
1064       retrieve the data in XML instead of plain-text BLAST report to
1065       insure proper parsing and retrieval of all information as NCBI
1066       fully expects to change things in the future.
1068     o Bio::Tree and Bio::TreeIO
1070       - Fixes so that re-rooting a tree works properly
1072       - Writing out nhx format from a newick/nexus file will properly output
1073         bootstrap information.  The use must move the internal node labels over
1074         to bootstraps.
1075          for my $node ( grep { ! $_->is_Leaf } $tree->get_nodes ) {
1076             $node->bootstrap($node->id);
1077             $node->id('');
1078          }
1079       - Nexus parsing is much more flexible now, does not care about
1080         LF.
1082       - Cladogram drawing module in Bio::Tree::Draw
1084       - Node height and depth now properly calculated
1086       - fix tree pruning algorithm so that node with 1 child gets merged
1088     o Graphics tweaks.  Glyph::xyplot improved.  Many other small-medium sized
1089       bugs and improvements were added, see Gbrowse mailing list for most of
1090       these.
1092     o Bio::DB::GFF partially supports GFF3.  See information about
1093       gff3_munge flag in scripts/Bio-DB-GFF/bulk_load_gff.pl.
1095     o Better location parsing in Bio::Factory::FTLocationFactory -
1096       this is part of the engine for parsing EMBL/GenBank feature table
1097       locations.  Nested join/order-by/complement are allowed now
1099     o Bio::PrimarySeqI->translate now takes named parameters
1101     o Bio::Tools::Phylo::PAML - parsing RST (ancestral sequence
1102       reconstruction) is now supported.  Parsing different models and
1103       branch specific parametes are now supported.
1105     o Bio::Factory::FTLocationFactory - parse hierarchical locations
1106       (joins of joins)
1108     o Bio::Matrix::DistanceMatrix returns arrayrefs instead of arrays
1109       for getter/setter functions
1111     o Bio::SearchIO
1113       - blast bug #1739; match scientific notation in score
1114         and possible e+ values
1116       - blast.pm reads more WU-BLAST parameters and parameters, match
1117         a full database pathname,
1119       - Handle NCBI WEB and newer BLAST formats specifically
1120         (Query|Sbjct:) match in alignment blocks can now be (Query|Sbjct).
1122       - psl off-by-one error fixed
1124       - exonerate parsing much improved, CIGAR and VULGAR can be parsed
1125         and HSPs can be constructed from them.
1127       - HSPs query/hit now have a seqdesc field filled out (this was
1128         always available via $hit->description and
1129         $result->query_description
1131       - hmmer.pm can parse -A0 hmmpfam files
1133       - Writer::GbrowseGFF more customizeable.
1135     o Bio::Tools::Hmmpfam
1136       make e-value default score displayed in gff, rather than raw score
1137       allow parse of multiple records
1140 1.5 Developer release
1142     o Bio::Align::DNAStatistics and Bio::Align::ProteinStatistics
1143       provide Jukes-Cantor and Kimura pairwise distance methods,
1144       respectively.
1146     o Bio::AlignIO support for "po" format of POA, and "maf";
1147       Bio::AlignIO::largemultifasta is a new alternative to
1148       Bio::AlignIO::fasta for temporary file-based manipulation of
1149       particularly large multiple sequence alignments.
1151     o Bio::Assembly::Singlet allows orphan, unassembled sequences to
1152       be treated similarly as an assembled contig.
1154     o Bio::CodonUsage provides new rare_codon() and probable_codons()
1155       methods for identifying particular codons that encode a given
1156       amino acid.
1158     o Bio::Coordinate::Utils provides new from_align() method to build
1159       a Bio::Coordinate pair directly from a
1160       Bio::Align::AlignI-conforming object.
1162     o Bio::DB::Biblio::eutils is a class for querying NCBI's Eutils.
1163       Send a Pubmed, Pubmed Central, Entrez, or other query to NCBI's
1164       web service using standard Pubmed query syntax, and retrieve
1165       results as XML.
1167     o Bio::DB::GFF has various sundry bug fixes.
1169     o Bio::FeatureIO is a new SeqIO-style subsystem for
1170       writing/reading genomic features to/from files.  I/O classes
1171       exist for BED, GTF (aka GFF v2.5), and GFF v3.  Bio::FeatureIO
1172       classes only read/write Bio::SeqFeature::Annotated objects.
1173       Notably, the GFF v3 class requires features to be typed into the
1174       Sequence Ontology.
1176     o Bio::Graph namespace contains new modules for manipulation and
1177       analysis of protein interaction graphs.
1179     o Bio::Graphics has many bug fixes and shiny new glyphs.
1181     o Bio::Index::Hmmer and Bio::Index::Qual provide multiple-file
1182       indexing for HMMER reports and FASTA qual files, respectively.
1184     o Bio::Map::Clone, Bio::Map::Contig, and Bio::Map::FPCMarker are
1185       new objects that can be placed within a Bio::Map::MapI-compliant
1186       genetic/physical map; Bio::Map::Physical provides a new physical
1187       map type; Bio::MapIO::fpc provides finger-printed clone mapping
1188       import.
1190     o Bio::Matrix::PSM provide new support for postion-specific
1191       (scoring) matrices (e.g. profiles, or "possums").
1193     o Bio::Ontology::Ontology and Bio::Ontology::Term objects can now
1194       be instantiated without explicitly using Bio::OntologyIO.  This
1195       is possible through changes to Bio::Ontology::OntologyStore to
1196       download ontology files from the web as necessary.  Locations of
1197       ontology files are hard-coded into
1198       Bio::Ontology::DocumentRegistry.
1200     o Bio::PopGen includes many new methods and data types for
1201       population genetics analyses.
1203     o New constructor to Bio::Range, unions().  Given a list of
1204       ranges, returns another list of "flattened" ranges --
1205       overlapping ranges are merged into a single range with the
1206       mininum and maximum coordinates of the entire overlapping group.
1208     o Bio::Root::IO now supports -url, in addition to -file and -fh.
1209       The new -url argument allows one to specify the network address
1210       of a file for input.  -url currently only works for GET
1211       requests, and thus is read-only.
1213     o Bio::SearchIO::hmmer now returns individual Hit objects for each
1214       domain alignment (thus containing only one HSP); previously
1215       separate alignments would be merged into one hit if the domain
1216       involved in the alignments was the same, but this only worked
1217       when the repeated domain occured without interruption by any
1218       other domain, leading to a confusing mixture of Hit and HSP
1219       objects.
1221     o Bio::Search::Result::ResultI-compliant report objects now
1222       implement the "get_statistics" method to access
1223       Bio::Search::StatisticsI objects that encapsulate any
1224       statistical parameters associated with the search (e.g. Karlin's
1225       lambda for BLAST/FASTA).
1227     o Bio::Seq::LargeLocatableSeq combines the functionality already
1228       found in Bio::Seq::LargeSeq and Bio::LocatableSeq.
1230     o Bio::SeqFeature::Annotated is a replacement for
1231       Bio::SeqFeature::Generic.  It breaks compliance with the
1232       Bio::SeqFeatureI interface because the author was sick of
1233       dealing with untyped annotation tags.  All
1234       Bio::SeqFeature::Annotated annotations are Bio::AnnotationI
1235       compliant, and accessible through Bio::Annotation::Collection.
1237     o Bio::SeqFeature::Primer implements a Tm() method for primer
1238       melting point predictions.
1240     o Bio::SeqIO now supports AGAVE, BSML (via SAX), CHAOS-XML,
1241       InterProScan-XML, TIGR-XML, and NCBI TinySeq formats.
1243     o Bio::Taxonomy::Node now implements the methods necessary for
1244       Bio::Species interoperability.
1246     o Bio::Tools::CodonTable has new reverse_translate_all() and
1247       make_iupac_string() methods.
1249     o Bio::Tools::dpAlign now provides sequence profile alignments.
1251     o Bio::Tools::GFF now parses GFF version 2.5 (a.k.a. GTF).
1253     o Bio::Tools::Fgenesh, Bio::Tools::tRNAscanSE are new report
1254       parsers.
1256     o Bio::Tools::SiRNA includes two new rulesets (Saigo and Tuschl)
1257       for designing small inhibitory RNA.
1259     o Bio::Tree::DistanceFactory provides NJ and UPGMA tree-building
1260       methods based on a distance matrix.
1262     o Bio::Tree::Statistics provides an assess_bootstrap() method to
1263       calculate bootstrap support values on a guide tree topology,
1264       based on provided bootstrap tree topologies.
1266     o Bio::TreeIO now supports the Pagel (PAG) tree format.
1268 1.4 branch
1270 1.4.1
1272   o Improvements to Bio::AlignIO::nexus for parsing TreeBase nexus files
1274   o Bio::Graphics will work with gd1 or gd2
1276   o Bio::SearchIO
1277    - hmmer.pm Better hmmpfam parsing, fix bug for small number of alignment outputs
1278      (RF lines alone)
1279    - blast.pm Parse multi-line query fields properly
1280    - small speed improvements to blasttable.pm and others
1282   o Bio::DB::Taxonomy has better support for hierarchy traversal so that
1283     Bio::Taxonomy::Node can be as simple as Bio::Species object while still
1284     supporting more complex queries
1287 1.4. Stable major release
1289 Since initial 1.2.0, 3000 separate changes have been made to make this release.
1291    o installable scripts
1293    o global module version from Bio::Root:Version
1295    o Bio::Graphics
1296       - major improvements; SVG support
1298    o Bio::Popgen
1299      - population genetics
1300      - support several population genetics types of questions.
1301      - Tests for statistical neutrality of mutations
1302        (Fu and Li's D/F, Tajima's D) are in Bio::PopGen::Statistics.
1303        Tests of population structure (Wright's F-statistic: Fst) is in
1304        Bio::PopGen::PopStats. Calculating composite linkage
1305        disequilibrium (LD) is available in Bio::PopGen::Statistics as
1306        well.
1307      - Bio::PopGen::IO for reading in prettybase (SeattleSNPs)
1308        and csv (comma delimited formatted) data.
1310      - a directory for implementing population simulations has
1311        been added Bio::PopGen::Simulation and 2 simulations - a
1312        Coalescent and a simple single-locus multi-allele genetic drift
1313        simulation have been provided.  This replaces the code in
1314        Bio::Tree::RandomTree which has been deprecated until proper
1315        methods for generating random phylogenetic trees are
1316        implemented.
1318    o Bio::Restriction
1319       - new restrion analysis modules
1321    o Bio::Tools::Analysis
1322       - web based DNA and Protein analysis framework and several
1323         implementations
1325    o Bio::Seq::Meta
1326      - per residue annotable sequences
1328    o Bio::Matrix
1329       - Bio::Matrix::PSM - Position Scoring Matrix
1330       - Bio::Matrix::IO has been added for generalized parsing of
1331         matrix data.  Matrix::IO::scoring and Matrix::IO::phylip are
1332         initial implementations for parsing BLOSUM/PAM and Phylip
1333         Distance matricies respectively.  A generic matrix
1334         implementation for general use was added in
1335         Bio::Matrix::Generic.
1337    o Bio::Ontology
1338      - major changes
1340    o Bio:Tree
1342    o Bio::Tools::SiRNA, Bio::SeqFeature::SiRNA
1343      - small inhibitory RNA
1345    o Bio::SeqFeature::Tools
1346      - seqFeature mapping tools
1347      - Bio::SeqFeature::Tools::Unflattener.pm
1348        -- deal with mapping GenBank feature collections into
1349           Chado/GFF3 processable feature sets (with SO term mappings)
1351    o Bio::Tools::dpAlign
1352      - pure perl dynamic programming sequence alignment
1353      - needs Bioperl-ext
1355    o new Bio::SearchIO formats
1356      - axt and psl:  UCSC formats.
1357      - blasttable: NCBI -m 8 or -m 9 format from blastall
1359    o new Bio::SeqIO formats
1360      - chado, tab, kegg, tigr, game
1361      - important fixes for old modules
1363    o Bio::AlignIO: maf
1365    o improved Bio::Tools::Genewise
1367    o Bio::SeqIO now can recongnize sequence formats automatically from
1368      stream
1370    o new parsers in Bio::Tools:
1371       Blat, Geneid, Lagan, Mdust, Promoterwise, PrositeScan,
1373    o Bio::DB::Registry bugs fixed
1374      - BerkeleyDB-indexed flat files can be used by the OBDA system
1375      - Multiple seqdatabase.ini locations in OBDA_SEARCH_PATH are all
1376        used by the OBDA system
1378    o several new HOWTOs
1379      - SimpleWebAnalysis, Trees, Feature Annotation, OBDA Access, Flat
1380        Databases
1382    o hundreds of new and improved files
1385    o
1386    o Bio::Tree::AlleleNode has been updated to be a container of
1387      an Bio::PopGen::Individual object for use in the Coalescent simulations.
1390 1.2 Branch
1392 1.2.3 Stable release update
1393     o Bug #1475 - Fix and add speedup to spliced_seq for remote location
1394                   handling.
1395     o Bug #1477 - Sel --> Sec abbreviation fixed
1396     o Fix bug #1487 where paring in-between locations when
1397       end < start caused the FTLocationFactory logic to fail.
1398     o Fix bug #1489 which was not dealing with keywords as an
1399       arrayref properly (this is fixed on the main trunk because
1400       keywords returns a string and the array is accessible via
1401       get_keywords).
1402     o Bio::Tree::Tree memory leak (bug #1480) fixed
1403       Added a new initialization option -nodelete which
1404       won't try and cleanup the containing nodes if this
1405       is true.
1406      o Bug with parsing labeled nodes with Bio::TreeIO::newick fixed
1407        this was only present on the branch for the 1.2.1 and 1.2.2 series
1408        - Also merged main trunk changes to the branch which make
1409          newick -> nhx round tripping more effective (storing branch length
1410          and bootstrap values in same locate for NodeNHX and Node
1411          implementations.)  Fixes to TreeIO parsing for labeled internal
1412          also required small changes to TreeIO::nhx.  Improved
1413          tests for this module as well.
1414     o Bio::SearchIO
1415       - Fixed bugs in BLAST parsing which couldn't parse NCBI
1416         gapped blast properly (was losing hit significance values due to
1417         the extra unexpeted column).
1418       - Parsing of blastcl3 (netblast from NCBI) now can handle case of
1419         integer overflow (# of letters in nt seq dbs is > MAX_INT)
1420         although doesn't try to correct it - will get the negative
1421         number for you.  Added a test for this as well.
1422       - Fixed HMMER parsing bug which prevented parsing when a hmmpfam report
1423         has no top-level family classification scores but does have scores and
1424         alignments for individual domains.
1425       - Parsing FASTA reports where ungapped percent ID is < 10 and the
1426         regular expression to match the line was missing the possibility of
1427         an extra space.  This is rare, which is why we probably did not
1428         catch it before.
1429       - BLAST parsing picks up more of the statistics/parameter fields
1430         at the bottom of reports.  Still not fully complete.
1431       - SearchIO::Writer::HTMLResultWriter and TextResultWriter
1432         were fixed to include many improvements and added flexiblity
1433         in outputting the files.  Bug #1495 was also fixed in the process.
1434      o Bio::DB::GFF
1435       - Update for GFF3 compatibility.
1436       - Added scripts for importing from UCSC and GenBank.
1437       - Added a 1.2003 version number.
1438      o Bio::Graphics
1439       - Updated tutorial.
1440       - Added a 1.2003 version number.
1441      o SeqIO::swiss Bug #1504 fixed with swiss writing which was not
1442        properly writing keywords out.
1443      o Bio::SeqIO::genbank
1444       - Fixed bug/enhancement #1513 where dates of
1445         the form D-MMM-YYYY were not parsed.  Even though this is
1446         invalid format we can handle it - and also cleanup the date
1447         string so it is properly formatted.
1448       - Bug/enhancement #1517 fixed so that SEGMENT line can be parsed
1449         and written with Genbank format.  Similarly bug #1515 is fixed to
1450         parse in the ORIGIN text.
1451      o Bio::SeqIO::fasta, a new method called preferred_id_type allows you
1452        to specify the ID type, one of (accession accession.version
1453        display primary).  See Bio::SeqIO::preferred_id_type method
1454        documentation for more information.
1455      o Unigene parsing updated to handle file format changes by NCBI
1457 1.2.2 Stable release update
1459     o A series of bug fixes of the Bio::OntologyIO dagflat-related parsers:
1460       - auto-discover ontology name
1461       - bug in parsing relationships when certain characters are in the term
1462       - fixed hard-coded prefix for term identifiers
1463       - various smaller issues
1465     o Fixed bug in Bio::Annotation::OntologyTerm of not implementing all
1466       of Bio::Ontology::TermI
1468     o brought the OBDA Registry code up to latest specs
1470     o Bio::DB::GenBank
1471       - eutils URL change
1472       - accession number retrieval fixed
1474     o Bio::SearchIO::blast - fix bug #1443 (missing last hits), parse megablast
1476     o Bio::SearchIO::Writer::(HTML|Text)ResultWriter fix bugs #1458,
1477       #1459 which now properly report alignment start/end info
1478       for translated BLAST/FASTA searches.
1480     o Bio::TreeIO::newick can parse labeled internal nodes
1482     o Bio::Tools::BPbl2seq can properly report strand info for HSPs
1483       for BLASTX if if you provide -report_type => 'BLASTX' when
1484       initializing a BPbl2seq object.  Bioperl 1.3 will have better
1485       support for bl2seq in the SearchIO system.
1487     o Bio::Root::IO support a -noclose boolean flag which will not
1488       close a filehandle upon object cleanup - useful when sharing
1489       a filehandle among objects.  Additionally code added s.t.
1490       STDOUT/STDIN/STDERR will never be closed by Root::IO cleanup.
1492     o Bio::Tools::Genemark bug #1435 fixed which was missing last prediction
1494     o Bio::SeqIO::genbank
1495       - bug #1456 fixed which generated extra sequence lines
1496       - write moltype correctly for genpept
1498 1.2.1 Stable release update
1500     o Inclusion of WrapperBase, a needed component for StandAloneBlast
1502     o Addition from main trunk of Ontology objects, principly to allow
1503       BioSQL releases against 1.2.1
1505     o Fixes and cleanup of Bio::Coordinate modules
1507     o A fix to Bio::Index::EMBL allowing  retrieval of entries using
1508       the primary accession number
1510     o Other bug fixes, including bpindex GenBank fix
1512     o Bio::SeqIO::genbank bug #1389 fixed
1514 1.2  Stable major release
1516     o More functionality added to Bio::Perl, the newbie module
1518     o Bug fixes in Bio::TreeIO::newick fixes bug introduced in 1.0.2
1519       Support for New Hampshire Extended (NHX) format parsing.
1521     o Bio::Tools added support for parsing Genomewise, Pseudowise, Est2Genome,
1522       Tmhmm, SignalP, Seg, RepeatMasker, FootPrinter, and a lightweight
1523       Hmmpfam parser.
1525     o New ontology parsing Bio::Ontology
1527     o Bug fixes in Bio::SearchIO for HMMer parsing, support for
1528       multi-report (mlib) fasta reports, support for waba and exonerate.
1530     o Bio::ClusterIO for parsing Unigene clusters
1532     o Bio::Assembly added for representing phrap and ace assembly clusters.
1534     o Rudimentary support for writing Chado XML (see
1535       GMOD project: www.gmod.org for more information)
1537     o Bio::Coordinate for mapping between different coordinate systems such
1538       as protein -> cDNA -> Exon -> DNA and back.  Useful for mapping
1539       features into different coordinate systems.
1541     o Bio::DB::GenBank/Bio::DB::GenPept now support Entrez queries
1542       with the get_Stream_by_query method and supports the latest
1543       NCBI eutils interface.
1545     o Bugs fixed in Bio::SeqFeature::Collection an in-memory fast
1546       object for extracting subsets of features : currently only
1547       supports extraction by location.
1549 1.1.1 Developer release
1551     o Deprecated modules are now listed in the DEPRECATED file
1553     o New HowTo documents located in doc/howto describing
1554       a domain of Bioperl.
1556     o Note that bugs are now stored at redmine.open-bio.org/projects/bioperl/
1557       and all old bugs are searchable through the bugzilla interface.
1559     o Several reported bugs in Bio::Tools::Sigcleave and Bio::SimpleAlign
1560       have been addressed.
1562     o Support for Genewise parsing in Bio::Tools::Genewise
1564     o Start of Ontology framework with Bio::Ontology
1566     o Speedup to the Bio::Root::Root object method _rearrange.
1567       A global _load_module method was implemented to simplify the
1568       dynamic loading of modules ala Bio::SeqIO::genbank.  This
1569       method is now used by all the XXIO (AlignIO,TreeIO,SearchIO,SeqIO,
1570       etc).
1572     o Several performance improvements to sequence parsing in Bio::SeqIO.
1573       Attempt to speedup by reducing object creation overhead.
1575     o Bio::DB::GenBank and Bio::DB::GenPept use the NCBI's approved
1576       method for sequence retrieval with their E-utils CGI scripts.
1577       More work to support Entrez queries to their fullest is planned
1578       before 1.2 release.
1580     o Numerous fixes to Bio::SearchIO and sequence parsing (swissprot)
1582 1.1 Developer release
1584     o Bio::Tools::Run has been broken off into a new pkg bioperl-run,
1585       this separation removes some of the complexity in our test suite
1586       and separates the core modules in bioperl from those that need
1587       external programs to run.
1589     o With latest ExtUtils::MakeMaker module installed SGI/IRIX should
1590       not run into trouble running the makefile
1592     o Bio::Location and Bio::SeqIO::FTHelper are fixed to properly
1593       read,create,and write locations for grouped/split locations
1594       (like mRNA features on genomic sequence).
1596     o Bio::Tools::Phlyo added for wrappers for parsing Molphy (protml)
1597       and PAML (codeml,aaml, etc) parsing.
1599     o Bio::Tree:: objects expanded to handle testing monophyly,
1600       paraphyly, least common ancestor, etc.
1602     o Bio::Coordinate for mapping locations from different coordinate spaces
1604     o Bio::SearchIO::waba added for parsing WABA, Bio::SearchIO::hmmer
1605       added for parsing hmmpfam and hmmsearch output.
1607     o Bio::SearchIO::Writer::TextResultWriter for outputting
1608       a pseudo-blast textfile format
1611 1.0.2 Bug fix release
1613     o Note: The modules Bio::DB::GenBank and Bio::DB::GenPept provided
1614       in this release will not work after December 2002 when NCBI
1615       shuts off the old Entrez cgi scripts.  We have already fixed
1616       on our main development branch and the functionality will be
1617       available in the next stable bioperl release (1.2) slated for
1618       Fall 2002.
1620     o Numerous parsing bugs in Bio::SearchIO::fasta found through
1621       testset by Robin Emig.  These were fixed as was the get_aln
1622       method in Bio::Search::HSP::GenericHSP to handle the extra
1623       context sequence that is provided with a FastA alignment.
1625     o Migrating differences between Bio::Search::XX::BlastXX to
1626       Bio::Search::XX::GenericXX objects.  This included mechanism
1627       to retrieve whole list of HSPs from Hits and whole list of Hits from
1628       Results in addition to the current next_XX iterator methods that
1629       are available.  Added seq_inds() method to GenericHSP which identifies
1630       indexes in the query or hit sequences where conserved,identical,gaps,
1631       or mismatch residues are located (adapted from Steve Chervitz's
1632       implementation in BlastHSP).
1634     o Bio::DB::GFF bugs fixed and are necessary for latest GBrowse release.
1635       Bio::DB::GFF::RelSegment is now Bio::SeqI compliant.
1637     o Bio::Graphics glyph set improved and extended for GBrowse release
1639     o Bio::Tree::Tree get_nodes implementation improvement thanks
1640       to Howard Ross notice performance problem when writing out
1641       unbalanced trees.
1643     o Bio::Location::Fuzzy::new named parameter -loc_type became
1644       -location_type, Bio::Location::Simple::new named parameter
1645       -seqid becamse -seq_id.
1647     o Fixed major Bio::AlignIO::emboss parsing bug on needle output,
1648       was mis-detecting that gaps should be placed at the beginning of
1649       the alignment when the best alignment starts internally in the
1650       sequence.
1652 1.0.1 Bug fix release
1654     o Minor bug fixes to Bio::DB:GFF.  Glyph sets improved.
1656     o Parser fixes in SearchIO blast, fasta for more complete WU BLAST
1657       and mixed (3.3 - 3.4) versions of FASTA.
1659     o Small API change to add methods for completeness across
1660       implementations of Bio::Search objects.  These new methods
1661       in the interface are implemented by the GenericXX object as well
1662       as the BlastXX objects.
1663         * Bio::Search::Result::ResultI
1664          - hits() method returns list of all Hits (next_hit is an
1665            iterator method)
1667         * Bio::Search::Hit::HitI
1668          - hsps() method returns list of all HSPs (next_hsp is an
1669            iterator method)
1671     o The Bio::SearchIO::Writer classes have been fixed to handle results
1672        created from either psiblast (Search::BlastXX objects) or
1673        blast|fasta|blastxml objects (Search::GenericXX objects).  More work
1674        has to be done here to make it work properly and will nee major
1675        API changes.
1677     o Bugs in Bio::Tools::HMMER fixed, including
1678        * #1178 - Root::IO destructor wasn't being called
1679        * #1034 - filter_on_cutoff now behaves properly
1681     o Bio::SeqFeature::Computation initialization args fixed and
1682       tests added.
1684     o Tests are somewhat cleaner, flat.t now properly cleans up after itsself,
1686     o Updated FAQ with more example based answers to typical questions
1688     o Bug #1202 was fixed which would improperly join together qual values
1689       parsed by Bio::SeqIO::qual when a trailing space was not present before
1690       the newline.
1692 1.0.0 Major Stable Release
1694   This represents a major release of bioperl with significant
1695   improvements over the 0.7.x series of releases.
1697     o Bio::Tools::Blast is officially deprecated.  Please see
1698       Bio::SearchIO for BLAST and FastA parsing.
1700     o The methods trunc() and subseq() in Bio::PrimarySeqI now accepts
1701       Bio::LocationI objects as well as start/end.
1703     o Bio::Biblio contains modules for Bibliographic data.
1704       Bio::DB::Biblio contains the query modules.  Additionally one can
1705       parse medlinexml from the ebi bibliographic query service (BQS)
1706       system and Pubmed xml from NCBI.  See Martin Senger's
1707       documentation in Bio::Biblio for more information.
1709     o Bio::DB::Registry is a sequence database registry part of
1710       Open Bioinformatics Database Access.  See
1711       http://obda.open-bio.org for more information.
1713     o File-based and In-Memory Sequence caching is provided by
1714       Bio::DB::InMemoryCache and Bio::DB::FileCache which acts like a
1715       local database.
1717     o Bio::Graphics for rendering sequences as PNG,JPG, or GIFs has
1718       been added by Lincoln Stein.
1720     o XEMBL SOAP service access in provided in Bio::DB::XEMBL.
1722     o A FAQ has been started and is included in the release to provide
1723       a starting point for frequent questions and issues.
1725 0.9.3 Developer's release
1727     o Event based parsing system improved (SearchIO).  With parsers for
1728       XML Blast (blastxml), Text Blast (blast), and FASTA results (fasta).
1729       Additionally a lazy parsing system for text and html blast reports was
1730       added and is called psiblast (name subject to change in future releases).
1732     o Bio::Search objects improved and standardized with associated Interfaces
1733       written.  The concept of a search "Hit" was standardized to be called
1734       "hit" consistently and the use of "subject" was deprecated in all active
1735       modules.
1737     o Bio::Structure added (since 0.9.1) for Protein structure objects
1738       and PDB parser to retrieve and write these structures from data files.
1740     o Several important Bio::DB::GFF bug fixes for handling features that
1741       are mapped to multiple reference points.  Updated mysql adaptor
1742       so as to be able to store large (>100 megabase) chunks of DNA into
1743       Bio::DB::GFF databases.
1745 0.9.2 Developer's release
1747     o Bio::Search and Bio::SearchIO system introduced for event based
1748       parsing of Blast,Fasta reports Bio::SearchIO supports ncbi BLAST
1749       in text and XML and FASTA reports in standard output format.
1751     o Bio::Tree and Bio::TreeIO for phylogenetic trees.  A Random tree
1752       generator is included in Bio::TreeIO::RandomTrees and a
1753       statistics module for evaluating.
1755     o Bio::DB::GFF, Lincoln Stein's GFF database suitable as a DB
1756       server for DAS servers.
1758     o Bio::Tools::BPlite is provides more robust parsing of BLAST
1759       files.  The entire BPlite system migrated to using Bio::Root::IO
1760       for the data stream.
1762     o Bio::Tools::Alignment for Consed and sequence Trimming
1763       functionality.
1765     o Bio::Structure for Protein structure information and parsing
1767     o Bio::DB::GenBank/Bio::DB::GenPept updated to new NCBI Entrez
1768       cgi-bin entry point which should be more reliable.
1770     o Bio::Map and Bio::MapIO for biological map navigation and a
1771       framework afor parsing them in.  Only preliminary work here.
1773     o Interface for executing EMBOSS programs locally in Bio::Factory::EMBOSS
1774       Future work will integrate Pise and allow submission of analysis on
1775       remote servers.
1777     o Bio::AnnotationCollectionI and Bio::Annotation::Collection
1778       introduced as new objects for handling Sequence Annotation
1779       information (dblinks, references, etc) and is more robust that
1780       previous system.
1782     o Bio::Tools::FASTAParser introduced.
1784     o Scripts from the bioperl script submission project and new
1785       scripts from bioperl authors are included in "scripts" directory.
1787     o Factory objects and interfaces are being introduced and are more
1788       strictly enforced.
1790     o Bio::Root::Root introduced as the base object while
1791       Bio::Root::RootI is now simply an interface.
1793     o Bio::DB::RefSeq provides database access to copy of the NCBI
1794       RefSeq database using the EBI dbfetch script.
1796 0.9.0 Developer's release
1798     o perl version at least 5.005 is now required instead of perl 5.004
1800     o Bio::Tools::Run::RemoteBlast is available for running remote
1801       blast jobs at NCBI.
1803     o Bio::Tools::BPbl2seq was fixed to handle multiple HSPs.
1805     o Bio::SeqFeature::GeneStructure migrated to Bio::SeqFeature::Gene.
1806       Also added are related modules UTR3, UTR5, Exon, Intron,
1807       Promotor, PolyA and Transcript.
1809     o Speedup of translate method in PrimarySeq
1811     o Bio::SimpleAlign has new methods: location_from_column(), slice(),
1812       select(), dot(), get_seq_by_pos(), column_from_residue_number()
1814     o Various fixes to Variation toolkit
1816     o Bio::DB::EMBL provides database access to EMBL sequence data.
1817       Bio::DB::Universal provides a central way to point to indexes
1818       and dbs in a single interface.
1820     o Bio::DB::GFF - a database suitable for running DAS servers locally.
1822     o Bio::Factory::EMBOSS is still in design phase as is
1823       Bio::Factory::ApplicationFactoryI
1825     o Dia models for bioperl design are provided in the models/ directory
1827 0.7.2 Bug fix release
1829     o documentation fixes in many modules - SYNOPSIS code verified
1830       to be runnable in many (but not all modules)
1832     o corrected MANIFEST file from 0.7.1 release
1834     o Bug fix in Bio::SeqIO::FTHelper to properly handle
1835       split locations
1837     o Bio::SeqIO::genbank
1838         * Correct parsing and writing of genbank format with protein data
1839         * moltype and molecule separation
1841     o Bio::SeqIO::largefasta fix to avoid inifinite loops
1843     o Bio::SimpleAlign fixed to correctly handle consensus
1844       sequence calculation
1846     o Bio::Tools::HMMER supports hmmer 2.2g
1848     o Bio::Tools::BPlite to support report type specific parsing.  Most
1849       major changes are not on the 0.7 branch.
1851     o Bio::Tools::Run::StandAloneBlast exists_blast() fixed and works
1852       with File::Spec
1854     o Bio::Variation::AAChange/RNAChange corrected labels and mutated alleles
1855         in several types of mutations:
1856         1.) AA level: deletion, complex
1857         2.) AA level: complex, inframe
1858         3.) RNA level: silent
1860     o  BPbl2seq parsing of empty reports will not die, but will return
1861        a valid, empty, Bio::SeqFeature::SimilarityFeature for
1862        $report->query() and $report->subject() methods.  So an easy
1863        way to test if report was empty is to see if
1864        $report->query->seqname is undefined.
1866 0.7.1 Bug fix release
1868     o Better parsing of genbank/EMBL files especially fixing bugs
1869       related to Feature table parsing and locations on remote
1870       sequences.  Additionally, species name parsing was better.
1872     o Bio::SeqIO::genbank can parse now NCBI produced genbank database
1873       which include a number of header lines.
1875     o More strict genbank and EMBL format writing (corrected number of
1876       spaces where appropriate).
1878     o Bio::Tools::BPlite can better parse BLASTX reports - see BUGS
1879       for related BPlite BUGS that are unresolved in this release.
1881     o Bio::DB::GenBank, Bio::DB::GenPept have less problems
1882       downloading sequences from NCBI via HTTP.  Bio::DB::SwissProt can
1883       use expasy mirrors or EBI dbfetch cgi-script.
1885     o A moderate number of documentation improvements were made as
1886       well to provide a better code synopsis in each module.
1889 0.7  Large number of changes, including refactoring of the
1890      Object system, new parsers, new functionality and
1891      all round better system. Highlights are:
1894      o Refactored root of inheritance: moved to a lightweight Bio::Root::RootI;
1895        Bio::Root::IO for I/O and file/handle capabilities.
1897      o Imported BPlite modules from Ian Korf for BLAST
1898        parsing. This is considered the supported BLAST parser;
1899        Bio::Tools::Blast.pm will eventually phase out due to lack of support.
1901      o Improved Sequence Feature model. Added complete location
1902        modelling (with fuzzy and compound locations).  See
1903        Bio::LocationI and the modules under Bio/Location.  Added
1904        support in Genbank/EMBL format parsing to completely parse
1905        feature tables for complex locations.
1907      o Moved special support for databanks etc to specialized modules under
1908        Bio/Seq/. One of these supports very large sequences through
1909        a temporary file as a backend.
1911      o Explicit Gene, Transcript and Exon SeqFeature objects, supporting
1912        CDS retrieval and exon shuffling.
1914      o More parsers: Sim4, Genscan, MZEF, ESTScan, BPbl2seq, GFF
1916      o Refactored Bio/DB/GenBank+GenPept. There is now also DB/SwissProt and
1917        DB/GDB (the latter has platform-specific limitations).
1919      o New analysis parser framework for HT sequence annotation (see
1920        Bio::SeqAnalysisParserI and Bio::Factory::SeqAnalysisParserFactory)
1922      o New Alignment IO framework
1924      o New Index modules (Swissprot)
1926      o New modules for running Blast within perl
1927        (Bio::Tools::Run::StandAloneBlast). Added modules for running
1928        Multiple Sequence Alignment tools ClustalW and TCoffee
1929        (Bio::Tools::Run::Alignment).
1931      o New Cookbook-style tutorial (see bptutorial.pl). Improved
1932        documentation across the package.
1934      o Much improved cross platform support. Many known incompatibilities
1935        have been fixed; however, NT and Mac do not work across the entire
1936        setup (see PLATFORMS).
1938      o Many bug fixes, code restructuring, etc. Overall stability and
1939        maintainability benefit a lot.
1941      o A total of 957 automatic tests
1944 0.6.2
1946    There are very few functionality changes but a large
1947    number of software improvements/bug fixes across the package.
1949    o The EMBL/GenBank parsing are improved.
1951    o The Swissprot reading is improved. Swissprot writing
1952      is disabled as it doesn't work at all. This needs to
1953      wait for 0.7 release
1955    o BLAST reports with no hits are correctly parsed.
1957    o Several other bugs of the BLAST parser (regular expressions, ...)
1958      fixed.
1960    o Old syntax calls have been replaced with more modern syntax
1962    o Modules that did not work at all, in particular the Sim4
1963      set have been removed
1965    o Bio::SeqFeature::Generic and Bio::SeqFeature::FeaturePair
1966      have improved compliance with interface specs and documentation
1968    o Mailing list documentation updated throughout the distribution
1970    o Most minor bug fixes have happened.
1972    o The scripts in /examples now work and have the modern syntax
1973      rather than the deprecated syntax
1976 0.6.1  Sun April 2 2000
1978    o Sequences can have Sequence Features attached to them
1979         - The sequence features can be read from or written to
1980           EMBL and GenBank style flat files
1982    o Objects for Annotation, including References (but not
1983      full medline abstracts), Database links and Comments are
1984      provided
1986    o A Species object to represent nodes on a taxonomy tree
1987      is provided
1989    o The ability to parse HMMER and Sim4 output has been added
1991    o The Blast parsing has been improved, with better PSI-BLAST
1992      support and better overall behaviour.
1994    o Flat file indexed databases provide both random access
1995      and sequential access to their component sequences.
1997    o A CodonTable object has been written with all known
1998      CodonTables accessible.
2000    o A number of new lightweight analysis tools have been
2001      added, such as molecular weight determination.
2003     The 0.6 release also has improved software engineering
2005    o The sequence objects have been rewritten, providing more
2006      maintainable and easier to implement objects. These
2007      objects are backwardly compatible with the 0.05.1 objects
2009    o Many objects are defined in terms of interfaces and then
2010      a Perl implementation has been provided. The interfaces
2011      are found in the 'I' files (module names ending in 'I').
2013      This means that it is possible to wrap C/CORBA/SQL access
2014      as true "bioperl" objects, compatible with the rest of
2015      bioperl.
2017    o The SeqIO system has been overhauled to provide better
2018      processing and perl-like automatic interpretation of <>
2019      over arguments.
2021    o Many more tests have been added (a total of 172 automatic
2022      tests are now run before release).
2026 0.05.1 Tue Jun 29 05:30:44 1999
2027         - Central distribution now requires Perl 5.004. This was
2028           done to get around 5.003-based problems in Bio/Index/*
2029           and SimpleAlign.
2030         - Various bug fixes in the Bio::Tools::Blast modules
2031           including better exception handling and PSI-Blast
2032           support. See Bio/Tools/Blast/CHANGES for more.
2033         - Fixed the Parse mechanism in Seq.pm to use readseq.
2034           Follow the instructions in README for how to install
2035           it (basically, you have to edit Parse.pm).
2036         - Improved documentation of Seq.pm, indicating where
2037           objects are returned and where strings are returned.
2038         - Fixed uninitialized warnings in Bio::Root::Object.pm
2039           and Bio::Tools::SeqPattern.pm.
2040         - Bug fixes for PR#s: 30,31,33-35,41,42,44,45,47-50,52.
2042 0.05  Sun Apr 25 01:14:11 1999
2043         - Bio::Tools::Blast modules have less memory problems
2044           and faster parsing. Webblast uses LWP and supports
2045           more functionality. See Bio/Tools/Blast/CHANGES for more.
2046         - The Bio::SeqIO system has been started, moving the
2047           sequence reformatting code out of the sequence object
2048         - The Bio::Index:: system has been started, providing
2049           generic index capabilities and specifically works for
2050           Fasta formatted databases and EMBL .dat formatted
2051           databases
2052         - The Bio::DB:: system started, providing access to
2053           databases, both via flat file + index (see above) and
2054           via http to NCBI
2055         - The scripts/ directory, where industrial strength scripts
2056           are put has been started.
2057         - Many changes - a better distribution all round.
2059 0.04.4  Wed Feb 17 02:20:13 1999
2060         - Bug fixes in the Bio::Tools::Blast modules and postclient.pl
2061           (see Bio::Tools::Blast::CHANGES).
2062         - Fixed a bug in Bio::Tools::Fasta::num_seqs().
2063         - Beefed up the t/Fasta.t test script.
2064         - Small fix in Bio::Seq::type() (now always returns a string).
2065         - Changed Bio::Root::Utilities::get_newline_char() to
2066           get_newline() since it could return more than one char.
2067         - Added $NEWLINE and $TIMEOUT_SECS to Bio::Root::Global.
2068         - Changed default timeout to 20 seconds (was 3).
2069         - Moved lengthy modification notes to the bottom of some files.
2070         - Fixed SimpleAlign write_fasta bug.
2071         - Beefed up SimpleAlign.t test
2073 0.04.3  Thu Feb  4 07:48:53 1999
2074         - Bio::Root::Object.pm and Global.pm now detect when
2075           script is run as a CGI and suppress output that is only
2076           appropriate when running interactively.
2077         - Bio::Root::Err::_set_context() adds name of script ($0).
2078         - Added comments in Bio::Tools::WWW.pm and Bio::Root::Utilities.pm
2079           regarding the use of the static objects via the qw(:obj) tag.
2080         - Fixed the ambiguous reverse calls in Seq.pm and UnivAln.pm to
2081           CORE::reverse, avoiding Perl warnings.
2082         - Bug fixes in Bio::Tools::Blast modules (version 0.074) and
2083           example scripts (see Bio::Tools::Blast::CHANGES).
2084         - examples/seq/seqtools.pl no longer always warns about using
2085           -prot or -nucl command-line arguments; only when using the
2086           -debug argument.
2087         - Methods added to Bio::Root::Utilities: create_filehandle(),
2088           get_newline_char(), and taste_file() to generalize filehandle
2089           creation and autodetect newline characters in files/streams
2090           (see bug report #19).
2091         - Bio::Root::IOManager::read() now handles timeouts and uses
2092           Utilities::create_filehandle().
2093         - Bio::Tools::Fasta.pm uses Utilities::get_newline_char() instead
2094           of hardwiring in "\n".
2095         - Bug fixes in the Bio::SimpleAlign and Bio::Tools::pSW
2097 0.04.2  Wed Dec 30 02:27:36 1998
2098         - Bug fixes in Bio::Tools::Blast modules, version 0.073
2099           (see Bio::Tools::Blast::CHANGES).
2100         - Changed reverse calls in Bio/Seq.pm and Bio/UnivAln.pm
2101           to CORE::reverse (prevents ambiguous warnings with 5.005).
2102         - Appending '.tmp.bioperl' to temporary files created by
2103           Bio::Root::Utilities::compress() or uncompress() to
2104           make it easy to identify & cleanup these files as needed.
2105         - Developers: Created CVS branch release-0-04-bug from
2106           release-0-04-1. Before making bug fixes to the 0.04.1 release,
2107           be sure to cvs checkout this branch into a clean area.
2109 0.04.1  Wed Dec 16 05:39:15 1998
2110         - Bug fixes in Bio::Tools::Blast modules, version 0.072
2111           (see Bio::Tools::Blast::CHANGES).
2112         - Compile/SW/Makefile.PL now removes *.o and *.a files
2113           with make clean.
2115 0.04  Tue Dec  8 07:49:19 1998
2116         - Lots of new modules added including:
2117            * Ewan Birney's Bio::SimpleAlign.pm, Bio::Tools::AlignFactory.pm,
2118              and Bio/Compile directory containing XS-linked C code for
2119              creating Smith-Waterman sequence alignments from within Perl.
2120            * Steve Chervitz's Blast distribution has been incorporated.
2121            * Georg Fuellen's Bio::UnivAln.pm for multiple alignment objects.
2122         - Bio/examples directory for demo scripts for all included modules.
2123         - Bio/t directory containing test suit for all included modules.
2124         - For changes specific to the Blast-related modules prior to
2125           incorporation in this central distribution, see the CHANGES
2126           file in the Bio/Tools/Blast directory.
2128 0.01  Tue Sep  8 14:23:22 1998
2129         - original version from central CVS tree; created by h2xs 1.18