runqueue.py: Fix idepends handling to avoid dependency errors, improve debugging...
[bitbake.git] / ChangeLog
1 Changes in Bitbake 1.9.x:
2         - Add PE (Package Epoch) support from Philipp Zabel (pH5)
3         - Treat python functions the same as shell functions for logging
4         - Use TMPDIR/anonfunc as a __anonfunc temp directory (T)
5         - Catch truncated cache file errors
6         - Allow operations other than assignment on flag variables
7         - Add code to handle inter-task dependencies
8         - Fix cache errors when generation dotGraphs
9         - Make sure __inherit_cache is updated before calling include() (from Michael Krelin)
10         - Fix bug when target was in ASSUME_PROVIDED (#2236)
11         - Raise ParseError for filenames with multiple underscores instead of infinitely looping (#2062)
12         - Fix invalid regexp in BBMASK error handling (missing import) (#1124)
13         - Promote certain warnings from debug to note 2 level
14         - Update manual
15         - Correctly redirect stdin when forking
16         - If parsing errors are found, exit, too many users miss the errors
17         - Remove supriours PREFERRED_PROVIDER warnings
18         - svn fetcher: Add _buildsvncommand function
19         - Improve certain error messages
20         - Rewrite svn fetcher to make adding extra operations easier 
21           as part of future SRCDATE="now" fixes
22           (requires new FETCHCMD_svn definition in bitbake.conf)
23         - Change SVNDIR layout to be more unique (fixes #2644 and #2624)
24         - Add ConfigParsed Event after configuration parsing is complete
25         - Add SRCREV support for svn fetcher
26         - data.emit_var() - only call getVar if we need the variable
27         - Stop generating the A variable (seems to be legacy code)
28         - Make sure intertask depends get processed correcting in recursive depends
29         - Add pn-PN to overrides when evaluating PREFERRED_VERSION
30         - Improve the progress indicator by skipping tasks that have 
31           already run before starting the build rather than during it
32         - Add profiling option (-P)
33         - Add BB_SRCREV_POLICY variable (clear or cache) to control SRCREV cache
34         - Add SRCREV_FORMAT support
35         - Fix local fetcher's localpath return values
36         - Apply OVERRIDES before performing immediate expansions
37         - Allow the -b -e option combination to take regular expressions
38         - Fix handling of variables with expansion in the name using _append/_prepend
39           e.g. RRECOMMENDS_${PN}_append_xyz = "abc"
40         - Add plain message function to bb.msg
41         - Sort the list of providers before processing so dependency problems are 
42           reproducible rather than effectively random
43         - Fix/improve bitbake -s output
44         - Add locking for fetchers so only one tries to fetch a given file at a given time
45         - Fix int(0)/None confusion in runqueue.py which causes random gaps in dependency chains          
46         - Expand data in addtasks
47         - Print the list of missing DEPENDS,RDEPENDS for the "No buildable providers available for required...."
48           error message.
49         - Rework add_task to be more efficient (6% speedup, 7% number of function calls reduction)
50         - Sort digraph output to make builds more reproducible
51         - Split expandKeys into two for loops to benefit from the expand_cache (12% speedup)
52         - runqueue.py: Fix idepends handling to avoid dependency errors
53
54 Changes in Bitbake 1.8.0:
55         - Release 1.7.x as a stable series
56
57 Changes in BitBake 1.7.x:
58         - Major updates of the dependency handling and execution
59           of tasks. Code from bin/bitbake replaced with runqueue.py
60           and taskdata.py
61         - New task execution code supports multithreading with a simplistic
62           threading algorithm controlled by BB_NUMBER_THREADS
63         - Change of the SVN Fetcher to keep the checkout around
64           courtsey of Paul Sokolovsky (#1367)
65         - PATH fix to bbimage (#1108)
66         - Allow debug domains to be specified on the commandline (-l)
67         - Allow 'interactive' tasks
68         - Logging message improvements
69         - Drop now uneeded BUILD_ALL_DEPS variable
70         - Add support for wildcards to -b option
71         - Major overhaul of the fetchers making a large amount of code common
72           including mirroring code
73         - Fetchers now touch md5 stamps upon access (to show activity)
74         - Fix -f force option when used without -b (long standing bug)
75         - Add expand_cache to data_cache.py, caching expanded data (speedup)
76         - Allow version field in DEPENDS (ignored for now)
77         - Add abort flag support to the shell
78         - Make inherit fail if the class doesn't exist (#1478)
79         - Fix data.emit_env() to expand keynames as well as values
80         - Add ssh fetcher
81         - Add perforce fetcher
82         - Make PREFERRED_PROVIDER_foobar defaults to foobar if available
83         - Share the parser's mtime_cache, reducing the number of stat syscalls
84         - Compile all anonfuncs at once! 
85           *** Anonfuncs must now use common spacing format ***
86         - Memorise the list of handlers in __BBHANDLERS and tasks in __BBTASKS
87           This removes 2 million function calls resulting in a 5-10% speedup
88         - Add manpage
89         - Update generateDotGraph to use taskData/runQueue improving accuracy
90           and also adding a task dependency graph
91         - Fix/standardise on GPLv2 licence
92         - Move most functionality from bin/bitbake to cooker.py and split into
93           separate funcitons
94         - CVS fetcher: Added support for non-default port
95         - Add BBINCLUDELOGS_LINES, the number of lines to read from any logfile
96         - Drop shebangs from lib/bb scripts
97
98 Changes in Bitbake 1.6.0:
99         - Better msg handling
100         - COW dict implementation from Tim Ansell (mithro) leading
101           to better performance
102         - Speed up of -s
103
104 Changes in Bitbake 1.4.4:
105         - SRCDATE now handling courtsey Justin Patrin
106         - #1017 fix to work with rm_work
107
108 Changes in BitBake 1.4.2:
109         - Send logs to oe.pastebin.com instead of pastebin.com
110           fixes #856
111         - Copy the internal bitbake data before building the
112           dependency graph. This fixes nano not having a
113           virtual/libc dependency
114         - Allow multiple TARBALL_STASH entries
115         - Cache, check if the directory exists before changing
116           into it
117         - git speedup cloning by not doing a checkout
118         - allow to have spaces in filenames (.conf, .bb, .bbclass)
119
120 Changes in BitBake 1.4.0:
121         - Fix to check both RDEPENDS and RDEPENDS_${PN}
122         - Fix a RDEPENDS parsing bug in utils:explode_deps()
123         - Update git fetcher behaviour to match git changes
124         - ASSUME_PROVIDED allowed to include runtime packages
125         - git fetcher cleanup and efficency improvements
126         - Change the format of the cache
127         - Update usermanual to document the Fetchers
128         - Major changes to caching with a new strategy
129           giving a major performance increase when reparsing
130           with few data changes
131
132 Changes in BitBake 1.3.3:
133         - Create a new Fetcher module to ease the
134           development of new Fetchers.
135           Issue #438 fixed by rpurdie@openedhand.com
136         - Make the Subversion fetcher honor the SRC Date
137           (CVSDATE).
138           Issue #555 fixed by chris@openedhand.com
139         - Expand PREFERRED_PROVIDER properly
140           Issue #436 fixed by rprudie@openedhand.com
141         - Typo fix for Issue #531 by Philipp Zabel for the
142           BitBake Shell
143         - Introduce a new special variable SRCDATE as
144           a generic naming to replace CVSDATE.
145         - Introduce a new keyword 'required'. In contrast
146           to 'include' parsing will fail if a to be included
147           file can not be found.
148         - Remove hardcoding of the STAMP directory. Patch
149           courtsey pHilipp Zabel
150         - Track the RDEPENDS of each package (rpurdie@openedhand.com)
151         - Introduce BUILD_ALL_DEPS to build all RDEPENDS. E.g
152           this is used by the OpenEmbedded Meta Packages.
153           (rpurdie@openedhand.com).
154
155 Changes in BitBake 1.3.2:
156         - reintegration of make.py into BitBake
157         - bbread is gone, use bitbake -e
158         - lots of shell updates and bugfixes
159         - Introduction of the .= and =. operator
160         - Sort variables, keys and groups in bitdoc
161         - Fix regression in the handling of BBCOLLECTIONS
162         - Update the bitbake usermanual
163
164 Changes in BitBake 1.3.0:
165         - add bitbake interactive shell (bitbake -i)
166         - refactor bitbake utility in OO style
167         - kill default arguments in methods in the bb.data module
168         - kill default arguments in methods in the bb.fetch module
169         - the http/https/ftp fetcher will fail if the to be 
170           downloaded file was not found in DL_DIR (this is needed
171           to avoid unpacking the sourceforge mirror page)
172         - Switch to a cow like data instance for persistent and non
173           persisting mode (called data_smart.py)
174         - Changed the callback of bb.make.collect_bbfiles to carry
175           additional parameters
176         - Drastically reduced the amount of needed RAM by not holding
177           each data instance in memory when using a cache/persistent
178           storage
179
180 Changes in BitBake 1.2.1:
181         The 1.2.1 release is meant as a intermediate release to lay the
182         ground for more radical changes. The most notable changes are:
183
184         - Do not hardcode {}, use bb.data.init() instead if you want to
185           get a instance of a data class
186         - bb.data.init() is a factory and the old bb.data methods are delegates
187         - Do not use deepcopy use bb.data.createCopy() instead.
188         - Removed default arguments in bb.fetch
189