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