taskdata/runqueue.py: Make taskdata and runqueue errors more user friendly
[bitbake.git] / ChangeLog
1 Changes in BitBake 1.8.x:
2         - Psyco is available only for x86 - do not use it on other architectures.
3         - Fix a bug in bb.decodeurl where http://some.where.com/somefile.tgz decoded to host="" (#1530)
4         - Warn about malformed PREFERRED_PROVIDERS (#1072)
5         - Add support for BB_NICE_LEVEL option (#1627)
6         - Sort initial providers list by default preference (#1145, #2024)
7         - Improve provider sorting so prefered versions have preference over latest versions (#768)
8         - Detect builds of tasks with overlapping providers and warn (will become a fatal error) (#1359)
9         - Add MULTI_PROVIDER_WHITELIST variable to allow known safe multiple providers to be listed
10         - Handle paths in svn fetcher module parameter
11         - Support the syntax "export VARIABLE"
12         - Add bzr fetcher
13         - Add support for cleaning directories before a task in the form:
14           do_taskname[cleandirs] = "dir"
15         - bzr fetcher tweaks from Robert Schuster (#2913)
16         - Add mercurial (hg) fetcher from Robert Schuster (#2913)
17         - Fix bogus preferred_version return values
18         - Fix 'depends' flag splitting
19         - Fix unexport handling (#3135)
20         - Add bb.copyfile function similar to bb.movefile (and improve movefile error reporting)
21         - Allow multiple options for deptask flag
22         - Use git-fetch instead of git-pull removing any need for merges when 
23           fetching (we don't care about the index). Fixes fetch errors.
24         - Add BB_GENERATE_MIRROR_TARBALLS option, set to 0 to make git fetches 
25           faster at the expense of not creating mirror tarballs.
26         - SRCREV handling updates, improvements and fixes from Poky
27         - Add bb.utils.lockfile() and bb.utils.unlockfile() from Poky
28         - Add support for task selfstamp and lockfiles flags
29         - Disable task number acceleration since it can allow the tasks to run 
30           out of sequence
31         - Improve runqueue code comments
32         - Add task scheduler abstraction and some example schedulers
33         - Improve circular dependency chain debugging code and user feedback
34         - Don't give a stacktrace for invalid tasks, have a user friendly message (#3431)
35         - Add support for "-e target" (#3432)
36         - Fix shell showdata command (#3259)
37         - Fix shell data updating problems (#1880)
38         - Properly raise errors for invalid source URI protocols
39         - Change the wget fetcher failure handling to avoid lockfile problems
40         - Add git branch support
41         - Add support for branches in git fetcher (Otavio Salvador, Michael Lauer)
42         - Make taskdata and runqueue errors more user friendly
43
44 Changes in Bitbake 1.8.8:
45         - Rewrite svn fetcher to make adding extra operations easier 
46           as part of future SRCDATE="now" fixes
47           (requires new FETCHCMD_svn definition in bitbake.conf)
48         - Change SVNDIR layout to be more unique (fixes #2644 and #2624)
49         - Import persistent data store from trunk
50         - Sync fetcher code with that in trunk, adding SRCREV support for svn
51         - Add ConfigParsed Event after configuration parsing is complete
52         - data.emit_var() - only call getVar if we need the variable
53         - Stop generating the A variable (seems to be legacy code)
54         - Make sure intertask depends get processed correcting in recursive depends
55         - Add pn-PN to overrides when evaluating PREFERRED_VERSION
56         - Improve the progress indicator by skipping tasks that have 
57           already run before starting the build rather than during it
58         - Add profiling option (-P)
59         - Add BB_SRCREV_POLICY variable (clear or cache) to control SRCREV cache
60         - Add SRCREV_FORMAT support
61         - Fix local fetcher's localpath return values
62         - Apply OVERRIDES before performing immediate expansions
63         - Allow the -b -e option combination to take regular expressions
64         - Add plain message function to bb.msg
65         - Sort the list of providers before processing so dependency problems are 
66           reproducible rather than effectively random
67         - Add locking for fetchers so only one tries to fetch a given file at a given time
68         - Fix int(0)/None confusion in runqueue.py which causes random gaps in dependency chains
69         - Fix handling of variables with expansion in the name using _append/_prepend
70           e.g. RRECOMMENDS_${PN}_append_xyz = "abc"
71         - Expand data in addtasks
72         - Print the list of missing DEPENDS,RDEPENDS for the "No buildable providers available for required...."
73           error message.
74         - Rework add_task to be more efficient (6% speedup, 7% number of function calls reduction)
75         - Sort digraph output to make builds more reproducible
76         - Split expandKeys into two for loops to benefit from the expand_cache (12% speedup)
77         - runqueue.py: Fix idepends handling to avoid dependency errors
78         - Clear the terminal TOSTOP flag if set (and warn the user)
79         - Fix regression from r653 and make SRCDATE/CVSDATE work for packages again
80
81 Changes in Bitbake 1.8.6:
82         - Correctly redirect stdin when forking
83         - If parsing errors are found, exit, too many users miss the errors
84         - Remove supriours PREFERRED_PROVIDER warnings
85
86 Changes in Bitbake 1.8.4:
87         - Make sure __inherit_cache is updated before calling include() (from Michael Krelin)
88         - Fix bug when target was in ASSUME_PROVIDED (#2236)
89         - Raise ParseError for filenames with multiple underscores instead of infinitely looping (#2062)
90         - Fix invalid regexp in BBMASK error handling (missing import) (#1124)
91         - Don't run build sanity checks on incomplete builds
92         - Promote certain warnings from debug to note 2 level
93         - Update manual
94
95 Changes in Bitbake 1.8.2:
96         - Catch truncated cache file errors
97         - Add PE (Package Epoch) support from Philipp Zabel (pH5)
98         - Add code to handle inter-task dependencies
99         - Allow operations other than assignment on flag variables
100         - Fix cache errors when generation dotGraphs
101
102 Changes in Bitbake 1.8.0:
103         - Release 1.7.x as a stable series
104
105 Changes in BitBake 1.7.x:
106         - Major updates of the dependency handling and execution
107           of tasks. Code from bin/bitbake replaced with runqueue.py
108           and taskdata.py
109         - New task execution code supports multithreading with a simplistic
110           threading algorithm controlled by BB_NUMBER_THREADS
111         - Change of the SVN Fetcher to keep the checkout around
112           courtsey of Paul Sokolovsky (#1367)
113         - PATH fix to bbimage (#1108)
114         - Allow debug domains to be specified on the commandline (-l)
115         - Allow 'interactive' tasks
116         - Logging message improvements
117         - Drop now uneeded BUILD_ALL_DEPS variable
118         - Add support for wildcards to -b option
119         - Major overhaul of the fetchers making a large amount of code common
120           including mirroring code
121         - Fetchers now touch md5 stamps upon access (to show activity)
122         - Fix -f force option when used without -b (long standing bug)
123         - Add expand_cache to data_cache.py, caching expanded data (speedup)
124         - Allow version field in DEPENDS (ignored for now)
125         - Add abort flag support to the shell
126         - Make inherit fail if the class doesn't exist (#1478)
127         - Fix data.emit_env() to expand keynames as well as values
128         - Add ssh fetcher
129         - Add perforce fetcher
130         - Make PREFERRED_PROVIDER_foobar defaults to foobar if available
131         - Share the parser's mtime_cache, reducing the number of stat syscalls
132         - Compile all anonfuncs at once! 
133           *** Anonfuncs must now use common spacing format ***
134         - Memorise the list of handlers in __BBHANDLERS and tasks in __BBTASKS
135           This removes 2 million function calls resulting in a 5-10% speedup
136         - Add manpage
137         - Update generateDotGraph to use taskData/runQueue improving accuracy
138           and also adding a task dependency graph
139         - Fix/standardise on GPLv2 licence
140         - Move most functionality from bin/bitbake to cooker.py and split into
141           separate funcitons
142         - CVS fetcher: Added support for non-default port
143         - Add BBINCLUDELOGS_LINES, the number of lines to read from any logfile
144         - Drop shebangs from lib/bb scripts
145
146 Changes in Bitbake 1.6.0:
147         - Better msg handling
148         - COW dict implementation from Tim Ansell (mithro) leading
149           to better performance
150         - Speed up of -s
151
152 Changes in Bitbake 1.4.4:
153         - SRCDATE now handling courtsey Justin Patrin
154         - #1017 fix to work with rm_work
155
156 Changes in BitBake 1.4.2:
157         - Send logs to oe.pastebin.com instead of pastebin.com
158           fixes #856
159         - Copy the internal bitbake data before building the
160           dependency graph. This fixes nano not having a
161           virtual/libc dependency
162         - Allow multiple TARBALL_STASH entries
163         - Cache, check if the directory exists before changing
164           into it
165         - git speedup cloning by not doing a checkout
166         - allow to have spaces in filenames (.conf, .bb, .bbclass)
167
168 Changes in BitBake 1.4.0:
169         - Fix to check both RDEPENDS and RDEPENDS_${PN}
170         - Fix a RDEPENDS parsing bug in utils:explode_deps()
171         - Update git fetcher behaviour to match git changes
172         - ASSUME_PROVIDED allowed to include runtime packages
173         - git fetcher cleanup and efficency improvements
174         - Change the format of the cache
175         - Update usermanual to document the Fetchers
176         - Major changes to caching with a new strategy
177           giving a major performance increase when reparsing
178           with few data changes
179
180 Changes in BitBake 1.3.3:
181         - Create a new Fetcher module to ease the
182           development of new Fetchers.
183           Issue #438 fixed by rpurdie@openedhand.com
184         - Make the Subversion fetcher honor the SRC Date
185           (CVSDATE).
186           Issue #555 fixed by chris@openedhand.com
187         - Expand PREFERRED_PROVIDER properly
188           Issue #436 fixed by rprudie@openedhand.com
189         - Typo fix for Issue #531 by Philipp Zabel for the
190           BitBake Shell
191         - Introduce a new special variable SRCDATE as
192           a generic naming to replace CVSDATE.
193         - Introduce a new keyword 'required'. In contrast
194           to 'include' parsing will fail if a to be included
195           file can not be found.
196         - Remove hardcoding of the STAMP directory. Patch
197           courtsey pHilipp Zabel
198         - Track the RDEPENDS of each package (rpurdie@openedhand.com)
199         - Introduce BUILD_ALL_DEPS to build all RDEPENDS. E.g
200           this is used by the OpenEmbedded Meta Packages.
201           (rpurdie@openedhand.com).
202
203 Changes in BitBake 1.3.2:
204         - reintegration of make.py into BitBake
205         - bbread is gone, use bitbake -e
206         - lots of shell updates and bugfixes
207         - Introduction of the .= and =. operator
208         - Sort variables, keys and groups in bitdoc
209         - Fix regression in the handling of BBCOLLECTIONS
210         - Update the bitbake usermanual
211
212 Changes in BitBake 1.3.0:
213         - add bitbake interactive shell (bitbake -i)
214         - refactor bitbake utility in OO style
215         - kill default arguments in methods in the bb.data module
216         - kill default arguments in methods in the bb.fetch module
217         - the http/https/ftp fetcher will fail if the to be 
218           downloaded file was not found in DL_DIR (this is needed
219           to avoid unpacking the sourceforge mirror page)
220         - Switch to a cow like data instance for persistent and non
221           persisting mode (called data_smart.py)
222         - Changed the callback of bb.make.collect_bbfiles to carry
223           additional parameters
224         - Drastically reduced the amount of needed RAM by not holding
225           each data instance in memory when using a cache/persistent
226           storage
227
228 Changes in BitBake 1.2.1:
229         The 1.2.1 release is meant as a intermediate release to lay the
230         ground for more radical changes. The most notable changes are:
231
232         - Do not hardcode {}, use bb.data.init() instead if you want to
233           get a instance of a data class
234         - bb.data.init() is a factory and the old bb.data methods are delegates
235         - Do not use deepcopy use bb.data.createCopy() instead.
236         - Removed default arguments in bb.fetch
237