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