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