ChangeLog 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498
  1. 2009-10-05 Marek Habersack <[email protected]>
  2. * Cache.cs: if item expiration time exceeds the maximum value
  3. Timer accepts, use the latter - item will expire properly anyway,
  4. as the timer will be rescheduled for the item's expiration time
  5. once that item is bubbled to the top of the priority queue. Fixes
  6. bug #544171
  7. 2009-09-26 Marek Habersack <[email protected]>
  8. * CacheItemPriorityQueue.cs, CacheItem.cs, CacheItemEnumerator.cs:
  9. added
  10. * Cache.cs: factored out CacheItem and CacheItemEnumerator to
  11. separate files.
  12. Use reader-writer locks instead of Monitor.
  13. Added two 3.5sp1 properties - EffectivePrivateBytesLimit and
  14. EffectivePercentagePhysicalMemoryLimit.
  15. Added support for disabling cache item expiration.
  16. One timer is used to expire all timed items (instead of one timer
  17. per item). Timed items are kept in a priority queue.
  18. 2009-03-03 Marek Habersack <[email protected]>
  19. * CachedRawResponse.cs: headers are stored in NameValueCollection
  20. now.
  21. 2009-01-09 Marek Habersack <[email protected]>
  22. * Cache.cs: System.Threading.Timer.Change takes a long, not an
  23. int. The maximum value of sliding expiration is 365 days
  24. (31536000000ms) which fits within the value range of long. The
  25. previous cast to int might yield negative values in certain
  26. situations which was the reason for bug #464221. Fixes bug #464221
  27. 2008-10-21 Marek Habersack <[email protected]>
  28. * OutputCacheModule.cs: seal the class.
  29. Made OnRawResponseRemoved a static method.
  30. * CachedVaryBy.cs: seal the class.
  31. Use portable line terminators instead of literal '\n'.
  32. * Cache.cs: seal the CacheItem and CacheItemEnumerator classes.
  33. * CacheDependency.cs: dispose the associated dependency in the
  34. DependencyDispose method.
  35. * CachedRawResponse.cs: seal the class
  36. 2008-10-15 Marek Habersack <[email protected]>
  37. * OutputCacheModule.cs: do not take any action if Response returns
  38. null from GetCachedResponse.
  39. 2008-09-30 Juraj Skripsky <[email protected]>
  40. * CachedRawResponse.cs: Don't allocate a 32k buffer that is never
  41. used. Fixes enhancement bug #430963.
  42. 2008-09-29 Marek Habersack <[email protected]>
  43. * OutputCacheModule.cs: invalidate cache entries when the
  44. corresponding source file (.as?x) is recompiled by hooking up to
  45. System.Web.Compilation.BuildManager's build cache entry removal
  46. event. Fixes bug #429926
  47. 2008-09-26 Juraj Skripsky <[email protected]>
  48. * OutputCacheModule.cs: Consistently use InternalCache for
  49. CachedRawResponse items and Cache for CachedVaryBy items.
  50. Partial fix for bug #429926.
  51. 2008-08-11 Marek Habersack <[email protected]>
  52. * Cache.cs: dispose item timer when removing an entry. Fixes bug
  53. #416076. Patch provided by Adriaan van Kekem
  54. <[email protected]>, thanks!
  55. Pass onRemoveCallback along in Insert. Fixes bugs #324528 and
  56. #382644. Patch provided by Juraj Skripsky <[email protected]>,
  57. thanks!
  58. 2008-06-18 Marek Habersack <[email protected]>
  59. * SqlCacheDependency.cs: added
  60. 2008-05-30 Marek Habersack <[email protected]>
  61. * CacheDependency.cs: do not use synthetized event accessors (to
  62. avoid locks).
  63. 2008-05-23 Marek Habersack <[email protected]>
  64. * Cache.cs: optimize lock usage
  65. 2008-04-28 Marek Habersack <[email protected]>
  66. * Cache.cs: refactoring - move the timeout setting code to
  67. separate methods, so that it can be accessed from outside the
  68. class. Fixes bug #382644
  69. 2008-03-18 Geoff Norton <[email protected]>
  70. * Cache.cs: MS allows calling Insert in a removed handler, we need to
  71. avoid double locking here otherwise the Insert will never succeed.
  72. 2008-02-26 Kornél Pál <[email protected]>
  73. * CachedRawResponse.cs, OutputCacheModule.cs: Don't add Date header because
  74. servers usually add a Date header that would result in duplicate Date header
  75. sent to the client. Fixes bug #363404.
  76. 2007-12-31 Vladimir Krasnov <[email protected]>
  77. * Cache.cs: added DependencyCache property, a cache object for
  78. creating dependencies
  79. 2007-12-19 Juraj Skripsky <[email protected]>
  80. * Cache.cs: Replace periodic timer (60s) with per-cache-item expiration
  81. timers.
  82. 2007-08-17 Marek Habersack <[email protected]>
  83. * CacheDependency.cs: use DependencyChanged as a list of events.
  84. OnChanged now calls OnDependencyChanged, to notify
  85. AggregateCacheDependency that it has changed. Fixes bug #82419.
  86. 2007-08-14 Marek Habersack <[email protected]>
  87. * AggregateCacheDependency.cs: propagate changes in any child
  88. dependencies to the base class.
  89. 2007-06-25 Juraj Skripsky <[email protected]>
  90. * Cache.cs: Re-introduce "InvokePrivateCallbacks" accidentally
  91. removed in r80321.
  92. 2007-06-20 Marek Habersack <[email protected]>
  93. * OutputCacheModule.cs: use Context.InternalCache.
  94. * Cache.cs: 2.0 profile uses generic containers to keep the cache
  95. entries.
  96. Gotten rid of the InsertPrivate and InsertInternal methods. The
  97. latter was moved to one of the Insert overloads.
  98. Private entries are no longer handled specifically, because the
  99. internal cache is now kept in a separate object.
  100. Iterate over the entries when filling the ArrayList in the 2.0
  101. profile to avoid type cast exceptions.
  102. 2007-05-03 Igor Zelmanovich <[email protected]>
  103. * AggregateCacheDependency.cs:
  104. * CacheDependency.cs:
  105. added missing API.
  106. 2007-04-10 Marek Habersack <[email protected]>
  107. * CacheDependency.cs: add the NotifyFilters.Size to the
  108. watcher flags, so that we watch for modifications to a file when
  109. using Linux inotify.
  110. 2006-11-29 Marek Habersack <[email protected]>
  111. * CachedVaryBy.cs: Make sure that the vary:* header is generated
  112. only when allowed under the 2.0 profile.
  113. 2006-11-25 Marek Habersack <[email protected]>
  114. * AggregateCacheDependency.cs: A small code optimization.
  115. 2006-11-14 Marek Habersack <[email protected]>
  116. * Cache.cs:
  117. * CacheDependency.cs:
  118. * AggregateCacheDependency.cs: implement this one.
  119. 2006-09-11 Andrew Skiba <[email protected]>
  120. * CacheDependency.cs: ifdef TARGET_JVM
  121. 2006-08-03 Gonzalo Paniagua Javier <[email protected]>
  122. * CacheDependency.cs:
  123. * Cache.cs: check dependencies on other cache keys. Fixes bug #79002.
  124. 2006-03-18 Robert Jordan <[email protected]>
  125. * OutputCacheModule.cs: invoke the validation callbacks of
  126. HttpCachePolicy. Fixes bug #77825.
  127. 2006-03-14 Robert Jordan <[email protected]>
  128. * CachedVaryBy.cs: Fixed VaryByParam="*". Replaced request.Param
  129. with QueryString and Form lookups. Made the param name output case
  130. insensitive. Fixes bug #77757.
  131. 2005-10-24 Gonzalo Paniagua Javier <[email protected]>
  132. * Cache.cs: new internal method.
  133. 2005-09-08 Eyal Alaluf <[email protected]>
  134. * OutputCacheModule.cs: Use C# 1.0 style of delegate instantiating.
  135. Needed to compile Grasshopper (TARGET_J2EE) which uses MS C# 1.0
  136. compiler and does not use msc.
  137. 2005-09-02 Gonzalo Paniagua Javier <[email protected]>
  138. * Cache.cs: ignore exceptions thrown by removed item callbacks.
  139. 2005-09-02 Sebastien Pouliot <[email protected]>
  140. * Cache.cs: Added security permissions with Minimal level for
  141. AspNetHostingPermissionLevel (only LinkDemand as the class is sealed).
  142. * CacheDependency.cs: : Added security permissions with Minimal level
  143. for AspNetHostingPermissionLevel (note class is sealed only in 1.x).
  144. 2005-09-01 Eyal Alaluf <[email protected]>
  145. * CacheDependency.cs: TARGET_J2EE fixes.
  146. 2005-08-20 Gonzalo Paniagua Javier <[email protected]>
  147. * CacheDependency.cs: add missing ctor.
  148. 2005-08-15 Jackson Harper <[email protected]>
  149. * CacheItemPriority.cs:
  150. * CacheItemRemovedCallback.cs:
  151. * CacheItemRemovedReason.cs: New implementations.
  152. 2005-07-30 Miguel de Icaza <[email protected]>
  153. * OutputCacheModule.cs: Make synchronous.
  154. 2005-07-15 Lluis Sanchez Gual <[email protected]>
  155. * Cache.cs: New implementation.
  156. * CacheDependency.cs: New implementation.
  157. 2005-06-25 Gonzalo Paniagua Javier <[email protected]>
  158. * Cache.cs: added new InsertPrivate overload.
  159. 2005-06-25 Gonzalo Paniagua Javier <[email protected]>
  160. * Cache.cs:
  161. * CacheEntry.cs: style. Removed doc. comments.
  162. 2005-06-08 Ilya Kharmatsky <ilyak-at-mainsoft.com>
  163. * CacheDependency.cs - added TARGET_JVM directives in places,
  164. where file watching is using (Mainsoft's implementation currently
  165. doesn't support the feature).
  166. 2005-05-09 Gonzalo Paniagua Javier <[email protected]>
  167. * CacheEntry.cs: credits for this patch should go to mcs. it catched
  168. that the code after 'if ((_enumFlags & Flags.Removed) != 0)' was
  169. unreachable.
  170. 2005-04-28 Gonzalo Paniagua Javier <[email protected]>
  171. * ExpiresBuckets.cs:
  172. * Cache.cs:
  173. * CacheExpires.cs: fix NullReferenceException thrown sometimes when
  174. using sliding expiration and under high load. Patch by Eyal Alayuf from
  175. Mainsoft.
  176. 2005-04-20 Gonzalo Paniagua Javier <[email protected]>
  177. * CacheDependency.cs: remove warnings.
  178. 2005-04-01 Gonzalo Paniagua Javier <[email protected]>
  179. * CachedVaryBy.cs: fixed VaryByParam and wildcard (*). Patch by Ilya
  180. Kharmatsky (Mainsoft) that fixes bug #73981.
  181. 2005-04-01 Lluis Sanchez Gual <[email protected]>
  182. * CachedRawResponse.cs: Fix warning.
  183. 2004-11-08 Gonzalo Paniagua Javier <[email protected]>
  184. * CacheEntry.cs: convert the external DateTime to GMT, as everything
  185. else uses that timezone. Fixes bug #69194.
  186. 2004-10-03 Ben Maurer <[email protected]>
  187. * Cache.cs, CacheEntry.cs, CacheExpires.cs, ExpiresBuckets.cs:
  188. use UtcNow rather than Now.
  189. 2004-05-27 Patrik Torstensson <[email protected]>
  190. * ExpiresBucket.cs (FlushExpiredItems): fix csc and a typo bug
  191. 2004-05-27 Patrik Torstensson <[email protected]>
  192. * CacheEntry.cs,CacheExpires.cs,ExpiresBucket.cs,
  193. Cache.cs : Fixed deadlock issues, fixed
  194. items not correctly being flushed, fixed update
  195. of item when expiration has been updated more
  196. than 1 min (placed in wrong bucket),
  197. fixed deadlock during cache callback when item
  198. is removed due to expiriation.
  199. Rewrite of locking handling in Cache class, leading
  200. to better performance and less bugs.
  201. This rewrite is due to a number of bugs found
  202. in the output caching during load (leading to memory
  203. leaks and deadlocks)
  204. 2004-05-16 Patrik Torstensson <[email protected]>
  205. * ExpiresBucket.cs: Style changes plus;
  206. (Update): Fixed possible lock bug (bug 54531)
  207. (Expand): remove lock optimization due to it can cause newly
  208. added items to be lost.
  209. (Remove): fixed possible lock bug.
  210. 2004-04-16 Gonzalo Paniagua Javier <[email protected]>
  211. * Cache.cs: fix from Jan Jaros for NullRef (bug #56996).
  212. 2004-04-07 Lluis Sanchez Gual <[email protected]>
  213. * Cache.cs, CacheEntry.cs, ExpiresBuckets.cs: The value to use to
  214. specify infinite timeout in ReaderWriterLock is -1, not 0.
  215. 2004-03-19 Gonzalo Paniagua Javier <[email protected]>
  216. * Watcher.cs: Removed file. Jackson made it obsolete and already
  217. removed it from the .sources file.
  218. 2004-02-09 Jackson Harper <[email protected]>
  219. * ExpiresBucket.cs: Remove duplicate code. Fixes bug #54031.
  220. 2004-02-09 Jackson Harper <[email protected]>
  221. * Cache.cs: Close entries that are removed.
  222. * CacheDependency.cs: Use FileSystemWatcher instead of custom
  223. Watcher for file dependencies.
  224. * OutputCacheModule.cs: Make the varyby objects dependent on the
  225. cached page.
  226. 2004-02-05 Jackson Harper <[email protected]>
  227. * CacheDependency.cs: Handle cache keys that have not been added
  228. to the cache yet.
  229. 2004-02-02 Jackson Harper <[email protected]>
  230. * OutputCacheModule.cs: We can use file dependancies now.
  231. 2004-01-14 Jackson Harper <[email protected]>
  232. * Cache.cs: Return null when items are expired but have not been
  233. removed yet.
  234. * OutputCacheModule.cs: Handle sliding expirations. Remove hacks
  235. checking if the item is expired, the cache no longer returns
  236. expired items.
  237. 2004-01-14 Jackson Harper <[email protected]>
  238. * Cache.cs: When using sliding expiration update the cache objects
  239. expires time as well as the expires entry expire time because the
  240. objects expire time is checked when objects are pulled out. This
  241. fixex bug #52778.
  242. 2004-01-11 Jackson Harper <[email protected]>
  243. * OutputCacheModule.cs: Remove varyby objects when there are no
  244. more raw responses that belong to them.
  245. * CachedRawResponse.cs: Keep a reference to the VaryBy object that
  246. this response belongs to this is so the varyby can be cleaned up.
  247. * CachedVaryBy.cs: Keep a reference to the keys that belong to the
  248. varyby and a reference to the varyby's key.
  249. 2004-01-04 Jackson Harper <[email protected]>
  250. * OutputCacheModule.cs: Dont cache items when trace is enabled.
  251. 2004-01-04 Jackson Harper <[email protected]>
  252. * OutputCacheModule.cs: Update the date header value.
  253. * CachedRawResponse.cs: Expose a ref to the date header, so it can
  254. be easily set/updated. Remove unused methods and vars.
  255. 2004-01-04 Jackson Harper <[email protected]>
  256. * CacheDependency.cs: Copy all the entries into the entries array,
  257. set on removed callback for items that we are dependent on.
  258. * Cache.cs: Add method to get CacheEntry objects.
  259. * OutputCacheModule.cs: Make raw repsonse entries dependent on
  260. their varyby param entries.
  261. 2004-01-04 Jackson Harper <[email protected]>
  262. * OutputCacheModule.cs: VaryBy keys now need the HttpContext not just the request.
  263. * CachedVaryBy.cs: Handle vary by headers, and vary by custom.
  264. 2004-01-03 Gonzalo Paniagua Javier <[email protected]>
  265. * ExpiresBuckets.cs: set _intPos when expanding the array. Fixes bug
  266. 52541. Patch by Jan Jaros ([email protected]).
  267. 2003-11-21 Jackson Harper <[email protected]>
  268. * OutputCacheModule.cs: Only cache a page if it has a 200 status
  269. code. Fix tabbing.
  270. * CachedVaryBy.cs: Give raw response keys a name, use the
  271. httpmethod in the key, and delimit items with \n so it is easier
  272. to read when debugging.
  273. 2003-11-21 Jackson Harper <[email protected]>
  274. * OutputCacheModule.cs: Store a CachedVaryBy object for each
  275. cached page. Then store a CachedRawResponse for each combination
  276. of varried parameters for a page.
  277. * CachedRawResponse.cs: Do not need to store param values anymore
  278. those are stored in the CachedVaryBy now. Get the content length
  279. so we dont send back the entire buffer.
  280. * CachedVaryBy.cs: New file - holds the varyby data for a page,
  281. and a method to generate a key based on params. Right now this
  282. only works with VaryByParams. TODO: support VaryByHeaders and
  283. VaryByCustom.
  284. 2003-11-20 Jackson Harper <[email protected]>
  285. * Cache.cs: New method so non public cache items can be added.
  286. * CachedRawResponse.cs: New file - A snapshot of a response that
  287. is stored in the cache and can be used to create a new response.
  288. * OutputCacheModule.cs: Module for inserting and retrieving
  289. responses from the cache.
  290. 2003-04-09 Gonzalo Paniagua Javier <[email protected]>
  291. * CacheDependency.cs:
  292. * CacheEntry.cs:
  293. * Watcher.cs: added a FileSystemWatcher-like class for dependency checking.
  294. 2003-03-13 Gonzalo Paniagua Javier <[email protected]>
  295. * Cache.cs:
  296. * CacheDefinitions.cs:
  297. * CacheDependency.cs:
  298. * CacheEntry.cs:
  299. * CacheExpires.cs:
  300. * ExpiresBuckets.cs: reformatted, make class status page happier. Does
  301. not work yet (wait for the next patch).
  302. 2002-12-27 Daniel Cazzulino <[email protected]>
  303. * CacheEntry.cs: several changes. New constants, use of constants
  304. defined in Cache.cs, modified locks to optimize perf. Fixed property
  305. sets which weren't using the keyword value to set the new values
  306. (don't know how this worked before!).
  307. * Cache.cs: changed singleton implementation to only create the object
  308. when actually used. Changed Insert overloads to use constants
  309. defined instead of hard values.
  310. * ExpiresBuchets: major changes. All locking now uses ReaderWriterLock
  311. class. Bucket now efectively reuses free indexes from removed items
  312. to avoid unnecessary expansions. Expansion now uses Array.CopyTo to
  313. add elements to the new list. Added private Int32Collection to
  314. handle int indexes efficiently (thanks Shawn Van Ness). See comments
  315. there.
  316. 2002-10-08 Gonzalo Paniagua Javier <[email protected]>
  317. * Cache.cs: little fixes.
  318. 2002-07-28 Gonzalo Paniagua Javier <[email protected]>
  319. * CacheDefinitions.cs: fixed a couple of enums.
  320. * CacheDependency.cs: the class is sealed.
  321. 2002-06-11 Gonzalo Paniagua Javier <[email protected]>
  322. * CacheDependency.cs: fixed a couple of typos and don't throw
  323. NotImplementedException in constructors.
  324. 2001-12-21 Gaurav Vaish <[email protected]>
  325. * CacheDependency.cs: Some unimplemented methods to make build
  326. 2001-07-20 Patrik Torstensson ([email protected])
  327. * Cache.cs: Implemented. (90% ready)
  328. * CacheDefinitions.cs: Implemented.
  329. * CacheDependency.cs: Added. (20% ready)
  330. * CacheExpires: Implemented.
  331. * CacheEntry.cs: Implemented. (95% ready, going to be changed due to CacheDependecy support)
  332. * ExpiresBuckets.cs: Implemented.