2004-11-18 Marek Safar <marek.safar@seznam.cz>
[mono.git] / mcs / mcs / ChangeLog
1 2004-11-18  Marek Safar  <marek.safar@seznam.cz>
2
3         Fix #69462\r
4         * attribute.cs (Attributable): Removed CheckTargets.\r
5         (Attributes.Emit): Explicit attribute targets are tested here.\r
6 \r
7         * class.cs (EventField.ValidAttributeTargets): Explicit target "field" is\r
8         not enabled for interfaces.\r
9
10         * codegen.cs (CommonAssemblyModulClass.AddAttributes): Removed CheckTargets.\r
11     \r
12 2004-11-18  Martin Baulig  <martin@ximian.com>
13
14         Merged latest changes into gmcs.  Please keep this comment in
15         here, it makes it easier for me to see what changed in MCS since
16         the last time I merged.
17
18 2004-11-17  Raja R Harinath  <rharinath@novell.com>
19
20         * typemanager.cs (TypeHandle.GetTypeHandle): Make private.
21         (TypeHandle.GetMemberCache): New.
22         (TypeHandle.TypeHandle): Update.
23         (TypeManager.LookupMemberCache): Rewritten from LookupMemberContainer.
24         (TypeManager.LookupParentInterfacesCache):
25         Rename from LookupInterfaceCache.  Optimize slightly.
26         (TypeManager.MemberLookup_FindMembers): Update.
27         * decl.cs (MemberCache.MemberCache): Set Container to null in the
28         multi-type variant.
29         (AddCacheContents): Rename from AddHashtable.
30         * class.cs (TypeContainer.parent_container): Remove.
31         (TypeContainer.VerifyClsCompliance): Don't use parent_container.
32         (TypeContainer.DoDefineMembers): Don't initialize it.
33         Update to name changes.
34         
35 2004-11-17  Miguel de Icaza  <miguel@ximian.com>
36
37         * class.cs (MethodCore.CheckAccessModifiers): New helper routine
38         that factors the code to check access modifiers on override.  
39
40         (PropertyBase): Use the code here.
41
42         Patch from Lluis S'anchez, fixes bug #69361.
43
44 2004-11-15  Miguel de Icaza  <miguel@ximian.com>
45
46         * anonymous.cs (AnonymousMethod.Error_AddressOfCapturedVar): New
47         routine that is used to report the use of a captured variable
48         whose address has been taken.
49
50         There are two checks: one when variables are being captured and
51         the other check is when the address of a variable is taken. 
52         
53         (because an anonymous methods might be resolved before *or* after
54         the address has been taken) and 
55
56         * expression.cs (Conditional.DoResolve): Remove the special
57         casing that Martin added to trueExpr and falseExpr being both
58         NullLiteral.  We get the right behavior now just by introducing
59         the null_type into the compiler. 
60
61         * convert.cs (ExplicitConversion): Change the code to use
62         null_type instead of testing `expr is NullLiteral'.
63         (ImplicitConversionStandard): use null_type too.
64         (ImplicitReferenceConversionExists): use null_type too.
65         (ImplicitReferenceConversion): use null_type too.
66
67         * literal.cs: The type of `NullLiteral' is now null_type instead
68         of object_type. 
69         (Resolve): Set the type here.
70
71         * typemanager.cs: Introduce null_type.
72
73 2004-11-17  Martin Baulig  <martin@ximian.com>
74
75         * decl.cs (MemberCache.AddHashtable): Add entries in the opposite
76         direction, like FindMembers() does.  Fixes #69546, testcase is in
77         test-315.cs.    
78
79 2004-11-16  Martin Baulig  <martin@ximian.com>
80
81         This is based on a patch from Marek Safar, see bug #69082.
82         Fixes bugs #63705 and #67130.
83
84         * typemanager.cs (TypeManager.LookupInterfaceCache): New public
85         method; create a MemberCache for an interface type and cache the
86         result.
87
88         * decl.cs (IMemberContainer.ParentContainer): Removed.
89         (IMemberContainer.ParentCache): New property.
90         (MemberCache.SetupCacheForInterface): Removed.
91         (MemberCache..ctor): Added .ctor which takes a `Type[]'; use this
92         to create a cache for an interface's "parent".
93
94         * class.cs (TypeContainer.DoDefineMembers): Setup cache for
95         interfaces too.
96
97 2004-11-16  Martin Baulig  <martin@ximian.com>
98
99         Merged back from gmcs; these changes already went into gmcs a
100         couple of weeks ago.
101
102         * typemanager.cs
103         (TypeManager.AddUserType): Removed the `ifaces' argument.
104         (TypeManager.RegisterBuilder): Take a `Type []' instead of a
105         `TypeExpr []'.
106         (TypeManager.AddUserInterface): Removed.
107         (TypeManager.ExpandInterfaces): Return a `Type []' instead of a
108         `TypeExpr []'.
109         (TypeManager.GetInterfaces): Likewise.
110         (TypeManager.GetExplicitInterfaces): Likewise.
111
112         * ecore.cs (TypeExpr.GetInterfaces): Removed.
113
114         * class.cs (TypeContainer.base_class_type): Replaced with `ptype'.
115         (TypeContainer.base_inteface_types): Replaced with `ifaces'.
116
117 2004-11-14  Ben Maurer  <bmaurer@ximian.com>
118
119         * statement.cs: Avoid adding bools to a hashtable.
120
121 2004-11-07  Miguel de Icaza  <miguel@ximian.com>
122
123         * expression.cs (Invocation.OverloadResolve): Flag error if we are
124         calling an unsafe method from a safe location.
125
126 2004-11-06  Marek Safar  <marek.safar@seznam.cz>
127
128         Fix #69167
129         * codegen.cs (ApplyAttributeBuilder): Do not return; it is only warning.
130
131 2004-11-06  Miguel de Icaza  <miguel@ximian.com>
132
133         * namespace.cs (VerifyUsing): use GetPartialName instead of
134         ToString. 
135
136 2004-11-05  Miguel de Icaza  <miguel@ximian.com>
137
138         * statement.cs (Return.Resolve): Fix regression in typo: if
139         `in_exc', we have to request a NeedReturnLabel, this was a typo
140         introduced in the anonymous method check-in.  Fixes #69131.
141
142         * Indexers were using the ShortName when defining themselves,
143         causing a regression in the compiler bootstrap when applying the
144         patch from 2004-11-02 (first part), now they use their full name
145         and the bug is gone.
146
147 2004-11-04  Zoltan Varga  <vargaz@freemail.hu>
148
149         * driver.cs: Strip the path from the names of embedded resources. Fixes
150         #68519.
151
152 2004-11-04  Raja R Harinath  <rharinath@novell.com>
153
154         Fix error message regression: cs0104-2.cs.
155         * namespace.cs (NamespaceEntry.Lookup): Remove 'silent' flag.
156         (AliasEntry.Resolve): Update.
157         * rootcontext.cs (RootContext.NamespaceLookup): Update.  Remove
158         'silent' flag.
159         (RootContext.LookupType): Update.
160
161 2004-11-03  Carlos Alberto Cortez <carlos@unixmexico.org>
162
163         * cs-parser.jay: Add support for handling accessor modifiers
164         * class: Add support port accessor modifiers and error checking,
165         define PropertyMethod.Define as virtual (not abstract anymore)
166         * ecore.cs: Add checking for proeprties access with access modifiers
167         * iterators.cs: Modify Accessor constructor call based in the modified
168         constructor
169 2004-11-02  Ben Maurer  <bmaurer@ximian.com>
170
171         * expression.cs (StringConcat): Handle being called twice,
172         as when we have a concat in a field init with more than two
173         ctors in the class
174
175 2004-11-02  Miguel de Icaza  <miguel@ximian.com>
176
177         * class.cs (Event.Define, Indexer.Define, Property.Define): Do not
178         special case explicit implementations, we should always produce
179         the .property or .event declaration.
180         
181         * decl.cs (MemberName): Renamed GetFullName to GetPartialName
182         since it will not return correct data if people use this
183         unresolved in the presence of using statements (see test-313).
184
185         * class.cs (MethodData.Define): If we are an explicit interface
186         implementation, set the method name to the full name of the
187         interface plus the name of the method.  
188
189         Notice that using the method.MethodName.GetFullName() does not
190         work, as it will only contain the name as declared on the source
191         file (it can be a shorthand in the presence of using statements)
192         and not the fully qualifed type name, for example:
193
194         using System;
195
196         class D : ICloneable {
197                 object ICloneable.Clone ()  {
198                 }
199         }
200
201         Would produce a method called `ICloneable.Clone' instead of
202         `System.ICloneable.Clone'.
203
204         * namespace.cs (Alias.Resolve): Use GetPartialName.
205         
206 2004-11-01  Marek Safar  <marek.safar@seznam.cz>
207
208         * cs-parser.jay: Add error 1055 report.
209
210 2004-11-01  Miguel de Icaza  <miguel@ximian.com>
211
212         * assign.cs (Assign.DoResolve): Only do the transform of
213         assignment into a New if the types are compatible, if not, fall
214         through and let the implicit code deal with the errors and with
215         the necessary conversions. 
216
217 2004-11-01  Marek Safar  <marek.safar@seznam.cz>
218
219         * cs-parser.jay: Add error 1031 report.
220
221         * cs-tokenizer.cs: Add location for error 1038.
222
223 2004-10-31  Marek Safar  <marek.safar@seznam.cz>
224
225         * cs-parser.jay: Add error 1016 report.
226
227 2004-10-31  Marek Safar  <marek.safar@seznam.cz>
228
229         * cs-parser.jay: Add errors 1575,1611 report.
230
231 2004-10-31  Marek Safar  <marek.safar@seznam.cz>
232
233         * cs-parser.jay: Add error 1001 report.
234
235 2004-10-31  Marek Safar  <marek.safar@seznam.cz>
236
237         Fix #68850
238         * attribute.cs (GetMarshal): Add method argument for
239         caller identification.
240
241         * class.cs, codegen.cs, enum.cs, parameter.cs: Added
242         agument for GetMarshal and RuntimeMissingSupport.
243
244 2004-10-31  Marek Safar  <marek.safar@seznam.cz>
245
246         * attribute.cs (ExtractSecurityPermissionSet): Removed
247         TypeManager.code_access_permission_type.
248
249         * typemanager.cs: Removed TypeManager.code_access_permission_type.
250
251 2004-10-27  Miguel de Icaza  <miguel@ximian.com>
252
253         * expression.cs (LocalVariableReference.DoResolveLValue): Check
254         for obsolete use of a variable here.   Fixes regression on errors
255         cs0619-25 and cs0619-26.
256
257 2004-10-27  Marek Safar  <marek.safar@seznam.cz>
258
259         Fix #62358, implemented security attribute encoding.
260
261         * attribute.cs (Attribute.CheckSecurityActionValididy): New method.
262         Tests permitted SecurityAction for assembly or other types.
263         (Assembly.ExtractSecurityPermissionSet): New method. Transforms
264         data from SecurityPermissionAttribute to PermisionSet class.
265
266         * class.cs (ApplyAttributeBuilder): Added special handling
267         for System.Security.Permissions.SecurityAttribute based types.
268
269         * codegen.cs (AssemblyClass.ApplyAttributeBuilder): Added
270         special handling for System.Security.Permissions.SecurityAttribute
271         based types.
272
273         * enum.cs (ApplyAttributeBuilder): Added special handling
274         for System.Security.Permissions.SecurityAttribute based types.
275
276         * parameter.cs (ApplyAttributeBuilder): Added special handling
277         for System.Security.Permissions.SecurityAttribute based types.
278
279         * rootcontext.cs: Next 2 core types.
280
281         * typemanager.cs (TypeManager.security_permission_attr_type):
282         Built in type for the SecurityPermission Attribute.
283         (code_access_permission_type): Build in type.
284
285 2004-10-17  Miguel de Icaza  <miguel@ximian.com>
286
287         * expression.cs (LocalVariableReference.DoResolveBase, Emit):
288         Remove the tests for `ec.RemapToProxy' from here, and encapsulate
289         all of this information into
290         EmitContext.EmitCapturedVariableInstance.
291         
292         * codegen.cs (EmitCapturedVariableInstance): move here the
293         funcionality of emitting an ldarg.0 in the presence of a
294         remapping.   This centralizes the instance emit code.
295
296         (EmitContext.EmitThis): If the ScopeInfo contains a THIS field,
297         then emit a load of this: it means that we have reached the
298         topmost ScopeInfo: the one that contains the pointer to the
299         instance of the class hosting the anonymous method.
300
301         * anonymous.cs (AddField, HaveCapturedFields): Propagate field
302         captures to the topmost CaptureContext.
303
304 2004-10-12  Miguel de Icaza  <miguel@ximian.com>
305
306         * expression.cs (LocalVariableReference): Move the knowledge about
307         the iterators into codegen's EmitCapturedVariableInstance.
308
309 2004-10-11  Miguel de Icaza  <miguel@ximian.com>
310
311         * codegen.cs (EmitContext.ResolveTopBlock): Emit a 1643 when not
312         all code paths return a value from an anonymous method (it is the
313         same as the 161 error, but for anonymous methods).
314
315 2004-10-08  Miguel de Icaza  <miguel@ximian.com>
316
317         The introduction of anonymous methods in the compiler changed
318         various ways of doing things in the compiler.  The most
319         significant one is the hard split between the resolution phase
320         and the emission phases of the compiler.
321
322         For instance, routines that referenced local variables no
323         longer can safely create temporary variables during the
324         resolution phase: they must do so from the emission phase,
325         since the variable might have been "captured", hence access to
326         it can not be done with the local-variable operations from the runtime.
327         
328         * statement.cs 
329
330         (Block.Flags): New flag `IsTopLevel' to indicate that this block
331         is a toplevel block.
332
333         (ToplevelBlock): A new kind of Block, these are the blocks that
334         are created by the parser for all toplevel method bodies.  These
335         include methods, accessors and anonymous methods.
336
337         These contain some extra information not found in regular blocks:
338         A pointer to an optional CaptureContext (for tracking captured
339         local variables and parameters).  A pointer to the parent
340         ToplevelBlock.
341         
342         (Return.Resolve): Catch missmatches when returning a value from an
343         anonymous method (error 1662).
344         Invoke NeedReturnLabel from the Resolve phase instead of the emit
345         phase.
346
347         (Break.Resolve): ditto.
348
349         (SwitchLabel): instead of defining the labels during the
350         resolution phase, we now turned the public ILLabel and ILLabelCode
351         labels into methods called GetILLabelCode() and GetILLabel() that
352         only define the label during the Emit phase.
353
354         (GotoCase): Track the SwitchLabel instead of the computed label
355         (its contained therein).  Emit the code by using
356         SwitchLabel.GetILLabelCode ().
357
358         (LocalInfo.Flags.Captured): A new flag has been introduce to track
359         whether the Local has been captured or not.
360
361         (LocalInfo.IsCaptured): New property, used to tell whether the
362         local has been captured.
363         
364         * anonymous.cs: Vastly updated to contain the anonymous method
365         support.
366
367         The main classes here are: CaptureContext which tracks any
368         captured information for a toplevel block and ScopeInfo used to
369         track the activation frames for various local variables.   
370
371         Each toplevel block has an optional capture context associated
372         with it.  When a method contains an anonymous method both the
373         toplevel method and the anonymous method will create a capture
374         context.   When variables or parameters are captured, they are
375         recorded on the CaptureContext that owns them, for example:
376
377         void Demo () {
378              int a;
379              MyDelegate d = delegate {
380                  a = 1;
381              }
382         }
383
384         Here `a' will be recorded as captured on the toplevel
385         CapturedContext, the inner captured context will not have anything
386         (it will only have data if local variables or parameters from it
387         are captured in a nested anonymous method.
388
389         The ScopeInfo is used to track the activation frames for local
390         variables, for example:
391
392         for (int i = 0; i < 10; i++)
393                 for (int j = 0; j < 10; j++){
394                    MyDelegate d = delegate {
395                         call (i, j);
396                    }
397                 }
398
399         At runtime this captures a single captured variable `i', but it
400         captures 10 different versions of the variable `j'.  The variable
401         `i' will be recorded on the toplevel ScopeInfo, while `j' will be
402         recorded on a child.  
403
404         The toplevel ScopeInfo will also track information like the `this'
405         pointer if instance variables were referenced (this is necessary
406         as the anonymous method lives inside a nested class in the host
407         type of the method). 
408
409         (AnonymousMethod): Expanded to track the Toplevel, implement
410         `AnonymousMethod.Compatible' to tell whether an anonymous method
411         can be converted to a target delegate type. 
412
413         The routine now also produces the anonymous method content
414
415         (AnonymousDelegate): A helper class that derives from
416         DelegateCreation, this is used to generate the code necessary to
417         produce the delegate for the anonymous method that was created. 
418
419         * assign.cs: API adjustments for new changes in
420         Convert.ImplicitStandardConversionExists.
421
422         * class.cs: Adjustments to cope with the fact that now toplevel
423         blocks are of type `ToplevelBlock'. 
424
425         * cs-parser.jay: Now we produce ToplevelBlocks for toplevel blocks
426         insteda of standard blocks.
427
428         Flag errors if params arguments are passed to anonymous methods.
429
430         * codegen.cs (EmitContext): Replace `InAnonymousMethod' with
431         `CurrentAnonymousMethod' which points to the current Anonymous
432         Method.  The variable points to the AnonymousMethod class that
433         holds the code being compiled.  It is set in the new EmitContext
434         created for the anonymous method.
435
436         (EmitContext.Phase): Introduce a variable and an enumeration to
437         assist in enforcing some rules about when and where we are allowed
438         to invoke certain methods (EmitContext.NeedsReturnLabel is the
439         only one that enfonces this right now).
440
441         (EmitContext.HaveCaptureInfo): new helper method that returns
442         whether we have a CapturedContext initialized.
443
444         (EmitContext.CaptureVariable): New method used to register that a
445         LocalInfo must be flagged for capturing. 
446
447         (EmitContext.CapturedParameter): New method used to register that a
448         parameters must be flagged for capturing. 
449         
450         (EmitContext.CapturedField): New method used to register that a
451         field must be flagged for capturing. 
452
453         (EmitContext.HaveCapturedVariables,
454         EmitContext.HaveCapturedFields): Return whether there are captured
455         variables or fields. 
456
457         (EmitContext.EmitMethodHostInstance): This is used to emit the
458         instance for the anonymous method.  The instance might be null
459         (static methods), this (for anonymous methods that capture nothing
460         and happen to live side-by-side with the current method body) or a
461         more complicated expression if the method has a CaptureContext.
462
463         (EmitContext.EmitTopBlock): Routine that drives the emission of
464         code: it will first resolve the top block, then emit any metadata
465         and then emit the code.  The split is done so that we can extract
466         any anonymous methods and flag any captured variables/parameters.
467         
468         (EmitContext.ResolveTopBlock): Triggers the resolution phase,
469         during this phase, the ILGenerator should not be used as labels
470         and local variables declared here might not be accessible to any
471         code that is part of an anonymous method.  
472
473         Exceptions to this include the temporary variables that are
474         created by some statements internally for holding temporary
475         variables. 
476         
477         (EmitContext.EmitMeta): New routine, in charge of emitting all the
478         metadata for a cb
479
480         (EmitContext.TemporaryReturn): This method is typically called
481         from the Emit phase, and its the only place where we allow the
482         ReturnLabel to be defined other than the EmitMeta.  The reason is
483         that otherwise we would have to duplicate a lot of logic in the
484         Resolve phases of various methods that today is on the Emit
485         phase. 
486
487         (EmitContext.NeedReturnLabel): This no longer creates the label,
488         as the ILGenerator is not valid during the resolve phase.
489
490         (EmitContext.EmitThis): Extended the knowledge in this class to
491         work in anonymous methods in addition to iterators. 
492
493         (EmitContext.EmitCapturedVariableInstance): This emits whatever
494         code is necessary on the stack to access the instance to a local
495         variable (the variable will be accessed as a field).
496
497         (EmitContext.EmitParameter, EmitContext.EmitAssignParameter,
498         EmitContext.EmitAddressOfParameter): Routines to support
499         parameters (not completed at this point). 
500         
501         Removals: Removed RemapLocal and RemapLocalLValue.  We probably
502         will also remove the parameters.
503
504         * convert.cs (Convert): Define a `ConstantEC' which points to a
505         null.  This is just to prefity some code that uses
506         ImplicitStandardConversion code and do not have an EmitContext
507         handy.
508
509         The idea is to flag explicitly that at that point in time, it is
510         known that the conversion will not trigger the delegate checking
511         code in implicit conversions (which requires a valid
512         EmitContext). 
513
514         Everywhere: pass new EmitContext parameter since
515         ImplicitStandardConversionExists now requires it to check for
516         anonymous method conversions. 
517
518         (Convert.ImplicitStandardConversionExists): If the type of an
519         expression is the anonymous_method_type, and the type is a
520         delegate, we invoke the AnonymousMethod.Compatible method to check
521         whether an implicit conversion is possible. 
522
523         (Convert.ImplicitConversionStandard): Only do implicit method
524         group conversions if the language level is not ISO_1.
525
526         * delegate.cs (Delegate.GetInvokeMethod): Common method to get the
527         MethodInfo for the Invoke method.  used by Delegate and
528         AnonymousDelegate.
529
530         * expression.cs (Binary.DoNumericPromotions): only allow anonymous
531         method conversions if the target type is a delegate.
532
533         Removed extra debugging nops.
534
535         (LocalVariableReference): Turn the `local_info' into a public
536         field. 
537
538         Add `prepared' field, the same hack used for FieldExprs to cope
539         with composed assignments, as Local variables do not necessarily
540         operate purely on the stack as they used to: they can be captured
541         fields. 
542
543         Add `temp' for a temporary result, like fields.
544
545         Refactor DoResolve and DoResolveLValue into DoResolveBase.
546
547         It now copes with Local variables that are captured and emits the
548         proper instance variable to load it from a field in the captured
549         case. 
550
551         (ParameterReference.DoResolveBase): During the resolve phase,
552         capture parameters if we are in an anonymous method.
553
554         (ParameterReference.Emit, ParameterReference.AddressOf): If in an
555         anonymous method, use the EmitContext helper routines to emit the
556         parameter reference.
557
558         * iterators.cs: Set RemapToProxy to true/false during the
559         EmitDispose class.
560
561         * parameters.cs (GetParameterByName): New helper method. 
562
563         * typemanager.cs (anonymous_method_type) a new type that
564         represents an anonyous method.  This is always an internal type,
565         used as a fencepost to test against the anonymous-methodness of an
566         expression. 
567         
568 2004-10-20  Marek Safar  <marek.safar@seznam.cz>
569
570         * class.cs (MethodCore.CheckBase): Add errors 505, 533, 544,
571         561 report.
572         (PropertyBase.FindOutParentMethod): Add errors 545, 546 report.
573
574 2004-10-18  Martin Baulig  <martin@ximian.com>
575
576         * statement.cs (Fixed.Resolve): Don't access the TypeExpr's
577         `Type' directly, but call ResolveType() on it.
578         (Catch.Resolve): Likewise.
579         (Foreach.Resolve): Likewise.
580
581 2004-10-18  Martin Baulig  <martin@ximian.com>
582
583         * expression.cs (Cast.DoResolve): Don't access the TypeExpr's
584         `Type' directly, but call ResolveType() on it.
585         (Probe.DoResolve): Likewise.
586         (ArrayCreation.LookupType): Likewise.
587         (TypeOf.DoResolve): Likewise.
588         (SizeOf.DoResolve): Likewise.
589
590 2004-10-18  Martin Baulig  <martin@ximian.com>
591
592         * expression.cs (Invocation.BetterFunction): Put back
593         TypeManager.TypeToCoreType().
594
595 2004-10-18  Raja R Harinath  <rharinath@novell.com>
596
597         * class.cs (FieldMember.DoDefine): Reset ec.InUnsafe after doing
598         the ResolveType.
599
600 2004-10-18  Martin Baulig  <martin@ximian.com>
601
602         * parameter.cs (Parameter.Resolve):  Don't access the TypeExpr's
603         `Type' directly, but call ResolveType() on it.
604
605 2004-10-18  Martin Baulig  <martin@ximian.com>
606
607         * class.cs (FieldMember.Define): Don't access the TypeExpr's
608         `Type' directly, but call ResolveType() on it.
609         (MemberBase.DoDefine): Likewise.
610
611         * expression.cs (New.DoResolve): Don't access the TypeExpr's
612         `Type' directly, but call ResolveType() on it.
613         (ComposedCast.DoResolveAsTypeStep): Likewise.
614
615         * statement.cs (LocalInfo.Resolve): Don't access the TypeExpr's
616         `Type' directly, but call ResolveType() on it.
617
618 2004-10-17  John Luke  <john.luke@gmail.com>
619
620         * class.cs (Operator.GetSignatureForError): use CSharpName
621
622         * parameter.cs (Parameter.GetSignatureForError): Returns
623         correct name even if was not defined.
624
625 2004-10-13  Raja R Harinath  <rharinath@novell.com>
626
627         Fix #65816.
628         * class.cs (TypeContainer.EmitContext): New property.
629         (DefineNestedTypes): Create an emitcontext for each part.
630         (MethodCore.DoDefineParameters): Use container's emitcontext.
631         Pass type array to InternalParameters.
632         (MemberBase.DoDefine): Use container's emitcontext.
633         (FieldMember.Define): Likewise.
634         (Event.Define): Likewise.
635         (SetMethod.GetParameterInfo): Change argument to EmitContext.
636         Pass type array to InternalParameters.
637         (SetIndexerMethod.GetParameterInfo): Likewise.
638         (SetMethod.Define): Pass emitcontext to GetParameterInfo.
639         * delegate.cs (Define): Pass emitcontext to
640         ComputeAndDefineParameterTypes and GetParameterInfo.  Pass type
641         array to InternalParameters.
642         * expression.cs (ParameterReference.DoResolveBase): Pass
643         emitcontext to GetParameterInfo.
644         (ComposedCast.DoResolveAsTypeStep): Remove check on
645         ec.ResolvingTypeTree.
646         * parameter.cs (Parameter.Resolve): Change argument to
647         EmitContext.  Use ResolveAsTypeTerminal.
648         (Parameter.GetSignature): Change argument to EmitContext.
649         (Parameters.ComputeSignature): Likewise.
650         (Parameters.ComputeParameterTypes): Likewise.
651         (Parameters.GetParameterInfo): Likewise.
652         (Parameters.ComputeAndDefineParameterTypes): Likewise.
653         Re-use ComputeParameterTypes.  Set ec.ResolvingTypeTree.
654         * support.cs (InternalParameters..ctor): Remove variant that takes
655         a DeclSpace.
656         * typemanager.cs (system_intptr_expr): New.
657         (InitExpressionTypes): Initialize it.
658
659 2004-10-12  Chris Toshok  <toshok@ximian.com>
660
661         * cs-parser.jay: fix location for try_statement and catch_clause.
662
663 2004-10-11  Martin Baulig  <martin@ximian.com>
664
665         * report.cs: Don't make --fatal abort on warnings, we have
666         -warnaserror for that.
667
668 2004-10-07  Raja R Harinath  <rharinath@novell.com>
669
670         More DeclSpace.ResolveType avoidance.
671         * decl.cs (MemberCore.InUnsafe): New property.
672         * class.cs (MemberBase.DoDefine): Use ResolveAsTypeTerminal 
673         with newly created EmitContext.
674         (FieldMember.Define): Likewise.
675         * delegate.cs (Delegate.Define): Likewise.
676         * ecore.cs (SimpleName.ResolveAsTypeStep): Lookup with alias
677         only if normal name-lookup fails.
678         (TypeExpr.DoResolve): Enable error-checking.
679         * expression.cs (ArrayCreation.DoResolve): Use ResolveAsTypeTerminal.
680         (SizeOf.DoResolve): Likewise.
681         (ComposedCast.DoResolveAsTypeStep): Likewise.
682         (StackAlloc.DoResolve): Likewise.
683         * statement.cs (Block.Flags): Add new flag 'Unsafe'.
684         (Block.Unsafe): New property.
685         (Block.EmitMeta): Set ec.InUnsafe as appropriate.
686         (Unsafe): Set 'unsafe' flag of contained block.
687         (LocalInfo.Resolve): Use ResolveAsTypeTerminal.
688         (Fixed.Resolve): Likewise.
689         (Catch.Resolve): Likewise.
690         (Using.ResolveLocalVariableDecls): Likewise.
691         (Foreach.Resolve): Likewise.
692
693 2004-10-05  John Luke <john.luke@gmail.com>
694
695         * cs-parser.jay: add location to error CS0175
696
697 2004-10-04  Miguel de Icaza  <miguel@ximian.com>
698
699         * ecore.cs (Expression.Constantity): Add support for turning null
700         into a constant.
701
702         * const.cs (Const.Define): Allow constants to be reference types
703         as long as the value is Null.
704
705 2004-10-04  Juraj Skripsky  <js@hotfeet.ch>
706
707         * namespace.cs (NamespaceEntry.Using): No matter which warning
708         level is set, check if this namespace name has already been added.
709
710 2004-10-03 Ben Maurer  <bmaurer@ximian.com>
711
712         * expression.cs: reftype [!=]= null should always use br[true,false].
713         # 67410
714
715 2004-10-03  Marek Safar  <marek.safar@seznam.cz>
716
717         Fix #67108
718         * attribute.cs: Enum conversion moved to 
719         GetAttributeArgumentExpression to be applied to the all
720         expressions.
721
722 2004-10-01  Raja R Harinath  <rharinath@novell.com>
723
724         Fix #65833, test-300.cs, cs0122-5.cs, cs0122-6.cs.
725         * class.c (TypeContainer.DefineType): Flag error if
726         base types aren't accessible due to access permissions.
727         * decl.cs (DeclSpace.ResolveType): Move logic to
728         Expression.ResolveAsTypeTerminal.
729         (DeclSpace.ResolveTypeExpr): Thin layer over
730         Expression.ResolveAsTypeTerminal.
731         (DeclSpace.CheckAccessLevel, DeclSpace.FamilyAccess):
732         Refactor code into NestedAccess.  Use it.
733         (DeclSpace.NestedAccess): New.
734         * ecore.cs (Expression.ResolveAsTypeTerminal): Add new
735         argument to silence errors.  Check access permissions.
736         (TypeExpr.DoResolve, TypeExpr.ResolveType): Update.
737         * expression.cs (ProbeExpr.DoResolve): Use ResolveAsTypeTerminal.
738         (Cast.DoResolve): Likewise.
739         (New.DoResolve): Likewise.
740         (InvocationOrCast.DoResolve,ResolveStatement): Likewise.
741         (TypeOf.DoResolve): Likewise.
742
743         * expression.cs (Invocation.BetterConversion): Return the Type of
744         the better conversion.  Implement section 14.4.2.3 more faithfully.
745         (Invocation.BetterFunction): Make boolean.  Make correspondence to
746         section 14.4.2.2 explicit.
747         (Invocation.OverloadResolve): Update.
748         (Invocation): Remove is_base field.
749         (Invocation.DoResolve): Don't use is_base.  Use mg.IsBase.
750         (Invocation.Emit): Likewise.
751
752 2004-09-27  Raja R Harinath  <rharinath@novell.com>
753
754         * README: Update to changes.
755
756 2004-09-24  Marek Safar  <marek.safar@seznam.cz>
757
758         * cs-parser.jay: Reverted 642 warning fix.
759
760 2004-09-23  Marek Safar  <marek.safar@seznam.cz>
761
762         Fix bug #66615
763         * decl.cs (FindMemberWithSameName): Indexer can have more than
764         1 argument.
765
766 2004-09-23  Marek Safar  <marek.safar@seznam.cz>
767
768         * expression.cs (LocalVariableReference.DoResolveLValue):
769         Do not report warning 219 for out values.
770         (EmptyExpression.Null): New member to avoid extra allocations.
771
772 2004-09-23  Marek Safar  <marek.safar@seznam.cz>
773
774         * cs-parser.jay: Fix wrong warning 642 report.
775
776         * cs-tokenizer.cs (CheckNextToken): New helper;
777         Inspect next character if is same as expected.
778
779 2004-09-23  Martin Baulig  <martin@ximian.com>
780
781         * convert.cs (Convert.ImplicitReferenceConversion): Some code cleanup.
782         (Convert.ImplicitReferenceConversionExists): Likewise.
783
784 2004-09-23  Marek Safar  <marek.safar@seznam.cz>
785
786         * class.cs (Operator.Define): Add error 448 and 559 report.
787
788 2004-09-22  Marek Safar  <marek.safar@seznam.cz>
789
790         * class.cs (MemberBase.IsTypePermitted): New protected
791         method for checking error CS0610.
792
793 2004-09-22  Marek Safar  <marek.safar@seznam.cz>
794
795         * class.cs (TypeContainer.HasExplicitLayout): New property
796         Returns whether container has StructLayout attribute set Explicit.
797         (FieldMember): New abstract class for consts and fields.
798         (FieldMember.ApplyAttributeBuilder): Add error 636 and 637 report.
799         (Field): Reuse FieldMember.
800
801         * const.cs (Const): Reuse FieldMember.
802
803         * rootcontext.cs: EmitConstants call moved to class.
804
805 2004-09-22  Martin Baulig  <martin@ximian.com>
806
807         Thanks to Peter Sestoft for this bug report.
808
809         * expression.cs (Conditional): If both the `trueExpr' and the
810         `falseExpr' is a NullLiteral, return a NullLiteral.
811
812 2004-09-22  Martin Baulig  <martin@ximian.com>
813
814         * statement.cs (Foreach.EmitCollectionForeach): If we're in an
815         iterator, use `enumerator.EmitThis()' instead of `ec.EmitThis()'
816         for the "get_Current" call.
817
818 2004-09-22  Martin Baulig  <martin@ximian.com>
819
820         Marek and me just fixed one of our oldest bugs: #28562 :-)
821
822         * ecore.cs (EnumConstant.GetValueAsEnumType): New public method.
823
824         * attribute.cs (Attribute.GetAttributeArgumentExpression): If
825         we're an EnumConstant, just return that.
826         (Attribute.Resolve): GetAttributeArgumentExpression() may give us
827         an EnumConstant.  In this case, we need to use GetValueAsEnumType()
828         to get the value which'll actually be written into the attribute.
829         However, we have to use GetValue() to access the attribute's value
830         in the compiler.        
831
832 2004-09-22  Marek Safar  <marek.safar@seznam.cz>
833
834         * constant.cs (Constant.IsNegative): New abstract property
835         IsNegative.
836
837         * expression.cs (ArrayAccess.DoResolve): Add warning 251.
838         (StackAlloc.DoResolve): Reused IsNegative.
839
840 2004-09-21  Martin Baulig  <martin@ximian.com>
841
842         * codegen.cs (VariableStorage): Don't store the ILGenerator here;
843         if we're used in an iterator, we may be called from different
844         methods.
845
846         * statement.cs (Foreach.EmitFinally): Only emit an `Endfinally' if
847         we actually have an exception block.
848
849 2004-09-20  John Luke <jluke@cfl.rr.com>
850
851         * class.cs, cs-parser.jay: Improve the error report for 1520:
852         report the actual line where the error happens, not where the
853         class was declared.
854
855         * assign.cs, delegate.cs, ecore.cs, expression.cs, statement.cs:
856         Pass location information that was available elsewhere.
857
858 2004-09-19  Sebastien Pouliot  <sebastien@ximian.com>
859
860         * codegen.cs: Fix bug #56621. It is now possible to use MCS on the MS
861         runtime to delay sign assemblies.
862
863 2004-09-19  Miguel de Icaza  <miguel@ximian.com>
864
865         * cs-parser.jay: Do not report the stack trace, this is barely
866         used nowadays.
867
868 2004-08-22  John Luke  <john.luke@gmail.com>
869  
870         * driver.cs : check that a resource id is not already used
871         before adding it, report CS1508 if it is, bug #63637
872
873 2004-09-19  Miguel de Icaza  <miguel@ximian.com>
874
875         * ecore.cs: Removed dead code.
876
877 2004-09-18  Marek Safar  <marek.safar@seznam.cz>
878
879         * class.cs: Do not report warning CS0067 on the interfaces.
880
881 2004-09-16  Marek Safar  <marek.safar@seznam.cz>
882
883         * cs-parser.jay: Add error 504 report.
884
885 2004-09-16  Marek Safar  <marek.safar@seznam.cz>
886
887         * rootcontext.cs: WarningLevel is 4 by default now.
888
889         * statement.cs (Fixed.Resolve): Do not null
890         VariableInfo.
891
892 2004-09-16  Marek Safar  <marek.safar@seznam.cz>
893
894         Fixed bug #55780
895         * ecore.cs (PropertyExpr.FindAccessors): Do not perform
896         deep search when property is not virtual.
897         (PropertyExpr.ResolveAccessors): Make one call for both
898         accessors.
899
900 2004-09-15  Marek Safar  <marek.safar@seznam.cz>
901
902         Fixed bug #65766
903         * statement.cs: Error 152 report constains also location.
904
905 2004-09-15  Marek Safar  <marek.safar@seznam.cz>
906
907         Fixed bug #65766
908         * const.cs: Explicitly set constant as static.
909
910 2004-09-15  Marek Safar  <marek.safar@seznam.cz>
911
912         Fixed bug #64226
913         * cs-parser.jay: Add error 1017 report.
914
915 2004-09-15  Marek Safar  <marek.safar@seznam.cz>
916
917         Fixed bug #59980, #64224
918         * expression.cs (Invocation.DoResolve): Fixed error CS0571 test.
919
920         * typemanager.cs (IsSpecialMethod): Simplified
921
922 2004-09-14  Marek Safar  <marek.safar@seznam.cz>
923
924         * decl.cs (MemberCore.Emit): Resuscitated VerifyObsoleteAttribute
925         condition with better params.
926
927 2004-09-14  Marek Safar  <marek.safar@seznam.cz>
928
929         Fixed bug #65238
930         * attribute.cs (Resolve): Property has to have both
931         accessors.
932
933 2004-09-14  Martin Baulig  <martin@ximian.com>
934
935         * decl.cs (MemberCore.Emit): Always call VerifyObsoleteAttribute().
936
937 2004-09-14  Marek Safar  <marek.safar@seznam.cz>
938
939         Fixed bug #61902
940         * codegen.cs (TestObsoleteMethodUsage): Trace when method is
941         called and is obsolete then this member suppress message
942         when call is inside next [Obsolete] method or type.
943
944         * expression.cs: Use TestObsoleteMethodUsage member.
945
946 2004-09-14  Martin Baulig  <martin@ximian.com>
947
948         * cs-parser.jay: Sync a bit with the GMCS version.
949
950 2004-09-14  Martin Baulig  <martin@ximian.com>
951
952         * cs-parser.jay (CSharpParser): Don't derive from GenericsParser.
953         (CSharpParser.yacc_verbose_flag): New public field.
954
955         * genericparser.cs: Removed.
956
957 2004-09-14  Raja R Harinath  <rharinath@novell.com>
958
959         * cs-parser.jay (event_declaration): Re-enable cs0071 error.
960
961 2004-09-13  Marek Safar  <marek.safar@seznam.cz>
962
963         * class.cs (MethodCore.CheckBase): Fix bug #65757.
964
965 2004-09-10  Martin Baulig  <martin@ximian.com>
966
967         Backported my MemberName changes from GMCS into MCS.
968
969         - we are now using a special `MemberName' class instead of using
970         strings; in GMCS, the `MemberName' also contains the type
971         arguments.
972
973         - changed the grammar rules a bit:
974           * the old `member_name' is now a `namespace_or_type_name':
975             The rule is that we use `namespace_or_type_name' everywhere
976             where we expect either a "member name" (GetEnumerator) or a
977             "member name" with an explicit interface name
978             (IEnumerable.GetEnumerator).
979             In GMCS, the explicit interface name may include type arguments
980             (IEnumerable<T>.GetEnumerator).
981           * we use `member_name' instead of just `IDENTIFIER' for
982             "member names":
983             The rule is that we use `member_name' wherever a member may
984             have type parameters in GMCS.       
985
986         * decl.cs (MemberName): New public class.
987         (MemberCore.MemberName): New public readonly field.
988         (MemberCore.ctor): Take a `MemberName' argument, not a string.
989         (DeclSpace): Likewise.
990
991         * delegate.cs (Delegate.ctor): Take a MemberName, not a string.
992         * enum.cs (Enum.ctor): Likewise.
993
994         * namespace.cs (AliasEntry.Alias): Changed type from Expression to
995         MemberName.     
996         (AliasEntry.ctor): Take a MemberName, not an Expression.
997         (AliasEntry.UsingAlias): Likewise.
998
999         * class.cs (TypeContainer.ctor): Take a MemberName, not a string.
1000         (IMethodData.MemberName): Changed type from string to MemberName.
1001         (MemberBase.ExplicitInterfaceName): Likewise.
1002         (AbstractPropertyEventMethod.SetupName): Make this private.
1003         (AbstractPropertyEventMethod.ctor): Added `string prefix'
1004         argument; compute the member name here.
1005         (AbstractPropertyEventMethod.UpdateName): Recompute the name based
1006         on the `member.MemberName' and the `prefix'.
1007
1008         * cs-parser.jay (attribute_name): Use `namespace_or_type_name',
1009         not `type_name'.
1010         (struct_declaration): Use `member_name' instead of `IDENTIFIER';
1011         thus, we get a `MemberName' instead of a `string'.  These
1012         declarations may have type parameters in GMCS.
1013         (interface_method_declaration, delegate_declaration): Likewise.
1014         (class_declaration, interface_declaration): Likewise.
1015         (method_header): Use `namespace_or_type_name' instead of
1016         `member_name'.  We may be an explicit interface implementation.
1017         (property_declaration, event_declaration): Likewise.
1018         (member_name): This is now just an `IDENTIFIER', not a
1019         `namespace_or_type_name'.
1020         (type_name, interface_type): Removed.
1021         (namespace_or_type_name): Return a MemberName, not an Expression.
1022         (primary_expression): Use `member_name' instead of `IDENTIFIER';
1023         call GetTypeExpression() on the MemberName to get an expression.
1024         (IndexerDeclaration.interface_type): Changed type from string to
1025         MemberName.
1026         (MakeName): Operate on MemberName's instead of string's.
1027
1028 2004-09-13  Raja R Harinath  <rharinath@novell.com>
1029
1030         Fix bug #55770.
1031         * namespace.cs (AliasEntry.Resolve): Implement section 16.3.1.
1032         (NamespaceEntry.Lookup): Add new argument to flag if we want the
1033         lookup to avoid symbols introduced by 'using'.
1034         * rootcontext.cs (NamespaceLookup): Update.
1035
1036 2004-09-12  Marek Safar  <marek.safar@seznam.cz>
1037
1038         * class.cs (TypeContainer.DoDefineMembers): Do not call
1039         DefineDefaultConstructor for static classes.
1040
1041 2004-09-12  Marek Safar  <marek.safar@seznam.cz>
1042
1043         * attribute.cs (Attribute.Resolve): Add error 653 report.
1044
1045         * class.cs (Class.ApplyAttributeBuilder): Add error 641
1046         report.
1047         (Method.ApplyAttributeBuilder): Add error 685 report.
1048         (Operator.Define): Add error 564 report.
1049
1050         * cs-tokenizer.cs (handle_hex): Add error 1013 report.
1051
1052         * expression.cs (Invocation.DoResolve): Add error
1053         245 and 250 report.
1054
1055         * parameter.cs (Parameter.ApplyAttributeBuilder): Add
1056         error 674 report.
1057
1058 2004-09-11  Marek Safar  <marek.safar@seznam.cz>
1059
1060         * class.cs (ConstructorInitializer.Resolve):
1061         Wrong error number (515->516).
1062
1063 2004-09-11  Marek Safar  <marek.safar@seznam.cz>
1064
1065         * class.cs (Indexer.Define): Add error 631 report.
1066
1067 2004-09-11  Marek Safar  <marek.safar@seznam.cz>
1068
1069         * ecore.cs (Error_NegativeArrayIndex): Fix 248 error.
1070
1071 2004-09-11  Marek Safar  <marek.safar@seznam.cz>
1072
1073         * expression.cs (Probe.DoResolve): Add error CS0241 report.
1074
1075 2004-09-10  Marek Safar  <marek.safar@seznam.cz>
1076
1077         * cs-parser.jay: Added error CS0241 report.
1078
1079 2004-09-10  Raja R Harinath  <rharinath@novell.com>
1080
1081         * cs-parser.jay (fixed_statement): Introduce a scope for the
1082         declaration in the 'fixed' statement.
1083
1084 2004-09-09  Marek Safar  <marek.safar@seznam.cz>
1085
1086         * cs-parser.jay: Added CS0230 error report.
1087
1088 2004-09-09  Marek Safar  <marek.safar@seznam.cz>
1089
1090         * cs-parser.jay: Added errors CS0231 and CS0257 report.
1091
1092 2004-09-09  Marek Safar  <marek.safar@seznam.cz>
1093
1094         * expression.cs (Argument.Resolve): Added error CS0192 and
1095         CS0199 report.
1096
1097 2004-09-09  Marek Safar  <marek.safar@seznam.cz>
1098
1099         C# 2.0 #pragma warning feature
1100
1101         * cs-tokenizer.cs (PreProcessPragma): New method; 
1102         Handles #pragma directive.
1103
1104         * report.cs (WarningRegions): New class; Support
1105         class for #pragma warning directive. It tests whether
1106         warning is enabled for a given line.
1107
1108 2004-09-08  Miguel de Icaza  <miguel@ximian.com>
1109
1110         * const.cs: Add more descriptive error report, tahnks to
1111         Sebastien. 
1112
1113 2004-09-08  Marek Safar  <marek.safar@seznam.cz>
1114
1115         * ecore.cs (FieldExpr.DoResolveLValue): Fixed CS0198 report.
1116
1117 2004-09-07  Miguel de Icaza  <miguel@ximian.com>
1118
1119         * expression.cs: Apply patch from Ben: Remove dead code from
1120         ArrayCreation, and remove the TurnintoConstant call in const.cs,
1121         as that code just threw an exception anwyays.
1122
1123         * const.cs: Remove the call to the turnintoconstant, for details
1124         see bug: #63144
1125         
1126         * literal.cs: The type of the null-literal is the null type;  So
1127         we use a placeholder type (literal.cs:System.Null, defined here)
1128         for it.
1129
1130         * expression.cs (Conditional.DoResolve): Remove some old code that
1131         is no longer needed, conversions have been fixed.
1132
1133         (ArrayCreationExpression.DoResolve): Return false if we fail to
1134         resolve the inner expression.
1135
1136 2004-09-07  Raja R Harinath  <rharinath@novell.com>
1137
1138         Fix test-290.cs.
1139         * cs-parser.jay (delegate_declaration): Record a delegate
1140         declaration as a type declaration.
1141         Reported by Jo Vermeulen <jo@lumumba.luc.ac.be>.
1142
1143 2004-09-06  Miguel de Icaza  <miguel@ximian.com>
1144
1145         * parameter.cs: Do not crash if the type can not be resolved. 
1146
1147         * expression.cs: Report errors with unsafe pointers, fixes #64896
1148
1149 2004-09-06 Ben Maurer  <bmaurer@users.sourceforge.net>
1150
1151         * expression.cs: Pointer arith always needs to do a conv.i
1152         if the operand is a long. fix 65320
1153
1154 2004-09-04  Marek Safar  <marek.safar@seznam.cz>
1155
1156         Fixed cs0619-37.cs, cs0619-38.cs
1157
1158         * enum.cs (GetObsoleteAttribute): Removed.
1159
1160         * expression.cs (MemberAccess.DoResolve): Test for [Obsolete]
1161         on Enum member is double staged. The first is tested member
1162         and then enum.
1163
1164 2004-09-04  Marek Safar  <marek.safar@seznam.cz>
1165
1166         Fixed #56986, #63631, #65231
1167
1168         * class.cs: (TypeContainer.AddToMemberContainer): New method,
1169         adds member to name container.
1170         (TypeContainer.AddToTypeContainer): New method, adds type to
1171         name container.
1172         (AddConstant, AddEnum, AddClassOrStruct, AddDelegate, AddMethod,
1173         AddConstructor, AddInterface, AddField, AddProperty, AddEvent,
1174         AddOperator): Simplified by reusing AddToMemberContainer.
1175         (TypeContainer.UserDefinedStaticConstructor): Changed to property
1176         instead of field.
1177         (Method.CheckForDuplications): Fixed implementation to test all
1178         possibilities.
1179         (MemberBase): Detection whether member is explicit interface
1180         implementation is now in constructor.
1181         (MemberBase.UpdateMemberName): Handles IndexerName.
1182         (Accessor): Changed to keep also location information.
1183         (AbstractPropertyEventMethod): Is derived from MemberCore.
1184         (AbstractPropertyEventMethod.IsDummy): Says whether accessor
1185         will be emited or not.
1186         (PropertyBase.AreAccessorsDuplicateImplementation):
1187         Tests whether accessors are not in collision with some method.
1188         (Operator): Is derived from MethodCore to simplify common
1189         operations.
1190
1191         * decl.cs (Flags.TestMethodDuplication): Test for duplication
1192         must be performed.
1193         (DeclSpace.AddToContainer): Adds the member to defined_names
1194         table. It tests for duplications and enclosing name conflicts.
1195
1196         * enum.cs (EnumMember): Clean up to reuse the base structures
1197
1198 2004-09-03  Martin Baulig  <martin@ximian.com>
1199
1200         * class.cs (TypeContainer.DefineDefaultConstructor): Put this back
1201         into TypeContainer, to make partial classes work again.
1202
1203 2004-09-03  Martin Baulig  <martin@ximian.com>
1204
1205         * rootcontext.cs (RootContext.V2): Removed.
1206
1207 2004-03-23  Martin Baulig  <martin@ximian.com>
1208
1209         * expression.cs (Invocation.OverloadResolve): Added `bool
1210         may_fail' argument and use it instead of the Location.IsNull() hack.
1211
1212 2004-09-03  Martin Baulig  <martin@ximian.com>
1213
1214         Merged latest changes into gmcs.  Please keep this comment in
1215         here, it makes it easier for me to see what changed in MCS since
1216         the last time I merged.
1217
1218 2004-09-03  Raja R Harinath  <rharinath@novell.com>
1219
1220         Fix #61128.
1221         * expression.cs (BetterConversion): Don't allow either conversion 
1222         to be null.  Remove redundant implicit conversion test when 'q ==
1223         null' -- when this function is invoked, we already know that the
1224         implicit conversion exists.
1225         (BetterFunction): Assume that 'best' is non-null.  Remove
1226         redundant reimplementation of IsApplicable when 'best' is null.
1227         (IsParamsMethodApplicable, IsApplicable): Add new parameter for
1228         number of arguments.
1229         (IsAncestralType): Extract from OverloadResolve.
1230         (OverloadResolve): Make robust to the MethodGroupExpr being
1231         unsorted.  Implement all the logic of Section 14.5.5.1, and
1232         support overloading of methods from multiple applicable types.
1233         Clean up logic somewhat.  Don't pass null methods to BetterFunction.
1234
1235         * report.cs (SymbolRelatedToPreviousError): Cleanup output.
1236         (RealError, Warning): Append type of report to related symbol.
1237
1238 2004-09-03  Marek Safar  <marek.safar@seznam.cz>
1239
1240         * enum.cs: Fixed CLS-Compliance checks for enum members.
1241         Error tests cs3008-8.cs, cs3014-8.cs
1242
1243 2004-09-02  Marek Safar  <marek.safar@seznam.cz>
1244
1245         Fixed bug #62342, #63102
1246         * class.cs: ImplementIndexer uses member.IsExplicitImpl
1247         like ImplementMethod.
1248
1249 2004-09-02  Marek Safar  <marek.safar@seznam.cz>
1250
1251         * attribute.cs (Attribute.GetAttributeArgumentExpression):
1252         Fixed bug #65170.
1253
1254 2004-09-02  Martin Baulig  <martin@ximian.com>
1255
1256         * statement.cs (Using.EmitLocalVariableDeclFinally): Use
1257         TypeManager.GetArgumentTypes() rather than calling GetParameters()
1258         on the MethodBase.
1259
1260 2004-09-01  Marek Safar  <marek.safar@seznam.cz>
1261
1262         C# 2.0 Static classes implemented
1263
1264         * class.cs (TypeContainer): instance_constructors,
1265         initialized_fields, initialized_static_fields,
1266         default_constructor, base_inteface_types are protected to be
1267         accessible from StaticClass.
1268         (TypeContainer.DefineDefaultConstructor): New virtual method
1269         for custom default constructor generating
1270         (StaticClass): New class to handle "Static classes" feature.
1271
1272         * cs-parser.jay: Handle static keyword on class like instance
1273         of StaticClass.
1274
1275         * driver.cs: Added "/langversion" command line switch with two
1276         options (iso-1, default).
1277
1278 2004-08-31  Marek Safar  <marek.safar@seznam.cz>
1279
1280         * ecore.cs (FieldExpr.Resolve): Fixed bug #64689.
1281
1282 2004-08-31  Miguel de Icaza  <miguel@ximian.com>
1283
1284         * delegate.cs: Style.
1285
1286 2004-08-31 Ben Maurer  <bmaurer@users.sourceforge.net>
1287
1288         * delegate.cs: Add seperate instance expr field for miguel.
1289
1290 2004-08-29 Ben Maurer  <bmaurer@users.sourceforge.net>
1291
1292         * PointerArithmetic (Resolve): make sure we are not doing
1293         pointer arith on void*. Also, make sure we are resolved
1294         by not setting eclass until resolve.
1295
1296         All callers: Make sure that PointerArithmetic gets resolved.
1297
1298 2004-08-29 Ben Maurer  <bmaurer@users.sourceforge.net>
1299
1300         * ArrayCreation (LookupType): If the type does not resolve 
1301         to an array, give an error.
1302
1303 2004-08-27  Marek Safar  <marek.safar@seznam.cz>
1304
1305         * statement.cs (Try.Resolve): Fixed bug #64222
1306
1307 2004-08-27  Martin Baulig  <martin@ximian.com>
1308
1309         * class.cs
1310         (TC.OperatorArrayList.OperatorEntry.CheckPairedOperators): Don't
1311         crash here.     
1312
1313 2004-08-26  Marek Safar  <marek.safar@seznam.cz>
1314
1315         * ecore.cs (Constantify): Get underlying type via
1316         System.Enum.GetUnderlyingType to avoid StackOverflow on the
1317         Windows in special cases.
1318
1319 2004-08-26  Marek Safar  <marek.safar@seznam.cz>
1320
1321         * typemanager.cs (GetAddMethod): Used GetAddMethod (true)
1322         for obtaining also private methods.
1323         (GetRemoveMethod): Used GetRemoveMethod (true)
1324         for obtaining also private methods.
1325
1326 2004-08-24  Martin Baulig  <martin@ximian.com>
1327
1328         * class.cs (Method.Define): Set MethodAttributes.SpecialName and
1329         MethodAttributes.HideBySig for operators.
1330
1331 2004-08-23  Martin Baulig  <martin@ximian.com>
1332
1333         Back to the old error reporting system :-)
1334
1335         * report.cs (Message): Removed.
1336         (Report.MessageData, ErrorData, WarningData): Removed.
1337         (Report.Error, Warning): Back to the old system.
1338
1339 2004-08-23  Martin Baulig  <martin@ximian.com>
1340
1341         * decl.cs (IMemberContainer.Parent): Renamed to ParentContainer.
1342
1343         * class.cs (TypeContainer.ParentContainer): New public virtual
1344         method; replaces the explicit interface implementation.
1345         (ClassPart.ParentContainer): Override.
1346
1347 2004-08-23  Martin Baulig  <martin@ximian.com>
1348
1349         * statement.cs (Switch): Added support for constant switches; see
1350         #59428 or test-285.cs.
1351
1352 2004-08-22  Marek Safar  <marek.safar@seznam.cz>
1353
1354         Fixed bug #62740.
1355         * statement.cs (GetEnumeratorFilter): Removed useless
1356         logic because C# specs is strict. GetEnumerator must be
1357         public.
1358
1359 2004-08-22  Martin Baulig  <martin@ximian.com>
1360
1361         * flowanalysis.cs (FlowBranching.UsageVector.MergeChild): If we're
1362         a switch and may break, reset the barrier.  Fixes #59867.
1363
1364 2004-08-22  Marek Safar  <marek.safar@seznam.cz>
1365
1366         CLS-Compliance speed up (~5% for corlib)
1367
1368         * attribute.cs (AttributeTester.VerifyTopLevelNameClsCompliance):
1369         New method. Tests container for CLS-Compliant names
1370
1371         * class.cs (TypeContainer.VerifyClsName): New method.
1372         Checks whether container name is CLS Compliant.
1373         (Constructor): Implements IMethodData.
1374
1375         * decl.cs (MemberCache.GetPublicMembers ): New method. Builds
1376         low-case table for CLS Compliance test.
1377         (MemberCache.VerifyClsParameterConflict): New method.
1378         Checks method parameters for CS3006 error.
1379
1380         * enum.cs (EnumMember): Is derived from MemberCore.
1381         (Enum.VerifyClsName): Optimized for better performance.
1382
1383 2004-08-06  Marek Safar  <marek.safar@seznam.cz>
1384
1385         * report.cs: Renamed Error_T to Error and changed all
1386         references.
1387
1388 2004-08-06  Marek Safar  <marek.safar@seznam.cz>
1389
1390         * class.cs (TypeContainer.IndexerArrayList): New inner class
1391         container for indexers.
1392         (TypeContainer.DefaultIndexerName): New constant for default
1393         indexer name. Replaced all "Item" with this constant.
1394         (TypeContainer.DefineIndexers): Moved to IndexerArrayList class.
1395
1396         * typemanager.cs (TypeManager.default_member_ctor): Cache here
1397         DefaultMemberAttribute constructor.
1398
1399 2004-08-05  Martin Baulig  <martin@ximian.com>
1400
1401         * flowanalysis.cs (FlowBranching.UsageVector.MergeJumpOrigins):
1402         Fix bug #59429.
1403
1404 2004-08-05  Marek Safar  <marek.safar@seznam.cz>
1405
1406         * mcs.exe.sources: $(EXTRA_SOURCES) are now here to avoid
1407         multi platforms problem.
1408
1409         * compiler.csproj: Included shared files.
1410
1411 2004-08-04  Marek Safar  <marek.safar@seznam.cz>
1412
1413         Fix bug 60333, 55971 in the more general way
1414         * attribute.cs (Attribute.GetAttributeArgumentExpression):
1415         Added arg_type argument for constant conversion.
1416         (Attribute.Resolve): Reuse GetAttributeArgumentExpression.
1417
1418 2004-08-04  Marek Safar  <marek.safar@seznam.cz>
1419
1420         Fix bug #59760
1421         * class.cs (TypeContainer ): New inner classes MethodArrayList, 
1422         OperatorArrayList, MethodCoreArrayList for typecontainer
1423         containers. Changed class member types to these new types.
1424         (MethodArrayList.DefineMembers): Added test for CS0659.
1425
1426 2004-08-04  Miguel de Icaza  <miguel@ximian.com>
1427
1428         * cfold.cs: Synchronize the folding with the code in expression.cs
1429         Binary.DoNumericPromotions for uint operands.
1430
1431         * attribute.cs: Revert patch from Raja, it introduced a regression
1432         while building Blam-1.2.1 (hard to isolate a test case).
1433
1434 2004-08-04  Marek Safar  <marek.safar@seznam.cz>
1435
1436         Fix for #55382
1437         * class.cs:
1438         (TypeContainer.Define): Renamed to DefineContainerMembers because of
1439         name collision.
1440         (MethodCore.parent_method): New member. The method we're overriding
1441         if this is an override method.
1442         (MethodCore.CheckBase): Moved from Method class and made common.
1443         (MethodCore.CheckMethodAgainstBase): Moved from MemberBase and made
1444         private.
1445         (MethodCore.CheckForDuplications): New abstract method. For custom
1446         member duplication search in a container
1447         (MethodCore.FindOutParentMethod): New abstract method. Gets parent
1448         method and its return type.
1449         (Event.conflict_symbol): New member. Symbol with same name in the
1450         parent class.
1451
1452         * decl.cs:
1453         (MemberCache.FindMemberWithSameName): New method. The method
1454         is looking for conflict with inherited symbols.
1455
1456 2004-08-04  Martin Baulig  <martin@ximian.com>
1457
1458         * codegen.cs (VariableStorage.EmitLoadAddress): New public method.
1459
1460         * statement.cs (Foreach.EmitFinally): Make this work for valuetypes.
1461
1462 2004-08-03  Marek Safar  <marek.safar@seznam.cz>
1463
1464         * report.cs (Message): New enum for better error, warning reference in
1465         the code.
1466         (MessageData): New inner abstract class. It generally handles printing of
1467         error and warning messages.
1468         Removed unused Error, Warning, Message methods.
1469
1470 2004-08-03  Marek Safar  <marek.safar@seznam.cz>
1471
1472         Fix for cs0592-8.cs test
1473         * attribute.cs
1474         (Attributable.ValidAttributeTargets): Made public.
1475         (Attribute.ExplicitTarget): New member for explicit target value.
1476         (Attribute.CheckTargets): Now we translate explicit attribute
1477         target to Target here.
1478
1479 2004-08-03  Ben Maurer  <bmaurer@ximian.com>
1480
1481         * ecore.cs (MethodGroupExpr): new IsBase property.
1482
1483         * expression.cs (BaseAccess): Set IsBase on MethodGroupExpr.
1484
1485         * delegate.cs (DelegateCreation): store a MethodGroupExpr
1486         rather than an instance expr.
1487
1488         (DelegateCreation.Emit): Use the method group rather than
1489         the instance expression. Also, if you have base.Foo as the
1490         method for a delegate, make sure to emit ldftn, not ldftnvirt.
1491
1492         (ResolveMethodGroupExpr): Use the MethodGroupExpr. 
1493
1494         (NewDelegate.DoResolve): Only check for the existance of Invoke
1495         if the method is going to be needed. Use MethodGroupExpr.
1496
1497         (NewDelegate.Emit): Remove, DelegateCreation implements this.   
1498
1499         * expression.cs: For pointer arith., make sure to use
1500         the size of the type, not the size of the pointer to
1501         the type.
1502
1503 2004-08-03  Marek Safar  <marek.safar@seznam.cz>
1504
1505         Fix for #60722
1506         * class.cs (Class): Added error CS0502 test.
1507
1508 2004-08-03  John Luke  <jluke@cfl.rr.com>
1509             Raja R Harinath  <rharinath@novell.com>
1510
1511         Fix for #60997.
1512         * attribute.cs (Attribute.complained_before): New flag.
1513         (Attribute.ResolveType, Attribute.Resolve),
1514         (Attribute.DefinePInvokeMethod): Set it.
1515         (Attributes.Search): Pass 'complain' to Attribute.ResolveType.
1516         
1517 2004-08-03  Martin Baulig  <martin@ximian.com>
1518
1519         * expression.cs (Binary.ResolveOperator): Don't abort if we can't
1520         use a user-defined operator; we still need to do numeric
1521         promotions in case one argument is a builtin type and the other
1522         one has an implicit conversion to that type.  Fixes #62322.
1523
1524 2004-08-02  Martin Baulig  <martin@ximian.com>
1525
1526         * statement.cs (LocalInfo.Flags): Added `IsThis'.
1527         (LocalInfo.IsThis): New public property.
1528         (Block.EmitMeta): Don't create a LocalBuilder for `this'.
1529
1530 2004-08-01  Martin Baulig  <martin@ximian.com>
1531
1532         * class.cs (TypeContainer.GetClassBases): Don't set the default
1533         here since we may get called from GetPartialBases().
1534         (TypeContainer.DefineType): If GetClassBases() didn't return a
1535         parent, use the default one.
1536
1537 2004-07-30  Duncan Mak  <duncan@ximian.com>
1538
1539         * Makefile (mcs2.exe, mcs3.exe): add $(EXTRA_SOURCES).
1540
1541 2004-07-30  Martin Baulig  <martin@ximian.com>
1542
1543         * Makefile (EXTRA_SOURCES): List the symbol writer's sources here.
1544
1545         * class.cs (SourceMethod): New public class, derive from the
1546         symbol writer's ISourceMethod.
1547         (Method): Use the new symbol writer API.
1548
1549         * codegen.cs (CodeGen.InitializeSymbolWriter): Take the filename
1550         as argument and use the new symbol writer.
1551
1552         * location.cs
1553         (SourceFile): Implement the symbol writer's ISourceFile.
1554         (Location.SymbolDocument): Removed.
1555         (Location.SourceFile): New public property.
1556
1557         * symbolwriter.cs: Use the new symbol writer API.
1558
1559 2004-07-30  Raja R Harinath  <rharinath@novell.com>
1560
1561         * Makefile (install-local): Remove.  Functionality moved to
1562         executable.make.
1563
1564 2004-07-28  Lluis Sanchez Gual  <lluis@novell.com>
1565
1566         * Makefile: Install mcs.exe.config file together with mcs.exe.
1567         * mcs.exe.config: Added supportedRuntime entry to make sure it runs in the
1568         correct runtime version.
1569         
1570 2004-07-25  Martin Baulig  <martin@ximian.com>
1571
1572         * class.cs
1573         (TypeContainer.RegisterOrder): Removed, this was unused.
1574         (TypeContainer, interface_order): Removed.
1575         (TypeContainer.AddClass, AddStruct, AddInterface): Take a
1576         TypeContainer as argument since we can also be called with a
1577         `PartialContainer' for a partial class/struct/interface.
1578         (TypeContainer.IsInterface): Use `Kind == Kind.Interface' instead
1579         of checking whether we're an `Interface' - we could be a
1580         `PartialContainer'.
1581         (PartialContainer.Register): Override; call
1582         AddClass()/AddStruct()/AddInterface() on our parent.
1583
1584         * cs-parser.jay (interface_member_declaration): Add things to the
1585         `current_container', not the `current_class'.
1586
1587         * rootcontext.cs (RegisterOrder): The overloaded version which
1588         takes an `Interface' was unused, removed.
1589
1590         * typemanager.cs (TypeManager.LookupInterface): Return a
1591         `TypeContainer', not an `Interface'.
1592         (TypeManager.IsInterfaceType): The `builder_to_declspace' may
1593         contain a `PartialContainer' for an interface, so check it's
1594         `Kind' to figure out what it is.
1595
1596 2004-07-25  Martin Baulig  <martin@ximian.com>
1597
1598         * class.cs (Class.DefaultTypeAttributes): New public constant.
1599         (Struct.DefaultTypeAttributes): Likewise.
1600         (Interface.DefaultTypeAttributes): Likewise.
1601         (PartialContainer.TypeAttr): Override this and add the
1602         DefaultTypeAttributes.
1603
1604 2004-07-25  Martin Baulig  <martin@ximian.com>
1605
1606         * decl.cs (DeclSpace.Emit): Removed the `TypeContainer' argument,
1607         we can just use the `Parent' field instead.
1608
1609 2004-07-25  Martin Baulig  <martin@ximian.com>
1610
1611         * class.cs (TypeContainer.Emit): Renamed to EmitType().
1612
1613 2004-07-25  Martin Baulig  <martin@ximian.com>
1614
1615         * class.cs (TypeContainer.DefineMembers): Call DefineMembers() on
1616         our parts before defining any methods.
1617         (TypeContainer.VerifyImplements): Make this virtual.
1618         (ClassPart.VerifyImplements): Override and call VerifyImplements()
1619         on our PartialContainer.
1620
1621 2004-07-25  Martin Baulig  <martin@ximian.com>
1622
1623         * iterators.cs (Iterator.Define): Renamed to DefineIterator().
1624
1625         * decl.cs (DeclSpace.Define): Removed the `TypeContainer'
1626         argument, we can just use the `Parent' field instead.
1627
1628         * class.cs
1629         (MemberBase.CheckBase): Removed the `TypeContainer' argument.   
1630         (MemberBase.DoDefine): Likewise.
1631
1632 2004-07-24  Martin Baulig  <martin@ximian.com>
1633
1634         * decl.cs (MemberCore.Parent): New public field.
1635         (DeclSpace.Parent): Moved to MemberCore.
1636
1637         * class.cs (MethodCore.ds): Removed; use `Parent' instead.
1638         (MemberBase.ctor): Added TypeContainer argument, pass it to our
1639         parent's .ctor.
1640         (FieldBase, Field, Operator): Likewise.
1641         (EventProperty.ctor): Take a TypeContainer instead of a DeclSpace.
1642         (EventField, Event): Likewise.
1643
1644 2004-07-23  Martin Baulig  <martin@ximian.com>
1645
1646         * class.cs (PartialContainer): New public class.
1647         (ClassPart): New public class.
1648         (TypeContainer): Added support for partial classes.
1649         (TypeContainer.GetClassBases): Splitted some of the functionality
1650         out into GetNormalBases() and GetPartialBases().
1651
1652         * cs-tokenizer.cs (Token.PARTIAL): New token.
1653         (Tokenizer.consume_identifier): Added some hacks to recognize
1654         `partial', but only if it's immediately followed by `class',
1655         `struct' or `interface'.
1656
1657         * cs-parser.jay: Added support for partial clases.
1658
1659 2004-07-23  Martin Baulig  <martin@ximian.com>
1660
1661         * class.cs (MethodCore.ds): Made this a `TypeContainer' instead of
1662         a `DeclSpace' and also made it readonly.
1663         (MethodCore.ctor): Take a TypeContainer instead of a DeclSpace.
1664         (Method.ctor, Constructor.ctor, Destruktor.ctor): Likewise.
1665         (PropertyBase.ctor, Property.ctor, Indexer.ctor): Likewise.
1666
1667         * cs-parser.jay: Pass the `current_class', not the
1668         `current_container' (at the moment, this is still the same thing)
1669         to a new Method, Property, Event, Indexer or Constructor.
1670
1671 2004-07-23  Martin Baulig  <martin@ximian.com>
1672
1673         * cs-parser.jay (CSharpParser): Added a new `current_class' field
1674         and removed the `current_interface' one.
1675         (struct_declaration, class_declaration, interface_declaration):
1676         Set `current_class' to the newly created class/struct/interface;
1677         set their `Bases' and call Register() before parsing their body.
1678
1679 2004-07-23  Martin Baulig  <martin@ximian.com>
1680
1681         * class.cs (Kind): New public enum.
1682         (TypeContainer): Made this class abstract.
1683         (TypeContainer.Kind): New public readonly field.
1684         (TypeContainer.CheckDef): New public method; moved here from
1685         cs-parser.jay.
1686         (TypeContainer.Register): New public abstract method.
1687         (TypeContainer.GetPendingImplementations): New public abstract
1688         method.
1689         (TypeContainer.GetClassBases): Removed the `is_class' and
1690         `is_iface' parameters.
1691         (TypeContainer.DefineNestedTypes): Formerly known as
1692         DoDefineType().
1693         (ClassOrStruct): Made this class abstract.
1694
1695         * tree.cs (RootTypes): New public type. 
1696
1697 2004-07-20  Martin Baulig  <martin@ximian.com>
1698
1699         * tree.cs (Tree.RecordNamespace): Removed.
1700         (Tree.Namespaces): Removed.
1701
1702         * rootcontext.cs (RootContext.IsNamespace): Removed.
1703
1704         * cs-parser.jay (namespace_declaration): Just create a new
1705         NamespaceEntry here.
1706
1707 2004-07-20  Martin Baulig  <martin@ximian.com>
1708
1709         * statement.cs (ExceptionStatement): New abstract class.  This is
1710         now used as a base class for everyone who's using `finally'.
1711         (Using.ResolveLocalVariableDecls): Actually ResolveLValue() all
1712         our local variables before using them.
1713
1714         * flowanalysis.cs (FlowBranching.StealFinallyClauses): New public
1715         virtual method.  This is used by Yield.Resolve() to "steal" an
1716         outer block's `finally' clauses.
1717         (FlowBranchingException): The .ctor now takes an ExceptionStatement
1718         argument.
1719
1720         * codegen.cs (EmitContext.StartFlowBranching): Added overloaded
1721         version which takes an ExceptionStatement.  This version must be
1722         used to create exception branchings.
1723
1724         * iterator.cs
1725         (Yield.Resolve): "Steal" all `finally' clauses from containing blocks.
1726         (Iterator.EmitMoveNext): Added exception support; protect the
1727         block with a `fault' clause, properly handle 'finally' clauses.
1728         (Iterator.EmitDispose): Run all the `finally' clauses here.
1729
1730 2004-07-20  Martin Baulig  <martin@ximian.com>
1731
1732         * iterator.cs: This is the first of a set of changes in the
1733         iterator code.  Match the spec more closely: if we're an
1734         IEnumerable, then GetEnumerator() must be called.  The first time
1735         GetEnumerator() is called, it returns the current instance; all
1736         subsequent invocations (if any) must create a copy.
1737
1738 2004-07-19  Miguel de Icaza  <miguel@ximian.com>
1739
1740         * expression.cs: Resolve the constant expression before returning
1741         it. 
1742
1743 2004-07-19  Martin Baulig  <martin@ximian.com>
1744
1745         * iterators.cs (Iterator.MapVariable): Don't define fields twice.
1746         (Iterator.MoveNextMethod.DoEmit): Use `TypeManager.int32_type' as
1747         the return type of the new EmitContext.
1748
1749 2004-07-18  Martin Baulig  <martin@ximian.com>
1750
1751         * class.cs (Property.Define): Fix iterators.
1752
1753         * iterators.cs (Iterator.Define): Moved the
1754         `container.AddInterator (this)' call here from the .ctor; only do
1755         it if we resolved successfully.
1756
1757 2004-07-17  Miguel de Icaza  <miguel@ximian.com>
1758
1759         * cs-tokenizer.cs (handle_preprocessing_directive): Do not return
1760         `true' for preprocessing directives that we parse.  The return
1761         value indicates whether we should return to regular tokenizing or
1762         not, not whether it was parsed successfully.
1763
1764         In the past if we were in: #if false ... #line #endif, we would
1765         resume parsing after `#line'.  See bug 61604.
1766
1767         * typemanager.cs: Removed an old hack from Gonzalo to get corlib
1768         building: IsEnumType should return true only for enums, not for
1769         enums or System.Enum itself.  This fixes #61593.
1770
1771         Likely what happened is that corlib was wrong: mcs depended on
1772         this bug in some places.  The bug got fixed, we had to add the
1773         hack, which caused bug 61593.
1774
1775         * expression.cs (ArrayAccess.GetStoreOpCode): Remove an old hack
1776         that was a workaround for the older conditions.
1777
1778 2004-07-16  Ben Maurer  <bmaurer@ximian.com>
1779
1780         * assign.cs: IAssignMethod has a new interface, as documented
1781         inline. All assignment code now uses this new api.
1782
1783         * ecore.cs, expression.cs: All classes which implement
1784         IAssignMethod now use the new interface.
1785
1786         * expression.cs (Invocation): add a hack to EmitCall so that
1787         IndexerAccess can be the target of a compound assignment without
1788         evaluating its arguments twice.
1789
1790         * statement.cs: Handle changes in Invocation api.
1791
1792 2004-07-16  Martin Baulig  <martin@ximian.com>
1793
1794         * iterators.cs: Rewrote this.  We're now using one single Proxy
1795         class for both the IEnumerable and the IEnumerator interface and
1796         `Iterator' derives from Class so we can use the high-level API.
1797
1798         * class.cs (TypeContainer.AddIterator): New method.
1799         (TypeContainer.DoDefineType): New protected virtual method, which
1800         is called from DefineType().
1801         (TypeContainer.DoDefineMembers): Call DefineType() and
1802         DefineMembers() on all our iterators.
1803         (TypeContainer.Emit): Call Emit() on all our iterators.
1804         (TypeContainer.CloseType): Call CloseType() on all our iterators.
1805
1806         * codegen.cs (EmitContext.CurrentIterator): New public field.
1807
1808 2004-07-15  Martin Baulig  <martin@ximian.com>
1809
1810         * typemanager.cs
1811         (TypeManager.not_supported_exception_type): New type.   
1812
1813 2004-07-14  Martin Baulig  <martin@ximian.com>
1814
1815         * iterators.cs: Use real error numbers.
1816
1817 2004-07-14  Martin Baulig  <martin@ximian.com>
1818
1819         * iterator.cs (IteratorHandle.IsIEnumerable): The spec explicitly
1820         requires this to be a System.Collection.IEnumerable and not a
1821         class implementing that interface.
1822         (IteratorHandle.IsIEnumerator): Likewise, for IEnumerator.      
1823
1824 2004-07-13  Marek Safar  <marek.safar@seznam.cz>
1825
1826         * class.cs: Fixed previous fix, it broke some error tests.
1827
1828 2004-07-12  Martin Baulig  <martin@ximian.com>
1829
1830         * enum.cs (Enum.Define): Call Emit() to emit the attributes.
1831         Fixes #61293.
1832
1833 2004-07-09  Miguel de Icaza  <miguel@ximian.com>
1834
1835         * assign.cs (LocalTemporary): Add new argument: is_address,If
1836         `is_address' is true, then the value that we store is the address
1837         to the real value, and not the value itself.
1838         
1839         * ecore.cs (PropertyExpr): use the new local temporary
1840         stuff to allow us to handle X.Y += z (where X is a struct)
1841
1842 2004-07-08  Martin Baulig  <martin@ximian.com>
1843
1844         * statement.cs (Lock.Resolve): Set ec.NeedReturnLabel() if we do
1845         not always return, just like we're doing in Using.Resolve().
1846
1847 2004-07-07  Miguel de Icaza  <miguel@ximian.com>
1848
1849         * cs-parser.jay (fixed_statement): flag this as Pinned.
1850
1851 2004-07-06  Miguel de Icaza  <miguel@ximian.com>
1852
1853         * typemanager.cs (TypeManager): Removed MakePinned method, this
1854         mechanism is replaced with the .NET 2.x compatible mechanism of
1855         calling `ILGenerator.DeclareLocal (Type t, bool pinned)'.
1856
1857         * statement.cs (LocalInfo): Remove MakePinned, add Pinned property 
1858         Rename `Fixed' to `Pinned' as a flag, to distinguish from the
1859         `IsFixed' property which has a different meaning.
1860
1861 2004-07-02  Raja R Harinath  <rharinath@novell.com>
1862
1863         * ecore.cs (DoSimpleNameResolve): Expand CS0038 check to all names
1864         visible from inside a nested class, not just the names of the
1865         immediately enclosing class.
1866         Fix for bug #60730.
1867
1868 2004-06-24  Raja R Harinath  <rharinath@novell.com>
1869
1870         * expression.cs (BetterConversion): Remove buggy special-case
1871         handling of "implicit constant expression conversions".  At this
1872         point, we already know that the conversion is possible -- we're
1873         only checking to see which is better.
1874
1875 2004-06-24  Marek Safar  <marek.safar@seznam.cz>
1876
1877         * cs-parser.jay: Added error CS0210 test.
1878
1879 2004-06-24  Marek Safar  <marek.safar@seznam.cz>
1880
1881         * cs-parser.jay: Added error CS0134 test.
1882
1883 2004-06-24  Marek Safar  <marek.safar@seznam.cz>
1884
1885         Fix bug #52507
1886         * cs-parser.jay: Added error CS0145 test.
1887
1888 2004-06-24  Marek Safar  <marek.safar@seznam.cz>
1889
1890         * class.cs (Operator.Define): Added test for errors CS0553, CS0554.
1891
1892 2004-06-23  Ben Maurer  <bmaurer@ximian.com>
1893         
1894         * expression.cs (StackAlloc.Resolve): The argument may not
1895         be a constant; deal with this case.
1896         
1897 2004-06-23  Marek Safar  <marek.safar@seznam.cz>
1898
1899         * attribute.cs (IndexerName_GetIndexerName): Renamed to
1900         GetIndexerAttributeValue.
1901         (ScanForIndexerName): Renamed to GetIndexerNameAttribute.
1902
1903         * class.cs (Indexer.Define): Added error tests for CS0415,
1904         CS0609.
1905
1906 2004-06-23  Miguel de Icaza  <miguel@ximian.com>
1907
1908         * attribute.cs (Attribute.Resolve): Keep field code in sync with
1909         property code.
1910
1911 2004-06-23  Martin Baulig  <martin@ximian.com>
1912
1913         * flowanalysis.cs (UsageVector.MergeChild): If we're a loop and we
1914         neither return nor throw, reset the barrier as well.  Fixes #60457.
1915
1916 2004-06-22  Atsushi Enomoto  <atsushi@ximian.com>
1917
1918         * class.cs : EventAttributes is now set to None by default.
1919           This fixes bug #60459.
1920
1921 2004-06-18  Marek Safar  <marek.safar@seznam.cz>
1922
1923         Fix bug #60219
1924         * class.cs (ConstructorInitializer.GetOverloadedConstructor):
1925         Don't throw exception but return null (it's sufficient now).
1926
1927 2004-06-18  Marek Safar  <marek.safar@seznam.cz>
1928
1929         * typemanager.cs (GetArgumentTypes): Faster implementation.
1930
1931 2004-06-18  Martin Baulig  <martin@ximian.com>
1932
1933         * attribute.cs (Attribute.Resolve): Check whether we're an
1934         EmptyCast which a Constant child.  Fixes #60333.
1935
1936 2004-06-17  Ben Maurer  <bmaurer@ximian.com>
1937
1938         * statement.cs (EmitCollectionForeach): Account for the fact that
1939         not all valuetypes are in areas which we can take the address of.
1940         For these variables, we store to a temporary variable. Also, make
1941         sure that we dont emit a `callvirt' on a valuetype method.
1942
1943 2004-06-15  Marek Safar  <marek.safar@seznam.cz>
1944
1945         * expression.cs (StackAlloc.DoReSolve): Added test for
1946         negative parameter (CS0247).
1947
1948 2004-06-15  Marek Safar  <marek.safar@seznam.cz>
1949
1950         Fix bug #59792
1951         * class.cs: (Event.DelegateMethod.Emit): Added synchronization flag.
1952
1953 2004-06-15  Marek Safar  <marek.safar@seznam.cz>
1954
1955         Fix bug #59781
1956         * expression.cs: (Binary.DoNumericPromotions): Added conversion for
1957         ulong.
1958
1959 2004-06-14  Marek Safar  <marek.safar@seznam.cz>
1960
1961         Fix bug #58254 & cs1555.cs, cs1556.cs
1962         * driver.cs (MainDriver): Added tests for errors CS1555, CS1556.
1963
1964 2004-06-14  Marek Safar  <marek.safar@seznam.cz>
1965
1966         * cs-parser.jay: Added error CS1669 test for indexers.
1967
1968 2004-06-11  Martin Baulig  <martin@ximian.com>
1969
1970         * expression.cs (Invocation.IsParamsMethodApplicable): We need to
1971         call this twice: for params and varargs methods.
1972
1973 2004-06-11  Marek Safar  <marek.safar@seznam.cz>
1974
1975         * class.cs:
1976         (FieldBase.DoDefine, PropertyBase.DoDefine): Added error test CS0610.
1977
1978 2004-06-11  Marek Safar  <marek.safar@seznam.cz>
1979
1980         * attribute.cs (Attribute.GetValidTargets): Made public.
1981
1982         * class.cs: 
1983         (AbstractPropertyEventMethod): New class for better code sharing.
1984         (AbstractPropertyEventMethod.ApplyAttributeBuilder): Add error
1985         CS1667 report.
1986         (PropertyMethod, DelegateMethod): Derived from AbstractPropertyEventMethod
1987
1988 2004-06-11  Raja R Harinath  <rharinath@novell.com>
1989
1990         Fix bug #59477.
1991         * ecore.cs (ResolveFlags): Add new 'Intermediate' flag to tell
1992         that the call to Resolve is part of a MemberAccess.
1993         (Expression.Resolve): Use it for SimpleName resolution.
1994         (SimpleName.SimpleNameResolve, SimpleName.DoResolveAllowStatic):
1995         Add 'intermediate' boolean argument.
1996         (SimpleName.DoSimpleNameResolve): Likewise.  Use it to disable an
1997         error message when the SimpleName can be resolved ambiguously
1998         between an expression and a type.
1999         * expression.cs (MemberAccess.IdenticalNameAndTypeName): Make
2000         public.
2001         (MemberAccess.Resolve): Pass 'Intermediate' flag to the Resolve()
2002         call on the left-side.
2003
2004 2004-06-11  Marek Safar  <marek.safar@seznam.cz>
2005
2006         * class.cs:
2007         (MethodCore.VerifyClsCompliance): Added test for error CS3000.
2008
2009 2004-06-11  Marek Safar  <marek.safar@seznam.cz>
2010
2011         * attribute.cs (Attribute.Emit): Fixed error CS0579 reporting.
2012
2013 2004-06-11  Martin Baulig  <martin@ximian.com>
2014
2015         * expression.cs (Invocation.EmitCall): Use OpCodes.Callvirt for
2016         varargs methods if applicable.
2017
2018 2004-06-11  Martin Baulig  <martin@ximian.com>
2019
2020         * expression.cs (Invocation.EmitCall): Don't use
2021         `method.CallingConvention == CallingConventions.VarArgs' since the
2022         method could also have `CallingConventions.HasThis'.
2023
2024 2004-06-11  Marek Safar  <marek.safar@seznam.cz>
2025
2026         * class.cs (Event.GetSignatureForError): Implemented.
2027         Fixed crash in error test cs3010.cs
2028
2029 2004-06-10  Miguel de Icaza  <miguel@ximian.com>
2030
2031         * cs-tokenizer.cs: Change the way we track __arglist to be
2032         consistent with the other keywords.
2033
2034 2004-06-09  Miguel de Icaza  <miguel@ximian.com>
2035
2036         * codegen.cs: FAQ avoider: turn 1577 into a warning for now until
2037         tomorrow.
2038
2039 2004-06-09  Sebastien Pouliot  <sebastien@ximian.com>
2040
2041         * codegen.cs: Check that all referenced assemblies have a strongname
2042         before strongnaming the compiled assembly. If not report error CS1577.
2043         Fix bug #56563. Patch by Jackson Harper.
2044         * typemanager.cs: Added a method to return all referenced assemblies.
2045         Fix bug #56563. Patch by Jackson Harper.
2046
2047 2004-06-08  Marek Safar  <marek.safar@seznam.cz>
2048
2049         * class.cs:
2050         (Method.ApplyAttributeBuilder): Moved and added conditional
2051         attribute error tests (CS0577, CS0578, CS0243, CS0582, CS0629).
2052
2053         * delegate.cs:
2054         (DelegateCreation.ResolveMethodGroupExpr): Added error CS1618 test.
2055
2056 2004-06-08  Marek Safar  <marek.safar@seznam.cz>
2057
2058         Fixed #59640
2059         * class.cs: (EventField.attribute_targets): Changed default target.
2060
2061 2004-06-08  Martin Baulig  <martin@ximian.com>
2062
2063         * expression.cs (Invocation.EmitCall): Enable varargs methods.
2064
2065 2004-06-08  Martin Baulig  <martin@ximian.com>
2066
2067         * rootcontext.cs (ResolveCore): Added "System.RuntimeArgumentHandle".
2068
2069 2004-06-07  Martin Baulig  <martin@ximian.com>
2070
2071         Added support for varargs methods.
2072
2073         * cs-tokenizer.cs (Token.ARGLIST): New token for the `__arglist'
2074         keyword.
2075
2076         * cs-parser.jay: Added support for `__arglist'.
2077
2078         * decl.cs (MemberCache.AddMethods): Don't ignore varargs methods.
2079
2080         * expression.cs (Argument.AType): Added `ArgList'.
2081         (Invocation): Added support for varargs methods.
2082         (ArglistAccess): New public class.
2083         (Arglist): New public class.
2084
2085         * parameter.cs (Parameter.Modifier): Added `ARGLIST'.
2086
2087         * statement.cs (Block.Flags): Added `HasVarargs'.  We set this on
2088         a method's top-level block if the method has varargs.
2089
2090         * support.cs (ReflectionParameters, InternalParameters): Added
2091         support for varargs methods.    
2092
2093 2004-06-07  Miguel de Icaza  <miguel@ximian.com>
2094
2095         * class.cs: Provide location in indexer error report.
2096
2097         * driver.cs: Use standard names.
2098
2099         * namespace.cs: Catch the use of using after a namespace has been
2100         declared also on using aliases.
2101
2102 2004-06-03  Raja R Harinath  <rharinath@novell.com>
2103
2104         Bug #50820.
2105         * typemanager.cs (closure_private_ok, closure_invocation_type)
2106         (closure_qualifier_type, closure_invocation_assembly)
2107         (FilterWithClosure): Move to ...
2108         (Closure): New internal nested class.
2109         (Closure.CheckValidFamilyAccess): Split out from Closure.Filter.
2110         (MemberLookup, RealMemberLookup): Add new almost_match parameter.
2111         * ecore.cs (almostMatchedMembers): New variable to help report CS1540.
2112         (MemberLookup, MemberLookupFailed): Use it.
2113         * expression.cs (New.DoResolve): Treat the lookup for the
2114         constructor as being qualified by the 'new'ed type.
2115         (Indexers.GetIndexersForTypeOrInterface): Update.
2116
2117 2004-06-03  Marek Safar  <marek.safar@seznam.cz>
2118
2119         * attribute.cs
2120         (GetConditionalAttributeValue): New method. Returns
2121         condition of ConditionalAttribute.
2122         (SearchMulti): New method.  Returns all attributes of type 't'.
2123         Use it when attribute is AllowMultiple = true.
2124         (IsConditionalMethodExcluded): New method.
2125
2126         * class.cs
2127         (Method.IsExcluded): Implemented. Returns true if method has conditional
2128         attribute and the conditions is not defined (method is excluded).
2129         (IMethodData): Extended interface for ConditionalAttribute support.
2130         (PropertyMethod.IsExcluded): Implemented.
2131
2132         * decl.cs
2133         (MemberCore.Flags): Excluded_Undetected, Excluded new caching flags.
2134
2135         * expression.cs
2136         (Invocation.IsMethodExcluded): Checks the ConditionalAttribute
2137         on the method.
2138
2139 2004-06-02 Ben Maurer  <bmaurer@users.sourceforge.net>
2140
2141         * expression.cs (ArrayCreationExpression): Make this just an
2142         `expression'. It can't be a statement, so the code here was
2143         dead.
2144
2145 2004-06-02  Marek Safar  <marek.safar@seznam.cz>
2146
2147         Fixed #59072
2148         * typemanager.cs (GetFullNameSignature): New method for
2149         MethodBase types.
2150
2151 2004-06-02  Marek Safar  <marek.safar@seznam.cz>
2152
2153         Fixed #56452
2154         * class.cs (MemberBase.GetSignatureForError): New virtual method.
2155         Use this method when MethodBuilder is null.
2156         (MethodData.DefineMethodBuilder): Encapsulated code to the new method.
2157         Added test for error CS0626 (MONO reports error for this situation).
2158         (IMethodData.GetSignatureForError): Extended interface.
2159
2160 2004-06-01  Marek Safar  <marek.safar@seznam.cz>
2161
2162         * attribute.cs
2163         (AttributeTester.GetObsoleteAttribute): Returns instance of
2164         ObsoleteAttribute when type is obsolete.
2165
2166         * class.cs
2167         (TypeContainer.VerifyObsoleteAttribute): Override.
2168         (Method.GetSignatureForError): New method for usage when MethodBuilder is null.
2169         (MethodCode.VerifyObsoleteAttribute): Override.
2170         (MemberBase.VerifyObsoleteAttribute): Override.
2171
2172         * decl.cs
2173         (MemberCore.CheckUsageOfObsoleteAttribute): Tests presence of ObsoleteAttribute
2174         and report proper error.
2175
2176         *delegate.cs
2177         Delegate.VerifyObsoleteAttribute): Override.
2178
2179         * ecore.cs
2180         (Expression.CheckObsoleteAttribute): Tests presence of ObsoleteAttribute
2181         and report proper error.
2182         (FieldExpr.DoResolve): Added tests for ObsoleteAttribute.
2183
2184         * enum.cs
2185         (Enum.GetObsoleteAttribute): Returns ObsoleteAttribute for both enum type
2186         and enum member.
2187
2188         * expression.cs
2189         (Probe.DoResolve, Cast.DoResolve, LocalVariableReference.DoResolve,
2190         New.DoResolve, SizeOf.DoResolve, TypeOf.DoResolce, MemberAccess.DoResolve):
2191         Added test for ObsoleteAttribute.
2192
2193         * statement.cs
2194         (Catch): Derived from Statement.
2195
2196 2004-06-01  Marek Safar  <marek.safar@seznam.cz>
2197  
2198         Fixed bug #59071 & cs0160.cs
2199  
2200         * statement.cs (Try.Resolve): Check here whether order of catch
2201         clauses matches their dependencies.
2202
2203 2004-05-31  Miguel de Icaza  <miguel@ximian.com>
2204
2205         * Reverted patch to namespace.cs (Use lookuptypedirect).  This
2206         caused a regression: #59343.  Referencing nested classes from an
2207         assembly stopped working.
2208
2209 2004-05-31  Martin Baulig  <martin@ximian.com>
2210
2211         MCS is now frozen for beta 2.
2212
2213 2004-05-30 Ben Maurer  <bmaurer@users.sourceforge.net>
2214
2215         * convert.cs: add a trivial cache for overload operator resolution.
2216
2217 2004-05-30 Ben Maurer  <bmaurer@users.sourceforge.net>
2218
2219         * decl.cs: If possible, use lookuptypedirect here. We can only do
2220         this if there is no `.' after the namespace. Avoids using
2221         LookupType, which does lots of slow processing.
2222         (FindNestedType) New method, does what it says :-).
2223         * namespace.cs: use LookupTypeDirect.
2224         * rootcontext.cs: use membercache, if possible.
2225         * typemanager.cs (LookupTypeDirect): Cache negative hits too.
2226
2227 2004-05-30 Ben Maurer  <bmaurer@users.sourceforge.net>
2228
2229         * expression.cs:
2230         According to the spec, 
2231
2232         In a member access of the form E.I, if E is a single identifier,
2233         and if the meaning of E as a simple-name (§7.5.2) is a constant,
2234         field, property, localvariable, or parameter with the same type as
2235         the meaning of E as a type-name (§3.8), then both possible
2236         meanings of E are permitted.
2237
2238         We did not check that E as a simple-name had the same type as E as
2239         a type name.
2240
2241         This trivial check gives us 5-7% on bootstrap time.
2242
2243 2004-05-30 Ben Maurer  <bmaurer@users.sourceforge.net>
2244
2245         * expression.cs (Invocation.OverloadResolve): Avoid the
2246         use of hashtables and boxing here by allocating on demand.
2247
2248 2004-05-30  Martin Baulig  <martin@ximian.com>
2249
2250         * rootcontext.cs (RootContext.LookupType): Don't cache things if
2251         we're doing a silent lookup.  Don't try to lookup nested types in
2252         TypeManager.object_type (thanks to Ben Maurer).
2253
2254 2004-05-30  Martin Baulig  <martin@ximian.com>
2255
2256         Committing a patch from Ben Maurer.
2257
2258         * rootcontext.cs (RootContext.LookupType): Cache negative results.
2259
2260 2004-05-29  Martin Baulig  <martin@ximian.com>
2261
2262         * class.cs (IMethodData.ShouldIgnore): New method.
2263
2264         * typemanager.cs (TypeManager.MethodFlags): Don't take a
2265         `Location' argument, we don't need it anywhere.  Use
2266         `IMethodData.ShouldIgnore ()' instead of
2267         `MethodData.GetMethodFlags ()'.
2268         (TypeManager.AddMethod): Removed.
2269         (TypeManager.AddMethod2): Renamed to AddMethod.
2270
2271 2004-05-29  Martin Baulig  <martin@ximian.com>
2272
2273         Committing a patch from Benjamin Jemlich <pcgod@gmx.net>.
2274
2275         * convert.cs (Convert.ImplicitReferenceConversion): If we're
2276         converting from a class type S to an interface type and we already
2277         have an object on the stack, don't box it again.  Fixes #52578.
2278
2279 2004-05-29  Martin Baulig  <martin@ximian.com>
2280
2281         * class.cs (ConstructorInitializer.GetOverloadedConstructor):
2282         Added support for `params' parameters.  Fixes #59267.
2283
2284 2004-05-29  Martin Baulig  <martin@ximian.com>
2285
2286         * literal.cs (NullPointer): Provide a private .ctor which sets
2287         `type' to TypeManager.object_type.  Fixes #59048.
2288
2289 2004-05-29  Martin Baulig  <martin@ximian.com>
2290
2291         * expression.cs (MemberAccess.ResolveMemberAccess): If we're an
2292         EventExpr, set `ee.InstanceExpression = left'.  Fixes #59188.
2293
2294         * ecore.cs (EventExpr.instance_expr): Make the field private.
2295
2296 2004-05-26  Marek Safar  <marek.safar@seznam.cz>
2297
2298         Fixed bug #50080 & cs0214-2.cs
2299         * expression.cs (Cast.DoResolve): Check unsafe context here.
2300         
2301         * statement.cs (Resolve.DoResolve): Likewise.
2302
2303 2004-05-26  Martin Baulig  <martin@ximian.com>
2304
2305         * namespace.cs (NamespaceEntry.Lookup): Added `bool silent'.
2306
2307         * rootcontext.cs (RootContext.NamespaceLookup): Added `bool silent'.
2308         (RootContext.LookupType): Pass down the `silent' flag.
2309
2310 2004-05-25  Martin Baulig  <martin@ximian.com>
2311
2312         * expression.cs
2313         (MethodGroupExpr.IdenticalTypeName): New public property.
2314         (Invocation.DoResolve): Don't report a CS0176 if the "instance"
2315         expression actually refers to a type.
2316
2317 2004-05-25  Martin Baulig  <martin@ximian.com>
2318
2319         * expression.cs (Invocation.DoResolve): Applied Ben Maurer's patch
2320         for #56176 and made it actually work.
2321
2322 2004-05-25  Martin Baulig  <martin@ximian.com>
2323
2324         * ecore.cs (Expression.CacheTemporaries): Make this virtual.
2325         (FieldExpr, PropertyExpr): Override and implement
2326         CacheTemporaries.  Fixes #52279.
2327
2328 2004-05-25  Miguel de Icaza  <miguel@ximian.com>
2329
2330         * location.cs: In the new compiler listing a file twice is a
2331         warning, not an error.
2332
2333 2004-05-24  Martin Baulig  <martin@ximian.com>
2334
2335         * enum.cs (Enum.DefineType): For the `BaseType' to be a
2336         TypeLookupExpression; otherwise, report a CS1008.  Fixes #58571.
2337
2338 2004-05-24  Martin Baulig  <martin@ximian.com>
2339
2340         * decl.cs (DeclSpace.FindType): Try doing an alias lookup before
2341         walking the `using' list.  Fixes #53921.
2342
2343 2004-05-24  Martin Baulig  <martin@ximian.com>
2344
2345         * const.cs (Const.LookupConstantValue): Added support for
2346         EmptyCast's; fixes #55251.
2347
2348 2004-05-24  Martin Baulig  <martin@ximian.com>
2349
2350         * ecore.cs (SimpleName.SimpleNameResolve): Renamed to
2351         DoSimpleNameResolve() and provide a SimpleNameResolve() wrapper
2352         which does the CS0135 check.  The reason is that we first need to
2353         check whether the variable actually exists.
2354
2355 2004-05-24  Martin Baulig  <martin@ximian.com>
2356
2357         * class.cs (MemberBase.DoDefine): Use DeclSpace.FindType() rather
2358         than RootContext.LookupType() to find the explicit interface
2359         type.  Fixes #58584.
2360
2361 2004-05-24  Raja R Harinath  <rharinath@novell.com>
2362
2363         * Makefile: Simplify.  Use executable.make.
2364         * mcs.exe.sources: New file.  List of sources of mcs.exe.
2365
2366 2004-05-24  Anders Carlsson  <andersca@gnome.org>
2367
2368         * decl.cs:
2369         * enum.cs:
2370         Use the invariant culture when doing String.Compare for CLS case
2371         sensitivity.
2372         
2373 2004-05-23  Martin Baulig  <martin@ximian.com>
2374
2375         * decl.cs (DeclSpace.FindType): Only check the `using' list if we
2376         don't have any dots.  Fixes #52622, added cs0246-8.cs.
2377
2378         * namespace.cs (NamespaceEntry.Lookup): Likewise.
2379         
2380 2004-05-23  Marek Safar  <marek.safar@seznam.cz>
2381
2382         * class.cs (MemberBase.Define): Reuse MemberType member for 
2383         resolved type. Other methods can use it too.
2384
2385 2004-05-23  Martin Baulig  <martin@ximian.com>
2386
2387         * ecore.cs (SimpleName.SimpleNameResolve): Only report a CS0135 if
2388         the variable also exists in the current block (otherwise, we need
2389         to report a CS0103).  Fixes #58670.
2390
2391 2004-05-23  Martin Baulig  <martin@ximian.com>
2392
2393         * flowanalysis.cs (Reachability.Reachable): Compute this
2394         on-the-fly rather than storing it as a field.
2395
2396 2004-05-23  Martin Baulig  <martin@ximian.com>
2397
2398         * flowanalysis.cs (Reachability.And): Manually compute the
2399         resulting `barrier' from the reachability.      
2400        
2401 2004-05-23  Marek Safar  <marek.safar@seznam.cz>
2402
2403         Fix bug #57835
2404         * attribute.cs (AttributeTester.GetMethodObsoleteAttribute): Returns
2405         instance of ObsoleteAttribute when symbol is obsolete.
2406
2407         * class.cs
2408         (IMethodData): Extended interface for ObsoleteAttribute support.
2409
2410 2004-05-22  Marek Safar  <marek.safar@seznam.cz>
2411
2412         * attribute.cs: Fix bug #55970
2413
2414 2004-05-22  Marek Safar  <marek.safar@seznam.cz>
2415
2416         Fix bug #52705
2417         * attribute.cs
2418         (GetObsoleteAttribute): New method. Creates the instance of
2419         ObsoleteAttribute.
2420         (AttributeTester.GetMemberObsoleteAttribute): Returns instance of
2421         ObsoleteAttribute when member is obsolete.
2422         (AttributeTester.Report_ObsoleteMessage): Common method for
2423         Obsolete error/warning reporting.
2424
2425         * class.cs
2426         (TypeContainer.base_classs_type): New member for storing parent type.
2427
2428         * decl.cs
2429         (MemberCore.GetObsoleteAttribute): Returns instance of ObsoleteAttribute
2430         for this MemberCore.
2431
2432 2004-05-21  Marek Safar  <marek.safar@seznam.cz>
2433
2434         * attribute.cs, const.cs: Fix bug #58590
2435
2436 2004-05-21  Martin Baulig  <martin@ximian.com>
2437
2438         * flowanalysis.cs (FlowBranching.MergeTopBlock): Don't check for
2439         out parameters if the end of the method is unreachable.  Fixes
2440         #58098. 
2441
2442 2004-05-21  Marek Safar  <marek.safar@seznam.cz>
2443
2444         * codegen.cs, cs-parser.jay: Removed SetAttributes method.
2445         Hari was right, why extra method.
2446
2447 2004-05-21  Marek Safar  <marek.safar@seznam.cz>
2448
2449         * attribute.cs, cs-parser.jay: Fix errors/cs0579-7.cs.
2450
2451 2004-05-20  Martin Baulig  <martin@ximian.com>
2452
2453         Merged this back from gmcs to keep the differences to a minumum.
2454
2455         * attribute.cs (Attribute.CheckAttributeType): Take an EmitContext
2456         instead of a Declspace.
2457         (Attribute.ResolveType): Likewise.
2458         (Attributes.Search): Likewise.
2459         (Attributes.Contains): Likewise.
2460         (Attributes.GetClsCompliantAttribute): Likewise.
2461
2462         * class.cs (TypeContainer.VerifyMembers): Added EmitContext
2463         argument.
2464         (MethodData.ApplyAttributes): Take an EmitContext instead of a
2465         DeclSpace.
2466
2467 2004-05-19  Marek Safar  <marek.safar@seznam.cz>
2468
2469         Fix bug #58688 (MCS does not report error when the same attribute
2470         is assigned twice)
2471
2472         * attribute.cs (Attribute.Emit): Distinction between null and default.
2473
2474 2004-05-19  Raja R Harinath  <rharinath@novell.com>
2475
2476         * cs-parser.jay (attribute): Create a GlobalAttribute for the case
2477         of a top-level attribute without an attribute target.
2478         * attribute.cs (Attribute.Error_AttributeConstructorMismatch): 
2479         Make non-static.
2480         (Attribute.Conditional_GetConditionName), 
2481         (Attribute.Obsolete_GetObsoleteMessage): Update.
2482         (Attribute.IndexerName_GetIndexerName): New.  Attribute-specific
2483         part of ScanForIndexerName.
2484         (Attribute.CanIgnoreInvalidAttribute): New function.
2485         (Attribute.ScanForIndexerName): Move to ...
2486         (Attributes.ScanForIndexerName): ... here.
2487         (Attributes.Attrs): Rename from now-misnamed AttributeSections.
2488         (Attributes.Search): New internal variant that can choose not to
2489         complain if types aren't resolved.  The original signature now
2490         complains.
2491         (Attributes.GetClsCompliantAttribute): Use internal variant, with
2492         complaints suppressed.
2493         (GlobalAttribute.CheckAttributeType): Overwrite ds.NamespaceEntry
2494         only if it not useful.
2495         (CanIgnoreInvalidAttribute): Ignore assembly attribute errors at
2496         top-level for attributes that are shared between the assembly
2497         and a top-level class.
2498         * parameter.cs (ImplicitParameter): Rename from ParameterAtribute.
2499         * class.cs: Update to reflect changes.
2500         (DefineIndexers): Fuse loops.
2501         * codegen.cs (GetAssemblyName): Update to reflect changes.  Accept
2502         a couple more variants of attribute names.
2503
2504 2004-05-18  Marek Safar  <marek.safar@seznam.cz>
2505
2506         Fix bug #52585 (Implemented explicit attribute declaration)
2507
2508         * attribute.cs:
2509         (Attributable.ValidAttributeTargets): New abstract method. It gets
2510         list of valid attribute targets for explicit target declaration.
2511         (Attribute.Target): It holds target itself.
2512         (AttributeSection): Removed.
2513         (Attribute.CheckTargets): New method. It checks whether attribute
2514         target is valid for the current element.
2515
2516         * class.cs:
2517         (EventProperty): New class. For events that are declared like
2518         property (with add and remove accessors).
2519         (EventField): New class. For events that are declared like field.
2520         class.cs
2521
2522         * cs-parser.jay: Implemented explicit attribute target declaration.
2523
2524         * class.cs, decl.cs, delegate.cs, enum.cs, parameter.cs:        
2525         Override ValidAttributeTargets.
2526
2527         * parameter.cs:
2528         (ReturnParameter): Class for applying custom attributes on 
2529         the return type.
2530         (ParameterAtribute): New class. Class for applying custom
2531         attributes on the parameter type.
2532
2533 2004-05-17  Miguel de Icaza  <miguel@ximian.com>
2534
2535         * class.cs (MemberBase.DoDefine): Pass UNSAFE on interface
2536         definitions. 
2537
2538         (Method): Allow UNSAFE here.
2539
2540         * modifiers.cs: Support unsafe reporting.
2541
2542 2004-05-17  Marek Safar  <marek.safar@seznam.cz>
2543
2544         * decl.cs: Fix bug #58478.
2545
2546 2004-05-17  Gonzalo Paniagua Javier <gonzalo@ximian.com>
2547
2548         * statement.cs: When checking for unreachable code on an EmptyStatement,
2549         set the location. Fixes bug #58488.
2550
2551 2004-05-13  Miguel de Icaza  <miguel@ximian.com>
2552
2553         * driver.cs: Add -pkg handling.
2554
2555         From Gonzalo: UseShelLExecute=false
2556
2557 2004-05-12  Marek Safar  <marek.safar@seznam.cz>
2558
2559         * attribute.cs:
2560         (Attribute.GetAttributeTargets): New method. Gets AttributeTargets
2561         for attribute.
2562         (Attribute.IsClsCompliaceRequired): Moved to base for better
2563         accesibility.
2564         (Attribute.UsageAttribute): New property for AttributeUsageAttribute
2565         when attribute is AttributeUsageAttribute.
2566         (Attribute.GetValidTargets): Simplified.
2567         (Attribute.GetAttributeUsage): New method returns AttributeUsage
2568         attribute for this type.
2569         (Attribute.ApplyAttributes): Method renamed to Emit and make
2570         non-static.
2571         (GlobalAttributeSection): New class for special handling of global
2572         attributes (assembly, module).
2573         (AttributeSection.Emit): New method.
2574
2575         * class.cs: Implemented Attributable abstract methods.
2576         (MethodCore.LabelParameters): Moved to Parameter class.
2577         (Accessor): Is back simple class.
2578         (PropertyMethod): Implemented Attributable abstract class.
2579         (DelegateMethod): Implemented Attributable abstract class.
2580         (Event): New constructor for disctintion between normal Event
2581         and Event with accessors.
2582
2583         * cs-parser.jay: Used new Event ctor and GlobalAttributeSection.
2584
2585         * codegen.cs, const.cs, decl.cs, delegate.cs:
2586         (CommonAssemblyModulClass): Implemented Attributable abstract class
2587         and simplified.
2588
2589         * enum.cs: Implement IAttributeSupport interface.
2590         (EnumMember): New class for emum members. Implemented Attributable
2591         abstract class
2592
2593         * parameter.cs:
2594         (ParameterBase): Is abstract.
2595         (ReturnParameter): New class for easier [return:] attribute handling.
2596
2597         * typemanager.cs: Removed builder_to_attr.
2598
2599 2004-05-11  Raja R Harinath  <rharinath@novell.com>
2600
2601         Fix bug #57151.
2602         * attribute.cs (Attribute.GetPositionalValue): New function.
2603         * class.cs (TypeContainer.VerifyMembers): New function.
2604         (TypeContainer.Emit): Use it.
2605         (ClassOrStruct): New base class for Class and Struct.
2606         (ClassOrStruct.ApplyAttributeBuilder): New function.  Note if 
2607         StructLayout(LayoutKind.Explicit) was ascribed to the struct or
2608         class.
2609         (ClassOrStruct.VerifyMembers): If the struct is explicitly laid out,
2610         then each non-static field should have a FieldOffset attribute.
2611         Otherwise, none of the fields should have a FieldOffset attribute.
2612         * rootcontext.cs (RootContext.ResolveCore): Resolve StructLayout 
2613         and FieldOffset attributes.
2614         * typemanager.cs (TypeManager.struct_layout_attribute_type)
2615         (TypeManager.field_offset_attribute_type): New core types.
2616         (TypeManager.InitCoreTypes): Initialize them.
2617
2618 2004-05-11  Michal Moskal  <malekith@pld-linux.org>
2619
2620         * class.cs (Event.RemoveDelegateMethod.DelegateMethodInfo):
2621         Return correct type.
2622         From bug #58270.
2623
2624 2004-05-09  Miguel de Icaza  <miguel@ximian.com>
2625
2626         * expression.cs (Binary.DoNumericPromotions): 0 long constant can
2627         be implicitly converted to ulong.
2628         
2629         * expression.cs: The logic for allowing operator &, | and ^ worked
2630         was wrong, it worked before because we did not report an error in
2631         an else branch.  Fixes 57895.
2632
2633         * class.cs: Applied patch from iain@mccoy.id.au Iain McCoy to
2634         allow volatile fields to be reference types.
2635
2636 2004-05-07  Miguel de Icaza  <miguel@ximian.com>
2637
2638         * driver.cs: Add support for /debug-
2639
2640 2004-05-07  Raja R Harinath  <rharinath@novell.com>
2641
2642         * attribute.cs (Attribute.CheckAttributeType, Attribute.ResolveType): 
2643         Add a 'complain' parameter to silence errors.
2644         (Attribute.Resolve): Update to changes.  Put in sanity check to catch
2645         silently overlooked type-resolutions.
2646         (Attribute.ScanForIndexerName, Attribute.DefinePInvokeMethod): Update
2647         to reflect changes.
2648         (Attributes.Search): New function.
2649         (Attributes.Contains, Attributes.GetClsCompliantAttribute): Use Search.
2650         (Attributes.GetAttributeFullName): Remove hack.
2651         * class.cs (MethodCore.LabelParameters, MethodData.ApplyAttributes): 
2652         Update to reflect changes.
2653         * codegen.cs (CommonAssemblyModulClass.GetClsCompliantAttribute):
2654         Use Attributes.Search instead of nested loops.
2655
2656 2004-05-07  Marek Safar  <marek.safar@seznam.cz>
2657
2658         * decl.cs:
2659         (MemberCore.Flags): Extended for caching presence of CLSCompliantAttribute.
2660         (MemberCore.VerifyClsCompliance): Implemented CS3019 error report.
2661         (DeclSpace.GetClsCompliantAttributeValue): Returns simple bool.
2662
2663         * report.cs: (Report.Warning): Renamed to Warning_T because of
2664         parameter collision.
2665
2666 2004-05-05  Raja R Harinath  <rharinath@novell.com>
2667
2668         * expression.cs (MemberAccess.ResolveMemberAccess):
2669         Exit with non-zero status after Report.Error.
2670         * rootcontext.cs (RootContext.BootstrapCorlib_ResolveDelegate):
2671         Likewise.
2672         * typemanager.cs (TypeManager.CoreLookupType): Likewise.
2673
2674 2004-05-04  Lluis Sanchez Gual  <lluis@ximian.com>
2675
2676         * support.cs: Don't hang when the file is empty.
2677
2678 2004-05-04  Lluis Sanchez Gual  <lluis@ximian.com>
2679
2680         * support.cs: In SeekableStreamReader, compute the preamble size of the
2681           underlying stream. Position changes should take into account that initial
2682           count of bytes.
2683
2684 2004-05-03  Todd Berman  <tberman@sevenl.net>
2685
2686         * driver.cs: remove unused GetSysVersion function.
2687
2688 2004-05-03  Todd Berman  <tberman@sevenl.net>
2689
2690         * driver.cs: Remove the hack from saturday, as well as the hack
2691         from jackson (LoadAssemblyFromGac), also adds the CWD to the
2692         link_paths to get that bit proper.
2693
2694 2004-05-01  Todd Berman  <tberman@sevenl.net>
2695
2696         * driver.cs: Try a LoadFrom before a Load, this checks the current
2697         path. This is currently a bug in mono that is be fixed, however, this
2698         provides a workaround for now. This will be removed when the bug
2699         is fixed.
2700
2701 2004-05-01  Sebastien Pouliot  <sebastien@ximian.com>
2702
2703         * CryptoConvert.cs: Updated to latest version. Fix issue with 
2704         incomplete key pairs (#57941).
2705
2706 2004-05-01  Todd Berman  <tberman@sevenl.net>
2707
2708         * driver.cs: Remove '.' from path_chars, now System.* loads properly
2709         from the GAC
2710
2711 2004-04-30  Jackson Harper  <jackson@ximian.com>
2712
2713         * codegen.cs: Open keys readonly.
2714         
2715 2004-04-30  Gonzalo Paniagua Javier <gonzalo@ximian.com>
2716
2717         * typemanager.cs: don't report cyclic struct layout when a struct
2718         contains 2 or more fields of the same type. Failed for Pango.AttrShape
2719         which has 2 Pango.Rectangle fields.
2720
2721 2004-04-29 Ben Maurer  <bmaurer@users.sourceforge.net>
2722
2723         * expression.cs: Handle IntPtr comparisons with IL code
2724         rather than a method call.
2725
2726 2004-04-29  Martin Baulig  <martin@ximian.com>
2727
2728         * ecore.cs (PropertyExpr.FindAccessor): New private method.  Walk
2729         the list of PropertyInfo's in class hierarchy and find the
2730         accessor.  Fixes #56013.
2731
2732 2004-04-29  Martin Baulig  <martin@ximian.com>
2733
2734         * typemanager.cs (TypeManager.CheckStructCycles): Fixed.
2735
2736 2004-04-29  Martin Baulig  <martin@ximian.com>
2737
2738         Applying a patch from Benjamin Jemlich <pcgod@gmx.net>.
2739
2740         * ecore.cs (FieldExpr.AddressOf): Make this work for valuetypes.
2741
2742 2004-04-29  Martin Baulig  <martin@ximian.com>
2743
2744         * class.cs (ConstructorInitializer.Resolve): Check whether the
2745         parent .ctor is accessible.  Fixes #52146.
2746
2747 2004-04-29  Martin Baulig  <martin@ximian.com>
2748
2749         Applying a patch from Benjamin Jemlich <pcgod@gmx.net>.
2750
2751         * statement.cs (Using.EmitLocalVariableDecls): Use
2752         TypeManager.idisposable_type, not typeof (IDisposable).
2753         (Foreach.EmitCollectionForeach): Added support for valuetypes.
2754
2755 2004-04-29  Martin Baulig  <martin@ximian.com>
2756
2757         * class.cs (Event.Define): Don't emit the field and don't set
2758         RTSpecialName and SpecialName for events on interfaces.  Fixes
2759         #57703. 
2760
2761 2004-04-29  Raja R Harinath  <rharinath@novell.com>
2762
2763         Refactor Attribute.ApplyAttributes.
2764         * attribute.cs (Attributable): New base class for objects that can
2765         have Attributes applied on them.
2766         (Attribute): Make AttributeUsage fields public.
2767         (Attribute.GetFieldValue, Attribute.GetMarshal): Make non-static.
2768         (Attribute.IsInternalCall): New property.
2769         (Attribute.UsageAttr): Convert to a public read-only property.
2770         (Attribute.CheckAttributeType): Use a DeclSpace, not an EmitContext.
2771         (Attribute.ResolveType, Attribute.Resolve)
2772         (Attribute.ScanForIndexerName): Update to reflect changes.
2773         (Attribute.CheckAttributeTarget): Re-format.
2774         (Attribute.ApplyAttributes): Refactor, to various
2775         Attributable.ApplyAttributeBuilder methods.
2776         * decl.cs (MemberCore): Make Attributable.
2777         * class.cs (Accessor): Make Attributable.
2778         (MethodData.ApplyAttributes): Use proper attribute types, not
2779         attribute names.
2780         (TypeContainer.LabelParameters): Pass Parameter to ApplyAttributes.
2781         (TypeContainer.ApplyAttributeBuilder)
2782         (Method.ApplyAttributeBuilder, Constructor.ApplyAttributeBuilder)
2783         (Field.ApplyAttributeBuilder, Accessor.ApplyAttributeBuilder)   
2784         (PropertyBase.ApplyAttributeBuilder, Event.ApplyAttributeBuilder)
2785         (Operator.ApplyAttributeBuilder): New factored-out methods.
2786         * const.cs (Const.ApplyAttributeBuilder): Likewise.
2787         * delegate.cs (Delegate.ApplyAttributeBuilder): Likewise.
2788         * enum.cs (Enum.ApplyAttributeBuilder): Likewise.
2789         * parameter.cs (ParameterBase): New Attributable base class
2790         that can also represent Return types.
2791         (Parameter): Update to the changes.
2792
2793 2004-04-29  Jackson Harper  <jackson@ximian.com>
2794
2795         * driver.cs: Prefer the corlib system version when looking for
2796         assemblies in the GAC. This is still a hack, but its a better hack
2797         now.
2798         
2799 2004-04-29  Marek Safar  <marek.safar@seznam.cz>
2800
2801         * decl.cs, enum.cs: Improved error 3005 reporting.
2802   
2803         * report.cs (SymbolRelatedToPreviousError): New method for error reporting.
2804         (related_symbols): New private member for list of symbols
2805         related to reported error/warning.
2806         
2807         * tree.cs: Do not use now obsolete Report.LocationOfPreviousError.
2808
2809 2004-04-29  Martin Baulig  <martin@ximian.com>
2810
2811         * ecore.cs (Expression.Constantify): If we're an enum and
2812         TypeManager.TypeToCoreType() doesn't give us another type, use
2813         t.UnderlyingSystemType.  Fixes #56178.  
2814
2815 2004-04-29  Martin Baulig  <martin@ximian.com>
2816
2817         * decl.cs (MemberCache.SetupCacheForInterface): Look over all our
2818         interfaces and for each interface, only add members directly
2819         declared in that interface.  Fixes #53255.
2820
2821 2004-04-28  Martin Baulig  <martin@ximian.com>
2822
2823         * expression.cs (ConditionalLogicalOperator): Use a temporary
2824         variable for `left' to avoid that we evaluate it more than once;
2825         bug #52588.
2826
2827 2004-04-28  Martin Baulig  <martin@ximian.com>
2828
2829         * expression.cs (ComposedCast.DoResolveAsTypeStep): Don't allow
2830         `void[]' (CS1547).
2831
2832 2004-04-28  Martin Baulig  <martin@ximian.com>
2833
2834         * statement.cs (LocalInfo.Resolve): Check whether the type is not
2835         void (CS1547).
2836
2837         * class.cs (MemberBase.CheckParameters, FieldBase.DoDefine): Check
2838         whether the type is not void (CS1547).
2839
2840 2004-04-28  Martin Baulig  <martin@ximian.com>
2841
2842         * expression.cs (Unary.DoResolveLValue): Override this and report
2843         CS0131 for anything but Operator.Indirection.
2844
2845 2004-04-28  Martin Baulig  <martin@ximian.com>
2846
2847         Committing a patch from Ben Maurer; see bug #50820.
2848
2849         * typemanager.cs (TypeManager.FilterWithClosure): Added CS1540
2850         check for classes.
2851
2852         * ecore.cs (Expression.MemberLookupFailed): Added CS1540 check for
2853         classes.        
2854
2855 2004-04-28  Martin Baulig  <martin@ximian.com>
2856
2857         Committing a patch from Ben Maurer; see bug #50820.
2858
2859         * typemanager.cs (TypeManager.FilterWithClosure): Added CS1540
2860         check for classes.
2861
2862         * ecore.cs (Expression.MemberLookupFailed): Added CS1540 check for
2863         classes.        
2864
2865 2004-04-28  Martin Baulig  <martin@ximian.com>
2866
2867         * statement.cs (Block.LookupLabel): Also lookup in implicit child blocks.
2868         (Block.AddLabel): Call DoLookupLabel() to only search in the
2869         current block.
2870
2871 2004-04-28  Martin Baulig  <martin@ximian.com>
2872
2873         * cfold.cs (ConstantFold.BinaryFold): Added special support for
2874         comparing StringConstants and NullLiterals in Equality and Inequality.
2875
2876 2004-04-28  Jackson Harper  <jackson@ximian.com>
2877
2878         * driver.cs: Attempt to load referenced assemblies from the
2879         GAC. This is the quick and dirty version of this method that
2880         doesnt take into account versions and just takes the first
2881         canidate found. Will be good enough for now as we will not have more
2882         then one version installed into the GAC until I update this method.
2883
2884 2004-04-28  Martin Baulig  <martin@ximian.com>
2885
2886         * typemanager.cs (TypeManager.CheckStructCycles): New public
2887         static method to check for cycles in the struct layout.
2888
2889         * rootcontext.cs (RootContext.PopulateTypes): Call
2890         TypeManager.CheckStructCycles() for each TypeContainer.
2891         [Note: We only need to visit each type once.]
2892
2893 2004-04-28  Martin Baulig  <martin@ximian.com>
2894
2895         * constant.cs (StringConstant.Emit): Emit Ldnull if we're null.
2896
2897         * const.cs (Const.LookupConstantValue): Return a `bool' signalling
2898         success and added `out object value'.  Use a `bool resolved' field
2899         to check whether we've already been called rather than
2900         `ConstantValue != null' since this breaks for NullLiterals.
2901
2902 2004-04-28  Raja R Harinath  <rharinath@novell.com>
2903
2904         * driver.cs (Driver.MainDriver) [IsModuleOnly]: Open code the
2905         setting of this flag, since the 'set' method may be non-public.
2906
2907 2004-04-28  Raja R Harinath  <rharinath@novell.com>
2908
2909         * flowanalysis.cs (FlowBranchingException.LookupLabel): Add a null
2910         check on current_vector.Block.
2911
2912 2004-04-27  Martin Baulig  <martin@ximian.com>
2913
2914         * expression.cs (BaseAccess.CommonResolve): Don't allow `base' in
2915         a field initializer.  Fixes #56459.
2916
2917 2004-04-27  Martin Baulig  <martin@ximian.com>
2918
2919         * ecore.cs (PropertyExpr.DoResolve/DoResolveLValue): Check whether
2920         we're not attempting to use an indexer.  Fixes #52154.
2921
2922 2004-04-27  Martin Baulig  <martin@ximian.com>
2923
2924         * statement.cs (Return): Don't create a return label if we don't
2925         need it; reverts my change from January 20th.  Thanks to Ben
2926         Maurer for this.
2927
2928 2004-04-27  Martin Baulig  <martin@ximian.com>
2929
2930         According to the spec, `goto' can only leave a nested scope, but
2931         never enter it.
2932
2933         * statement.cs (Block.LookupLabel): Only lookup in the current
2934         block, don't recurse into parent or child blocks.
2935         (Block.AddLabel): Check in parent and child blocks, report
2936         CS0140/CS0158 if we find a duplicate.
2937         (Block): Removed this indexer for label lookups.
2938         (Goto.Resolve): Call LookupLabel() on our current FlowBranching;
2939         this already does the error reporting for us.
2940
2941         * flowanalysis.cs
2942         (FlowBranching.UsageVector.Block): New public variable; may be null.
2943         (FlowBranching.CreateSibling): Added `Block' argument.
2944         (FlowBranching.LookupLabel): New public virtual method.  Lookup a
2945         label for the target of a `goto' and check whether we're not
2946         leaving a `finally'.
2947
2948 2004-04-27  Martin Baulig  <martin@ximian.com>
2949
2950         * flowanalysis.cs (FlowBranching.UsageVector.MergeChild): If we're
2951         a finite loop block, also do the ALWAYS->SOMETIMES for throws (not
2952         just for returns).
2953
2954 2004-04-27  Martin Baulig  <martin@ximian.com>
2955
2956         * statement.cs (Block.AddLabel): Also check for implicit blocks
2957         and added a CS0158 check.
2958
2959 2004-04-27  Martin Baulig  <martin@ximian.com>
2960
2961         * flowanalysis.cs (FlowBranchingLoop): New class.
2962         (FlowBranching.UsageVector.MergeJumpOrigins): Take a list of
2963         UsageVector's instead of an ArrayList.
2964         (FlowBranching.Label): Likewise.
2965         (FlowBranching.UsageVector.MergeBreakOrigins): New method.
2966         (FlowBranching.AddBreakVector): New method.
2967
2968 2004-04-27  Miguel de Icaza  <miguel@ximian.com>
2969
2970         * attribute.cs: Small regression fix: only convert the type if we
2971         the type is different, fixes System.Drawing build.
2972
2973 2004-04-27  Martin Baulig  <martin@ximian.com>
2974
2975         * attribute.cs (Attribute.Resolve): If we have a constant value
2976         for a named field or property, implicity convert it to the correct
2977         type.
2978
2979 2004-04-27  Raja R Harinath  <rharinath@novell.com>
2980
2981         * statement.cs (Block.Block): Implicit blocks share
2982         'child_variable_names' fields with parent blocks.
2983         (Block.AddChildVariableNames): Remove.
2984         (Block.AddVariable): Mark variable as "used by a child block" in
2985         every surrounding block.
2986         * ecore.cs (SimpleName.SimpleNameResolve): If the name has already
2987         been used in a child block, complain about violation of "Invariant
2988         meaning in blocks" rule.
2989         * cs-parser.jay (declare_local_variables): Don't use
2990         AddChildVariableNames.
2991         (foreach_statement): Don't create an implicit block: 'foreach'
2992         introduces a scope.
2993
2994 2004-04-23  Miguel de Icaza  <miguel@ximian.com>
2995
2996         * convert.cs (ImplicitNumericConversion): 0 is also positive when
2997         converting from 0L to ulong.  Fixes 57522.
2998
2999 2004-04-22  Marek Safar  <marek.safar@seznam.cz>
3000
3001         * decl.cs (FindMemberToOverride): Fix wrong warning for case when
3002         derived class hides via 'new' keyword field from base class (test-242.cs).
3003         TODO: Handle this in the more general way.
3004         
3005         * class.cs (CheckBase): Ditto.
3006
3007 2004-04-22  Marek Safar  <marek.safar@seznam.cz>
3008
3009         * decl.cs (caching_flags): New member for storing cached values
3010         as bit flags.
3011         (MemberCore.Flags): New enum where bit flags for caching_flags
3012         are defined.
3013         (MemberCore.cls_compliance): Moved to caching_flags.
3014         (DeclSpace.Created): Moved to caching_flags.
3015
3016         * class.cs: Use caching_flags instead of DeclSpace.Created
3017         
3018 2004-04-21  Miguel de Icaza  <miguel@ximian.com>
3019
3020         * ecore.cs (PropertyExpr.GetAccesor): Only perform the 1540 check
3021         if we are only a derived class, not a nested class.
3022
3023         * typemanager.cs: Same as above, but do this at the MemberLookup
3024         level (used by field and methods, properties are handled in
3025         PropertyExpr).   Allow for the qualified access if we are a nested
3026         method. 
3027
3028 2004-04-21  Marek Safar  <marek.safar@seznam.cz>
3029
3030         * class.cs: Refactoring.
3031         (IMethodData): New inteface; Holds links to parent members
3032         to avoid member duplication (reduced memory allocation).
3033         (Method): Implemented IMethodData interface.
3034         (PropertyBase): New inner classes for get/set methods.
3035         (PropertyBase.PropertyMethod): Implemented IMethodData interface
3036         (Event): New inner classes for add/remove methods.
3037         (Event.DelegateMethod): Implemented IMethodData interface.
3038
3039         * cs-parser.jay: Pass DeclSpace to Event class for creation of valid
3040         EmitContext (related to class.cs refactoring).
3041
3042 2004-04-21  Raja R Harinath  <rharinath@novell.com>
3043
3044         * delegate.cs (Delegate.VerifyApplicability): If the number of
3045         arguments are the same as the number of parameters, first try to
3046         verify applicability ignoring  any 'params' modifier on the last
3047         parameter.
3048         Fixes #56442.
3049
3050 2004-04-16  Raja R Harinath  <rharinath@novell.com>
3051
3052         * class.cs (TypeContainer.AddIndexer): Use
3053         'ExplicitInterfaceName' to determine if interface name was
3054         explicitly specified.  'InterfaceType' is not initialized at this time.
3055         (TypeContainer.DefineIndexers): Remove use of temporary list.  The
3056         Indexers array is already in the required order.  Initialize
3057         'IndexerName' only if there are normal indexers.
3058         (TypeContainer.DoDefineMembers): Don't initialize IndexerName.
3059         (TypeContainer.Emit): Emit DefaultMember attribute only if
3060         IndexerName is initialized.
3061         Fixes #56300.
3062
3063 2004-04-15  Benjamin Jemlich  <pcgod@gmx.net>
3064
3065         * enum.cs (Enum.DefineType): Don't allow char as type for enum.
3066         Fixes #57007
3067
3068 2004-04-15  Raja R Harinath  <rharinath@novell.com>
3069
3070         * attribute.cs (Attribute.CheckAttributeType): Check for ambiguous
3071         attributes.
3072         Fix for #56456.
3073
3074         * attribute.cs (Attribute.Resolve): Check for duplicate named
3075         attributes.
3076         Fix for #56463.
3077
3078 2004-04-15  Miguel de Icaza  <miguel@ximian.com>
3079
3080         * iterators.cs (MarkYield): track whether we are in an exception,
3081         and generate code accordingly.  Use a temporary value to store the
3082         result for our state.
3083
3084         I had ignored a bit the interaction of try/catch with iterators
3085         since their behavior was not entirely obvious, but now it is
3086         possible to verify that our behavior is the same as MS .NET 2.0
3087
3088         Fixes 54814
3089
3090 2004-04-14  Miguel de Icaza  <miguel@ximian.com>
3091
3092         * iterators.cs: Avoid creating temporaries if there is no work to
3093         do. 
3094
3095         * expression.cs (ArrayAccess.EmitLoadOpcode): If dealing with
3096         Enumerations, use TypeManager.EnumToUnderlying and call
3097         recursively. 
3098
3099         Based on the patch from Benjamin Jemlich (pcgod@gmx.net), fixes
3100         bug #57013
3101
3102         (This.Emit): Use EmitContext.EmitThis to emit our
3103         instance variable.
3104
3105         (This.EmitAssign): Ditto.
3106
3107         * ecore.cs (FieldExpr.Emit): Remove RemapToProxy special
3108         codepaths, we will move all the functionality into
3109         Mono.CSharp.This 
3110
3111         (FieldExpr.EmitAssign): Ditto.
3112
3113         This fixes several hidden bugs that I uncovered while doing a code
3114         review of this today.
3115
3116         * codegen.cs (EmitThis): reworked so the semantics are more clear
3117         and also support value types "this" instances.
3118
3119         * iterators.cs: Changed so that for iterators in value types, we
3120         do not pass the value type as a parameter.  
3121
3122         Initialization of the enumerator helpers is now done in the caller
3123         instead of passing the parameters to the constructors and having
3124         the constructor set the fields.
3125
3126         The fields have now `assembly' visibility instead of private.
3127
3128 2004-04-11  Miguel de Icaza  <miguel@ximian.com>
3129
3130         * expression.cs (Argument.Resolve): Check if fields passed as ref
3131         or out are contained in a MarshalByRefObject.
3132
3133         * typemanager.cs, rootcontext.cs: Add System.Marshalbyrefobject as
3134         another compiler type.
3135
3136 2004-04-06 Ben Maurer  <bmaurer@users.sourceforge.net>
3137
3138         * class.cs (Indexer.Define): use the new name checking method.
3139         Also, return false on an error.
3140         * cs-tokenizer.cs (IsValidIdentifier): Checks for a valid identifier.
3141         (is_identifier_[start/part]_character): make static.
3142
3143 2004-04-10  Miguel de Icaza  <miguel@ximian.com>
3144
3145         * expression.cs (Binary.ResolveOperator): Do no append strings
3146         twice: since we can be invoked more than once (array evaluation)
3147         on the same concatenation, take care of this here.  Based on a fix
3148         from Ben (bug #56454)
3149
3150 2004-04-08  Sebastien Pouliot  <sebastien@ximian.com>
3151
3152         * codegen.cs: Fix another case where CS1548 must be reported (when 
3153         delay-sign isn't specified and no private is available #56564). Fix
3154         loading the ECMA "key" to delay-sign an assembly. Report a CS1548 
3155         error when MCS is used on the MS runtime and we need to delay-sign 
3156         (which seems unsupported by AssemblyBuilder - see #56621).
3157
3158 2004-04-08  Marek Safar  <marek.safar@seznam.cz>
3159
3160         * typemanager.cs (TypeManager.TypeToCoreType): Handle IntPtr too.
3161         (TypeManager.ComputeNamespaces): Faster implementation for
3162         Microsoft runtime.
3163
3164         * compiler.csproj: Updated AssemblyName to mcs.
3165
3166 2004-04-07  Miguel de Icaza  <miguel@ximian.com>
3167
3168         * rootcontext.cs: Add new types to the boot resolution.
3169
3170         * ecore.cs (TypeExpr.CanInheritFrom): Inheriting from
3171         MulticastDelegate is not allowed.
3172
3173         * typemanager.cs: Add new types to lookup: System.TypedReference
3174         and ArgIterator.
3175
3176         * paramter.cs (Parameter.Resolve): if we are an out/ref parameter,
3177         check for TypedReference or ArgIterator, they are not allowed. 
3178
3179         * ecore.cs (BoxedCast): Set the eclass to ExprClass.Value, this
3180         makes us properly catch 1510 in some conditions (see bug 56016 for
3181         details). 
3182
3183 2004-04-06  Bernie Solomon  <bernard@ugsolutions.com>
3184
3185         * CryptoConvert.cs: update from corlib version
3186         with endian fixes.
3187
3188 2004-04-05  Miguel de Icaza  <miguel@ximian.com>
3189
3190         * class.cs (Indexer.Define): Check indexername declaration
3191
3192 2004-04-05  Marek Safar  <marek.safar@seznam.cz>
3193
3194         * attribute.cs (IsClsCompliant): Fixed problem with handling
3195         all three states (compliant, not-compliant, undetected).
3196
3197 2004-03-30  Marek Safar  <marek.safar@seznam.cz>
3198
3199         * attribute.cs (Attribute): Location is now public.
3200         (Resolve): Store resolved arguments (pos_values) in attribute class.
3201         Attribute extractors (now GetClsCompliantAttributeValue) can reuse them.
3202         (GetClsCompliantAttributeValue): New method that gets
3203         CLSCompliantAttribute value.
3204         (GetClsCompliantAttribute): Returns CLSCompliantAttribute for DeclSpace
3205         if exists else null.
3206         (AttributeTester): New class for CLS-Compliant verification routines.
3207
3208         * class.cs (Emit): Add CLS-Compliant verification.
3209         (Method.GetSignatureForError): Implemented.
3210         (Constructor.GetSignatureForError): Implemented
3211         (Constructor.HasCompliantArgs): Returns if constructor has
3212         CLS-Compliant arguments.
3213         (Constructor.Emit): Override.
3214         (Construcor.IsIdentifierClsCompliant): New method; For constructors
3215         is needed to test only parameters.
3216         (FieldBase.GetSignatureForError): Implemented.
3217         (TypeContainer): New member for storing base interfaces.
3218         (TypeContainer.FindMembers): Search in base interfaces too.
3219
3220         * codegen.cs (GetClsComplianceAttribute): New method that gets
3221         assembly or module CLSCompliantAttribute value.
3222         (ResolveClsCompliance): New method that resolve CLSCompliantAttribute
3223         for assembly.
3224         (ModuleClass.Emit): Add error 3012 test.
3225
3226         * const.cs (Emit): Override and call base for CLS-Compliant tests.
3227
3228         * decl.cs (ClsComplianceValue): New enum that holds CLS-Compliant
3229         state for all decl types.
3230         (MemberCore.Emit): Emit is now virtual and call VerifyClsCompliance
3231         if CLS-Compliant tests are required.
3232         (IsClsCompliaceRequired): New method. Analyze whether code
3233         must be CLS-Compliant.
3234         (IsExposedFromAssembly): New method. Returns true when MemberCore
3235         is exposed from assembly.
3236         (GetClsCompliantAttributeValue): New method. Resolve CLSCompliantAttribute
3237         value or gets cached value.
3238         (HasClsCompliantAttribute): New method. Returns true if MemberCore
3239         is explicitly marked with CLSCompliantAttribute.
3240         (IsIdentifierClsCompliant): New abstract method. This method is
3241         used to testing error 3005.
3242         (IsIdentifierAndParamClsCompliant): New method. Common helper method
3243         for identifier and parameters CLS-Compliant testing.
3244         (VerifyClsCompliance): New method. The main virtual method for
3245         CLS-Compliant verifications.
3246         (CheckAccessLevel): In one special case (System.Drawing) was TypeBuilder
3247         null. I don't know why is null (too many public members !).
3248         (GetClsCompliantAttributeValue). New method. Goes through class hierarchy
3249         and get value of first CLSCompliantAttribute that found.
3250
3251         * delegate.cs (Emit): Override and call base for CLS-Compliant tests.
3252         (VerifyClsCompliance): Override and add extra tests.
3253
3254         * driver.cs (CSCParseOption): New command line options (clscheck[+|-]).
3255         clscheck- disable CLS-Compliant verification event if assembly is has
3256         CLSCompliantAttribute(true).
3257
3258         * enum.cs (Emit): Override and call base for CLS-Compliant tests.
3259         ApllyAttribute is now called in emit section as in the other cases.
3260         Possible future Emit integration.
3261         (IsIdentifierClsCompliant): New override.
3262         (VerifyClsCompliance): New override.
3263         (GetEnumeratorName): Returns full enum name.
3264
3265         * parameter.cs (GetSignatureForError): Implemented.
3266
3267         * report.cs (WarningData): New struct for Warning message information.
3268         (LocationOfPreviousError): New method.
3269         (Warning): New method. Reports warning based on the warning table.
3270         (Error_T): New method. Reports error based on the error table.
3271
3272         * rootcontext.cs (EmitCode): Added new Emit(s) because CLS-Compliant
3273         verifications are done here.
3274
3275         * tree.cs (RecordDecl): Used new LocationOfPreviousError method.
3276
3277         * typemanager.cs (cls_compliant_attribute_type): New member thath holds
3278         CLSCompliantAttribute.
3279         (all_imported_types): New member holds all imported types from other
3280         assemblies.
3281         (LoadAllImportedTypes): New method fills static table with exported types
3282         from all referenced assemblies.
3283         (Modules): New property returns all assembly modules.
3284
3285 2004-03-30  Miguel de Icaza  <miguel@ximian.com>
3286
3287         * cs-parser.jay: Add a rule to catch wrong event syntax instead of
3288         throwing a parser error.
3289
3290         * ecore.cs (PropertyExpr.GetAccessor): Apply patch from Patrik Reali
3291         which removes the hardcoded get_/set_ prefixes for properties, as
3292         IL allows for the properties to be named something else.  
3293
3294         Bug #56013
3295
3296         * expression.cs: Do not override operand before we know if it is
3297         non-null.  Fix 56207
3298
3299 2004-03-29 Ben Maurer  <bmaurer@users.sourceforge.net>
3300
3301         * typemanager.cs: support for pinned variables.
3302
3303 2004-03-29 Ben Maurer  <bmaurer@users.sourceforge.net>
3304
3305         * decl.cs, typemanager.cs: Avoid using an arraylist
3306         as a buffer if there is only one result set.
3307
3308 2004-03-29 Ben Maurer  <bmaurer@users.sourceforge.net>
3309
3310         * expression.cs: Make sure you cant call a static method
3311         with an instance expression, bug #56174.
3312
3313 2004-03-29  Miguel de Icaza  <miguel@ximian.com>
3314
3315         * class.cs (IsDuplicateImplementation): Improve error reporting to
3316         flag 663 (method only differs in parameter modifier).
3317
3318         * cs-tokenizer.cs: Do not require whitespace when a ( or " will do
3319         in preprocessor directives.
3320
3321         * location.cs (LookupFile): Allow for the empty path.
3322
3323         * attribute.cs (DefinePInvokeMethod): Fix 56148;  I would like a
3324         better approach for some of that patch, but its failing with the
3325         CharSet enumeration.  For now try/catch will do.
3326
3327         * typemanager.cs: Do not crash if a struct does not have fields.
3328         Fixes 56150.
3329
3330 2004-03-28 Ben Maurer  <bmaurer@users.sourceforge.net>
3331
3332         * expression.cs: cs0213, cant fix a fixed expression.
3333         fixes 50231.
3334
3335 2004-03-28 Ben Maurer  <bmaurer@users.sourceforge.net>
3336
3337         * cs-parser.jay: detect invalid embeded statements gracefully.
3338         bug #51113.
3339
3340 2004-03-28 Ben Maurer  <bmaurer@users.sourceforge.net>
3341
3342         * ecore.cs, typemanager.cs: Correct impl of cs1540 check.
3343         As a regex:
3344         s/
3345         the invocation type may not be a subclass of the tye of the item/
3346         The type of the item must be a subclass of the invocation item.
3347         /g
3348
3349         Fixes bug #50820.
3350
3351 2004-03-25  Sebastien Pouliot  <sebastien@ximian.com>
3352
3353         * attribute.cs: Added methods to get a string and a bool from an
3354         attribute. Required to information from AssemblyKeyFileAttribute,
3355         AttributeKeyNameAttribute (string) and AssemblyDelaySign (bool).
3356         * codegen.cs: Modified AssemblyName creation to include support for
3357         strongnames. Catch additional exceptions to report them as CS1548.
3358         * compiler.csproj: Updated include CryptoConvert.cs.
3359         * compiler.csproj.user: Removed file - user specific configuration.
3360         * CryptoConvert.cs: New. A COPY of the class CryptoConvert from 
3361         Mono.Security assembly. The original class is maintained and tested in
3362         /mcs/class/Mono.Security/Mono.Security.Cryptography/CryptoConvert.cs.
3363         * drivers.cs: Added support for /keyfile, /keycontainer and /delaysign
3364         like CSC 8.0 (C# v2) supports.
3365         * Makefile: Added CryptoConvert.cs to mcs sources.
3366         * rootcontext.cs: Added new options for strongnames.
3367
3368 2004-03-24 Ben Maurer  <bmaurer@users.sourceforge.net>
3369
3370         * driver.cs: For --expect-error, report error code `2'
3371         if the program compiled with no errors, error code `1' if
3372         it compiled with an error other than the one expected.
3373
3374 2004-03-24  Sebastien Pouliot  <sebastien@ximian.com>
3375
3376         * compiler.csproj: Updated for Visual Studio .NET 2003.
3377         * compiler.csproj.user: Updated for Visual Studio .NET 2003.
3378         * compiler.sln: Updated for Visual Studio .NET 2003.
3379
3380 2004-03-24  Ravi Pratap M  <ravi@ximian.com>
3381
3382         * expression.cs: Fix bug #47234. We basically need to apply the
3383         rule that we prefer the conversion of null to a reference type
3384         when faced with a conversion to 'object' (csc behaviour).
3385
3386 2004-03-23 Ben Maurer  <bmaurer@users.sourceforge.net>
3387
3388         * statement.cs: Shorter form for foreach, eliminates
3389         a local variable. r=Martin.
3390
3391 2004-03-23 Ben Maurer  <bmaurer@users.sourceforge.net>
3392
3393         * constant.cs, ecore.cs, literal.cs: New prop IsZeroInteger that
3394         checks if we can use brtrue/brfalse to test for 0.
3395         * expression.cs: use the above in the test for using brtrue/brfalse.
3396         cleanup code a bit.
3397
3398 2004-03-23 Ben Maurer  <bmaurer@users.sourceforge.net>
3399
3400         * expression.cs: Rewrite string concat stuff. Benefits:
3401
3402         - "a" + foo + "b" + "c" becomes "a" + foo + "bc"
3403         - "a" + foo + "b" + bar + "c" + baz ... uses concat (string []).
3404         rather than a concat chain.
3405
3406         * typemanager.cs: Add lookups for more concat overloads.
3407
3408 2004-03-23 Ben Maurer  <bmaurer@users.sourceforge.net>
3409
3410         * expression.cs: Emit shorter il code for array init.
3411
3412         newarr
3413         dup
3414         // set 1
3415
3416         // set 2
3417
3418         newarr
3419         stloc.x
3420
3421         ldloc.x
3422         // set 1
3423
3424         ldloc.x
3425         // set 2
3426
3427 2004-03-22 Ben Maurer  <bmaurer@users.sourceforge.net>
3428
3429         * statement.cs: Before, two switch blocks would be merged if the
3430         total size of the blocks (end_item - begin_item + 1) was less than
3431         two times the combined sizes of the blocks.
3432
3433         Now, it will only merge if after the merge at least half of the
3434         slots are filled.
3435
3436         fixes 55885.
3437
3438 2004-03-20  Atsushi Enomoto  <atsushi@ximian.com>
3439
3440         * class.cs : csc build fix for GetMethods(). See bug #52503.
3441
3442 2004-03-20 Ben Maurer  <bmaurer@users.sourceforge.net>
3443
3444         * expression.cs: Make sure fp comparisons work with NaN.
3445         This fixes bug #54303. Mig approved this patch a long
3446         time ago, but we were not able to test b/c the runtime
3447         had a related bug.
3448
3449 2004-03-19  Miguel de Icaza  <miguel@ximian.com>
3450
3451         * ecore.cs (TypExpr.GetHashCode): implement this overload. 
3452
3453 2004-03-19  Martin Baulig  <martin@ximian.com>
3454
3455         * class.cs (MemberCore.IsDuplicateImplementation): Report the
3456         error here and not in our caller.
3457
3458 2004-03-19  Martin Baulig  <martin@ximian.com>
3459
3460         * interface.cs: Completely killed this file.
3461         (Interface): We're now a TypeContainer and live in class.cs.
3462
3463         * class.cs (TypeContainer.GetClassBases): Added `bool is_iface'
3464         argument; we're now also called for interfaces.
3465         (TypeContainer.DefineMembers): Allow this method being called
3466         multiple times.
3467         (TypeContainer.GetMethods): New public method; formerly known as
3468         Interface.GetMethod().  This is used by PendingImplementation.
3469         (TypeContainer.EmitDefaultMemberAttr): Moved here from Interface;
3470         it's now private and non-static.
3471         (Interface): Moved this here; it's now implemented similar to
3472         Class and Struct.
3473         (Method, Property, Event, Indexer): Added `bool is_interface'
3474         argument to their .ctor's.
3475         (MemberBase.IsInterface): New public field.
3476
3477         * cs-parser.jay: Create normal Method, Property, Event, Indexer
3478         instances instead of InterfaceMethod, InterfaceProperty, etc.
3479         (opt_interface_base): Removed; we now use `opt_class_base' instead.
3480         (InterfaceAccessorInfo): Create `Get' and `Set' Accessor's.
3481
3482 2004-03-19  Martin Baulig  <martin@ximian.com>
3483
3484         * class.cs (MethodCore.IsDuplicateImplementation): New private
3485         method which does the CS0111 checking.
3486         (Method.CheckBase, Constructor.CheckBase, PropertyBase.CheckBase):
3487         Use IsDuplicateImplementation().
3488
3489 2004-03-17 Ben Maurer  <bmaurer@users.sourceforge.net>
3490
3491         * decl.cs (FindMemberToOverride): New method to find the correct
3492         method or property to override in the base class.
3493         * class.cs
3494             - Make Method/Property use the above method to find the
3495               version in the base class.
3496             - Remove the InheritableMemberSignatureCompare as it is now
3497               dead code.
3498
3499         This patch makes large code bases much faster to compile, as it is
3500         O(n) rather than O(n^2) to do this validation.
3501
3502         Also, it fixes bug 52458 which is that nested classes are not
3503         taken into account when finding the base class member.
3504
3505         Reviewed/Approved by Martin.
3506
3507 2004-03-17  Marek Safar  <marek.safar@seznam.cz>
3508
3509         * interface.cs: In all interface classes removed redundant
3510         member initialization.
3511
3512 2004-03-16  Martin Baulig  <martin@ximian.com>
3513
3514         * class.cs (TypeContainer.GetClassBases): Fix the CS0528 check.
3515
3516 2004-03-15  Miguel de Icaza  <miguel@ximian.com>
3517
3518         * decl.cs (DefineTypeAndParents): New helper method to define a
3519         type's containers before the type itself is defined;  This is a
3520         bug exposed by the recent changes to Windows.Forms when an
3521         implemented interface was defined inside a class that had not been
3522         built yet.   
3523
3524         * modifiers.cs (MethodAttr): All methods in C# are HideBySig.
3525
3526         (Check): Loop correctly to report errors modifiers
3527         (UNSAFE was not in the loop, since it was the same as TOP).
3528
3529         * interface.cs: Every interface member now takes a ModFlags,
3530         instead of a "is_new" bool, which we set on the base MemberCore. 
3531
3532         Every place where we called "UnsafeOk" in the interface, now we
3533         call the proper member (InterfaceMethod.UnsafeOK) instead to get
3534         the unsafe settings from the member declaration instead of the
3535         container interface. 
3536
3537         * cs-parser.jay (opt_new): Allow unsafe here per the spec. 
3538
3539         * pending.cs (TypeAndMethods): Add `get_indexer_name' and
3540         `set_indexer_name' to the pending bits (one per type).
3541
3542         We fixed a bug today that was picking the wrong method to
3543         override, since for properties the existing InterfaceMethod code
3544         basically ignored the method name.  Now we make sure that the
3545         method name is one of the valid indexer names.
3546
3547 2004-03-14  Gustavo Giráldez  <gustavo.giraldez@gmx.net>
3548  
3549         * support.cs (SeekableStreamReader): Keep track of stream byte
3550         positions and don't mix them with character offsets to the buffer.
3551
3552         Patch from Gustavo Giráldez
3553
3554 2004-03-15  Marek Safar  <marek.safar@seznam.cz>
3555
3556         * interface.cs (InterfaceSetGetBase): Removed double member
3557         initialization, base class does it as well.
3558
3559 2004-03-13  Martin Baulig  <martin@ximian.com>
3560
3561         * class.cs: Reverted Miguel's latest commit; it makes mcs crash
3562         when compiling corlib.
3563
3564 2004-03-13  Miguel de Icaza  <miguel@ximian.com>
3565
3566         * convert.cs (ExplicitConversion): We were reporting an error on
3567         certain conversions (object_type source to a value type, when the
3568         expression was `null') before we had a chance to pass it through
3569         the user defined conversions.
3570
3571         * driver.cs: Replace / and \ in resource specifications to dots.
3572         Fixes 50752
3573
3574         * class.cs: Add check for duplicate operators.  Fixes 52477
3575
3576 2004-03-11  Miguel de Icaza  <miguel@ximian.com>
3577
3578         * statement.cs (Switch.SimpleSwitchEmit): Deal with default labels
3579         that are in the middle of the statements, not only at the end.
3580         Fixes #54987
3581
3582         * class.cs (TypeContainer.AddField): No longer set the
3583         `HaveStaticConstructor' flag, now we call it
3584         `UserDefineStaticConstructor' to diferentiate the slightly
3585         semantic difference.
3586
3587         The situation is that we were not adding BeforeFieldInit (from
3588         Modifiers.TypeAttr) to classes that could have it.
3589         BeforeFieldInit should be set to classes that have no static
3590         constructor. 
3591
3592         See:
3593
3594         http://www.yoda.arachsys.com/csharp/beforefieldinit.html
3595
3596         And most importantly Zoltan's comment:
3597
3598         http://bugzilla.ximian.com/show_bug.cgi?id=44229
3599
3600         "I think beforefieldinit means 'it's ok to initialize the type sometime 
3601          before its static fields are used', i.e. initialization does not need
3602          to be triggered by the first access to the type. Setting this flag
3603          helps the JIT to compile better code, since it can run the static
3604          constructor at JIT time, and does not need to generate code to call it
3605          (possibly lots of times) at runtime. Unfortunately, mcs does not set
3606          this flag for lots of classes like String. 
3607          
3608          csc sets this flag if the type does not have an explicit static 
3609          constructor. The reasoning seems to be that if there are only static
3610          initalizers for a type, and no static constructor, then the programmer
3611          does not care when this initialization happens, so beforefieldinit
3612          can be used.
3613          
3614          This bug prevents the AOT compiler from being usable, since it 
3615          generates so many calls to mono_runtime_class_init that the AOT code
3616          is much slower than the JITted code. The JITted code is faster, 
3617          because it does not generate these calls if the vtable is type is
3618          already initialized, which is true in the majority of cases. But the
3619          AOT compiler can't do this."
3620
3621 2004-03-10  Miguel de Icaza  <miguel@ximian.com>
3622
3623         * class.cs (MethodData.Emit): Refactor the code so symbolic
3624         information is generated for destructors;  For some reasons we
3625         were taking a code path that did not generate symbolic information
3626         before. 
3627
3628 2004-03-11 Ben Maurer  <bmaurer@users.sourceforge.net>
3629
3630         * class.cs: Create a Constructor.CheckBase method that
3631         takes care of all validation type code. The method
3632         contains some code that was moved from Define.
3633
3634         It also includes new code that checks for duplicate ctors.
3635         This fixes bug #55148.
3636
3637 2004-03-09  Joshua Tauberer <tauberer@for.net>
3638
3639         * expression.cs (ArrayCreation): Fix: More than 6 nulls in
3640         a { ... }-style array creation invokes EmitStaticInitializers
3641         which is not good for reference-type arrays.  String, decimal
3642         and now null constants (NullCast) are not counted toward
3643         static initializers.
3644
3645 2004-03-05  Martin Baulig  <martin@ximian.com>
3646
3647         * location.cs (SourceFile.HasLineDirective): New public field;
3648         specifies whether the file contains or is referenced by a "#line"
3649         directive.
3650         (Location.DefineSymbolDocuments): Ignore source files which
3651         either contain or are referenced by a "#line" directive.        
3652
3653 2004-02-29  Ben Maurer <bmaurer@users.sourceforge.net>
3654
3655         * class.cs (Method.CheckBase): Avoid using FindMembers, we have
3656         direct access to our parent, so check the method inline there.
3657
3658 2004-02-27 Ben Maurer  <bmaurer@users.sourceforge.net>
3659
3660         * expression.cs (Invocation.EmitCall): Miguel's last commit
3661         caused a regression. If you had:
3662
3663             T t = null;
3664             t.Foo ();
3665
3666         In Foo the implict this would be null.
3667
3668 2004-02-27  Miguel de Icaza  <miguel@ximian.com>
3669
3670         * expression.cs (Invocation.EmitCall): If the method is not
3671         virtual, do not emit a CallVirt to it, use Call.
3672
3673         * typemanager.cs (GetFullNameSignature): Improve the method to
3674         cope with ".ctor" and replace it with the type name.
3675
3676         * class.cs (ConstructorInitializer.Resolve): Now the method takes
3677         as an argument the ConstructorBuilder where it is being defined,
3678         to catch the recursive constructor invocations.
3679
3680 2004-02-26  Miguel de Icaza  <miguel@ximian.com>
3681
3682         * iterators.cs (IteratorHandler.IsIEnumerator, IsIEnumerable): New
3683         routines to check if a type is an enumerable/enumerator allow
3684         classes that implement the IEnumerable or IEnumerator interfaces.
3685
3686         * class.cs (Property, Operator): Implement IIteratorContainer, and
3687         implement SetYields.
3688
3689         (Property.Define): Do the block swapping for get_methods in the
3690         context of iterators.   We need to check if Properties also
3691         include indexers or not.
3692
3693         (Operator): Assign the Block before invoking the
3694         OperatorMethod.Define, so we can trigger the Iterator code
3695         replacement. 
3696
3697         * cs-parser.jay (SimpleIteratorContainer): new helper class.  Both
3698         Property and Operator classes are not created when we parse the
3699         declarator but until we have the block completed, so we use a
3700         singleton SimpleIteratorContainer.Simple to flag whether the
3701         SetYields has been invoked.
3702
3703         We propagate this setting then to the Property or the Operator to
3704         allow the `yield' to function.
3705
3706 2004-02-25  Marek Safar  <marek.safar@seznam.cz>
3707
3708         * codegen.cs: Implemented attribute support for modules.
3709         New AssemblyClass, ModuleClass and CommonAssemblyModulClass for
3710         Assembly/Module functionality.
3711
3712         * attribute.cs, class.cs, cs-parser.jay, delegate.cs, driver.cs, enum.cs
3713         interface.cs, rootcontext.cs, statement.cs, typemanager.cs:
3714         Updated dependencies on CodeGen.ModuleBuilder and CodeGen.AssemblyBuilder.
3715
3716 2004-02-16  Marek Safar  <marek.safar@seznam.cz>
3717
3718         * interface.cs (FindMembers): The operation is performed on all base
3719         interfaces and not only on the first. It is required for future CLS Compliance patch.
3720
3721 2004-02-12 Ben Maurer  <bmaurer@users.sourceforge.net>
3722
3723         * statement.cs, codegen.cs:
3724         This patch deals with patterns such as:
3725
3726         public class List : IEnumerable {
3727
3728                 public MyEnumerator GetEnumerator () {
3729                         return new MyEnumerator(this);
3730                 }
3731
3732                 IEnumerator IEnumerable.GetEnumerator () {
3733                         ...
3734                 }
3735                 
3736                 public struct MyEnumerator : IEnumerator {
3737                         ...
3738                 }
3739         }
3740
3741         Before, there were a few things we did wrong:
3742         1) we would emit callvirt on a struct, which is illegal
3743         2) we emited ldarg when we needed to emit ldarga
3744         3) we would mistakenly call the interface methods on an enumerator
3745         type that derived from IEnumerator and was in another assembly. For example:
3746
3747         public class MyEnumerator : IEnumerator
3748
3749         Would have the interface methods called, even if there were public impls of the
3750         method. In a struct, this lead to invalid IL code.
3751
3752 2004-02-11  Marek Safar  <marek.safar@seznam.cz>
3753
3754         * const.cs: Const is now derived from FieldBase. Method EmitConstant name
3755           renamed to Emit.
3756
3757         * delegate.cs (Define): Fixed crash when delegate type is undefined.
3758
3759 2004-02-11  Miguel de Icaza  <miguel@ximian.com>
3760
3761         * cs-parser.jay: Fix small regression: we were not testing V2
3762         compiler features correctly.
3763
3764         * interface.cs: If the emit context is null, then create one
3765
3766 2004-02-09  Marek Safar  <marek.safar@seznam.cz>
3767
3768         * decl.cs (GetSignatureForError): New virtual method to get full name
3769           for error messages.
3770
3771         * attribute.cs (IAttributeSupport): New interface for attribute setting.
3772           Now it is possible to rewrite ApplyAttributes method to be less if/else.
3773
3774         * interface.cs : All InterfaceXXX classes are now derived from MemberCore.
3775           Duplicated members and code in these classes has been removed.
3776           Better encapsulation in these classes.
3777
3778 2004-02-07  Miguel de Icaza  <miguel@ximian.com>
3779
3780         * assign.cs (Assign.DoResolve): When dealing with compound
3781         assignments, there is a new rule in ECMA C# 2.4 (might have been
3782         there before, but it is documented here) that states that in:
3783
3784         a op= b;
3785
3786         If b is of type int, and the `op' is a shift-operator, then the
3787         above is evaluated as:
3788
3789         a = (int) a op b 
3790
3791         * expression.cs (Binary.ResolveOperator): Instead of testing for
3792         int/uint/long/ulong, try to implicitly convert to any of those
3793         types and use that in pointer arithmetic.
3794
3795         * delegate.cs (Error_NoMatchingMethodForDelegate): Compute the
3796         method to print information for from the type, not from the
3797         null-method we were given.
3798
3799 2004-02-01  Duncan Mak  <duncan@ximian.com>
3800
3801         * cs-tokenizer.cs (get_cmd_arg): Skip over whitespace before
3802         parsing for cmd, fixes bug #53694.
3803
3804 2004-02-04  Marek Safar  <marek.safar@seznam.cz>
3805
3806         * class.cs, decl.cs: Fixed problem where IndexerName attribute was ignored
3807         in the member name duplication tests. Property and operator name duplication
3808         was missing too (error tests cs0102-{2,3,4,5}.cs, cs0111-{3,4}.cs).
3809
3810 2004-02-03  Marek Safar  <marek.safar@seznam.cz>
3811
3812         * interface.cs (PopulateMethod): Fixed crash when interface method
3813         returns not existing type (error test cs0246-3.cs).
3814
3815 2004-02-02  Ravi Pratap M <ravi@ximian.com>
3816
3817         * cs-parser.jay (interface_accessors): Re-write actions to also
3818         store attributes attached to get and set methods. Fix spelling
3819         while at it.
3820
3821         (inteface_property_declaration): Modify accordingly.
3822
3823         (InterfaceAccessorInfo): New helper class to store information to pass
3824         around between rules that use interface_accessors.
3825
3826         * interface.cs (Emit): Apply attributes on the get and set
3827         accessors of properties and indexers too.
3828
3829         * attribute.cs (ApplyAttributes): Modify accordingly to use the
3830         right MethodBuilder when applying attributes to the get and set accessors.
3831
3832 2004-01-31  Miguel de Icaza  <miguel@ximian.com>
3833
3834         * cs-tokenizer.cs: Applied patch from Marek Safar to fix bug 53386
3835
3836 2004-01-26  Miguel de Icaza  <miguel@ximian.com>
3837
3838         * cs-tokenizer.cs: Handle #line hidden from PDC bits.
3839
3840 2004-01-25  Miguel de Icaza  <miguel@ximian.com>
3841
3842         * cs-parser.jay: Remove YIELD token, instead use the new grammar
3843         changes that treat `yield' specially when present before `break'
3844         or `return' tokens.
3845
3846         * cs-tokenizer.cs: yield is no longer a keyword.
3847
3848 2004-01-23  Marek Safar  <marek.safar@seznam.cz>
3849
3850         * cs-parser.jay, class.cs (DefineDefaultConstructor): Fixed ModFlags
3851         setting for default constructors.
3852         For default constructors are almost every time set wrong Modifier. The
3853         generated IL code has been alright. But inside mcs this values was
3854         wrong and this was reason why several of my CLS Compliance tests
3855         failed.
3856
3857 2004-01-22  Martin Baulig  <martin@ximian.com>
3858
3859         * cs-parser.jay (namespace_or_type_name): Return an Expression,
3860         not a QualifiedIdentifier.  This is what `type_name_expression'
3861         was previously doing.
3862         (type_name_expression): Removed; the code is now in
3863         `namespace_or_type_name'.
3864         (qualified_identifier): Removed, use `namespace_or_type_name'
3865         instead.
3866         (QualifiedIdentifier): Removed this class.      
3867
3868 2004-01-22  Martin Baulig  <martin@ximian.com>
3869
3870         * namespace.cs (NamespaceEntry.UsingAlias): Take an Expression,
3871         not a string as alias name.
3872
3873 2004-01-21  Miguel de Icaza  <miguel@ximian.com>
3874
3875         * ecore.cs (FieldInfo.AddressOf): Revert patch from previous
3876         #52730 bug, and instead compute correctly the need to use a
3877         temporary variable when requesting an address based on the
3878         static/instace modified of the field and the constructor.
3879  
3880 2004-01-21  Martin Baulig  <martin@ximian.com>
3881
3882         * ecore.cs (SimpleName.ResolveAsTypeStep): Lookup in the current
3883         class and namespace before looking up aliases.  Fixes #52517.
3884
3885 2004-01-21  Martin Baulig  <martin@ximian.com>
3886
3887         * flowanalysis.cs (UsageVector.Merge): Allow variables being
3888         assinged in a 'try'; fixes exception4.cs.
3889
3890 2004-01-21  Marek Safar  <marek.safar@seznam.cz>
3891         * class.cs : Implemented parameter-less constructor for TypeContainer
3892
3893         * decl.cs: Attributes are now stored here. New property OptAttributes
3894
3895         * delegate.cs, enum.cs, interface.cs: Removed attribute member.
3896
3897         * rootcontext.cs, tree.cs: Now use parameter-less constructor of TypeContainer
3898
3899 2004-01-21  Marek Safar  <marek.safar@seznam.cz>
3900
3901         * typemanager.cs (CSharpSignature): Now reports also inner class name.
3902           (CSharpSignature): New method for indexer and property signature.
3903
3904 2004-01-21  Marek Safar  <marek.safar@seznam.cz>
3905
3906         * pending.cs (IsVirtualFilter): Faster implementation.
3907
3908 2004-01-21  Marek Safar  <marek.safar@seznam.cz>
3909
3910         * typemanager.cs: Avoid inclusion of same assembly more than once.
3911
3912 2004-01-21  Marek Safar  <marek.safar@seznam.cz>
3913
3914         * cs-parser.jay: Fixed problem where the last assembly attribute
3915           has been applied also to following declaration (class, struct, etc.)
3916           
3917 2004-01-21  Marek Safar  <marek.safar@seznam.cz>
3918
3919         * class.cs: Added error CS0538, CS0539 reporting.
3920         Fixed crash on Microsoft runtime when field type is void.
3921
3922         * cs-parser.jay: Added error CS0537 reporting.
3923
3924         * pending.cs: Added error CS0535 reporting.
3925         Improved error report for errors CS0536, CS0534.
3926
3927 2004-01-20  Miguel de Icaza  <miguel@ximian.com>
3928
3929         Merge a few bits from the Anonymous Method MCS tree.
3930
3931         * statement.cs (ToplevelBlock): New class for toplevel methods,
3932         will hold anonymous methods, lifted variables.
3933
3934         * cs-parser.jay: Create toplevel blocks for delegates and for
3935         regular blocks of code. 
3936
3937 2004-01-20  Martin Baulig  <martin@ximian.com>
3938
3939         * codegen.cs (EmitContext): Removed `InTry', `InCatch',
3940         `InFinally', `InLoop', `TryCatchLevel', `LoopBeginTryCatchLevel'
3941         and `NeedExplicitReturn'; added `IsLastStatement'.
3942         (EmitContext.EmitTopBlock): Emit the explicit "ret" if we either
3943         have a `ReturnLabel' or we're not unreachable.
3944
3945         * flowanalysis.cs (FlowBranching.MergeChild): Actually merge the
3946         child's reachability; don't just override ours with it.  Fixes
3947         #58058 (lluis's example).
3948         (FlowBranching): Added public InTryOrCatch(), InCatch(),
3949         InFinally(), InLoop(), InSwitch() and
3950         BreakCrossesTryCatchBoundary() methods.
3951
3952         * statement.cs (Return): Do all error checking in Resolve().
3953         Unless we are the last statement in a top-level block, always
3954         create a return label and jump to it.
3955         (Break, Continue): Do all error checking in Resolve(); also make
3956         sure we aren't leaving a `finally'.
3957         (Block.DoEmit): Set `ec.IsLastStatement' when emitting the last
3958         statement in a top-level block.
3959         (Block.Flags): Added `IsDestructor'.
3960         (Block.IsDestructor): New public property.
3961
3962 2004-01-20  Martin Baulig  <martin@ximian.com>
3963
3964         * statement.cs (Break.DoEmit): Set ec.NeedExplicitReturn; fixes #52427.
3965
3966 2004-01-20  Martin Baulig  <martin@ximian.com>
3967
3968         * statement.cs (Statement.ResolveUnreachable): New public method.
3969         (If, While): Do the dead-code elimination in Resolve(), not in Emit().
3970         (Block.Resolve): Resolve unreachable statements.
3971
3972 2004-01-19 Ben Maurer  <bmaurer@users.sourceforge.net>
3973
3974         * expression.cs: We need to fix the case where we do
3975         not have a temp variable here.
3976
3977         * assign.cs: Only expression compound assignments need
3978         temporary variables.
3979
3980 2004-01-19 Ben Maurer  <bmaurer@users.sourceforge.net>
3981
3982         * flowanalysis.cs: Reduce memory allocation in a few ways:
3983           - A block with no variables should not allocate a bit
3984             vector for itself.
3985           - A method with no out parameters does not need any tracking
3986             for assignment of the parameters, so we need not allocate
3987             any data for it.
3988           - The arrays:
3989                 public readonly Type[] VariableTypes;
3990                 public readonly string[] VariableNames;
3991             Are redundant. The data is already stored in the variable
3992             map, so we need not allocate another array for it.
3993           - We need to add alot of checks for if (params | locals) == null
3994             due to the first two changes.
3995
3996 2004-01-18  Miguel de Icaza  <miguel@ximian.com>
3997
3998         * ecore.cs (FieldExpr.AddressOf): For ValueTypes that do not
3999         implement IMemoryLocation, we store a copy on a local variable and
4000         take the address of it.  Patch from Benjamin Jemlich
4001
4002         * cs-parser.jay: Applied patch from Ben Maurer to the "type" rule
4003         to use a special "type_name_expression" rule which reduces the
4004         number of "QualifiedIdentifier" classes created, and instead
4005         directly creates MemberAccess expressions.
4006
4007 2004-01-17  Miguel de Icaza  <miguel@ximian.com>
4008
4009         * convert.cs: Applied patch from Benjamin Jemlich (pcgod@gmx.net)
4010         that fixes #52853.  Null literal assignment to ValueType
4011
4012         * class.cs (MethodData.Emit): Instead of checking the name of the
4013         method to determine if its a destructor, create a new derived
4014         class from Method called Destructor, and test for that.  
4015
4016         * cs-parser.jay: Create a Destructor object instead of a Method.  
4017
4018         Based on a fix from Benjamin Jemlich (pcgod@gmx.net)
4019
4020         Fixes: 52933
4021
4022 2004-01-16  Miguel de Icaza  <miguel@ximian.com>
4023
4024         * expression.cs (Binary.ResolveOperator): Perform an implicit
4025         conversion from MethodGroups to their delegate types on the
4026         Addition operation.
4027
4028         * delegate.cs: Introduce a new class DelegateCreation that is the
4029         base class for `NewDelegate' and `ImplicitDelegateCreation',
4030         factor some code in here.
4031
4032         * convert.cs (Convert.ImplicitConversionStandard): Add an implicit
4033         conversion from MethodGroups to compatible delegate types. 
4034
4035         * ecore.cs (Expression.Resolve): Do not flag error 654
4036         (Methodgroupd needs parenthesis) if running on the V2 compiler, as
4037         we allow conversions from MethodGroups to delegate types now.
4038
4039         * assign.cs (Assign.DoResolve): Do not flag errors on methodgroup
4040         assignments in v2 either.
4041
4042 2004-01-10  Miguel de Icaza  <miguel@ximian.com>
4043
4044         * ecore.cs (FieldExpr.AddressOf): Fix generated IL for accessing
4045         static read-only fields in ctors.
4046
4047         Applied patch from Benjamin Jemlich 
4048
4049         * expression.cs (UnaryMutator): Avoid leaking local variables. 
4050
4051 2004-01-09  Miguel de Icaza  <miguel@ximian.com>
4052
4053         * cs-tokenizer.cs (IsCastToken): Allow the various native types
4054         here to return true, as they can be used like this:
4055
4056                 (XXX) int.MEMBER ()
4057
4058         Fixed 49836 and all the other dups
4059
4060 2004-01-09  Zoltan Varga  <vargaz@freemail.hu>
4061
4062         * driver.cs: Implement /win32res and /win32icon.
4063
4064 2004-01-08  Miguel de Icaza  <miguel@ximian.com>
4065
4066         * cs-parser.jay: Add a rule to improve error handling for the
4067         common mistake of placing modifiers after the type.
4068
4069 2004-01-07  Miguel de Icaza  <miguel@ximian.com>
4070
4071         * cs-parser.jay (interface_event_declaration): Catch
4072         initialization of events on interfaces, and report cs0068
4073
4074         * cs-parser.jay (interface_event_declaration): Catch
4075         initialization of events. 
4076
4077         * ecore.cs: Better report missing constructors.
4078
4079         * expression.cs (Binary.ResolveOperator): My previous bug fix had
4080         the error reporting done in the wrong place.  Fix.
4081
4082         * expression.cs (Binary.ResolveOperator): Catch the 
4083         operator + (E x, E y) error earlier, and later allow for implicit
4084         conversions in operator +/- (E e, U x) from U to the underlying
4085         type of E.
4086
4087         * class.cs (TypeContainer.DefineDefaultConstructor): Fix bug
4088         52596, if the container class is abstract, the default constructor
4089         is protected otherwise its public (before, we were always public).
4090
4091         * statement.cs (Fixed.Resolve): Catch a couple more errors in the
4092         fixed statement.
4093
4094         (Using.EmitLocalVariableDecls): Applied patch from Benjamin
4095         Jemlich that fixes bug #52597, MCS was generating invalid code for
4096         idisposable structs.   Thanks to Ben for following up with this
4097         bug as well.
4098
4099 2004-01-06  Miguel de Icaza  <miguel@ximian.com>
4100
4101         * driver.cs: Allow assemblies without code to be generated, fixes
4102         52230.
4103
4104 2004-01-07  Nick Drochak <ndrochak@gol.com>
4105
4106         * attribute.cs: Remove unneeded catch variables. Eliminates a warning.
4107
4108 2004-01-05  Miguel de Icaza  <miguel@ximian.com>
4109
4110         * cs-parser.jay: Add rules to improve error reporting if fields or
4111         methods are declared at the namespace level (error 116)
4112
4113         * Add rules to catch event add/remove
4114
4115 2004-01-04  David Sheldon <dave-mono@earth.li>
4116
4117   * expression.cs: Added matching ")" to error message for 
4118   CS0077
4119
4120 2004-01-03 Todd Berman <tberman@gentoo.org>
4121
4122         * ecore.cs, attribute.cs:
4123         Applying fix from #52429.
4124
4125 2004-01-03 Ben Maurer  <bmaurer@users.sourceforge.net>
4126
4127         * ecore.cs, expression.cs, statement.cs:
4128         Total rewrite of how we handle branching. We
4129         now handle complex boolean expressions with fewer
4130         jumps. As well if (x == 0) no longer emits a ceq.
4131
4132         if (x is Foo) is much faster now, because we generate
4133         better code.
4134
4135         Overall, we get a pretty big improvement on our benchmark
4136         tests. The code we generate is smaller and more readable.
4137
4138         I did a full two-stage bootstrap. The patch was reviewed
4139         by Martin and Miguel.
4140
4141 2004-01-03 Ben Maurer  <bmaurer@users.sourceforge.net>
4142
4143         * cs-parser.jay: Make primary_expression not take a QI.
4144         we dont need this because the member_access rule covers
4145         us here. So we replace the rule with just IDENTIFIER.
4146
4147         This has two good effects. First, we remove a s/r conflict.
4148         Second, we allocate many fewer QualifiedIdentifier objects.
4149
4150 2004-01-03 Ben Maurer  <bmaurer@users.sourceforge.net>
4151
4152         * attribute.cs: Handle MarshalAs attributes as pseudo, and
4153         set the correct information via SRE. This prevents
4154         hanging on the MS runtime. Fixes #29374.
4155
4156 2004-01-03 Ben Maurer  <bmaurer@users.sourceforge.net>
4157
4158         * convert.cs: correctly handle conversions to value types
4159         from Enum and ValueType as unboxing conversions.
4160
4161         Fixes bug #52569. Patch by Benjamin Jemlich.
4162
4163 2004-01-02  Ravi Pratap  <ravi@ximian.com>
4164
4165         * expression.cs (BetterConversion): Prefer int -> uint
4166         over int -> ulong (csc's behaviour). This fixed bug #52046.
4167
4168 2004-01-02 Ben Maurer  <bmaurer@users.sourceforge.net>
4169
4170         * decl.cs (MemberCache.FindMembers): now returns a
4171         MemberInfo [].
4172
4173         * typemanager.cs: In general, go with with ^^.
4174         (CopyNewMethods): take an IList.
4175         (RealMemberLookup): Only allocate an arraylist
4176         if we copy from two sets of methods.
4177
4178         This change basically does two things:
4179         1) Fewer array lists allocated due to CopyNewMethods.
4180         2) the explicit cast in MemberList costed ALOT.
4181
4182 2004-01-02  Zoltan Varga  <vargaz@freemail.hu>
4183
4184         * cs-tokenizer.cs (consume_identifier) driver.cs: Cache identifiers in
4185         a hashtable to avoid needless string allocations when an identifier is
4186         used more than once (the common case).
4187
4188 2004-01-01 Ben Maurer  <bmaurer@users.sourceforge.net>
4189
4190         * pending.cs: MS's TypeBuilder.GetInterfaces ()
4191         is broken, it will not return anything. So, we
4192         have to use the information we have in mcs to
4193         do the task.
4194
4195         * typemanager.cs: Add a cache for GetInterfaces,
4196         since this will now be used more often (due to ^^)
4197
4198         (GetExplicitInterfaces) New method that gets the
4199         declared, not effective, interfaces on a type
4200         builder (eg, if you have interface IFoo, interface
4201         IBar, Foo : IFoo, Bar : Foo, IBar, GetExplInt (Bar) ==
4202         { IBar }.
4203
4204         This patch makes MCS able to bootstrap itself on
4205         Windows again.
4206
4207 2004-01-01 Ben Maurer  <bmaurer@users.sourceforge.net>
4208
4209         * expression.cs: Remove the Nop's that Miguel put
4210         in by mistake.
4211
4212 2003-12-31 Ben Maurer  <bmaurer@users.sourceforge.net>
4213
4214         * report.cs, codegen.cs: Give the real stack trace to
4215         the error when an exception is thrown.
4216
4217 2003-12-31 Ben Maurer  <bmaurer@users.sourceforge.net>
4218
4219         * decl.cs: only allocate hashtables for ifaces if 
4220         it is an iface!
4221
4222 2003-12-31 Ben Maurer  <bmaurer@users.sourceforge.net>
4223
4224         * expression.cs: fix the error from cs0121-2.cs
4225         (a parent interface has two child interfaces that
4226         have a function with the same name and 0 params
4227         and the function is called through the parent).
4228
4229 2003-12-30 Ben Maurer  <bmaurer@users.sourceforge.net>
4230
4231         * class.cs, rootcontext.cs, typmanager.cs: do not
4232         leak pointers.
4233
4234 2003-12-28 Ben Maurer  <bmaurer@users.sourceforge.net>
4235
4236         * codegen.cs: remove stack for the ec flow branching.
4237         It is already a linked list, so no need.
4238
4239 2003-12-27 Ben Maurer  <bmaurer@users.sourceforge.net>
4240
4241         * Makefile: Allow custom profiler here.
4242
4243 2003-12-26 Ben Maurer  <bmaurer@users.sourceforge.net>
4244
4245         * typemanager.cs (LookupType):
4246           - Use a static char [], because split takes
4247             a param array for args, so it was allocating
4248             every time.
4249           - Do not store true in a hashtable, it boxes.
4250
4251 2003-12-26 Ben Maurer  <bmaurer@users.sourceforge.net>
4252
4253         * flowanalysis.cs: bytify common enums.
4254
4255 2003-12-25 Ben Maurer  <bmaurer@users.sourceforge.net>
4256
4257         * modifiers.cs: Add a new set of flags for the
4258         flags allowed on explicit interface impls.
4259         * cs-parser.jay: catch the use of modifiers in
4260         interfaces correctly.
4261         * class.cs: catch private void IFoo.Blah ().
4262
4263         All related to bug #50572.
4264
4265 2003-12-25 Ben Maurer  <bmaurer@users.sourceforge.net>
4266
4267         * decl.cs: Rewrite the consistant accessability checking.
4268         Accessability is not linear, it must be implemented in
4269         a tableish way. Fixes #49704.
4270
4271 2003-12-25 Ben Maurer  <bmaurer@users.sourceforge.net>
4272
4273         * expression.cs: Handle negation in a checked context.
4274         We must use subtraction from zero. Fixes #38674.
4275
4276 2003-12-23 Ben Maurer  <bmaurer@users.sourceforge.net>
4277
4278         * class.cs: Ignore static void main in DLLs.
4279         * rootcontext.cs: Handle the target type here,
4280         since we are have to access it from class.cs
4281         * driver.cs: account for the above.
4282
4283 2003-12-23 Ben Maurer  <bmaurer@users.sourceforge.net>
4284
4285         * report.cs: Give line numbers and files if available.
4286
4287 2003-12-20  Zoltan Varga  <vargaz@freemail.hu>
4288
4289         * driver.cs: Implement /addmodule.
4290
4291         * typemanager.cs:  Change 'modules' field so it now contains Modules not
4292         ModuleBuilders.
4293
4294 2003-12-20  Martin Baulig  <martin@ximian.com>
4295
4296         * class.cs (TypeContainer.DefineMembers): Don't do the CS0649 check here.
4297         (FieldBase.IsAssigned): Removed this field.
4298         (FieldBase.SetAssigned): New public method.
4299         (TypeContainer.Emit): Make the CS0169/CS0649 checks actually work.
4300
4301 2003-12-20  Martin Baulig  <martin@ximian.com>
4302
4303         * expression.cs (LocalVariableReference.DoResolve): Don't set
4304         `vi.Used' if we're called from DoResolveLValue().
4305
4306         * statement.cs (Block.DoResolve): `ec.DoEndFlowBranching()' now
4307         returns the usage vector it just merged into the current one -
4308         pass this one to UsageWarning().
4309         (Block.UsageWarning): Take the `FlowBranching.UsageVector' instead
4310         of the `EmitContext', don't call this recursively on our children.
4311
4312 2003-12-19  Zoltan Varga  <vargaz@freemail.hu>
4313
4314         * driver.cs: Implement /target:module.
4315
4316 2003-12-18  Zoltan Varga  <vargaz@freemail.hu>
4317
4318         * support.cs (CharArrayHashtable): New helper class.
4319
4320         * cs-tokenizer.cs: Store keywords in a hashtable indexed by 
4321         char arrays, not strings, so we can avoid creating a string in
4322         consume_identifier if the identifier is a keyword.
4323
4324 2003-12-16  Martin Baulig  <martin@ximian.com>
4325
4326         * statement.cs (LocalInfo.Assigned): Removed this property.
4327         (LocalInfo.Flags): Removed `Assigned'.
4328         (LocalInfo.IsAssigned): New public method; takes the EmitContext
4329         and uses flow analysis.
4330         (Block.UsageWarning): Made this method private.
4331         (Block.Resolve): Call UsageWarning() if appropriate.
4332
4333         * expression.cs (LocalVariableReference.DoResolve): Always set
4334         LocalInfo.Used here.
4335
4336 2003-12-13  Martin Baulig  <martin@ximian.com>
4337
4338         * statement.cs (Statement.DoEmit, Statement.Emit): Don't return
4339         any value here; we're now using flow analysis to figure out
4340         whether a statement/block returns a value.
4341
4342 2003-12-13  Martin Baulig  <martin@ximian.com>
4343
4344         * flowanalysis.cs (UsageVector.MergeFinallyOrigins): Made this
4345         working again.
4346         (FlowBranching.MergeFinally): Don't call
4347         `branching.CheckOutParameters()' here, this is called in
4348         MergeTopBlock().
4349         (FlowBranchingException.AddSibling): Call MergeFinallyOrigins()
4350         when adding the `finally' vector.       
4351
4352 2003-12-13  Martin Baulig  <martin@ximian.com>
4353
4354         * flowanalysis.cs
4355         (UsageVector.MergeJumpOrigins, FlowBranching.Label): Make this
4356         actually work and also fix #48962.
4357
4358 2003-12-12 Ben Maurer  <bmaurer@users.sourceforge.net>
4359
4360         * decl.cs: Do not check System.Object for nested types,
4361         since we know it does not have any. Big bang for buck:
4362
4363         BEFORE:
4364            Run 1:   8.35 seconds
4365            Run 2:   8.32 seconds
4366            corlib:  17.99 seconds
4367         AFTER:
4368            Run 1:   8.17 seconds
4369            Run 2:   8.17 seconds
4370            corlib:  17.39 seconds
4371
4372 2003-12-11 Ben Maurer  <bmaurer@users.sourceforge.net>
4373
4374         * class.cs (FindMembers): Allocate arraylists on demand. Most of the
4375         time we are returning 0 members, so we save alot here.
4376
4377 2003-12-11  Martin Baulig  <martin@ximian.com>
4378
4379         * flowanalysis.cs (UsageVector.MergeResult): Renamed this back to
4380         `MergeChild()', also just take the `FlowBranching' as argument;
4381         call Merge() on it and return the result.
4382         (FlowBranching.Merge): We don't need to do anything if we just
4383         have one sibling.
4384
4385 2003-12-11  Martin Baulig  <martin@ximian.com>
4386
4387         * flowanalysis.cs: Use a list of `UsageVector's instead of storing
4388         them in an `ArrayList' to reduce memory usage.  Thanks to Ben
4389         Maurer for this idea.
4390
4391 2003-12-11  Martin Baulig  <martin@ximian.com>
4392
4393         * flowanalysis.cs (MergeResult): This class is now gone; we now
4394         use the `UsageVector' for this.  The reason for this is that if a
4395         branching just has one sibling, we don't need to "merge" them at
4396         all - that's the next step to do.
4397         (FlowBranching.Merge): We now return a `UsageVector' instead of a
4398         `MergeResult'.
4399
4400 2003-12-11  Martin Baulig  <martin@ximian.com>
4401
4402         Reworked flow analyis and made it more precise and bug-free.  The
4403         most important change is that we're now using a special `Reachability'
4404         class instead of having "magic" meanings of `FlowReturns'.  I'll
4405         do some more cleanups and optimizations and also add some more
4406         documentation this week.
4407
4408         * flowanalysis.cs (Reachability): Added `Throws' and `Barrier';
4409         largely reworked this class.
4410         (FlowReturns): Removed `Unreachable' and `Exception'; we now use
4411         the new `Reachability' class instead of having "magic" values here.
4412         (FlowBranching): We're now using an instance of `Reachability'
4413         instead of having separate `Returns', `Breaks' etc. fields.
4414
4415         * codegen.cs (EmitContext.EmitTopBlock): Set `has_ret' solely
4416         based on flow analysis; ignore the return value of block.Emit ().
4417
4418 2003-12-10  Zoltan Varga  <vargaz@freemail.hu>
4419
4420         * driver.cs typemanager.cs: Find the mono extensions to corlib even
4421         if they are private.
4422
4423 2003-12-09  Martin Baulig  <martin@ximian.com>
4424
4425         * flowanalyis.cs (FlowBranching.Return, Goto, Throw): Removed;
4426         call them directly on the UsageVector.
4427
4428 2003-12-09  Martin Baulig  <martin@ximian.com>
4429
4430         * flowanalysis.cs (FlowBranching.MergeChild, MergeTopBlock):
4431         Changed return type from `FlowReturns' to `Reachability'.
4432
4433 2003-12-09  Martin Baulig  <martin@ximian.com>
4434
4435         * flowanalysis.cs (FlowBranching.Reachability): New sealed class.
4436         (FlowBranching.MergeResult): Replaced the `Returns', `Breaks' and
4437         `Reachable' fields with a single `Reachability' one.
4438
4439 2003-12-08 Ben Maurer  <bmaurer@users.sourceforge.net>
4440
4441         * class.cs (FindMembers): Remove foreach's.
4442
4443         Bootstrap times:
4444
4445         BEFORE
4446                 Run 1:   8.74 seconds
4447                 Run 2:   8.71 seconds
4448
4449         AFTER
4450                 Run 1:   8.64 seconds
4451                 Run 2:   8.58 seconds
4452
4453
4454 2003-12-08 Ben Maurer  <bmaurer@users.sourceforge.net>
4455
4456         * cs-parser.jay:
4457         * gen-treedump.cs:
4458         * statement.cs:
4459         This patch does a few things:
4460                 1. EmptyStatement is now a singleton, so it is never reallocated.
4461                 2. All blah is EmptyStatement constructs have been changed to
4462                    blah == EmptyStatement.Value, which is much faster and valid
4463                    now that EmptyStatement is a singleton.
4464                 3. When resolving a block, rather than allocating a new array for
4465                    the non-empty statements, empty statements are replaced with
4466                    EmptyStatement.Value
4467                 4. Some recursive functions have been made non-recursive.
4468         Mainly the performance impact is from (3), however (1) and (2) are needed for
4469         this to work. (4) does not make a big difference in normal situations, however
4470         it makes the profile look saner.
4471
4472         Bootstrap times:
4473
4474         BEFORE
4475         9.25user 0.23system 0:10.28elapsed 92%CPU (0avgtext+0avgdata 0maxresident)k
4476         9.34user 0.13system 0:10.23elapsed 92%CPU (0avgtext+0avgdata 0maxresident)k
4477         Total memory allocated: 56397 KB
4478
4479         AFTER
4480         9.13user 0.09system 0:09.64elapsed 95%CPU (0avgtext+0avgdata 0maxresident)k
4481         8.96user 0.24system 0:10.13elapsed 90%CPU (0avgtext+0avgdata 0maxresident)k
4482         Total memory allocated: 55666 KB
4483
4484 2003-12-08 Ben Maurer  <bmaurer@users.sourceforge.net>
4485
4486         * support.cs: Rewrite DoubleHash to use its own impl. Is faster
4487         than the hashtable in a hashtable version
4488
4489         * decl.cs: Right now, whenever we try to lookup a type inside a namespace,
4490         we always end up concating a string. This results in a huge perf
4491         loss, because many strings have to be tracked by the GC. In this
4492         patch, we first use a hashtable that works with two keys, so that
4493         the strings do not need to be concat'ed.
4494
4495         Bootstrap times:
4496         BEFORE
4497                 Run 1:   8.74 seconds
4498                 Run 2:   8.71 seconds
4499
4500         AFTER
4501                 Run 1:   8.65 seconds
4502                 Run 2:   8.56 seconds
4503
4504 2003-12-08 Ben Maurer  <bmaurer@users.sourceforge.net>
4505
4506         * Makefile: Add a new target `do-time' that does a quick and simple
4507         profile, leaving easy to parse output.
4508
4509 2003-12-08  Zoltan Varga  <vargaz@freemail.hu>
4510
4511         * codegen.cs (Init): Create the dynamic assembly with 
4512         AssemblyBuilderAccess.Save, to enable some optimizations in the runtime.
4513
4514 2003-12-02 Ben Maurer  <bmaurer@users.sourceforge.net>
4515
4516         * support.cs: Make the PtrHashtable use only one
4517         instance of its comparer.
4518
4519 2003-11-30  Zoltan Varga  <vargaz@freemail.hu>
4520
4521         * typemanager.cs: Fix lookup of GetNamespaces.
4522
4523 2003-11-29  Miguel de Icaza  <miguel@ximian.com>
4524
4525         * expression.cs: Removed redundant line.
4526
4527         * statement.cs (Block.Resolve, Block.Emit): Avoid foreach on
4528         ArrayLists, use for loops with bounds.  
4529
4530         * flowanalysis.cs (FlowBranching.Merge): Avoid foreach on
4531         arraylist.
4532
4533         * expression.cs (Invocation.OverloadResolve): Avoid foreach on
4534         arraylists, use for loop with bounds.
4535
4536         The above three changes give us a 0.071 second performance
4537         improvement out of 3.294 seconds down to 3.223.  On my machine
4538         the above changes reduced the memory usage by 1,387 KB during
4539         compiler bootstrap.
4540
4541         * cs-parser.jay (QualifiedIdentifier): New class used to represent
4542         QualifiedIdentifiers.  Before we created a new string through
4543         concatenation, and mostly later on, the result would be
4544         manipulated by DecomposeQI through string manipulation.
4545
4546         This reduced the compiler memory usage for bootstrapping from
4547         59380 KB to 59007 KB on my machine, 373 KB, and also reduced the
4548         compile times in 0.05 seconds.
4549
4550 2003-11-28  Dick Porter  <dick@ximian.com>
4551
4552         * support.cs: Do string compares with the Invariant culture.
4553
4554         * rootcontext.cs: 
4555         * gen-treedump.cs: 
4556         * expression.cs: 
4557         * driver.cs: 
4558         * decl.cs: 
4559         * codegen.cs: 
4560         * class.cs: Use the char forms of IndexOf and LastIndexOf, so that
4561         the comparison is done with the Invariant culture.
4562
4563 2003-11-27  Miguel de Icaza  <miguel@ximian.com>
4564
4565         * statement.cs (Foreach.TryType): Use DeclaredOnly to find the
4566         GetEnumerator method.
4567
4568         (ProbeCollectionType): Iterate starting at the most specific type
4569         upwards looking for a GetEnumerator
4570
4571         * expression.cs: Shift count can be up to 31 for int/uint and 63
4572         for long/ulong.
4573
4574 2003-11-26  Miguel de Icaza  <miguel@ximian.com>
4575
4576         * statement.cs (Block.LookupLabel): Also look for the label on the
4577         children blocks.  Use a hash table to keep track of visited
4578         nodes. 
4579
4580         * cfold.cs (IntConstant to UIntConstant mapping): Only return if
4581         we actually did transform the other operand, otherwise fall back
4582         to the common codepath that casts to long.
4583
4584         * cs-tokenizer.cs: Use the same code pattern as the int case.
4585         Maybe I should do the parsing myself, and avoid depending on the
4586         Parse routines to get this done.
4587
4588 2003-11-25  Miguel de Icaza  <miguel@ximian.com>
4589
4590         * expression.cs: Apply fix from l_m@pacbell.net (Laurent Morichetti),  
4591         which fixes bug 51347.  This time test it.
4592
4593         * expression.cs: Make TypeOfVoid derive from TypeOf, so code in
4594         attributes for example can not tell the difference between these.
4595         The difference was only a syntax feature of the language. 
4596
4597         * attribute.cs: Apply attributes to delegates.
4598
4599         * delegate.cs: Call the apply attributes method.
4600
4601 2003-11-24  Miguel de Icaza  <miguel@ximian.com>
4602
4603         * convert.cs (TryImplicitIntConversion): One line bug fix: we were
4604         comparing 0 vs Byte.MinValue, not the value
4605
4606         (ImplicitConversionRequired): When reporting a conversion error,
4607         use error 31 to print out the constant error instead of the
4608         simpler 29.
4609
4610         * expression.cs: Apply fix from l_m@pacbell.net (Laurent Morichetti),  
4611         which fixes bug 51347.
4612
4613 2003-11-22  Miguel de Icaza  <miguel@ximian.com>
4614
4615         * driver.cs: Applied patch from gert.driesen@pandora.be (Gert Driesen) 
4616         which fixes the -warnaserror command line option.
4617
4618 2003-11-21  Miguel de Icaza  <miguel@ximian.com>
4619
4620         * cfold.cs (DoNumericPromotions): During constant folding of
4621         additions on UIntConstant, special case intconstants with
4622         IntConstants like we do on the expression binary operator. 
4623
4624 2003-11-12  Miguel de Icaza  <miguel@ximian.com>
4625
4626         * convert.cs (ImplicitReferenceConversion): We were missing a case
4627         (System.Enum are not value types or class types, so we need to
4628         classify them separatedly).
4629
4630         * driver.cs: We do not support error 2007.
4631
4632 2003-11-12 Jackson Harper <jackson@ximian.com>
4633
4634         * driver.cs: Use corlib.dll or mscorlib.dll when looking up the
4635         system directory. Also use the full file name so users can
4636         libraries names mscorlib-o-tron.dll in a non system dir.
4637
4638 2003-11-10  Martin Baulig  <martin@ximian.com>
4639
4640         * typemanager.cs (TypeManager.ResolveExpressionTypes): Removed.
4641         (TypeManager.InitCoreTypes): Initialize them here, but instead of
4642         calling `ResolveType()' on them, directly assign their `Type'.
4643
4644 2003-11-08  Martin Baulig  <martin@ximian.com>
4645
4646         * class.cs (TypeContainer.GetClassBases): Use TypeExpr's for the
4647         return value and the `out parent' parameter.
4648         (TypeContainer.DefineType): Moved the CS0644 check into
4649         GetClassBases().  Don't pass the interface types to the
4650         `builder.DefineType()'/`builder.DefineNestedType()', but resolve
4651         them later and then call `TypeBuilder.AddInterfaceImplementation()'.
4652
4653         * ecore.cs (TypeExpr.IsAttribute): New property.
4654         (TypeExpr.GetInterfaces): New method.
4655
4656         * interface.cs (Interface.GetInterfaceTypeByName): Return a
4657         TypeExpr instead of a Type.
4658         (Interface.GetInterfaceBases): Return TypeExpr's instead of Type's.
4659         (Interface.DefineType): Don't pass the interface types to the
4660         `builder.Definetype()'/`builder.DefineNestedType()', but resolve
4661         them later and then call `TypeBulider.AddInterfaceImplementation()'.
4662
4663         * typemanager.cs (TypeManager.AddUserType): Take a `TypeExpr[]'
4664         instead of a `Type[]'.
4665         (TypeManager.RegisterBuilder): Likewise.
4666         (TypeManager.AddUserInterface): Likewise.
4667         (TypeManager.ExpandInterfaces): Take a `Type[]' instead of a
4668         `Type[]' and also return a `TypeExpr[]'.
4669         (TypeManager.GetInterfaces): Return a `TypeExpr[]'.
4670
4671 2003-11-08  Martin Baulig  <martin@ximian.com>
4672
4673         * decl.cs (DeclSpace.ResolveTypeExpr): Return a TypeExpr, not an
4674         Expression.     
4675
4676 2003-11-08  Martin Baulig  <martin@ximian.com>
4677
4678         * decl.cs (DeclSpace.GetTypeResolveEmitContext): Call
4679         TypeManager.ResolveExpressionTypes().
4680
4681         * ecore.cs (Expression.ResolveAsTypeTerminal): Return a TypeExpr
4682         instead of an Expression.
4683         (TypeExpr): This is now an abstract base class for `TypeExpression'.
4684         (TypeExpression): New public class; formerly known as `TypeExpr'.
4685
4686         * expression.cs (ComposedCast): Derive from TypeExpr.
4687
4688         * typemanager.cs (TypeManager.system_*_expr): These are now
4689         TypExpr's instead of Expression's.
4690         (TypeManager.ResolveExpressionTypes): New public static function;
4691         called from DeclSpace.GetTypeResolveEmitContext() to resolve all
4692         of them.        
4693
4694 2003-11-06  Miguel de Icaza  <miguel@ximian.com>
4695
4696         * expression.cs (New.DoResolve): Do not dereference value that
4697         might be a null return.
4698
4699         * statement.cs (Block.EmitMeta): Use the Const.ChangeType to make
4700         sure that the constant value has the right type.  Fixes an
4701         unreported bug, similar to 50425.
4702
4703         * const.cs (Const.LookupConstantValue): Call
4704         ImplicitStandardConversionExists before doing a conversion to
4705         avoid havng the TypeManager.ChangeType do conversions.
4706
4707         Reduced the number of casts used
4708
4709         (Const.ChangeType): New routine to enable reuse of the constant
4710         type changing code from statement.
4711
4712         * typemanager.cs (ChangeType): Move common initialization to
4713         static global variables.
4714
4715         Fixes #50425.
4716
4717         * convert.cs (ImplicitReferenceConversion): Somehow we allowed
4718         every value type to go through, even if it was void.  Fix that. 
4719
4720         * cs-tokenizer.cs: Use is_identifier_start_character on the start
4721         character of the define, and the is_identifier_part_character for
4722         the rest of the string.
4723
4724 2003-11-05  Miguel de Icaza  <miguel@ximian.com>
4725
4726         * expression.cs (UnaryMutator.EmitCode): When I updated
4727         LocalVariableReference.DoResolve, I overdid it, and dropped an
4728         optimization done on local variable references.
4729
4730 2003-11-04  Miguel de Icaza  <miguel@ximian.com>
4731
4732         * ecore.cs: Convert the return from Ldlen into an int.
4733
4734 2003-10-20  Miguel de Icaza  <miguel@ximian.com>
4735
4736         * decl.cs (DeclSpace.GetAccessLevel): Handle NotPublic case for
4737         the accessibility, this is a special case for toplevel non-public
4738         classes (internal for instance).
4739
4740 2003-10-20  Nick Drochak <ndrochak@gol.com>
4741
4742         * ecore.cs: Fix typo and build.  Needed another right paren.
4743
4744 2003-10-19  Miguel de Icaza  <miguel@ximian.com>
4745
4746         * ecore.cs: Applied fix from Ben Maurer.   We were handling in the
4747         `internal' case regular and protected, but not allowing protected
4748         to be evaluated later.  Bug 49840
4749
4750 2003-10-15  Miguel de Icaza  <miguel@ximian.com>
4751
4752         * statement.cs (Switch.TableSwitchEmit): Compare the upper bound
4753         to kb.Nlast, and not the kb.nFirst to isolate the switch
4754         statement.
4755
4756         Extract the underlying type, so enumerations of long/ulong are
4757         treated like long/ulong.
4758
4759 2003-10-14  Miguel de Icaza  <miguel@ximian.com>
4760
4761         * expression.cs (New): Overload the meaning of RequestedType to
4762         track the possible creation of the NewDelegate type, since
4763         DoResolve is invoked more than once for new constructors on field
4764         initialization.
4765
4766         See bugs: #48800 and #37014
4767
4768         * cs-parser.jay (declare_local_constants): Take an arraylist
4769         instead of a single constant.
4770
4771         (local_constant_declaration): It should take a
4772         constant_declarators, not a constant_declarator.  Fixes 49487
4773
4774         * convert.cs: Fix error report.
4775
4776 2003-10-13 Jackson Harper <jackson@ximian.com>
4777
4778         * typemanager.cs (TypeToCoreType): Add float and double this fixes
4779         bug #49611
4780
4781 2003-10-09  Martin Baulig  <martin@ximian.com>
4782
4783         * class.cs (MethodCore): Added additional `DeclSpace ds' argument
4784         to the .ctor.
4785         (MethodCore.DoDefineParameters): Removed the TypeContainer
4786         argument; use the DeclSpace which was passed to the .ctor instead.
4787         (MethodCore.CheckParameter): Take a DeclSpace instead of a
4788         TypeContainer; we only need a DeclSpace here.
4789
4790 2003-10-09  Martin Baulig  <martin@ximian.com>
4791
4792         * class.cs (MethodData): Added additional `DeclSpace ds' argument
4793         to the .ctor.
4794         (MethodData.Define, MethodData.Emit): Pass the `ds' to the
4795         EmitContext's .ctor.    
4796
4797 2003-10-09  Martin Baulig  <martin@ximian.com>
4798
4799         * decl.cs (DeclSpace.AsAccessible): Moved here from TypeContainer.
4800         (AccessLevel, CheckAccessLevel, GetAccessLevel): They're used by
4801         AsAccessible(), moved them as well.
4802
4803         * class.cs (TypeContainer.AsAccessible): Moved to DeclSpace.
4804
4805 2003-10-08  Atsushi Enomoto <ginga@kit.hi-ho.ne.jp>
4806
4807         * cs-parser.jay : Renamed yyName to yyNames related to jay.
4808
4809 2003-10-07  Miguel de Icaza  <miguel@ximian.com>
4810
4811         * expression.cs (Binary.Emit.GreatherThanOrEqual): Fix the code
4812         generation for >=, as spotted by Paolo, bug 48679.  
4813         Patch from David Waite.
4814
4815         * cs-tokenizer.cs: Add handling for #pragma.
4816
4817         * cs-parser.jay: Allow for both yield and yield return in the
4818         syntax.  The anti-cobolization of C# fight will go on!
4819
4820         * class.cs (TypeBuilder.DefineType): Catch error condition here
4821         (Parent.DefineType erroring out and returning null).
4822
4823         * expression.cs (ArrayCreation.EmitDynamicInitializers): When
4824         coping with enumerations variables, we were mistakenly processing
4825         them as a regular value type instead of built-in types.  Fixes the
4826         bug #48063
4827
4828         * typemanager.cs (IsBuiltinOrEnum): New method.
4829
4830 2003-09-30  Miguel de Icaza  <miguel@ximian.com>
4831
4832         * cs-parser.jay: Upgrade: yield now needs the return clause.
4833
4834 2003-09-19  Martin Baulig  <martin@ximian.com>
4835
4836         * decl.cs (MemberCache.SetupCacheForInterface): Take a
4837         `MemberCache parent' argument.  Normally, an interface doesn't
4838         have a parent type except System.Object, but we use this in gmcs
4839         for generic type parameters.
4840
4841 2003-09-18  Martin Baulig  <martin@ximian.com>
4842
4843         * typemanager.cs (TypeHandle.ctor): Set `IsInterface' solely based
4844         on `type.IsInterface'; don't check whether the type has a parent
4845         to determine whether it's an interface.
4846
4847 2003-09-15  Martin Baulig  <martin@ximian.com>
4848
4849         * class.cs (TypeContainer.DefineType): Added an error flag to
4850         avoid reporting duplicate CS0146's ("class definition is
4851         circular.").
4852
4853         * driver.cs (Driver.MainDriver): Abort if
4854         RootContext.ResolveTree() reported any errors.
4855
4856 2003-09-07  Martin Baulig  <martin@ximian.com>
4857
4858         * report.cs (Error, Warning): Added overloaded versions which take
4859         a `params object[] args' and call String.Format().
4860
4861 2003-09-07  Martin Baulig  <martin@ximian.com>
4862
4863         * decl.cs (DeclSpace..ctor): Don't call
4864         NamespaceEntry.DefineName() here; do it in RecordDecl() which is
4865         called from Tree.RecordDecl().  Fixes the CS0101 reporting.
4866         (DeclSpace.RecordDecl): New method.
4867
4868         * tree.cs (Tree.RecordDecl): Call ds.RecordDecl().
4869
4870 2003-09-02  Ravi Pratap  <ravi@ximian.com>
4871
4872         * attribute.cs (CheckAttributeTarget): Ensure that we allow return
4873         value attributes to be applied to ParameterBuilders.
4874
4875         * class.cs (MethodCore.LabelParameters): Make static and more
4876         generic so that it can be used from other places - like interface
4877         methods, for instance.
4878
4879         * interface.cs (Interface.Emit): Call LabelParameters before
4880         emitting attributes on the InterfaceMethod.
4881
4882 2003-08-26  Martin Baulig  <martin@ximian.com>
4883
4884         * ecore.cs (SimpleName.SimpleNameResolve): Look for members before
4885         resolving aliases; fixes #47927.
4886
4887 2003-08-26  Martin Baulig  <martin@ximian.com>
4888
4889         * statement.cs (Using.DoResolve): This is internally emitting a
4890         try/finally clause, so we need to set ec.NeedExplicitReturn if we
4891         do not always return.  Fixes #47681.
4892
4893 2003-08-26  Martin Baulig  <martin@ximian.com>
4894
4895         * decl.cs (MemberCore): Moved WarningNotHiding(),
4896         Error_CannotChangeAccessModifiers() and CheckMethodAgainstBase()
4897         into MemberBase.
4898         (AdditionResult): Make this nested in DeclSpace.
4899         (DeclSpace.ctor): The .ctor now takes an additional NamespaceEntry
4900         argument; call NamespaceEntry.Define() unless we're nested in a
4901         class or struct.
4902
4903         * namespace.cs (Namespace.DefineName): New public function.  This
4904         is called from DeclSpace's .ctor to add 
4905         (Namespace.Lookup): Include DeclSpaces in the lookup.
4906
4907         * class.cs (Operator): Derive from MemberBase, not MemberCore.
4908
4909         * const.cs (Const): Derive from MemberBase, not MemberCore.     
4910
4911 2003-08-25  Martin Baulig  <martin@ximian.com>
4912
4913         * convert.cs (Convert.ExplicitReferenceConversion): When
4914         converting from an interface type to a class, unbox if the target
4915         type is a struct type.  Fixes #47822.
4916
4917 2003-08-24  Gonzalo Paniagua Javier <gonzalo@ximian.com>
4918
4919         * typemanager.cs: fixed the values of MethodFlags. Closes #47855 and
4920         #47854.
4921
4922 2003-08-22  Martin Baulig  <martin@ximian.com>
4923
4924         * class.cs (TypeManager.DefineType): When defining a nested type,
4925         call DefineType() on our parent; fixes #47801.
4926
4927 2003-08-22  Martin Baulig  <martin@ximian.com>
4928
4929         * class.cs (MethodData.Define): While checking if a method is an
4930         interface implementation, improve the test a bit more to fix #47654.
4931
4932 2003-08-22  Martin Baulig  <martin@ximian.com>
4933
4934         * expression.cs (Probe.DoResolve): Check whether `expr' resolved
4935         correctly; fixes #47722.
4936
4937 2003-08-22  Martin Baulig  <martin@ximian.com>
4938
4939         * expression.cs (UnaryMutator.ResolveVariable): If the target is a
4940         LocalVariableReference, ensure it's not read-only.  Fixes #47536.
4941
4942         * statement.cs (Fixed.DoResolve): Make all variables read-only. 
4943
4944 2003-08-22  Martin Baulig  <martin@ximian.com>
4945
4946         * ecore.cs (FieldExpr.DoResolveLValue): Static read-only fields
4947         can only be assigned in static constructors.  Fixes #47161.
4948
4949 2003-08-22  Martin Baulig  <martin@ximian.com>
4950
4951         Rewrote and improved the flow analysis code.
4952
4953         * flowbranching.cs (FlowBranching): Make this class abstract.
4954         (FlowBranching.CreateBranching): New static function to create a
4955         new flow branching.
4956         (FlowBranchingBlock, FlowBranchingException): New classes.
4957         (FlowBranching.UsageVector.Type): New public readonly field.
4958         (FlowBranching.UsageVector.Breaks): Removed the setter.
4959         (FlowBranching.UsageVector.Returns): Removed the setter.
4960         (FlowBranching.UsageVector): Added Break(), Return(),
4961         NeverReachable() and Throw() methods to modify the reachability.
4962         (FlowBranching.UsageVector.MergeChildren): Removed, this is now
4963         done by FlowBranching.Merge().
4964         (FlowBranching.UsageVector.MergeChild): New method; merges the
4965         merge result into the current vector.
4966         (FlowBranching.Merge): New abstract method to merge a branching.
4967
4968 2003-08-12  Martin Baulig  <martin@ximian.com>
4969
4970         * expression.cs (Indirection.CacheTemporaries): Create the
4971         LocalTemporary with the pointer type, not its element type.
4972
4973 2003-08-10  Miguel de Icaza  <miguel@ximian.com>
4974
4975         * cs-parser.jay: FIRST_KEYWORD, LAST_KEYWORD: used to know if a
4976         token was a keyword or not.
4977
4978         Add `error' options where an IDENTIFIER was expected;  Provide
4979         CheckToken and CheckIdentifierToken convenience error reporting
4980         functions. 
4981
4982         Do not use `DeclSpace.Namespace', use `DeclSpace.NamespaceEntry'.
4983
4984         * decl.cs: Rename `NamespaceEntry Namespace' public field into
4985         NameSpaceEntry NameSpaceEntry.
4986
4987         (LookupInterfaceOrClass): Avoid creating a full qualified name
4988         from namespace and name: avoid doing lookups when we know the
4989         namespace is non-existant.   Use new Tree.LookupByNamespace which
4990         looks up DeclSpaces based on their namespace, name pair.
4991
4992         * driver.cs: Provide a new `parser verbose' to display the
4993         exception thrown during parsing.  This is turned off by default
4994         now, so the output of a failure from mcs is more graceful.
4995
4996         * namespace.cs: Track all the namespaces defined in a hashtable
4997         for quick lookup.
4998
4999         (IsNamespace): New method
5000
5001 2003-08-09  Miguel de Icaza  <miguel@ximian.com>
5002
5003         * namespace.cs: Remove redundant call;  Avoid using MakeFQN when
5004         we know that we need to concatenate (full typename can never be
5005         null). 
5006
5007         * class.cs: ditto.
5008
5009         * statement.cs: Use a bitfield;  Do not initialize to null things
5010         which are done by the constructor by default.
5011
5012         * cs-parser.jay: bug fix, parameter was 4, not 3.
5013
5014         * expression.cs: Just use the property;
5015
5016         * statement.cs: No need for GetVariableInfo method.
5017
5018 2003-08-08  Martin Baulig  <martin@ximian.com>
5019
5020         * flowanalysis.cs (FlowReturns): This is now nested in the
5021         `FlowBranching' class.
5022         (MyBitVector): Moved this here from statement.cs.
5023         (FlowBranching.SiblingType): New enum type.
5024         (FlowBranching.CreateSibling): Added `SiblingType' argument.
5025
5026 2003-08-07  Martin Baulig  <martin@ximian.com>
5027
5028         * flowanalysis.cs (FlowBranchingType): This is now nested in the
5029         `FlowBranching' class and called `BranchingType'.
5030
5031 2003-08-07  Martin Baulig  <martin@ximian.com>
5032
5033         * flowanalysis.cs: Moved all the control flow analysis code into
5034         its own file.
5035
5036 2003-08-07  Martin Baulig  <martin@ximian.com>
5037
5038         * assign.cs (Assign.DoResolve): `target' must either be an
5039         IAssignMethod or an EventAccess; report a CS0131 otherwise.  Fixes
5040         #37319.
5041
5042 2003-08-07  Miguel de Icaza  <miguel@ximian.com>
5043
5044         * expression.cs (BinaryMethod): This kind of expression is created by the
5045         Binary class if it determines that the operator has to be handled
5046         by a method.
5047
5048         (BinaryDelegate): This kind of expression is created if we are
5049         dealing with a + or - operator on delegates.
5050
5051         (Binary): remove method, argumetns, and DelegateOperator: when
5052         dealing with methods, 
5053
5054         * ecore.cs (EventExpr.EmitAddOrRemove): Update to new layout.
5055
5056         * statement.cs (Block): use bitfields for the three extra booleans
5057         we had in use.   Remove unused topblock parameter.
5058
5059         * codegen.cs: Remove unecessary argument to Block.EmitTopBlock
5060
5061         * assign.cs: Drop extra unneeded tests.
5062
5063 2003-08-06  Miguel de Icaza  <miguel@ximian.com>
5064
5065         * iterators.cs (Mapvariable): provide a mechanism to use prefixes.
5066
5067         * statement.cs (Foreach): Use VariableStorage instead of
5068         LocalBuilders.   
5069
5070         * codegen.cs (VariableStorage): New class used by clients that
5071         require a variable stored: locals or fields for variables that
5072         need to live across yield.
5073
5074         Maybe provide a convenience api for EmitThis+EmitLoad?
5075
5076         (GetTemporaryLocal, FreeTemporaryLocal): Recycle
5077         these bad boys.
5078
5079 2003-08-05  Miguel de Icaza  <miguel@ximian.com>
5080
5081         * codegen.cs (RemapLocal, RemapLocalLValue, RemapParameter,
5082         RemapParameterLValue): New methods that are used to turn a
5083         precomputed FieldInfo into an expression like this:
5084
5085                 instance.FieldInfo
5086
5087         The idea is to use this instead of making LocalVariableReference
5088         have more than one meaning.
5089
5090         * cs-parser.jay: Add error production to BASE.
5091
5092         * ecore.cs: Deal with TypeManager.GetField returning null, which
5093         is now a valid return value.
5094
5095         (FieldExprNoAddress): New expression for Fields whose address can
5096         not be taken.
5097
5098         * expression.cs (LocalVariableReference): During the resolve
5099         phases, create new expressions if we are in a remapping context.
5100         Remove code that dealt with remapping here.
5101
5102         (ParameterReference): same.
5103
5104         (ProxyInstance): New expression, like the `This' expression, but
5105         it is born fully resolved.  We know what we are doing, so remove
5106         the errors that are targeted to user-provided uses of `this'.
5107
5108         * statement.cs (Foreach): our variable is now stored as an
5109         Expression;  During resolution, follow the protocol, dont just
5110         assume it will return this.
5111
5112 2003-08-06  Martin Baulig  <martin@ximian.com>
5113
5114         * support.cs (SeekableStreamReader.cs): New public class.
5115
5116         * cs-tokenizer.cs, cs-parser.jay, driver.cs: Use the new
5117         SeekableStreamReader instead of the normal StreamReader.
5118
5119 2003-08-04  Martin Baulig  <martin@ximian.com>
5120
5121         * cs-parser.jay (CLOSE_PARENS_CAST, CLOSE_PARENS_NO_CAST,
5122         CLOSE_PARENS_OPEN_PARENS, CLOSE_PARENS_MINUS): New tokens to
5123         deambiguate casts and delegate invocations.
5124         (parenthesized_expression): Use the new tokens to ensure this is
5125         not a cast of method invocation.
5126
5127         * cs-tokenizer.cs (is_punct): Return one of the new special tokens
5128         when reading a `)' and Deambiguate_CloseParens () was previously
5129         called.
5130
5131         * expression.cs (ParenthesizedExpression): New class.  This is
5132         just used for the CS0075 test.
5133         (Binary.DoResolve): Check for CS0075.   
5134
5135 2003-07-29  Ravi Pratap  <ravi@ximian.com>
5136
5137         * expression.cs (Invocation.MakeUnionSet): Patch from Lluis
5138         Sanchez : use TypeManager.ArrayContainsMethod instead of a direct
5139         reference comparison.
5140
5141         (TypeManager.ArrayContainsMethod): When we have a MethodInfo, also
5142         examine the ReturnType for equality - this is necessary in the
5143         cases of implicit and explicit operators whose signature also
5144         includes the return type.
5145
5146 2003-07-26  Miguel de Icaza  <miguel@ximian.com>
5147
5148         * namespace.cs: Cache the result of the namespace computation,
5149         instead of computing it every time.
5150
5151 2003-07-24  Miguel de Icaza  <miguel@ximian.com>
5152
5153         * decl.cs: Use a global arraylist that we reuse over invocations
5154         to avoid excesive memory consumption.  Reduces memory usage on an
5155         mcs compile by one meg (45 average).
5156
5157         * typemanager.cs (LookupTypeReflection): In .NET pointers are
5158         private, work around that.
5159
5160 2003-07-23  Miguel de Icaza  <miguel@ximian.com>
5161
5162         * literal.cs (IntLiteral): Define Zero and One static literals. 
5163
5164         * cs-parser.jay (integer_literal): use static literals to reduce
5165         memory usage for the most used literals (0, 1 and -1).  211kb
5166         reduced in memory usage.
5167
5168         Replace all calls to `new ArrayList' with `new
5169         ArrayList(4)' which is a good average number for most allocations,
5170         and also requires only 16 bytes of memory for its buffer by
5171         default. 
5172
5173         This reduced MCS memory usage in seven megabytes for the RSS after
5174         bootstrapping.
5175
5176 2003-07-28  Ravi Pratap  <ravi@ximian.com>
5177
5178         * expression.cs (Invocation.OverloadResolve): Fix the algorithm to
5179         handle params methods the correct way by forming only one
5180         applicable set with params and normal methods in them. Earlier we
5181         were looking at params methods only if we found no normal methods
5182         which was not the correct thing to do.
5183
5184         (Invocation.BetterFunction): Take separate arguments indicating
5185         when candidate and the best method are params methods in their
5186         expanded form.
5187
5188         This fixes bugs #43367 and #46199.
5189
5190         * attribute.cs: Documentation updates.
5191
5192         (CheckAttribute): Rename to CheckAttributeTarget.
5193         (GetValidPlaces): Rename to GetValidTargets.
5194
5195         * expression.cs (Invocation.IsParamsMethodApplicable): Fix trivial
5196         bug - use Convert.ImplicitConversion, not ImplicitUserConversion!
5197
5198         Fixes bug #44468.
5199
5200 2003-07-28  Martin Baulig  <martin@ximian.com>
5201
5202         * class.cs (TypeContainer.DefineMembers): Use the base type's full
5203         name when looking up the base class of a nested class.  Fixes #46977.
5204
5205 2003-07-26  Martin Baulig  <martin@ximian.com>
5206
5207         * expression.cs (Indexers.Indexer): New nested struct; contains
5208         getter, setter and the indexer's type.
5209         (Indexers.Properties): This is now an ArrayList of
5210         Indexers.Indexer's.
5211         (IndexerAccess.DoResolveLValue): Correctly set the type if the
5212         indexer doesn't have any getters.
5213
5214         * assign.cs (Assign.DoResolve): Also do the implicit conversions
5215         for embedded property and indexer assignments.
5216
5217 2003-07-26  Martin Baulig  <martin@ximian.com>
5218
5219         * cs-tokenizer.cs (Tokenizer.xtoken): Report a CS1040 if a
5220         preprocessor directive is not the first non-whitespace character
5221         on a line.
5222
5223 2003-07-26  Martin Baulig  <martin@ximian.com>
5224
5225         * namespace.cs (NamespaceEntry.Lookup): New method; rewrote the
5226         namespace parsing, follow the spec more closely.
5227
5228         * rootcontext.cs (RootContext.NamespaceLookup): Use the new
5229         NamespaceEntry.Lookup().
5230
5231 2003-07-25  Martin Baulig  <martin@ximian.com>
5232
5233         * MethodCore.cs (OverridesSomething): New public field; it's set
5234         from TypeContainer.DefineMembers if this method overrides
5235         something (which doesn't need to be a method).  Fix #39462.
5236
5237 2003-07-25  Ravi Pratap  <ravi@ximian.com>
5238
5239         * typemanager.cs (GetMembers): Ensure that the list of members is
5240         reversed. This keeps things in sync.
5241
5242         * attribute.cs (Attribute.CheckAttribute): Break as soon as we
5243         find an AttributeUsage attribute.
5244
5245         * expression.cs (Invocation.OverloadResolve): Perform the check
5246         which disallows Invoke to be directly called on a Delegate.
5247
5248         (Error_InvokeOnDelegate): Report error cs1533.
5249
5250 2003-07-25  Martin Baulig  <martin@ximian.com>
5251
5252         * expression.cs (Indexers.GetIndexersForType): Only look in the
5253         interface hierarchy if the requested type is already an
5254         interface.  Fixes #46788 while keeping #46502 fixed.
5255
5256 2003-07-25  Martin Baulig  <martin@ximian.com>
5257
5258         * class.cs (TypeContainer.DefineMembers): Check whether all
5259         readonly fields have been assigned and report warning CS0649 if
5260         not.
5261
5262         * statement.cs (LocalInfo.IsFixed): Always return true if this is
5263         a valuetype.
5264
5265 2003-07-24  Ravi Pratap  <ravi@ximian.com>
5266
5267         * decl.cs (MemberCache.AddMethods): Reverse the order of the array
5268         returned from GetMethods to make things consistent with the
5269         assumptions MCS makes about ordering of methods.
5270
5271         This should comprehensively fix bug #45127 and it does :-)
5272
5273         * ecore.cs (MethodGroupExpr.DeclaringType): Correct bug - the
5274         ordering is actually reverse.
5275
5276         * Clean up some debug messages I left lying around.
5277
5278         * interface.cs (Populate*): Get rid of code which emits attributes
5279         since the stage in which we emit attributes is the 'Emit' stage,
5280         not the define stage.
5281
5282         (Emit): Move attribute emission for interface members here.
5283
5284 2003-07-22  Ravi Pratap  <ravi@ximian.com>
5285
5286         * expression.cs (Invocation.OverloadResolve): Follow the spec more
5287         closely: we eliminate methods in base types when we have an
5288         applicable method in a top-level type.
5289
5290         Please see section 14.5.5.1 for an exact description of what goes
5291         on. 
5292
5293         This fixes bug #45127 and a host of other related to corlib compilation.
5294
5295         * ecore.cs (MethodGroupExpr.DeclaringType): The element in the
5296         array is the method corresponding to the top-level type (this is
5297         because of the changes made to icall.c) so we change this
5298         accordingly.
5299
5300         (MethodGroupExpr.Name): This too.
5301
5302         * typemanager.cs (GetElementType): New method which does the right
5303         thing when compiling corlib. 
5304
5305         * everywhere: Make use of the above in the relevant places.
5306
5307 2003-07-22  Martin Baulig  <martin@ximian.com>
5308
5309         * cs-parser.jay (invocation_expression): Moved
5310         `OPEN_PARENS expression CLOSE_PARENS unary_expression' here from
5311         `cast_expression', but create a InvocationOrCast which later
5312         resolves to either an Invocation or a Cast.
5313
5314         * ecore.cs (ExpressionStatement.ResolveStatement): New virtual
5315         method; call this before EmitStatement() to make sure that this
5316         expression can be used as a statement.
5317
5318         * expression.cs (InvocationOrCast): New class; resolves to either
5319         an Invocation or a Cast.
5320
5321         * statement.cs (StatementExpression): Call ResolveStatement() on
5322         the ExpressionStatement before emitting it.
5323
5324 2003-07-21  Martin Baulig  <martin@ximian.com>
5325
5326         * expression.cs (Invocation.VerifyArgumentsCompat): Check whether
5327         `ref' and `out' attributes match; fixes #46220.
5328         (MemberAccess.ResolveMemberAccess): You can't reference a type
5329         through an expression; fixes #33180.
5330         (Indexers.GetIndexersForType): Don't return the indexers from
5331         interfaces the class implements; fixes #46502.
5332
5333 2003-07-21  Martin Baulig  <martin@ximian.com>
5334
5335         * class.cs (TypeContainer.CheckPairedOperators): Added CS0660 and
5336         CS0661 checks; fixes bug #30442.
5337
5338 2003-07-21  Martin Baulig  <martin@ximian.com>
5339
5340         * decl.cs (AdditionResult): Added `Error'.
5341
5342         * enum.cs (AddEnumMember): Report a CS0076 if name is `value__'.
5343
5344         * typemanager.cs (TypeManager.ChangeType): Catch exceptions;
5345         makes cs0031.cs actually work.
5346
5347 2003-07-20  Martin Baulig  <martin@ximian.com>
5348
5349         * namespace.cs: Fixed that bug which caused a crash when compiling
5350         the debugger's GUI.
5351
5352 2003-07-20  Miguel de Icaza  <miguel@ximian.com>
5353
5354         * typemanager.cs (LookupTypeReflection): Never expose types which
5355         are NotPublic, NestedPrivate, NestedAssembly, or
5356         NestedFamANDAssem.  We used to return these, and later do a check
5357         that would report a meaningful error, but the problem is that we
5358         would not get the real match, if there was a name override.
5359
5360 2003-07-18  Miguel de Icaza  <miguel@ximian.com>
5361
5362         * namespace.cs (Namespace, Name): Do not compute the namespace
5363         name dynamically, compute it in the constructor.  This reduced
5364         memory usage by 1697 KB.
5365
5366         * driver.cs: Use --pause to pause at the end.
5367
5368 2003-07-17  Peter Williams  <peter@newton.cx>
5369
5370         * Makefile: Change the name of the test target so that it doesn't
5371         conflict with the recursive test target.
5372
5373 2003-07-17  Miguel de Icaza  <miguel@ximian.com>
5374
5375         * expression.cs (LocalVariableReference.Emit, EmitAssign,
5376         AddressOf): Do not use EmitThis, that was wrong, use the actual
5377         this pointer.
5378
5379 2003-07-15  Miguel de Icaza  <miguel@ximian.com>
5380
5381         * class.cs (MethodData.Define): While checking if a method is an
5382         interface implementation, improve the test: If we are not public
5383         (use new test here: use the computed MethodAttributes directly,
5384         instead of the parsed modifier flags) check if the `implementing'
5385         method comes from an interface or not.
5386
5387         * pending.cs (VerifyPendingMethods): Slightly better error
5388         message.
5389
5390         * makefile: add test target that does the mcs bootstrap.
5391
5392 2003-07-16  Ravi Pratap  <ravi@ximian.com>
5393
5394         * interface.cs (Define): Do nothing here since there are no
5395         members to populate etc. Move the attribute emission out of here
5396         since this was just totally the wrong place to put it. Attribute
5397         application happens during the 'Emit' phase, not in the 'Define'
5398         phase.
5399
5400         (Emit): Add this method and move the attribute emission here
5401
5402         * rootcontext.cs (EmitCode): Call the Emit method on interface
5403         types too.
5404
5405 2003-07-14  Ravi Pratap M  <ravi@ximian.com>
5406
5407         * expression.cs (OverloadResolve): Report error only if Location
5408         is not 'Null' which means that there was a probe going on.
5409
5410 2003-07-14  Martin Baulig  <martin@ximian.com>
5411
5412         * expression.cs (ConditionalLogicalOperator): New public class to
5413         implement user defined conditional logical operators.
5414         This is section 14.11.2 in the spec and bug #40505.
5415
5416 2003-07-14  Martin Baulig  <martin@ximian.com>
5417
5418         * ecore.cs (FieldExpr.DoResolveLValue): Fixed bug #46198.
5419
5420 2003-07-14  Martin Baulig  <martin@ximian.com>
5421
5422         * codegen.cs (EmitContext.InFixedInitializer): New public field.
5423
5424         * ecore.cs (IVariable.VerifyFixed): New interface method.
5425
5426         * expression.cs (Unary.ResolveOperator): When resolving the `&'
5427         operator, check whether the variable is actually fixed.  Fixes bug
5428         #36055.  Set a variable definitely assigned when taking its
5429         address as required by the spec.
5430
5431         * statement.cs (LocalInfo.IsFixed): New field.
5432         (LocalInfo.MakePinned): Set `IsFixed' to true.
5433
5434 2003-07-14  Ravi Pratap M  <ravi@ximian.com>
5435
5436         * attribute.cs (Attribute.Resolve): While doing a Member lookup
5437         for .ctors, ensure that we only ask for members declared in the
5438         attribute type (BindingFlags.DeclaredOnly).
5439
5440         Fixes bug #43632.
5441
5442         * expression.cs (Error_WrongNumArguments): Report error 1501
5443         correctly the way CSC does.
5444
5445 2003-07-13  Martin Baulig  <martin@ximian.com>
5446
5447         * expression.cs (MemberAccess.ResolveAsTypeStep): Try to do a type
5448         lookup on the fully qualified name, to make things like "X.X" work
5449         where "X.X" is a fully qualified type name, but we also have a
5450         namespace "X" in the using list.  Fixes #41975.
5451
5452 2003-07-13  Martin Baulig  <martin@ximian.com>
5453
5454         * assign.cs (Assign.GetEmbeddedAssign): New protected virtual
5455         function. If we're a CompoundAssign, we need to create an embedded
5456         CompoundAssign, not an embedded Assign.
5457         (Assign.DoResolve): Make this work for embedded CompoundAssign's.
5458         Fixes #45854.
5459
5460 2003-07-13  Martin Baulig  <martin@ximian.com>
5461
5462         * typemanager.cs (TypeManager.IsNestedChildOf): Make this actually
5463         work to fix bug #46088.
5464
5465 2003-07-13  Ravi Pratap <ravi@ximian.com>
5466
5467         * class.cs (Operator.Emit): Do not emit attributes here - it is
5468         taken care of by the Method class that we delegate too. This takes
5469         care of bug #45876.
5470
5471 2003-07-10  Martin Baulig  <martin@ximian.com>
5472
5473         * expression.cs (TypeOfVoid): New class.
5474         (TypeOf): Report a CS0673 if it's System.Void.  Fixes #42264.
5475
5476 2003-07-10  Martin Baulig  <martin@ximian.com>
5477
5478         * class.cs (MethodCore.DoDefineParameters): Added CS0225 check;
5479         bug #35957.
5480
5481 2003-07-10  Martin Baulig  <martin@ximian.com>
5482
5483         * rootcontext.cs (RootContext.NamespaceLookup): Take a DeclSpace,
5484         not a NamespaceEntry, so we can use DeclSpace.CheckAccessLevel().
5485
5486         * decl.cs (DeclSpace.FindType): Use DeclSpace.CheckAccessLevel().
5487
5488         * typemanager.cs (TypeManager.IsAccessibleFrom): Removed.
5489
5490 2003-07-10  Martin Baulig  <martin@ximian.com>
5491
5492         * expression.cs (ArrayCreation): Don't use a byte blob for arrays
5493         of decimal.  Fixes #42850.
5494
5495         NOTE: I also fixed the created byte blob, but this doesn't work on
5496         the MS runtime and csc never produces any byte blobs for decimal
5497         arrays.
5498
5499 2003-07-10  Martin Baulig  <martin@ximian.com>
5500
5501         * statement.cs (StructInfo.GetStructInfo): Catch deep cycles in
5502         structs; fixes #32068.
5503         (Block.AddChildVariableNames): Fixed #44302.
5504
5505 2003-07-07  Gonzalo Paniagua Javier <gonzalo@ximian.com>
5506
5507         * namespace.cs: fixed compilation with csc. It's bugzilla #44302.
5508
5509 2003-07-07  Miguel de Icaza  <miguel@ximian.com>
5510
5511         * attribute.cs: And this test is onger needed.
5512
5513 2003-07-08  Martin Baulig  <martin@ximian.com>
5514
5515         * rootcontext.cs (RootContext.NamespaceLookup): Ignore
5516         inaccessible types.  Fixes #36313.
5517
5518         * decl.cs (DeclSpace.FindType): Ignore inaccessible types.
5519
5520         * namespace.cs (NamespaceEntry): Create implicit entries for all
5521         namespaces; ie. if we have `namespace N1.N2.N3 { ... }', we create
5522         implicit entries for N1.N2 and N1.
5523
5524 2003-07-08  Martin Baulig  <martin@ximian.com>
5525
5526         Rewrote the handling of namespaces to fix a lot of the issues
5527         wrt. `using' aliases etc.
5528
5529         * namespace.cs (Namespace): Splitted this class into a
5530         per-assembly `Namespace' and a per-file `NamespaceEntry'.
5531
5532         * typemanager.cs (TypeManager.IsNamespace): Removed.
5533         (TypeManager.ComputeNamespaces): Only compute namespaces from
5534         loaded assemblies here, not the namespaces from the assembly we're
5535         currently compiling.
5536
5537 2003-07-08  Martin Baulig  <martin@ximian.com>
5538
5539         * rootcontext.cs, class.cs: Fixed the CS1530 reporting.
5540
5541 2003-07-07  Miguel de Icaza  <miguel@ximian.com>
5542
5543         * typemanager.cs: Reverted patch from Gonzalo, my previous patch
5544         already fixed it.  
5545
5546         I thought about the memory savings here, but LookupTypeReflection
5547         is used under already very constrained scenarios.  Compiling
5548         corlib or mcs only exposes one hit, so it would not really reduce
5549         any memory consumption.
5550
5551 2003-07-07  Gonzalo Paniagua Javier <gonzalo@ximian.com>
5552
5553         * typemanager.cs: fixes bug #45889 by only adding public types from
5554         other assemblies to the list of known types.
5555
5556 2003-07-07  Miguel de Icaza  <miguel@ximian.com>
5557
5558         * attribute.cs (Attribute.Resolve): Add call to CheckAccessLevel
5559         on the type we resolved.
5560
5561 2003-07-05  Martin Baulig  <martin@ximian.com>
5562
5563         * pending.cs (PendingImplementation.ParentImplements): Don't
5564         create the proxy if the parent is abstract.
5565
5566         * class.cs (TypeContainer.DefineIndexers): Process explicit
5567         interface implementations first.  Fixes #37714.
5568
5569 2003-07-04  Miguel de Icaza  <miguel@ximian.com>
5570
5571         * expression.cs (MemberAccess.ResolveMemberAccess): Events are
5572         defined recursively;  but since we modify the input parameters
5573         (left is set to `this' temporarily), we reset this value if the
5574         left_is_explicit is false, which gives the original semantics to
5575         the code.  
5576
5577         * literal.cs (NullPointer): new class used to represent a null
5578         literal in a pointer context.
5579
5580         * convert.cs (Convert.ImplicitReferenceConversion): Is the target
5581         type is a pointer, use a NullPointer object instead of a
5582         NullLiteral.   Closes 43687
5583
5584         (ExplicitConversion): Convert pointer values using
5585         the conv opcode to the proper type.
5586
5587         * ecore.cs (New): change ValueTypeVariable property into a method,
5588         that returns whether the valuetype is suitable for being used.
5589
5590         * expression.cs (Binary.DoNumericPromotions): Only return if we
5591         the int constant was a valid uint, and we can return both left and
5592         right as uints.  If not, we continue processing, to trigger the
5593         type conversion.  This fixes 39018.
5594
5595         * statement.cs (Block.EmitMeta): During constant resolution, set
5596         the CurrentBlock property on the emitcontext, so that we resolve
5597         constants propertly.
5598
5599 2003-07-02  Martin Baulig  <martin@ximian.com>
5600
5601         * codegen.cs (EmitContext.NeedExplicitReturn): New public variable.
5602         (EmitContext.EmitTopBlock): Emit an explicit return if it's set.
5603
5604         * statement.cs (Try.Resolve): Set ec.NeedExplicitReturn rather
5605         than emitting it here.
5606
5607         * statement.cs: Fixed some more flow analysis bugs.
5608
5609 2003-07-02  Martin Baulig  <martin@ximian.com>
5610
5611         * class.cs (MethodData.Define): When implementing interface
5612         methods, set Final unless we're Virtual.
5613
5614         * decl.cs (MemberCore.CheckMethodAgainstBase): Make the CS0506
5615         check work for interface methods.
5616
5617 2003-07-01  Martin Baulig  <martin@ximian.com>
5618
5619         * ecore.cs (EmitContext.This): Replaced this property with a
5620         GetThis() method which takes a Location argument.  This ensures
5621         that we get the correct error location for a CS0188.
5622
5623 2003-07-01  Miguel de Icaza  <miguel@ximian.com>
5624
5625         * ecore.cs: (Convert.ConvertIntLiteral): Add test for
5626         ImplicitStandardConversion.
5627
5628         * class.cs (TypeContainer.GetClassBases): Small bug fix for 45649.
5629
5630 2003-07-01  Zoltan Varga  <vargaz@freemail.hu>
5631
5632         * expression.cs (ResolveOperator): Fix Concat (string, string, string)
5633         optimization.
5634
5635 2003-06-30  Miguel de Icaza  <miguel@ximian.com>
5636
5637         * class.cs (Constructor.Define): Turn off initlocals for unsafe
5638         constructors.
5639
5640         (MethodData.Define): Turn off initlocals for unsafe methods.
5641
5642 2003-06-29  Miguel de Icaza  <miguel@ximian.com>
5643
5644         * decl.cs (DeclSpace.CheckAccessLevel): Make this routine
5645         complete;  Fixes #37521.
5646
5647         * delegate.cs: Use Modifiers.TypeAttr to compute the
5648         TypeAttributes, instead of rolling our own.  This makes the flags
5649         correct for the delegates.
5650
5651 2003-06-28  Miguel de Icaza  <miguel@ximian.com>
5652
5653         * class.cs (Constructor.Define): Set the private flag for static
5654         constructors as well.
5655
5656         * cs-parser.jay (statement_expression): Set the return value to
5657         null, to avoid a crash when we catch an error.
5658
5659 2003-06-24  Miguel de Icaza  <miguel@ximian.com>
5660
5661         * cs-parser.jay: Applied patch from Jackson that adds support for
5662         extern and unsafe modifiers to destructor declarations.
5663
5664         * expression.cs: Report error 21 if the user is trying to index a
5665         System.Array.
5666
5667         * driver.cs: Add an error message, suggested by the bug report.
5668
5669         * class.cs (TypeContainer.Emit): Only call EmitFieldInitializers
5670         if we do not have a ": this ()" constructor initializer.  Fixes 45149
5671
5672 2003-06-14  Miguel de Icaza  <miguel@ximian.com>
5673
5674         * namespace.cs: Add some information to reduce FAQs.
5675
5676 2003-06-13  Miguel de Icaza  <miguel@ximian.com>
5677
5678         * cfold.cs (BinaryFold): BitwiseAnd, BitwiseOr: handle other
5679         underlying enumeration types.  Fixes #43915.
5680
5681         * expression.cs: Treat ushort/short as legal values to be used in
5682         bitwise operations.
5683
5684 Wed Jun 4 13:19:04 CEST 2003 Paolo Molaro <lupus@ximian.com>
5685
5686         * delegate.cs: transfer custom attributes for paramenters from
5687         the delegate declaration to Invoke and BeginInvoke.
5688
5689 Tue Jun 3 11:11:08 CEST 2003 Paolo Molaro <lupus@ximian.com>
5690
5691         * attribute.cs: handle custom marshalers and emit marshal info
5692         for fields, too.
5693
5694 2003-05-28  Hector E. Gomez Morales  <hgomez_36@flashmail.com>
5695
5696         * makefile.gnu: Added anonymous.cs to the compiler sources.
5697
5698 2003-05-28  Miguel de Icaza  <miguel@ximian.com>
5699
5700         * iterators.cs: Change the name of the proxy class to include two
5701         underscores.
5702
5703         * cs-parser.jay: Update grammar to include anonymous methods.
5704
5705         * anonymous.cs: new file.
5706
5707 2003-05-27  Miguel de Icaza  <miguel@ximian.com>
5708
5709         * class.cs (Field.Define): Add missing test for pointers and
5710         safety. 
5711
5712 2003-05-27  Ravi Pratap  <ravi@ximian.com>
5713
5714         * expression.cs (ArrayAccess.GetStoreOpCode): For System.IntPtr,
5715         we use the stobj opcode.
5716
5717         (ArrayCreation.EmitDynamicInitializers): Revert Miguel's patch
5718         since it wasn't the correct fix. 
5719
5720         It still is puzzling that we are required to use stobj for IntPtr
5721         which seems to be a ValueType.
5722
5723 2003-05-26  Miguel de Icaza  <miguel@ximian.com>
5724
5725         * ecore.cs (SimpleName.SimpleNameResolve): Consider using aliases
5726         during regular simple name resolution.   Now, the trick is that
5727         instead of returning for processing the simplename, we do a
5728         TypeManager.LookupType (ie, a rooted lookup as opposed to a
5729         contextual lookup type).   If a match is found, return that, if
5730         not, return for further composition.
5731
5732         This fixes long-standing 30485.
5733
5734         * expression.cs (ArrayCreation.EmitDynamicInitializers): When
5735         using the address to initialize an object, do an Stobj instead of
5736         using the regular Stelem.
5737
5738         (IndexerAccess.Emit, IndexerAccess.EmitAssign):
5739         Pass `is_base_indexer' to Invocation.EmitCall instead of false.
5740         Because if we are a BaseIndexerAccess that value will be true.
5741         Fixes 43643.
5742
5743         * statement.cs (GotoCase.Resolve): Return after reporting an
5744         error, do not attempt to continue. 
5745
5746         * expression.cs (PointerArithmetic.Emit): If our operand is a
5747         long, convert our constants to match the operand before
5748         multiplying.  Convert to I type before adding.   Fixes 43670.
5749
5750 2003-05-14  Ravi Pratap  <ravi@ximian.com>
5751
5752         * enum.cs (ImplicitConversionExists) : Rename to
5753         ImplicitEnumConversionExists to remove ambiguity. 
5754
5755         * ecore.cs (NullCast): New type of cast expression class which
5756         basically is very similar to EmptyCast with the difference being
5757         it still is a constant since it is used only to cast a null to
5758         something else
5759         (eg. (string) null)
5760
5761         * convert.cs (ImplicitReferenceConversion): When casting a null
5762         literal, we return a NullCast.
5763
5764         * literal.cs (NullLiteralTyped): Remove - I don't see why this
5765         should be around anymore.
5766
5767         The renaming (reported was slightly wrong). Corrections:
5768
5769         ConvertImplicitStandard -> ImplicitConversionStandard
5770         ConvertExplicitStandard -> ExplicitConversionStandard
5771
5772         * expression.cs (StaticCallExpr.MakeSimpleCall): Resolve arguments
5773         before passing them in !
5774
5775         * convert.cs (ImplicitConversionStandard): When comparing for
5776         equal expr and target types, ensure that expr is not a
5777         NullLiteral.
5778
5779         In general, we must not be checking (expr_type ==
5780         target_type) in the top level conversion methods
5781         (ImplicitConversion, ExplicitConversion etc). This checking is
5782         done in the methods that they delegate to.
5783
5784 2003-05-20  Miguel de Icaza  <miguel@ximian.com>
5785
5786         * convert.cs: Move Error_CannotConvertType,
5787         ImplicitReferenceConversion, ImplicitReferenceConversionExists,
5788         ImplicitNumericConversion, ImplicitConversionExists,
5789         ImplicitUserConversionExists, StandardConversionExists,
5790         FindMostEncompassedType, FindMostSpecificSource,
5791         FindMostSpecificTarget, ImplicitUserConversion,
5792         ExplicitUserConversion, GetConversionOperators,
5793         UserDefinedConversion, ConvertImplicit, ConvertImplicitStandard,
5794         TryImplicitIntConversion, Error_CannotConvertImplicit,
5795         ConvertImplicitRequired, ConvertNumericExplicit,
5796         ExplicitReferenceConversionExists, ConvertReferenceExplicit,
5797         ConvertExplicit, ConvertExplicitStandard from the ecore.cs into
5798         its own file.
5799
5800         Perform the following renames:
5801
5802         StandardConversionExists -> ImplicitStandardConversionExists
5803         ConvertImplicit -> ImplicitConversion
5804         ConvertImplicitStandard -> ImplicitStandardConversion
5805         TryImplicitIntConversion -> ImplicitIntConversion
5806         ConvertImplicitRequired -> ImplicitConversionRequired
5807         ConvertNumericExplicit -> ExplicitNumericConversion
5808         ConvertReferenceExplicit -> ExplicitReferenceConversion
5809         ConvertExplicit -> ExplicitConversion
5810         ConvertExplicitStandard -> ExplicitStandardConversion
5811
5812 2003-05-19  Martin Baulig  <martin@ximian.com>
5813
5814         * statement.cs (TypeInfo.StructInfo): Made this type protected.
5815         (TypeInfo): Added support for structs having structs as fields.
5816
5817         * ecore.cs (FieldExpr): Implement IVariable.
5818         (FieldExpr.DoResolve): Call VariableInfo.GetSubStruct() to get the
5819         VariableInfo for the field.
5820
5821 2003-05-18  Martin Baulig  <martin@ximian.com>
5822
5823         * expression.cs (This.DoResolve): Report a CS0027 if we're
5824         emitting a field initializer.
5825
5826 2003-05-18  Martin Baulig  <martin@ximian.com>
5827
5828         * expression.cs (This.ResolveBase): New public function.
5829         (This.DoResolve): Check for CS0188.
5830
5831         * codegen.cs (EmitContext.This): Just call This.ResolveBase(), not
5832         This.Resolve().
5833
5834         * ecore.cs (MethodGroupExpr.DoResolve): Set the
5835         `instance_expression' to null if we don't have any non-static
5836         methods.
5837
5838 2003-05-18  Martin Baulig  <martin@ximian.com>
5839
5840         Reworked the way how local variables and parameters are handled by
5841         the flow analysis code.
5842
5843         * statement.cs (TypeInfo, VariableMap): New public classes.
5844         (VariableInfo): New public class.  This is now responsible for
5845         checking whether a variable has been assigned.  It is used for
5846         parameters and local variables.
5847         (Block.EmitMeta): Take the InternalParameters as argument; compute
5848         the layout of the flow vectors here.
5849         (Block.LocalMap, Block.ParameterMap): New public properties.
5850         (FlowBranching): The .ctor doesn't get the InternalParameters
5851         anymore since Block.EmitMeta() now computes the layout of the flow
5852         vector.
5853         (MyStructInfo): This class is now known as `StructInfo' and nested
5854         in `TypeInfo'; we don't access this directly anymore.
5855
5856         * ecore.cs (IVariable): Added `VariableInfo VariableInfo'
5857         property and removed IsAssigned(), IsFieldAssigned(),
5858         SetAssigned() and SetFieldAssigned(); we now call them on the
5859         VariableInfo so we don't need to duplicate this code everywhere.
5860
5861         * expression.cs (ParameterReference): Added `Block block' argument
5862         to the .ctor.
5863         (LocalVariableReference, ParameterReference, This): The new
5864         VariableInfo class is now responsible for all the definite
5865         assignment stuff.
5866
5867         * codegen.cs (EmitContext.IsVariableAssigned, SetVariableAssigned,
5868         IsParameterAssigned, SetParameterAssigned): Removed.
5869
5870 2003-05-18  Martin Baulig  <martin@ximian.com>
5871
5872         * typemanager.cs (InitCoreTypes): Try calling
5873         SetCorlibTypeBuilders() with 4 args; if that fails, fall back to
5874         the 3-args-version.  Corlib now also needs our `void_type'.
5875         (GetMethod): Added overloaded version which takes an optional
5876         `bool report_errors' to allow lookups of optional methods.
5877
5878 2003-05-12  Martin Baulig  <martin@ximian.com>
5879
5880         * statement.cs (VariableInfo): Renamed to LocalInfo since it's
5881         only used for locals and not for parameters.
5882
5883 2003-05-12  Miguel de Icaza  <miguel@ximian.com>
5884
5885         * support.cs (InternalParameters.ParameterType): Return the
5886         ExternalType of the parameter.
5887
5888         * parameter.cs (Parameter.ExternalType): drop the two arguments,
5889         they were unused.
5890
5891 2003-05-11  Miguel de Icaza  <miguel@ximian.com>
5892
5893         * class.cs (MethodData.Define): Do not set the `newslot' on
5894         interface members, if they are also flagged as "override".
5895
5896         * expression.cs (UnaryMutator.EmitCode): Simple workaround to emit
5897         better code for ++i and i++.  This only works for static fields
5898         and local variables.
5899
5900         * typemanager.cs (LookupDeclSpace): Add new method, sometimes we
5901         want to pull the DeclSpace out of the builder_to_declspace instead
5902         of the TypeBuilder (like in TypeContainer.FindMembers).
5903
5904         * class.cs (TypeContainer.FindMembers): Use LookupDeclSpace
5905         instead of LookupTypeContainer.  Fixes the crash on .NET for
5906         looking up interface members.
5907
5908         * const.cs: Create our own emit context during the Definition
5909         stage, so that constants are evaluated in the proper context, when
5910         a recursive definition happens.
5911
5912 2003-05-11  Martin Baulig  <martin@ximian.com>
5913
5914         * statement.cs (Block.CreateSwitchBlock): New method.  Creates a
5915         new block for a switch section.
5916         (Block.AddLabel, Block.LookupLabel): If we're a switch section, do
5917         the adding/lookup in the switch block.  Fixes #39828.
5918
5919 2003-05-09  Miguel de Icaza  <miguel@ximian.com>
5920
5921         * expression.cs (UnaryMutator.LoadOneAndEmitOp): Missing
5922         functionality: I needed to convert the data after I had performed
5923         the add/sub operation into the operands type size.
5924
5925         * ecore.cs (ImplicitReferenceConversion): When boxing an interface
5926         pass the type for the box operation, otherwise the resulting
5927         object would have been of type object.
5928
5929         (BoxedCast): Add constructor to specify the type to box as.
5930
5931 2003-05-07  Miguel de Icaza  <miguel@ximian.com>
5932
5933         * iterators.cs: I was reusing the `count' variable inadvertently,
5934         take steps to not allow this to happen.
5935
5936 2003-05-06  Miguel de Icaza  <miguel@ximian.com>
5937
5938         * attribute.cs (Attribute.Resolve): Params attributes are encoded
5939         by creating an array at the point where the params starts and
5940         putting all those arguments there, then adjusting the size of the
5941         array.
5942
5943 2003-05-05  Miguel de Icaza  <miguel@ximian.com>
5944
5945         * expression.cs (New.AddressOf): Implement interface
5946         IMemoryLocation.  This is used when the `new' operator is used in
5947         the context of an invocation to a method on a value type.
5948
5949         See http://bugzilla.ximian.com/show_bug.cgi?id=#42390 for an
5950         example. 
5951
5952         * namespace.cs: Also check the using aliases here.
5953
5954         * driver.cs: Move the test for using validity after the types have
5955         been entered, so we do a single pass that also includes the using
5956         aliases. 
5957
5958         * statement.cs (Try.Resolve): Avoid crashing if there is a failure
5959         in the regular case.   CreateSiblingForFinally is doing extra
5960         error checking.
5961
5962         * attribute.cs (GetAttributeArgumentExpression): Store the result
5963         on an out value, and use the return value to indicate failure
5964         instead of using null (which is a valid return for Constant.GetValue).
5965
5966         * statement.cs: Perform the analysis flow for the increment
5967         portion after the statement, because this will be the real flow of
5968         execution.  Fixes #42385
5969
5970         * codegen.cs (EmitContext.EmitArgument,
5971         EmitContext.EmitStoreArgument): New helper functions when the
5972         RemapToProxy flag is set.
5973
5974         * expression.cs (ParameterReference.EmitLdarg): Expose this useful
5975         function.
5976
5977         Add support for remapping parameters. 
5978
5979         * iterators.cs: Propagate parameter values;  Store parameter
5980         values in the proxy classes.
5981
5982 2003-05-04  Miguel de Icaza  <miguel@ximian.com>
5983
5984         * ecore.cs (FieldExpr): Fix an obvious bug.  static fields do not
5985         need a proxy reference;  I do not know what I was thinking
5986
5987         * cs-parser.jay (constructor_initializer): catch another error,
5988         and display nice message.
5989
5990         (field_declaration): catch void field declaration
5991         to flag a better error. 
5992
5993         * class.cs (MemberBase.CheckBase): Report an error instead of a
5994         warning if a new protected member is declared in a struct. 
5995         (Field.Define): catch the error of readonly/volatile.
5996
5997         * ecore.cs (FieldExpr.EmitAssign): reuse the field lookup.
5998
5999         (FieldExpr.AddressOf): ditto.  Catch error where the address of a
6000         volatile variable is taken
6001
6002 2003-05-02  Miguel de Icaza  <miguel@ximian.com>
6003
6004         * statement.cs (Fixed.Resolve): Report an error if we are not in
6005         an unsafe context.
6006
6007 2003-05-01  Miguel de Icaza  <miguel@ximian.com>
6008
6009         * typemanager.cs: reuse the code that handles type clashes for
6010         delegates and enumerations.
6011
6012         * class.cs (Report28): Always report.
6013
6014         * expression.cs (EncodeAsAttribute): Allow nulls here.
6015
6016 2003-04-28  Miguel de Icaza  <miguel@ximian.com>
6017
6018         * attribute.cs (Attribute.GetAttributeArgumentExpression): Moved
6019         the functionality for testing whether an expression is valid for
6020         an attribute here.  Also handle the case of arrays of elements
6021         being stored. 
6022
6023         * expression.cs (ArrayCreation.EncodeAsAttribute): Add support for
6024         encoding a linear array into an array of objects that are suitable
6025         to be passed to an CustomAttributeBuilder.
6026
6027         * delegate.cs: Check unsafe types being used outside of an Unsafe context.
6028
6029         * ecore.cs: (FieldExpr): Handle field remapping here.
6030
6031         * iteratators.cs: Pass the instance variable (if the method is an
6032         instance method) to the constructors, so we can access the field
6033         variables on the class.
6034
6035         TODO: Test this with structs.  I think the THIS variable on
6036         structs might have to be a pointer, and not a refenrece
6037
6038 2003-04-27  Miguel de Icaza  <miguel@ximian.com>
6039
6040         * codegen.cs (EmitContext.Mapvariable): Adds a mechanism to map
6041         local variables to fields in a proxy class.
6042
6043         * iterators.cs (PopulateProxy): Rename our internal fields to
6044         <XXX>.  
6045         Create a <THIS> field if we are an instance method, so we can
6046         reference our parent container variables.
6047         (MapVariable): Called back from the EmitContext code to enter a
6048         new variable to field mapping into the proxy class (we just create
6049         a FieldBuilder).
6050
6051         * expression.cs
6052         (LocalVariableReference.{Emit,EmitAssign,AddressOf}): Add support
6053         for using the remapped locals to fields.
6054
6055         I placed the code here, because that gives the same semantics to
6056         local variables, and only changes the Emit code.
6057
6058         * statement.cs (Fixed.Resolve): it is not allowed to have fixed
6059         statements inside iterators.
6060         (VariableInfo): Add a FieldBuilder for the cases when we are
6061         remapping local variables to fields in a proxy class
6062
6063         * ecore.cs (SimpleNameResolve): Avoid testing two times for
6064         current_block != null.
6065
6066         * statement.cs (Swithc.SimpleSwitchEmit): Removed code that did
6067         not cope with strings, as it has been moved to the
6068         TableSwitchEmit.  Fixed bug in switch generation.
6069
6070         * expression.cs (New.DoResolve): Provide more context for the user
6071         when reporting an error.
6072
6073         * ecore.cs (Expression.LoadFromPtr): Use ldind_i when loading
6074         pointers. 
6075
6076         * expression.cs (MemberAccess.DoResolve): When we get a type back,
6077         check the permissions for it.  Note than in a type-resolution
6078         context the check was already present in DeclSpace.ResolveType,
6079         but was missing from the MemberAccess.
6080
6081         (ArrayCreation.CheckIndices): warn if the user has
6082         more nested levels of expressions, but there are no more
6083         dimensions specified.  Avoids crash on bug 41906.
6084
6085 2003-04-26  Miguel de Icaza  <miguel@ximian.com>
6086
6087         * statement.cs (Block): replace Implicit bool, for a generic
6088         flags.   
6089         New flag: `Unchecked'.  This is used during the EmitMeta phase
6090         (which is out-of-line with the regular Resolve/Emit process for a
6091         statement, as this is done ahead of time, but still gets a chance
6092         to call constant resolve).
6093
6094         (Block.Flags): new enum for adding a new flag.
6095
6096         (Block.EmitMeta): track the state of unchecked.
6097
6098         (Unchecked): Set the "UnChecked" flags on any blocks we enclose,
6099         to enable constant resolution to work there as well.
6100
6101 2003-04-22  Miguel de Icaza  <miguel@ximian.com>
6102
6103         * typemanager.cs (ienumerable_type): Also look up
6104         System.Collections.IEnumerable. 
6105
6106 2003-04-21  Miguel de Icaza  <miguel@ximian.com>
6107
6108         TODO: Test more than one conditional per method.
6109
6110         * class.cs (Indexer.Define): Report the location where the user is
6111         referencing the unsupported feature.
6112
6113         (MethodData): Overload the use of `conditionals' to
6114         minimize the creation of needless ArrayLists.   This saves roughly
6115         212kb on my machine.
6116
6117         (Method): Implement the new IIteratorContainer interface.
6118         (Method.SetYields): Implement the method by setting the ModFlags
6119         to contain METHOD_YIELDS.
6120
6121         * expression.cs (Unary.ResolveOperator): Use expr_type, not Expr,
6122         which just got set to null.
6123
6124         * iterators.cs: New file.
6125
6126         (Yield, YieldBreak): New statements.
6127
6128         * statement.cs (Return.Resolve): Flag an error if we are used in
6129         an iterator method.
6130
6131         * codegen.cs (InIterator): New flag set if the code is being
6132         compiled in an iterator method.
6133
6134         * modifiers.cs: New flag METHOD_YIELDS.  This modifier is an
6135         internal modifier, and we just use it to avoid adding extra
6136         fields, as this is seldom used.  
6137
6138         * cs-parser.jay: Add yield_statement (yield and yield break).
6139
6140         * driver.cs: New flag -v2 to turn on version 2 features. 
6141
6142         * cs-tokenizer.cs (Tokenizer): Add yield and __yield to the
6143         hashtable when v2 is enabled.
6144
6145 2003-04-20  Miguel de Icaza  <miguel@ximian.com>
6146
6147         * typemanager.cs (TypeManager.NamespaceClash): Use to check if
6148         there is already a namespace defined with this name.
6149
6150         (TypeManager.InitCoreTypes): Remove the temporary workaround, as
6151         people upgraded their corlibs.
6152
6153         (TypeManager.CoreLookupType): Use LookupTypeDirect, as we
6154         always use fully qualified types, no need to use the compiler
6155         front end.
6156
6157         (TypeManager.IsNamespace): Use binarysearch.
6158
6159         * class.cs (AddClass, AddStruct, AddInterface, AddEvent,
6160         AddDelegate): I did not quite use the new IsValid API properly: I
6161         have to pass the short-name and the fullname.  I was passing only
6162         the basename instead of the fullname sometimes. 
6163
6164         (TypeContainer.DefineType): call NamespaceClash.
6165
6166         * interface.cs (Interface.DefineType): use NamespaceClash before
6167         defining the type.
6168
6169         * delegate.cs (Delegate.DefineType): use NamespaceClash before
6170         defining the type.
6171
6172         * enum.cs: (Enum.DefineType): use NamespaceClash before
6173         defining the type.
6174
6175         * typemanager.cs (: 3-line patch that gives us some tasty 11%
6176         speed increase.  First, use the negative_hits cache when we get a
6177         negative.  Second, add the type with its full original name
6178         instead of the new . and + encoded name (reflection uses + to
6179         separate type from a nested type).  Use LookupTypeReflection
6180         directly which bypasses the type->name hashtable (that we already
6181         know does not contain the type.
6182
6183         * decl.cs (DeclSpace.ResolveTypeExpr): track the
6184         location/container type. 
6185
6186         * driver.cs: When passing utf8, use directly the UTF8Encoding.
6187
6188 2003-04-19  Miguel de Icaza  <miguel@ximian.com>
6189
6190         * decl.cs (ResolveTypeExpr): Mirror check acess here too.
6191
6192         * delegate.cs (NewDelegate.Resolve): Test whether an instance
6193         method is being referenced in the method group from a static
6194         context, and report error 120 if so.
6195
6196         * expression.cs, ecore.cs (Error_UnexpectedKind): New name for
6197         Error118. 
6198
6199         * typemanager.cs: Add intermediate namespaces (if a namespace A.B
6200         is created, we create the A namespace).
6201
6202         * cs-parser.jay: A namespace also introduces a DeclarationFound.
6203         Fixes #41591
6204
6205 2003-04-18  Miguel de Icaza  <miguel@ximian.com>
6206
6207         * typemanager.cs (GetReferenceType, GetPointerType): In .NET each
6208         invocation to ModuleBuilder.GetType with the same values will
6209         return a new type instance, so we need to cache its return
6210         values. 
6211
6212         * expression.cs (Binary.ResolveOperator): Only allow the compare
6213         operators on enums if they are of the same type.
6214
6215         * ecore.cs (Expression.ImplicitReferenceConversion): handle target
6216         types of ValueType on their own case.  Before we were giving them
6217         the same treatment as objects.
6218
6219         * decl.cs (DeclSpace.IsValid): IsValid takes the short name and
6220         fullname.  Short name is used to compare against container name.
6221         Fullname is used to check against defined namespace names.
6222
6223         * class.cs (AddProperty, AddField, AddClass, AddStruct, AddEnum,
6224         AddDelegate, AddEvent): Pass new parameter to DeclSpace.IsValid
6225
6226         (Method.CheckBase): Call parent.
6227         (MemberBase.CheckBase): Check for protected members on sealed
6228         classes.
6229         (PropertyBase.CheckBase): Call parent.
6230         (Field.Define): Call parent.
6231
6232         * report.cs: Negative error codes are now mapped to 8000 - code,
6233         so that the display is render more nicely.
6234
6235         * typemanager.cs: Do not use try/catch, instead report a regular
6236         error. 
6237
6238         (GetPointerType, GetReferenceType): These methods provide
6239         mechanisms to obtain the T* and T& from a T.  We had the code
6240         previously scattered around the code base, and it also used
6241         TypeManager.LookupType that would go through plenty of caches.
6242         This one goes directly to the type source.
6243
6244         In some places we did the Type.GetType followed by
6245         ModuleBuilder.GetType, but not in others, so this unifies the
6246         processing as well.
6247
6248         * namespace.cs (VerifyUsing): Perform a non-lazy approach to using
6249         statements now that we have namespace information.
6250
6251         * typemanager.cs (IsNamespace): New method, returns whether the
6252         string presented is a namespace or not.
6253
6254         (ComputeNamespaces): New public entry point, computes the list of
6255         available namespaces, using the GetNamespaces API call in Mono, or
6256         the slower version in MS.NET.   
6257
6258         Now before we start the semantic analysis phase, we have a
6259         complete list of namespaces including everything that the user has
6260         provided.
6261
6262         Deleted old code to cache namespaces in .nsc files.
6263
6264 2003-04-17  Miguel de Icaza  <miguel@ximian.com>
6265
6266         * class.cs: (TypeContainer.DefineDefaultConstructor): Use the
6267         class/struct location definition Location for the implicit
6268         constructor location.
6269
6270         (Operator.Define): Use the location of the operator for the
6271         implicit Method definition.
6272
6273         (Constructor.Emit): use the constructor location for the implicit
6274         base initializer constructor.
6275
6276         * ecore.cs: Remove ITypeExpression.  This interface is now gone,
6277         and the Expression class now contains two new methods:
6278
6279         ResolveAsTypeStep and ResolveAsTypeTerminal.  This is used to
6280         isolate type lookup from the rest of the resolution process.
6281
6282         Since we use Expressions to hold type definitions due to the way
6283         we parse the input we have historically overloaded Resolve to
6284         perform the Type lookups if a special flag is passed.  Now this is
6285         eliminated and two methods take their place. 
6286
6287         The differences in the two methods between xStep and xTerminal is
6288         that xStep is involved in our current lookup system that uses
6289         SimpleNames to compose a name, while xTerminal is used just to
6290         catch the case where the simplename lookup failed.
6291
6292 2003-04-16  Miguel de Icaza  <miguel@ximian.com>
6293
6294         * expression.cs (ResolveMemberAccess): Remove redundant code.
6295         TypeExpr expressions are always born fully resolved.
6296
6297         * interface.cs (PopulateMethod): Do not lookup the types twice.
6298         We were doing it once during SemanticAnalysis and once during
6299         PopulateMethod.
6300
6301         * cs-parser.jay: Due to our hack in the grammar, things like A.B[]
6302         in local variable type definitions, were being returned as a
6303         SimpleName (we decomposed everything into a string), that is
6304         because primary_expression was being used instead of a type in the
6305         grammar (reduce/reduce conflicts).
6306
6307         The part that was wrong is that we converted the expression into a
6308         string (an oversimplification in one hand, compounded with primary
6309         expressions doing string concatenation).
6310
6311         So things like:
6312
6313         A.B.C [] x;
6314
6315         Would return "A.B.C[]" as a SimpleName.  This stopped things like
6316         using clauses from working on this particular context.  And a type
6317         was being matched directly against "A.B.C[]".
6318
6319         We now use the correct approach, and allow for ComposedCast to be
6320         part of the unary expression.  So the "A.B.C []" become a composed
6321         cast of "A.B.C" (as a nested group of MemberAccess with a
6322         SimpleName at the end) plus the rank composition "[]". 
6323
6324         Also fixes 35567
6325
6326 2003-04-10  Miguel de Icaza  <miguel@ximian.com>
6327
6328         * decl.cs (CheckAccessLevel): Implement the NestedPrivate rules
6329         for the access level checking.
6330
6331         * class.cs: Cosmetic changes.  Renamed `TypeContainer parent' to
6332         `TypeContainer container', because I kept getting confused when I
6333         was debugging this code.
6334
6335         * expression.cs (Indexers): Instead of tracking getters/setters,
6336         we now track them in parallel.  We create one arraylist less, but
6337         most importantly it is possible now for the LValue code to find a
6338         matching get for a set.
6339
6340         (IndexerAccess.DoResolveLValue): Update the code.
6341         GetIndexersForType has been modified already to extract all the
6342         indexers from a type.  The code assumed it did not.
6343
6344         Also make the code set the correct return type for the indexer.
6345         This was fixed a long time ago for properties, but was missing for
6346         indexers.  It used to be void_type.
6347
6348         (Binary.Emit): Test first for doubles instead of
6349         floats, as they are more common.
6350
6351         (Binary.EmitBranchable): Use the .un version of the branch opcodes
6352         when dealing with floats and the <=, >= operators.  This fixes bug
6353         #39314 
6354
6355         * statement.cs (Foreach.EmitArrayForeach): bug fix: The code used
6356         to load the array value by emitting a load on the foreach variable
6357         type.  This was incorrect.  
6358
6359         We now emit the code to load an element using the the array
6360         variable type, and then we emit the conversion operator.
6361
6362         Fixed #40176
6363
6364 2003-04-10  Zoltan Varga  <vargaz@freemail.hu>
6365
6366         * attribute.cs: Avoid allocation of ArrayLists in the common case.
6367
6368 2003-04-09  Miguel de Icaza  <miguel@ximian.com>
6369
6370         * class.cs (MethodSignature.InheritableMemberSignatureCompare):
6371         test for protection before we test for signatures. 
6372
6373         (MethodSignature.ToString): implement.
6374
6375         * expression.cs (Unary.TryReduceNegative): Add missing minus sign
6376         to the case where we reduced into a LongConstant.
6377
6378         * decl.cs (CheckAccessLevel): If the type is an array, we can not
6379         depend on whether the information is acurrate, because the
6380         Microsoft runtime will always claim that the array type is public,
6381         regardless of the real state.
6382
6383         If the type is a pointer, another problem happens: the type is
6384         reported as non-public in Microsoft.  
6385
6386         In both cases we have to call CheckAccessLevel recursively with
6387         the underlying type as the argument to be tested.
6388
6389 2003-04-08  Miguel de Icaza  <miguel@ximian.com>
6390
6391         * assign.cs (Assign.Emit): If we are dealing with a compound
6392         assignment expression, we should use the code path that stores the
6393         intermediate result in a temporary value.  This fixes #40903.
6394
6395         *expression.cs (Indirection.ToString): Provide ToString method for
6396         debugging. 
6397
6398 2003-04-08  Zoltan Varga  <vargaz@freemail.hu>
6399
6400         * class.cs: Null out fields holding references to Block objects so
6401         they can be garbage collected.
6402
6403         * expression.cs (OverloadResolve): Remove unused local.
6404
6405 2003-04-07  Martin Baulig  <martin@ximian.com>
6406
6407         * codegen.cs (EmitContext.CurrentFile): New public field.
6408         (EmitContext.Mark): Use the CurrentFile to check whether the
6409         location is in the correct file.
6410         (EmitContext.EmitTopBlock): Initialize CurrentFile here.
6411
6412 2003-04-07  Martin Baulig  <martin@ximian.com>
6413
6414         * ecore.cs (Expression.ResolveBoolean): Don't call ec.Mark().
6415
6416         * codegen.cs (EmitContext.EmitTopBlock): Don't call Mark() on the
6417         location.  [FIXME: The location argument which gets passed to this
6418         method is sometimes wrong!]
6419
6420 2003-04-07  Nick Drochak <ndrochak@gol.com>
6421
6422         * codegen.cs: Be more verbose when we can't find the symbol writer dll.
6423
6424 2003-04-07  Miguel de Icaza  <miguel@ximian.com>
6425
6426         * expression.cs (Indirection.EmitAssign): We were using the
6427         temporary, but returning immediately instead of continuing the
6428         EmitAssing flow.
6429
6430 2003-04-06  Martin Baulig  <martin@ximian.com>
6431
6432         * ecore.cs (SimpleName.SimpleNameResolve): Don't report an error
6433         if it's a nested child, but also deriving from the outer class.
6434         See test 190.cs.
6435
6436         * typemanager.cs (IsNestedChildOf): Make this work if it's a
6437         nested child, but also deriving from the outer class.  See
6438         test-190.cs.
6439         (FilterWithClosure): We may access private members of the outer
6440         class if we're a nested child and deriving from the outer class.
6441         (RealMemberLookup): Only set `closure_private_ok' if the
6442         `original_bf' contained BindingFlags.NonPublic.
6443
6444 2003-04-05  Martin Baulig  <martin@ximian.com>
6445
6446         * statement.cs (FlowBranching.UsageVector.MergeChildren): Fix bug #40670.
6447
6448 2003-04-02  Miguel de Icaza  <miguel@ximian.com>
6449
6450         * class.cs (Event.Define): Do not allow abstract events to have
6451         initializers. 
6452
6453 2003-04-01  Miguel de Icaza  <miguel@ximian.com>
6454
6455         * cs-parser.jay: Add error productions for ADD/REMOVE missing a
6456         block in event declarations.
6457
6458         * ecore.cs (FieldExpr.AddressOf): If our instance expression is a
6459         value type, get its address.
6460
6461         * expression.cs (Is.Emit): For action `LeaveOnStack' we were
6462         leaving a class on the stack instead of a boolean value (int
6463         0/1).  Change the code so we compare against null, and then the
6464         result against zero.
6465
6466         * class.cs (TypeContainer.GetClassBases): We were checking for the
6467         parent class being sealed too late.
6468
6469         * expression.cs (Binary.Emit): For <= and >= when dealing with
6470         floating point values, use cgt.un and clt.un instead of cgt and
6471         clt alone.
6472
6473 2003-04-01  Zoltan Varga  <vargaz@freemail.hu>
6474
6475         * statement.cs: Apply the same optimization as MS: skip the 
6476         GetEnumerator returning an IEnumerator, and use the one returning a 
6477         CharEnumerator instead. This allows us to avoid the try-finally block 
6478         and the boxing.
6479
6480 2003-03-31  Gaurav Vaish <gvaish_mono@lycos.com>
6481
6482         * cs-parser.jay: Attributes cannot be applied to
6483                          namespaces. Fixes #40473
6484
6485 2003-03-31  Gonzalo Paniagua Javier <gonzalo@ximian.com>
6486
6487         * class.cs:
6488         (Add*): check if the name is valid using the full name for constants,
6489         fields, properties and events.
6490
6491 2003-03-28  Miguel de Icaza  <miguel@ximian.com>
6492
6493         * enum.cs (Enum.DefineType, Enum.IsValidEnumConstant): Also allow
6494         char constants to be part of the enumeration.
6495
6496         * expression.cs (Conditional.DoResolve): Add support for operator
6497         true. Implements the missing functionality from 14.12
6498
6499         * class.cs (TypeContainer.CheckPairedOperators): Report error for missmatch on
6500         operator true/false as required by the spec.
6501
6502         * expression.cs (Unary.ResolveOperator): In LogicalNot, do an
6503         implicit conversion to boolean.
6504
6505         * statement.cs (Statement.ResolveBoolean): A boolean expression is
6506         also one where the type implements `operator true'. 
6507
6508         * ecore.cs (Expression.GetOperatorTrue): New helper routine to
6509         get an expression that will invoke operator true based on an
6510         expression.  
6511
6512         (GetConversionOperators): Removed the hack that called op_True
6513         here.  
6514
6515         (Expression.ResolveBoolean): Move this from Statement.
6516
6517 2003-03-17  Miguel de Icaza  <miguel@ximian.com>
6518
6519         * ecore.cs (FieldExpr): do not allow initialization of initonly
6520         fields on derived classes
6521
6522 2003-03-13  Martin Baulig  <martin@ximian.com>
6523
6524         * statement.cs (Block.Emit): Call ig.BeginScope() and
6525         ig.EndScope() when compiling with debugging info; call
6526         LocalBuilder.SetLocalSymInfo _after_ opening the scope.
6527
6528 2003-03-08  Miguel de Icaza  <miguel@ximian.com>
6529
6530         * expression.cs (Indexers): Do not construct immediately, allow
6531         for new members to be appended as we go.  Fixes 38143
6532
6533 2003-03-07  Gonzalo Paniagua Javier <gonzalo@ximian.com>
6534
6535         * expression.cs: save/restore context when resolving an unchecked
6536         expression.
6537
6538 2003-03-05  Miguel de Icaza  <miguel@ximian.com>
6539
6540         * cfold.cs: Catch division by zero in modulus operator during
6541         constant folding.
6542
6543 2003-03-03  Miguel de Icaza  <miguel@ximian.com>
6544
6545         * interface.cs (Interface.DefineMembers): Avoid defining members
6546         twice. 
6547
6548 2003-02-27  Miguel de Icaza  <miguel@ximian.com>
6549
6550         * driver.cs: handle the +/- options for -noconfig
6551
6552         * statement.cs (Unckeched.Resolve): Also track the state of
6553         unchecked in the Resolve phase.
6554
6555 2003-02-27  Martin Baulig  <martin@ximian.com>
6556
6557         * ecore.cs (Expression.MemberLookup): Don't create a
6558         MethodGroupExpr for something which is not a method.  Fixes #38291.
6559
6560 2003-02-25  Miguel de Icaza  <miguel@ximian.com>
6561
6562         * class.cs (MemberBase.CheckParameters): Also check that the type
6563         is unmanaged if it is a pointer.
6564
6565         * expression.cs (SizeOf.Resolve): Add location information.
6566
6567         * statement.cs (Block.EmitMeta): Flag error (208) if a pointer to
6568         a managed type is declared.
6569
6570         * expression.cs (Invocation.VerifyArgumentsCompat): Check for the
6571         parameter modifiers as well.  Fixes bug 38606
6572
6573         * class.cs: Very sad.  Am backing out the speed up changes
6574         introduced by the ArrayList -> Array in the TypeContainer, as they
6575         were not actually that much faster, and introduced a bug (no error
6576         reports on duplicated methods).
6577
6578         * assign.cs (CompoundAssign.DoLResolve): Resolve the original
6579         source first, this will guarantee that we have a valid expression
6580         before calling in lower levels functions that will require a
6581         resolved object.  Then use this original_source in the
6582         target.ResolveLValue instead of the original source that was
6583         passed to us.
6584
6585         Another change.  Use target.Resolve instead of LValueResolve.
6586         Although we are resolving for LValues, we will let the Assign code
6587         take care of that (it will be called again from Resolve).  This
6588         basically allows code like this:
6589
6590         class X { X operator + (X x, object o) {} X this [int idx] { get; set; } }
6591         class Y { void A (X x) { x [0] += o; }
6592
6593         The problem was that the indexer was trying to resolve for
6594         set_Item (idx, object o) and never finding one.  The real set_Item
6595         was set_Item (idx, X).  By delaying the process we get the right
6596         semantics. 
6597
6598         Fixes bug 36505
6599
6600 2003-02-23  Martin Baulig  <martin@ximian.com>
6601
6602         * statement.cs (Block.Emit): Override this and set ec.CurrentBlock
6603         while calling DoEmit ().
6604
6605         * codegen.cs (EmitContext.Mark): Don't mark locations in other
6606         source files; if you use the #line directive inside a method, the
6607         compiler stops emitting line numbers for the debugger until it
6608         reaches the end of the method or another #line directive which
6609         restores the original file.
6610
6611 2003-02-23  Martin Baulig  <martin@ximian.com>
6612
6613         * statement.cs (FlowBranching.UsageVector.MergeChildren): Fix bug #37708.
6614
6615 2003-02-23  Martin Baulig  <martin@ximian.com>
6616
6617         * statement.cs (Block.AddChildVariableNames): We need to call this
6618         recursively, not just for our immediate children.
6619
6620 2003-02-23  Martin Baulig  <martin@ximian.com>
6621
6622         * class.cs (Event.Define): Always make the field private, like csc does.
6623
6624         * typemanager.cs (TypeManager.RealMemberLookup): Make events
6625         actually work, fixes bug #37521.
6626
6627 2003-02-23  Miguel de Icaza  <miguel@ximian.com>
6628
6629         * delegate.cs: When creating the various temporary "Parameters"
6630         classes, make sure that we call the ComputeAndDefineParameterTypes
6631         on those new parameters (just like we do with the formal ones), to
6632         allow them to be resolved in the context of the DeclSpace.
6633
6634         This fixes the bug that Dick observed in Bugzilla #38530.
6635
6636 2003-02-22  Miguel de Icaza  <miguel@ximian.com>
6637
6638         * expression.cs (ResolveMemberAccess): When resolving a constant,
6639         do not attempt to pull a constant if the value was not able to
6640         generate a valid constant.
6641
6642         * const.cs (LookupConstantValue): Do not report more errors than required.
6643
6644 2003-02-19  Gonzalo Paniagua Javier <gonzalo@ximian.com>
6645
6646         * expression.cs: fixes bug #38328.
6647
6648 2003-02-18  Miguel de Icaza  <miguel@ximian.com>
6649
6650         * class.cs: Changed all the various members that can be part of a
6651         class from being an ArrayList to be an Array of the right type.
6652         During the DefineType type_list, interface_list, delegate_list and
6653         enum_list are turned into types, interfaces, delegates and enums
6654         arrays.  
6655
6656         And during the member population, indexer_list, event_list,
6657         constant_list, field_list, instance_constructor_list, method_list,
6658         operator_list and property_list are turned into their real arrays.
6659
6660         Although we could probably perform this operation earlier, for
6661         good error reporting we need to keep the lists and remove the
6662         lists for longer than required.
6663
6664         This optimization was triggered by Paolo profiling the compiler
6665         speed on the output of `gen-sample-program.pl' perl script. 
6666
6667         * decl.cs (DeclSpace.ResolveType): Set the ContainerType, so we do
6668         not crash in methods like MemberLookupFailed that use this field.  
6669
6670         This problem arises when the compiler fails to resolve a type
6671         during interface type definition for example.
6672
6673 2003-02-18  Miguel de Icaza  <miguel@ximian.com>
6674
6675         * expression.cs (Indexers.GetIndexersForType): Interfaces do not
6676         inherit from System.Object, so we have to stop at null, not only
6677         when reaching System.Object.
6678
6679 2003-02-17  Miguel de Icaza  <miguel@ximian.com>
6680
6681         * expression.cs: (Indexers.GetIndexersForType): Martin's fix used
6682         DeclaredOnly because the parent indexer might have had a different
6683         name, but did not loop until the top of the hierarchy was reached.
6684
6685         The problem this one fixes is 35492: when a class implemented an
6686         indexer from an interface, we were getting the interface method
6687         (which was abstract) and we were flagging an error (can not invoke
6688         abstract method).
6689
6690         This also keeps bug 33089 functioning, and test-148 functioning.
6691
6692         * typemanager.cs (IsSpecialMethod): The correct way of figuring
6693         out if a method is special is to see if it is declared in a
6694         property or event, or whether it is one of the predefined operator
6695         names.   This should fix correctly #36804.
6696
6697 2003-02-15  Miguel de Icaza  <miguel@ximian.com>
6698
6699         The goal here is to remove the dependency on EmptyCast.Peel ().
6700         Killing it completely.
6701
6702         The problem is that currently in a number of places where
6703         constants are expected, we have to "probe" for an EmptyCast, and
6704         Peel, which is not the correct thing to do, as this will be
6705         repetitive and will likely lead to errors. 
6706
6707         The idea is to remove any EmptyCasts that are used in casts that
6708         can be reduced to constants, so we only have to cope with
6709         constants. 
6710
6711         This bug hunt was triggered by Bug 37363 and the desire to remove
6712         the duplicate pattern where we were "peeling" emptycasts to check
6713         whether they were constants.  Now constants will always be
6714         constants.
6715
6716         * ecore.cs: Use an enumconstant here instead of wrapping with
6717         EmptyCast.  
6718
6719         * expression.cs (Cast.TryReduce): Ah, the tricky EnumConstant was
6720         throwing me off.  By handling this we can get rid of a few hacks.
6721
6722         * statement.cs (Switch): Removed Peel() code.
6723
6724 2003-02-14  Miguel de Icaza  <miguel@ximian.com>
6725
6726         * class.cs: Location information for error 508
6727
6728         * expression.cs (New.DoResolve): Add a guard against double
6729         resolution of an expression.  
6730
6731         The New DoResolve might be called twice when initializing field
6732         expressions (see EmitFieldInitializers, the call to
6733         GetInitializerExpression will perform a resolve on the expression,
6734         and later the assign will trigger another resolution
6735
6736         This leads to bugs (#37014)
6737
6738         * delegate.cs: The signature for EndInvoke should contain any ref
6739         or out parameters as well.  We were not doing this in the past. 
6740
6741         * class.cs (Field.Define): Do not overwrite the type definition
6742         inside the `volatile' group.  Turns out that volatile enumerations
6743         were changing the type here to perform a validity test, which
6744         broke conversions. 
6745
6746 2003-02-12  Miguel de Icaza  <miguel@ximian.com>
6747
6748         * ecore.cs (FieldExpr.AddressOf): In the particular case of This
6749         and structs, we do not want to load the instance variable
6750
6751         (ImplicitReferenceConversion, ImplicitReferenceConversionExists):
6752         enum_type has to be handled like an object reference (implicit
6753         conversions exists from this to object), but the regular IsClass
6754         and IsValueType tests will never return true for this one.
6755
6756         Also we use TypeManager.IsValueType instead of type.IsValueType,
6757         just for consistency with the rest of the code (this is only
6758         needed if we ever use the construct exposed by test-180.cs inside
6759         corlib, which we dont today).
6760
6761 2003-02-12  Zoltan Varga  <vargaz@freemail.hu>
6762
6763         * attribute.cs (ApplyAttributes): apply all MethodImplAttributes, not
6764         just InternalCall.
6765
6766 2003-02-09  Martin Baulig  <martin@ximian.com>
6767
6768         * namespace.cs (Namespace..ctor): Added SourceFile argument.
6769         (Namespace.DefineNamespaces): New static public method; this is
6770         called when we're compiling with debugging to add all namespaces
6771         to the symbol file.
6772
6773         * tree.cs (Tree.RecordNamespace): Added SourceFile argument and
6774         pass it to the Namespace's .ctor.
6775
6776         * symbolwriter.cs (SymbolWriter.OpenMethod): Added TypeContainer
6777         and MethodBase arguments; pass the namespace ID to the symwriter;
6778         pass the MethodBase instead of the token to the symwriter.
6779         (SymbolWriter.DefineNamespace): New method to add a namespace to
6780         the symbol file.
6781
6782 2003-02-09  Martin Baulig  <martin@ximian.com>
6783
6784         * symbolwriter.cs: New file.  This is a wrapper around
6785         ISymbolWriter with a cleaner API.  We'll dynamically Invoke()
6786         methods here in near future.
6787
6788 2003-02-09  Martin Baulig  <martin@ximian.com>
6789
6790         * codegen.cs (EmitContext.Mark): Just pass the arguments to
6791         ILGenerator.MarkSequencePoint() which are actually used by the
6792         symbol writer.
6793
6794 2003-02-09  Martin Baulig  <martin@ximian.com>
6795
6796         * location.cs (SourceFile): New public sealed class.  This
6797         contains the name and an index which is used in the location's token.
6798         (Location): Reserve an appropriate number of bits in the token for
6799         the source file instead of walking over that list, this gives us a
6800         really huge performance improvement when compiling with debugging.
6801
6802         * driver.cs (Driver.parse, Driver.tokenize_file): Take a
6803         `SourceFile' argument instead of a string.
6804         (Driver.ProcessFile): Add all the files via Location.AddFile(),
6805         but don't parse/tokenize here, we need to generate the list of all
6806         source files before we do that.
6807         (Driver.ProcessFiles): New static function.  Parses/tokenizes all
6808         the files.
6809
6810         * cs-parser.jay (CSharpParser): Take a `SourceFile' argument
6811         instead of a string.
6812
6813         * cs-tokenizer.cs (Tokenizer): Take `SourceFile' argument instead
6814         of a string.
6815
6816 2003-02-09  Martin Baulig  <martin@ximian.com>
6817
6818         * cs-tokenizer.cs (Tokenizer.PreProcessLine): Also reset the
6819         filename on `#line default'.
6820
6821 Sat Feb 8 17:03:16 CET 2003 Paolo Molaro <lupus@ximian.com>
6822
6823         * statement.cs: don't clear the pinned var when the fixed statement
6824         returns from the method (fixes bug#37752).
6825
6826 Sat Feb 8 12:58:06 CET 2003 Paolo Molaro <lupus@ximian.com>
6827
6828         * typemanager.cs: fix from mathpup@mylinuxisp.com (Marcus Urban) 
6829         to IsValueType.
6830
6831 2003-02-07  Martin Baulig  <martin@ximian.com>
6832
6833         * driver.cs: Removed the `--debug-args' command line argument.
6834
6835         * codegen.cs (CodeGen.SaveSymbols): Removed, this is now done
6836         automatically by the AsssemblyBuilder.
6837         (CodeGen.InitializeSymbolWriter): We don't need to call any
6838         initialization function on the symbol writer anymore.  This method
6839         doesn't take any arguments.
6840
6841 2003-02-03  Miguel de Icaza  <miguel@ximian.com>
6842
6843         * driver.cs: (AddAssemblyAndDeps, LoadAssembly): Enter the types
6844         from referenced assemblies as well.
6845
6846 2003-02-02  Martin Baulig  <martin@ximian.com>
6847
6848         * class.cs (MethodData.Emit): Generate debugging info for external methods.
6849
6850 2003-02-02  Martin Baulig  <martin@ximian.com>
6851
6852         * class.cs (Constructor.Emit): Open the symbol writer before
6853         emitting the constructor initializer.
6854         (ConstructorInitializer.Emit): Call ec.Mark() to allow
6855         single-stepping through constructor initializers.
6856
6857 2003-01-30  Miguel de Icaza  <miguel@ximian.com>
6858
6859         * class.cs: Handle error 549: do not allow virtual methods in
6860         sealed classes. 
6861
6862 2003-02-01 Jackson Harper <jackson@latitudegeo.com>
6863
6864         * decl.cs: Check access levels when resolving types
6865
6866 2003-01-31 Jackson Harper <jackson@latitudegeo.com>
6867
6868         * statement.cs: Add parameters and locals set in catch blocks that might 
6869         return to set vector
6870
6871 2003-01-29  Miguel de Icaza  <miguel@ximian.com>
6872
6873         * class.cs (Operator): Set the SpecialName flags for operators.
6874
6875         * expression.cs (Invocation.DoResolve): Only block calls to
6876         accessors and operators on SpecialName methods.
6877
6878         (Cast.TryReduce): Handle conversions from char constants.
6879
6880
6881 Tue Jan 28 17:30:57 CET 2003 Paolo Molaro <lupus@ximian.com>
6882
6883         * statement.cs: small memory and time optimization in FlowBranching.
6884
6885 2003-01-28  Pedro Mart  <yoros@wanadoo.es>
6886
6887         * expression.cs (IndexerAccess.DoResolveLValue): Resolve the same
6888         problem that the last fix but in the other sid (Set).
6889
6890         * expression.cs (IndexerAccess.DoResolve): Fix a problem with a null
6891         access when there is no indexer in the hierarchy.
6892
6893 2003-01-27 Jackson Harper <jackson@latitudegeo.com>
6894
6895         * class.cs: Combine some if statements.
6896
6897 2003-01-27  Gonzalo Paniagua Javier <gonzalo@ximian.com>
6898
6899         * driver.cs: fixed bug #37187.
6900
6901 2003-01-27  Pedro Martinez Juliá  <yoros@wanadoo.es>
6902
6903         * expression.cs (IndexerAccess.DoResolve): Before trying to resolve
6904         any indexer, it's needed to build a list with all the indexers in the
6905         hierarchy (AllGetters), else we have problems. Fixes #35653.
6906
6907 2003-01-23  Miguel de Icaza  <miguel@ximian.com>
6908
6909         * class.cs (MethodData.Define): It is wrong for an interface
6910         implementation to be static in both cases: explicit and implicit.
6911         We were only handling this in one case.
6912
6913         Improve the if situation there to not have negations.
6914
6915         * class.cs (Field.Define): Turns out that we do not need to check
6916         the unsafe bit on field definition, only on usage.  Remove the test.
6917
6918 2003-01-22  Gonzalo Paniagua Javier <gonzalo@ximian.com>
6919
6920         * driver.cs: use assembly.Location instead of Codebase (the latest
6921         patch made mcs fail when using MS assemblies).
6922
6923 2003-01-21  Tim Haynes <thaynes@openlinksw.com>
6924
6925         * driver.cs: use DirectorySeparatorChar instead of a hardcoded "/" to
6926         get the path to *corlib.dll.
6927
6928 2003-01-21  Nick Drochak <ndrochak@gol.com>
6929
6930         * cs-tokenizer.cs:
6931         * pending.cs:
6932         * typemanager.cs: Remove compiler warnings
6933
6934 2003-01-20  Duncan Mak  <duncan@ximian.com>
6935
6936         * AssemblyInfo.cs: Bump the version number to 0.19.
6937
6938 2003-01-20  Gonzalo Paniagua Javier <gonzalo@ximian.com>
6939
6940         * cs-tokenizer.cs: little fixes to line numbering when #line is used.
6941
6942 2003-01-18  Zoltan Varga  <vargaz@freemail.hu>
6943
6944         * class.cs (Constructor::Emit): Emit debugging info for constructors.
6945
6946 2003-01-17  Miguel de Icaza  <miguel@ximian.com>
6947
6948         * cs-parser.jay: Small fix: we were not comparing the constructor
6949         name correctly.   Thanks to Zoltan for the initial pointer.
6950
6951 2003-01-16 Jackson Harper <jackson@latitudegeo.com>
6952
6953         * cs-tokenizer.cs: Set file name when specified with #line
6954
6955 2003-01-15  Miguel de Icaza  <miguel@ximian.com>
6956
6957         * cs-parser.jay: Only perform the constructor checks here if we
6958         are named like the class;  This will help provider a better
6959         error.  The constructor path is taken when a type definition is
6960         not found, but most likely the user forgot to add the type, so
6961         report that rather than the constructor error.
6962
6963 Tue Jan 14 10:36:49 CET 2003 Paolo Molaro <lupus@ximian.com>
6964
6965         * class.cs, rootcontext.cs: small changes to avoid unnecessary memory
6966         allocations.
6967
6968 2003-01-13 Jackson Harper <jackson@latitudegeo.com>
6969
6970         * cs-parser.jay: Add cleanup call.
6971
6972 2003-01-13  Duncan Mak  <duncan@ximian.com>
6973
6974         * cs-tokenizer.cs (Cleanup): Rename to 'cleanup' to make it more
6975         consistent with other methods.
6976
6977 2003-01-13 Jackson Harper <jackson@latitudegeo.com>
6978
6979         * cs-tokenizer.cs: Add Cleanup method, also fix #region error messages.
6980
6981 Sun Jan 12 19:58:42 CET 2003 Paolo Molaro <lupus@ximian.com>
6982
6983         * attribute.cs: only set GuidAttr to true when we have a
6984         GuidAttribute.
6985
6986 2003-01-09  Gonzalo Paniagua Javier <gonzalo@ximian.com>
6987
6988         * ecore.cs:
6989         * expression.cs:
6990         * typemanager.cs: fixes to allow mcs compile corlib with the new
6991         Type.IsSubclassOf fix.
6992
6993 2003-01-08  Miguel de Icaza  <miguel@ximian.com>
6994
6995         * expression.cs (LocalVariableReference.DoResolve): Classify a
6996         constant as a value, not as a variable.   Also, set the type for
6997         the variable.
6998
6999         * cs-parser.jay (fixed_statement): take a type instead of a
7000         pointer_type, so we can produce a better error message later.
7001
7002         * statement.cs (Fixed.Resolve): Flag types that are not pointers
7003         as an error.  
7004
7005         (For.DoEmit): Make inifinite loops have a
7006         non-conditional branch back.
7007
7008         (Fixed.DoEmit): First populate the pinned variables, then emit the
7009         statement, then clear the variables.  Before I was emitting the
7010         code once for each fixed piece.
7011
7012
7013 2003-01-08  Martin Baulig  <martin@ximian.com>
7014
7015         * statement.cs (FlowBranching.MergeChild): A break in a
7016         SWITCH_SECTION does not leave a loop.  Fixes #36155.
7017
7018 2003-01-08  Martin Baulig  <martin@ximian.com>
7019
7020         * statement.cs (FlowBranching.CheckOutParameters): `struct_params'
7021         lives in the same number space than `param_map'.  Fixes #36154.
7022
7023 2003-01-07  Miguel de Icaza  <miguel@ximian.com>
7024
7025         * cs-parser.jay (constructor_declaration): Set the
7026         Constructor.ModFlags before probing for it.  This makes the
7027         compiler report 514, 515 and 132 (the code was there, but got
7028         broken). 
7029
7030         * statement.cs (Goto.Resolve): Set `Returns' to ALWAYS.
7031         (GotoDefault.Resolve): Set `Returns' to ALWAYS.
7032         (GotoCase.Resolve): Set `Returns' to ALWAYS.
7033
7034 Tue Jan 7 18:32:24 CET 2003 Paolo Molaro <lupus@ximian.com>
7035
7036         * enum.cs: create the enum static fields using the enum type.
7037
7038 Tue Jan 7 18:23:44 CET 2003 Paolo Molaro <lupus@ximian.com>
7039
7040         * class.cs: don't try to create the ParamBuilder for the return
7041         type if it's not needed (and handle it breaking for the ms runtime
7042         anyway).
7043
7044 2003-01-06 Jackson Harper <jackson@latitudegeo.com>
7045
7046         * cs-tokenizer.cs: Add REGION flag to #region directives, and add checks to make sure that regions are being poped correctly
7047
7048 2002-12-29  Miguel de Icaza  <miguel@ximian.com>
7049
7050         * cs-tokenizer.cs (get_cmd_arg): Fixups to allow \r to terminate
7051         the command.   This showed up while compiling the JANET source
7052         code, which used \r as its only newline separator.
7053
7054 2002-12-28  Miguel de Icaza  <miguel@ximian.com>
7055
7056         * class.cs (Method.Define): If we are an operator (because it
7057         reuses our code), then set the SpecialName and HideBySig.  #36128
7058
7059 2002-12-22  Miguel de Icaza  <miguel@ximian.com>
7060
7061         * ecore.cs (FieldExpr.DoResolve): Instead of throwing an
7062         exception, report error 120 `object reference required'.
7063
7064         * driver.cs: Add --pause option, used during to measure the size
7065         of the process as it goes with --timestamp.
7066
7067         * expression.cs (Invocation.DoResolve): Do not allow methods with
7068         SpecialName to be invoked.
7069
7070 2002-12-21  Miguel de Icaza  <miguel@ximian.com>
7071
7072         * cs-tokenizer.cs: Small fix to the parser: compute the ascii
7073         number before adding it.
7074
7075 2002-12-21  Ravi Pratap  <ravi@ximian.com>
7076
7077         * ecore.cs (StandardImplicitConversion): When in an unsafe
7078         context, we allow conversion between void * to any other pointer
7079         type. This fixes bug #35973.
7080
7081 2002-12-20 Jackson Harper <jackson@latitudegeo.com>
7082
7083         * codegen.cs: Use Path.GetFileNameWithoutExtension so an exception
7084         is not thrown when extensionless outputs are used 
7085
7086 2002-12-20  Gonzalo Paniagua Javier <gonzalo@ximian.com>
7087
7088         * rootcontext.cs: fixed compilation of corlib.
7089
7090 2002-12-19  Miguel de Icaza  <miguel@ximian.com>
7091
7092         * attribute.cs (Attributes.Contains): Add new method.
7093
7094         * class.cs (MethodCore.LabelParameters): if the parameter is an
7095         `out' parameter, check that no attribute `[In]' has been passed.
7096
7097         * enum.cs: Handle the `value__' name in an enumeration.
7098
7099 2002-12-14  Jaroslaw Kowalski <jarek@atm.com.pl>
7100
7101         * decl.cs: Added special case to allow overrides on "protected
7102         internal" methods
7103
7104 2002-12-18  Ravi Pratap  <ravi@ximian.com>
7105
7106         * attribute.cs (Attributes.AddAttributeSection): Rename to this
7107         since it makes much more sense.
7108
7109         (Attributes.ctor): Don't require a Location parameter.
7110
7111         * rootcontext.cs (AddGlobalAttributeSection): Rename again.
7112
7113         * attribute.cs (ApplyAttributes): Remove extra Location parameters
7114         since we already have that information per attribute.
7115
7116         * everywhere : make appropriate changes.
7117
7118         * class.cs (LabelParameters): Write the code which actually
7119         applies attributes to the return type. We can't do this on the MS
7120         .NET runtime so we flag a warning in the case an exception is
7121         thrown.
7122
7123 2002-12-18  Miguel de Icaza  <miguel@ximian.com>
7124
7125         * const.cs: Handle implicit null conversions here too.
7126
7127 2002-12-17  Ravi Pratap  <ravi@ximian.com>
7128
7129         * class.cs (MethodCore.LabelParameters): Remove the extra
7130         Type [] parameter since it is completely unnecessary. Instead
7131         pass in the method's attributes so that we can extract
7132         the "return" attribute.
7133
7134 2002-12-17  Miguel de Icaza  <miguel@ximian.com>
7135
7136         * cs-parser.jay (parse): Use Report.Error to flag errors instead
7137         of ignoring it and letting the compile continue.
7138
7139         * typemanager.cs (ChangeType): use an extra argument to return an
7140         error condition instead of throwing an exception.
7141
7142 2002-12-15  Miguel de Icaza  <miguel@ximian.com>
7143
7144         * expression.cs (Unary.TryReduce): mimic the code for the regular
7145         code path.  Perform an implicit cast in the cases where we can
7146         implicitly convert to one of the integral types, and then reduce
7147         based on that constant.   This fixes bug #35483.
7148
7149 2002-12-14  Gonzalo Paniagua Javier <gonzalo@ximian.com>
7150
7151         * typemanager.cs: fixed cut & paste error in GetRemoveMethod.
7152
7153 2002-12-13  Gonzalo Paniagua Javier <gonzalo@ximian.com>
7154
7155         * namespace.cs: fixed bug #35489.
7156
7157 2002-12-12  Miguel de Icaza  <miguel@ximian.com>
7158
7159         * class.cs: Remove some dead code.
7160
7161         * cs-parser.jay: Estimate the number of methods needed
7162         (RootContext.MethodCount);
7163
7164         * cs-tokenizer.cs: Use char arrays for parsing identifiers and
7165         numbers instead of StringBuilders.
7166
7167         * support.cs (PtrHashtable): Add constructor with initial size;
7168         We can now reduce reallocations of the method table.
7169
7170 2002-12-10  Ravi Pratap  <ravi@ximian.com>
7171
7172         * attribute.cs (ApplyAttributes): Keep track of the emitted
7173         attributes on a per-target basis. This fixes bug #35413.
7174
7175 2002-12-10  Miguel de Icaza  <miguel@ximian.com>
7176
7177         * driver.cs (MainDriver): On rotor encoding 28591 does not exist,
7178         default to the Windows 1252 encoding.
7179
7180         (UnixParseOption): Support version, thanks to Alp for the missing
7181         pointer. 
7182
7183         * AssemblyInfo.cs: Add nice assembly information.
7184
7185         * cs-tokenizer.cs: Add fix from Felix to the #if/#else handler
7186         (bug 35169).
7187
7188         * cs-parser.jay: Allow a trailing comma before the close bracked
7189         in the attribute_section production.
7190
7191         * ecore.cs (FieldExpr.AddressOf): Until I figure out why the
7192         address of the instance was being taken, I will take this out,
7193         because we take the address of the object immediately here.
7194
7195 2002-12-09  Ravi Pratap  <ravi@ximian.com>
7196
7197         * typemanager.cs (AreMultipleAllowed): Take care of the most
7198         obvious case where attribute type is not in the current assembly -
7199         stupid me ;-)
7200
7201 2002-12-08  Miguel de Icaza  <miguel@ximian.com>
7202
7203         * ecore.cs (SimpleName.DoResolve): First perform lookups on using
7204         definitions, instead of doing that afterwards.  
7205
7206         Also we use a nice little hack, depending on the constructor, we
7207         know if we are a "composed" name or a simple name.  Hence, we
7208         avoid the IndexOf test, and we avoid 
7209
7210         * codegen.cs: Add code to assist in a bug reporter to track down
7211         the source of a compiler crash. 
7212
7213 2002-12-07  Ravi Pratap  <ravi@ximian.com>
7214
7215         * attribute.cs (Attribute.ApplyAttributes) : Keep track of which attribute
7216         types have been emitted for a given element and flag an error
7217         if something which does not have AllowMultiple set is used more
7218         than once.
7219
7220         * typemanager.cs (RegisterAttributeAllowMultiple): Keep track of
7221         attribute types and their corresponding AllowMultiple properties
7222
7223         (AreMultipleAllowed): Check the property for a given type.
7224
7225         * attribute.cs (Attribute.ApplyAttributes): Register the AllowMultiple
7226         property in the case we have a TypeContainer.
7227
7228         (Attributes.AddAttribute): Detect duplicates and just skip on
7229         adding them. This trivial fix catches a pretty gross error in our
7230         attribute emission - global attributes were being emitted twice!
7231
7232         Bugzilla bug #33187 is now fixed.
7233
7234 2002-12-06  Miguel de Icaza  <miguel@ximian.com>
7235
7236         * cs-tokenizer.cs (pp_expr): Properly recurse here (use pp_expr
7237         instead of pp_and).
7238
7239         * expression.cs (Binary.ResolveOperator): I can only use the
7240         Concat (string, string, string) and Concat (string, string,
7241         string, string) if the child is actually a concatenation of
7242         strings. 
7243
7244 2002-12-04  Miguel de Icaza  <miguel@ximian.com>
7245
7246         * cs-tokenizer.cs: Small fix, because decimal_digits is used in a
7247         context where we need a 2-character lookahead.
7248
7249         * pending.cs (PendingImplementation): Rework so we can keep track
7250         of interface types all the time, and flag those which were
7251         implemented by parents as optional.
7252
7253 2002-12-03  Miguel de Icaza  <miguel@ximian.com>
7254
7255         * expression.cs (Binary.ResolveOperator): Use
7256         String.Concat(string,string,string) or
7257         String.Concat(string,string,string,string) when possible. 
7258
7259         * typemanager: More helper methods.
7260
7261
7262 Tue Dec 3 19:32:04 CET 2002 Paolo Molaro <lupus@ximian.com>
7263
7264         * pending.cs: remove the bogus return from GetMissingInterfaces()
7265         (see the 2002-11-06 entry: the mono runtime is now fixed in cvs).
7266
7267 2002-12-02  Gonzalo Paniagua Javier <gonzalo@ximian.com>
7268
7269         * namespace.cs: avoid duplicated 'using xxx' being added to
7270         using_clauses. This prevents mcs from issuing and 'ambiguous type' error
7271         when we get more than one 'using' statement for the same namespace.
7272         Report a CS0105 warning for it.
7273
7274 2002-11-30  Miguel de Icaza  <miguel@ximian.com>
7275
7276         * cs-tokenizer.cs (consume_identifier): use read directly, instead
7277         of calling getChar/putback, uses internal knowledge of it.    
7278
7279         (xtoken): Reorder tokenizer so most common patterns are checked
7280         first.  This reduces the compilation time in another 5% (from 8.11s
7281         average to 7.73s for bootstrapping mcs on my Mobile p4/1.8ghz).
7282
7283         The parsing time is 22% of the compilation in mcs, and from that
7284         64% is spent on the tokenization process.  
7285
7286         I tried using a binary search for keywords, but this is slower
7287         than the hashtable.  Another option would be to do a couple of
7288         things:
7289
7290                 * Not use a StringBuilder, instead use an array of chars,
7291                   with a set value.  Notice that this way we could catch
7292                   the 645 error without having to do it *afterwards*.
7293
7294                 * We could write a hand-parser to avoid the hashtable
7295                   compares altogether.
7296
7297         The identifier consumption process takes 37% of the tokenization
7298         time.  Another 15% is spent on is_number.  56% of the time spent
7299         on is_number is spent on Int64.Parse:
7300
7301                 * We could probably choose based on the string length to
7302                   use Int32.Parse or Int64.Parse and avoid all the 64-bit
7303                   computations. 
7304
7305         Another 3% is spend on wrapping `xtoken' in the `token' function.
7306
7307         Handle 0xa0 as whitespace (#34752)
7308
7309 2002-11-26  Miguel de Icaza  <miguel@ximian.com>
7310
7311         * typemanager.cs (IsCLRType): New routine to tell whether a type
7312         is one of the builtin types.  
7313
7314         Maybe it needs to use TypeCodes to be faster.  Maybe we could use
7315         typecode in more places instead of doing pointer comparissions.
7316         We could leverage some knowledge about the way the typecodes are
7317         laid out.
7318
7319         New code to cache namespaces in assemblies, it is currently not
7320         invoked, to be used soon.
7321
7322         * decl.cs (DeclSpace.MakeFQN): Simple optimization.
7323
7324         * expression.cs (Binary.ResolveOperator): specially handle
7325         strings, and do not perform user-defined operator overloading for
7326         built-in types.
7327
7328 2002-11-24  Miguel de Icaza  <miguel@ximian.com>
7329
7330         * cs-tokenizer.cs: Avoid calling Char.IsDigit which is an
7331         internalcall as it is a pretty simple operation;  Avoid whenever
7332         possible to call Char.IsLetter.
7333
7334         (consume_identifier): Cut by half the number of
7335         hashtable calls by merging the is_keyword and GetKeyword behavior.
7336
7337         Do not short-circuit, because if we do, we
7338         report errors (ie, #if false && true would produce an invalid
7339         directive error);
7340
7341
7342 2002-11-24  Martin Baulig  <martin@ximian.com>
7343
7344         * expression.cs (Cast.TryReduce): If we're in checked syntax,
7345         check constant ranges and report a CS0221.  Fixes #33186.
7346
7347 2002-11-24  Martin Baulig  <martin@ximian.com>
7348
7349         * cs-parser.jay: Make this work for uninitialized variable
7350         declarations in the `for' initializer.  Fixes #32416.
7351
7352 2002-11-24  Martin Baulig  <martin@ximian.com>
7353
7354         * ecore.cs (Expression.ConvertExplicit): Make casting from/to
7355         System.Enum actually work.  Fixes bug #32269, added verify-6.cs.
7356
7357 2002-11-24  Martin Baulig  <martin@ximian.com>
7358
7359         * expression.cs (Binary.DoNumericPromotions): Added `check_user_conv'
7360         argument; if true, we also check for user-defined conversions.
7361         This is only needed if both arguments are of a user-defined type.
7362         Fixes #30443, added test-175.cs.
7363         (Binary.ForceConversion): Pass the location argument to ConvertImplicit.
7364
7365         * ecore.cs (Expression.ImplicitUserConversionExists): New method.
7366
7367 2002-11-24  Martin Baulig  <martin@ximian.com>
7368
7369         * expression.cs (ArrayAccess.GetStoreOpcode): New public static
7370         function to get the store opcode.
7371         (Invocation.EmitParams): Call ArrayAccess.GetStoreOpcode() and
7372         only emit the Ldelema if the store opcode is Stobj.  You must run
7373         both test-34 and test-167 to test this.  Fixes #34529.
7374
7375 2002-11-23  Martin Baulig  <martin@ximian.com>
7376
7377         * ecore.cs (Expression.MemberLookup): Added additional
7378         `qualifier_type' argument which is used when we're being called
7379         from MemberAccess.DoResolve() and null if we're called from a
7380         SimpleName lookup.
7381         (Expression.MemberLookupFailed): New method to report errors; this
7382         does the CS1540 check and reports the correct error message.
7383
7384         * typemanager.cs (MemberLookup): Added additional `qualifier_type'
7385         argument for the CS1540 check and redone the way how we're dealing
7386         with private members.  See the comment in the source code for details.
7387         (FilterWithClosure): Reverted this back to revision 1.197; renamed
7388         `closure_start_type' to `closure_qualifier_type' and check whether
7389         it's not null.  It was not this filter being broken, it was just
7390         being called with the wrong arguments.
7391
7392         * expression.cs (MemberAccess.DoResolve): use MemberLookupFinal()
7393         and pass it the correct `qualifier_type'; this also does the error
7394         handling for us.
7395
7396 2002-11-22  Miguel de Icaza  <miguel@ximian.com>
7397
7398         * expression.cs (Invocation.EmitParams): If the we are dealing
7399         with a non-built-in value type, load its address as well.
7400
7401         (ArrayCreation): Use a a pretty constant instead
7402         of the hardcoded value 2.   Use 6 instead of 2 for the number of
7403         static initializers.  
7404
7405         (ArrayCreation.EmitDynamicInitializers): Peel enumerations,
7406         because they are not really value types, just glorified integers. 
7407
7408         * driver.cs: Do not append .exe, the CSC compiler does not do it.
7409
7410         * ecore.cs: Remove redundant code for enumerations, make them use
7411         the same code path as everything else, fixes the casting issue
7412         with enumerations in Windows.Forms.
7413
7414         * attribute.cs: Do only cast to string if it is a string, the
7415         validation happens later.
7416
7417         * typemanager.cs: Temproary hack to avoid a bootstrap issue until
7418         people upgrade their corlibs.
7419
7420         * ecore.cs: Oops, enumerations were not following the entire code path
7421
7422 2002-11-21  Miguel de Icaza  <miguel@ximian.com>
7423
7424         * typemanager.cs (FilterWithClosure): Commented out the test for
7425         1540 in typemanager.cs, as it has problems when accessing
7426         protected methods from a parent class (see test-174.cs). 
7427
7428         * attribute.cs (Attribute.ValidateGuid): new method.
7429         (Attribute.Resolve): Use above.
7430
7431 2002-11-19  Miguel de Icaza  <miguel@ximian.com>
7432
7433         * enum.cs: In FindMembers, perform a recursive lookup for values. (34308)
7434
7435         * ecore.cs (SimpleName.SimpleNameResolve): Remove the special
7436         handling for enumerations, as we only needed the TypeContainer
7437         functionality to begin with (this is required for the fix below to
7438         work for enums that reference constants in a container class for
7439         example). 
7440
7441         * codegen.cs (EmitContext): Make TypeContainer a DeclSpace.
7442
7443         * enum.cs (Enum.Define): Use `this' instead of parent, so we have
7444         a valid TypeBuilder to perform lookups on.o
7445
7446         * class.cs (InheritableMemberSignatureCompare): Use true in the
7447         call to GetGetMethod and GetSetMethod, because we are comparing
7448         the signature, and we need to get the methods *even* if they are
7449         private. 
7450
7451         (PropertyBase.CheckBase): ditto.
7452
7453         * statement.cs (Switch.ResolveAndReduce, Block.EmitMeta,
7454         GotoCase.Resolve): Use Peel on EmpytCasts.
7455
7456         * ecore.cs (EmptyCast): drop child, add Peel method.
7457
7458 2002-11-17  Martin Baulig  <martin@ximian.com>
7459
7460         * ecore.cs (EmptyCast.Child): New public property.
7461
7462         * statement.cs (SwitchLabel.ResolveAndReduce): Check whether the
7463         label resolved to an EmptyCast.  Fixes #34162.
7464         (GotoCase.Resolve): Likewise.
7465         (Block.EmitMeta): Likewise.
7466
7467 2002-11-17  Martin Baulig  <martin@ximian.com>
7468
7469         * expression.cs (Invocation.BetterConversion): Prefer int over
7470         uint; short over ushort; long over ulong for integer literals.
7471         Use ImplicitConversionExists instead of StandardConversionExists
7472         since we also need to check for user-defined implicit conversions.
7473         Fixes #34165.  Added test-173.cs.
7474
7475 2002-11-16  Martin Baulig  <martin@ximian.com>
7476
7477         * expression.cs (Binary.EmitBranchable): Eliminate comparisions
7478         with the `true' and `false' literals.  Fixes #33151.
7479
7480 2002-11-16  Martin Baulig  <martin@ximian.com>
7481
7482         * typemanager.cs (RealMemberLookup): Reverted Miguel's patch from
7483         October 22nd; don't do the cs1540 check for static members.
7484
7485         * ecore.cs (PropertyExpr.ResolveAccessors): Rewrote this; we're
7486         now using our own filter here and doing the cs1540 check again.
7487
7488 2002-11-16  Martin Baulig  <martin@ximian.com>
7489
7490         * support.cs (InternalParameters): Don't crash if we don't have
7491         any fixed parameters.  Fixes #33532.
7492
7493 2002-11-16  Martin Baulig  <martin@ximian.com>
7494
7495         * decl.cs (MemberCache.AddMethods): Use BindingFlags.FlattenHierarchy
7496         when looking up static methods to make this work on Windows.
7497         Fixes #33773.
7498
7499 2002-11-16  Martin Baulig  <martin@ximian.com>
7500
7501         * ecore.cs (PropertyExpr.VerifyAssignable): Check whether we have
7502         a setter rather than using PropertyInfo.CanWrite.
7503
7504 2002-11-15  Nick Drochak  <ndrochak@gol.com>
7505
7506         * class.cs: Allow acces to block member by subclasses. Fixes build
7507         breaker.
7508
7509 2002-11-14  Martin Baulig  <martin@ximian.com>
7510
7511         * class.cs (Constructor.Emit): Added the extern/block check.
7512         Fixes bug #33678.
7513
7514 2002-11-14  Martin Baulig  <martin@ximian.com>
7515
7516         * expression.cs (IndexerAccess.DoResolve): Do a DeclaredOnly
7517         iteration while looking for indexers, this is needed because the
7518         indexer may have a different name in our base classes.  Fixed the
7519         error reporting (no indexers at all, not get accessor, no
7520         overloaded match).  Fixes bug #33089.
7521         (IndexerAccess.DoResolveLValue): Likewise.
7522
7523 2002-11-14  Martin Baulig  <martin@ximian.com>
7524
7525         * class.cs (PropertyBase.CheckBase): Make this work for multiple
7526         indexers.  Fixes the first part of bug #33089.
7527         (MethodSignature.InheritableMemberSignatureCompare): Added support
7528         for properties.
7529
7530 2002-11-13  Ravi Pratap  <ravi@ximian.com>
7531
7532         * attribute.cs (Attribute.Resolve): Catch the
7533         NullReferenceException and report it since it isn't supposed to
7534         happen. 
7535
7536 2002-11-12  Miguel de Icaza  <miguel@ximian.com>
7537
7538         * expression.cs (Binary.EmitBranchable): Also handle the cases for
7539         LogicalOr and LogicalAnd that can benefit from recursively
7540         handling EmitBranchable.  The code now should be nice for Paolo.
7541
7542 2002-11-08  Miguel de Icaza  <miguel@ximian.com>
7543
7544         * typemanager.cs (LookupType): Added a negative-hit hashtable for
7545         the Type lookups, as we perform quite a number of lookups on
7546         non-Types.  This can be removed once we can deterministically tell
7547         whether we have a type or a namespace in advance.
7548
7549         But this might require special hacks from our corlib.
7550
7551         * TODO: updated.
7552
7553         * ecore.cs (TryImplicitIntConversion): Handle conversions to float
7554         and double which avoids a conversion from an integer to a double.
7555
7556         * expression.cs: tiny optimization, avoid calling IsConstant,
7557         because it effectively performs the lookup twice.
7558
7559 2002-11-06  Miguel de Icaza  <miguel@ximian.com>
7560
7561         But a bogus return here to keep the semantics of the old code
7562         until the Mono runtime is fixed.
7563
7564         * pending.cs (GetMissingInterfaces): New method used to remove all
7565         the interfaces that are already implemented by our parent
7566         classes from the list of pending methods. 
7567
7568         * interface.cs: Add checks for calls after ResolveTypeExpr.
7569
7570 2002-11-05  Miguel de Icaza  <miguel@ximian.com>
7571
7572         * class.cs (Class.Emit): Report warning 67: event not used if the
7573         warning level is beyond 3.
7574
7575         * ecore.cs (Expression.ConvertExplicit): Missed a check for expr
7576         being a NullLiteral.
7577
7578         * cs-parser.jay: Fix, Gonzalo reverted the order of the rank
7579         specifiers. 
7580
7581         * class.cs (TypeContainer.GetClassBases): Cover a missing code
7582         path that might fail if a type can not be resolved.
7583
7584         * expression.cs (Binary.Emit): Emit unsigned versions of the
7585         operators. 
7586
7587         * driver.cs: use error 5.
7588
7589 2002-11-02  Gonzalo Paniagua Javier <gonzalo@gnome-db.org>
7590
7591         * cs-parser.jay: simplified a rule and 5 SR conflicts dissapeared.
7592
7593 2002-11-01  Miguel de Icaza  <miguel@ximian.com>
7594
7595         * cs-parser.jay (switch_section): A beautiful patch from Martin
7596         Baulig that fixed 33094.
7597
7598 2002-10-31  Miguel de Icaza  <miguel@ximian.com>
7599
7600         * ecore.cs (PropertyExpr.DoResolveLValue, PropertyExpr.DoResolve):
7601         Check whether the base is abstract and report an error if so.
7602
7603         * expression.cs (IndexerAccess.DoResolveLValue,
7604         IndexerAccess.DoResolve): ditto. 
7605
7606         (Invocation.DoResolve): ditto.
7607
7608         (Invocation.FullMethodDesc): Improve the report string.
7609
7610         * statement.cs (Block): Eliminate IsVariableDefined as it is
7611         basically just a wrapper for GetVariableInfo.
7612
7613         * ecore.cs (SimpleName): Use new 
7614
7615         * support.cs (ReflectionParamter.ParameterType): We unwrap the
7616         type, as we return the actual parameter ref/unref state on a
7617         different call.
7618
7619 2002-10-30  Miguel de Icaza  <miguel@ximian.com>
7620
7621         * support.cs: Return proper flags REF/OUT fixing the previous
7622         commit.  
7623
7624         * expression.cs: Reverted last patch, that was wrong.  Is_ref is
7625         not used to mean `ref' but `ref or out' in ParameterReference
7626
7627         * delegate.cs (FullDelegateDesc): use ParameterDesc to get the
7628         full type signature instead of calling TypeManger.CSharpName
7629         ourselves. 
7630
7631         * support.cs (InternalParameters.ParameterDesc): Do not compare
7632         directly to the modflags, because REF/OUT will actually be bitsets
7633         if set. 
7634
7635         * delegate.cs (VerifyMethod): Check also the modifiers.
7636
7637         * cs-tokenizer.cs: Fix bug where floating point values with an
7638         exponent where a sign was missing was ignored.
7639
7640         * driver.cs: Allow multiple assemblies to be specified in a single
7641         /r: argument
7642
7643 2002-10-28  Miguel de Icaza  <miguel@ximian.com>
7644
7645         * cs-parser.jay: Ugly.  We had to add a multiplicative_expression,
7646         because identifiers after a parenthesis would end up in this kind
7647         of production, and we needed to desamiguate it for having casts
7648         like:
7649
7650                 (UserDefinedType *) xxx
7651
7652 2002-10-24  Miguel de Icaza  <miguel@ximian.com>
7653
7654         * typemanager.cs (RealMemberLookup): when we deal with a subclass,
7655         we should set on the Bindingflags.NonPublic, but not turn on
7656         private_ok.  private_ok controls whether a Private member is
7657         returned (this is chekced on the filter routine), while the
7658         BindingFlags.NonPublic just controls whether private/protected
7659         will be allowed.   This fixes the problem part of the problem of
7660         private properties being allowed to be used in derived classes.
7661
7662         * expression.cs (BaseAccess): Provide an DoResolveLValue method,
7663         so we can call the children DoResolveLValue method (this will
7664         properly signal errors on lvalue assignments to base properties)
7665
7666         * ecore.cs (PropertyExpr.ResolveAccessors): If both setter and
7667         getter are null, and we have a property info, we know that this
7668         happened because the lookup failed, so we report an error 122 for
7669         protection level violation.
7670
7671         We also silently return if setter and getter are null in the
7672         resolve functions, this condition only happens if we have flagged
7673         the error before.  This is the other half of the problem. 
7674
7675         (PropertyExpr.ResolveAccessors): Turns out that PropertyInfo does
7676         not have accessibility information, that is why we were returning
7677         true in the filter function in typemanager.cs.
7678
7679         To properly report 122 (property is inaccessible because of its
7680         protection level) correctly, we report this error in ResolveAccess
7681         by failing if both the setter and the getter are lacking (ie, the
7682         lookup failed). 
7683
7684         DoResolve and DoLResolve have been modified to check for both
7685         setter/getter being null and returning silently, the reason being
7686         that I did not want to put the knowledge about this error in upper
7687         layers, like:
7688
7689         int old = Report.Errors;
7690         x = new PropertyExpr (...);
7691         if (old != Report.Errors)
7692                 return null;
7693         else
7694                 return x;
7695
7696         So the property expr is returned, but it is invalid, so the error
7697         will be flagged during the resolve process. 
7698
7699         * class.cs: Remove InheritablePropertySignatureCompare from the
7700         class, as we no longer depend on the property signature to compute
7701         whether it is possible to implement a method or not.
7702
7703         The reason is that calling PropertyInfo.GetGetMethod will return
7704         null (in .NET, in Mono it works, and we should change this), in
7705         cases where the Get Method does not exist in that particular
7706         class.
7707
7708         So this code:
7709
7710         class X { public virtual int A { get { return 1; } } }
7711         class Y : X { }
7712         class Z : Y { public override int A { get { return 2; } } }
7713
7714         Would fail in Z because the parent (Y) would not have the property
7715         defined.  So we avoid this completely now (because the alternative
7716         fix was ugly and slow), and we now depend exclusively on the
7717         method names.
7718
7719         (PropertyBase.CheckBase): Use a method-base mechanism to find our
7720         reference method, instead of using the property.
7721
7722         * typemanager.cs (GetPropertyGetter, GetPropertySetter): These
7723         routines are gone now.
7724
7725         * typemanager.cs (GetPropertyGetter, GetPropertySetter): swap the
7726         names, they were incorrectly named.
7727
7728         * cs-tokenizer.cs: Return are more gentle token on failure. 
7729
7730         * pending.cs (PendingImplementation.InterfaceMethod): This routine
7731         had an out-of-sync index variable, which caused it to remove from
7732         the list of pending methods the wrong method sometimes.
7733
7734 2002-10-22  Miguel de Icaza  <miguel@ximian.com>
7735
7736         * ecore.cs (PropertyExpr): Do not use PropertyInfo.CanRead,
7737         CanWrite, because those refer to this particular instance of the
7738         property, and do not take into account the fact that we can
7739         override single members of a property.
7740
7741         Constructor requires an EmitContext.  The resolution process does
7742         not happen here, but we need to compute the accessors before,
7743         because the resolution does not always happen for properties.
7744
7745         * typemanager.cs (RealMemberLookup): Set private_ok if we are a
7746         subclass, before we did not update this flag, but we did update
7747         bindingflags. 
7748
7749         (GetAccessors): Drop this routine, as it did not work in the
7750         presence of partially overwritten set/get methods. 
7751
7752         Notice that this broke the cs1540 detection, but that will require
7753         more thinking. 
7754
7755 2002-10-22  Gonzalo Paniagua Javier <gonzalo@ximian.com>
7756
7757         * class.cs:
7758         * codegen.cs:
7759         * driver.cs: issue a warning instead of an error if we don't support
7760         debugging for the platform. Also ignore a couple of errors that may
7761         arise when trying to write the symbols. Undo my previous patch.
7762
7763 2002-10-22  Gonzalo Paniagua Javier <gonzalo@ximian.com>
7764
7765         * driver.cs: ignore /debug switch except for Unix platforms.
7766
7767 2002-10-23  Nick Drochak  <ndrochak@gol.com>
7768
7769         * makefile: Remove mcs2.exe and mcs3.exe on 'make clean'
7770
7771 2002-10-21  Miguel de Icaza  <miguel@ximian.com>
7772
7773         * driver.cs: Do not make mcs-debug conditional, so we do not break
7774         builds that use it.
7775
7776         * statement.cs (UsageVector.MergeChildren): I would like Martin to
7777         review this patch.  But basically after all the children variables
7778         have been merged, the value of "Breaks" was not being set to
7779         new_breaks for Switch blocks.  I think that it should be set after
7780         it has executed.  Currently I set this to the value of new_breaks,
7781         but only if new_breaks is FlowReturn.ALWAYS, which is a bit
7782         conservative, but I do not understand this code very well.
7783
7784         I did not break anything in the build, so that is good ;-)
7785
7786         * cs-tokenizer.cs: Also allow \r in comments as a line separator.
7787
7788 2002-10-20  Mark Crichton  <crichton@gimp.org>
7789
7790         * cfold.cs: Fixed compile blocker.  Really fixed it this time.
7791
7792 2002-10-20  Nick Drochak  <ndrochak@gol.com>
7793
7794         * cfold.cs: Fixed compile blocker.
7795
7796 2002-10-20  Miguel de Icaza  <miguel@ximian.com>
7797
7798         * driver.cs: I was chekcing the key, not the file.
7799
7800 2002-10-19  Ravi Pratap  <ravi@ximian.com>
7801
7802         * ecore.cs (UserDefinedConversion): Get rid of the bogus error
7803         message that we were generating - we just need to silently return
7804         a null.
7805
7806 2002-10-19  Miguel de Icaza  <miguel@ximian.com>
7807
7808         * class.cs (Event.Define): Change my previous commit, as this
7809         breaks the debugger.  This is a temporary hack, as it seems like
7810         the compiler is generating events incorrectly to begin with.
7811
7812         * expression.cs (Binary.ResolveOperator): Added support for 
7813         "U operator - (E x, E y)"
7814
7815         * cfold.cs (BinaryFold): Added support for "U operator - (E x, E
7816         y)".
7817
7818         * ecore.cs (FieldExpr.AddressOf): We had a special code path for
7819         init-only variables, but this path did not take into account that
7820         there might be also instance readonly variables.  Correct this
7821         problem. 
7822
7823         This fixes bug 32253
7824
7825         * delegate.cs (NewDelegate.DoResolve): Catch creation of unsafe
7826         delegates as well.
7827
7828         * driver.cs: Change the extension for modules to `netmodule'
7829
7830         * cs-parser.jay: Improved slightly the location tracking for
7831         the debugger symbols.
7832
7833         * class.cs (Event.Define): Use Modifiers.FieldAttr on the
7834         modifiers that were specified instead of the hardcoded value
7835         (FamAndAssem).  This was basically ignoring the static modifier,
7836         and others.  Fixes 32429.
7837
7838         * statement.cs (Switch.SimpleSwitchEmit): Simplified the code, and
7839         fixed a bug in the process (32476)
7840
7841         * expression.cs (ArrayAccess.EmitAssign): Patch from
7842         hwang_rob@yahoo.ca that fixes bug 31834.3
7843
7844 2002-10-18  Miguel de Icaza  <miguel@ximian.com>
7845
7846         * driver.cs: Make the module extension .netmodule.
7847
7848 2002-10-16  Miguel de Icaza  <miguel@ximian.com>
7849
7850         * driver.cs: Report an error if the resource file is not found
7851         instead of crashing.
7852
7853         * ecore.cs (PropertyExpr.EmitAssign): Pass IsBase instead of
7854         false, like Emit does.
7855
7856 2002-10-16  Nick Drochak  <ndrochak@gol.com>
7857
7858         * typemanager.cs: Remove unused private member.  Also reported mcs
7859         bug to report this as a warning like csc.
7860
7861 2002-10-15  Martin Baulig  <martin@gnome.org>
7862
7863         * statement.cs (Statement.Emit): Made this a virtual method; emits
7864         the line number info and calls DoEmit().
7865         (Statement.DoEmit): New protected abstract method, formerly knows
7866         as Statement.Emit().
7867
7868         * codegen.cs (EmitContext.Mark): Check whether we have a symbol writer.
7869
7870 2002-10-11  Miguel de Icaza  <miguel@ximian.com>
7871
7872         * class.cs: Following the comment from 2002-09-26 to AddMethod, I
7873         have fixed a remaining problem: not every AddXXXX was adding a
7874         fully qualified name.  
7875
7876         Now everyone registers a fully qualified name in the DeclSpace as
7877         being defined instead of the partial name.  
7878
7879         Downsides: we are slower than we need to be due to the excess
7880         copies and the names being registered this way.  
7881
7882         The reason for this is that we currently depend (on the corlib
7883         bootstrap for instance) that types are fully qualified, because
7884         we dump all the types in the namespace, and we should really have
7885         types inserted into the proper namespace, so we can only store the
7886         basenames in the defined_names array.
7887
7888 2002-10-10  Martin Baulig  <martin@gnome.org>
7889
7890         * expression.cs (ArrayAccess.EmitStoreOpcode): Reverted the patch
7891         from bug #31834, see the bug report for a testcase which is
7892         miscompiled.
7893
7894 2002-10-10  Martin Baulig  <martin@gnome.org>
7895
7896         * codegen.cs (EmitContext.Breaks): Removed, we're now using the
7897         flow analysis code for this.
7898
7899         * statement.cs (Do, While, For): Tell the flow analysis code about
7900         infinite loops.
7901         (FlowBranching.UsageVector): Added support for infinite loops.
7902         (Block.Resolve): Moved the dead code elimination here and use flow
7903         analysis to do it.
7904
7905 2002-10-09  Miguel de Icaza  <miguel@ximian.com>
7906
7907         * class.cs (Field.Define): Catch cycles on struct type
7908         definitions. 
7909
7910         * typemanager.cs (IsUnmanagedtype): Do not recursively check
7911         fields if the fields are static.  We only need to check instance
7912         fields. 
7913
7914         * expression.cs (As.DoResolve): Test for reference type.
7915
7916         * statement.cs (Using.ResolveExpression): Use
7917         ConvertImplicitRequired, not ConvertImplicit which reports an
7918         error on failture
7919         (Using.ResolveLocalVariableDecls): ditto.
7920
7921         * expression.cs (Binary.ResolveOperator): Report errors in a few
7922         places where we had to.
7923
7924         * typemanager.cs (IsUnmanagedtype): Finish implementation.
7925
7926 2002-10-08  Miguel de Icaza  <miguel@ximian.com>
7927
7928         * expression.cs: Use StoreFromPtr instead of extracting the type
7929         and then trying to use Stelem.  Patch is from hwang_rob@yahoo.ca
7930
7931         * ecore.cs (ImplicitReferenceConversion): It is possible to assign
7932         an enumeration value to a System.Enum, but System.Enum is not a
7933         value type, but an class type, so we need to box.
7934
7935         (Expression.ConvertExplicit): One codepath could return
7936         errors but not flag them.  Fix this.  Fixes #31853
7937
7938         * parameter.cs (Resolve): Do not allow void as a parameter type.
7939
7940 2002-10-06  Martin Baulig  <martin@gnome.org>
7941
7942         * statemenc.cs (FlowBranching.SetParameterAssigned): Don't crash
7943         if it's a class type and not a struct.  Fixes #31815.
7944
7945 2002-10-06  Martin Baulig  <martin@gnome.org>
7946
7947         * statement.cs: Reworked the flow analysis code a bit to make it
7948         usable for dead code elimination.
7949
7950 2002-10-06  Gonzalo Paniagua Javier <gonzalo@ximian.com>
7951
7952         * cs-parser.jay: allow empty source files. Fixes bug #31781.
7953
7954 2002-10-04  Miguel de Icaza  <miguel@ximian.com>
7955
7956         * expression.cs (ComposedCast.DoResolveType): A quick workaround
7957         to fix the test 165, will investigate deeper.
7958
7959 2002-10-04  Martin Baulig  <martin@gnome.org>
7960
7961         * statement.cs (FlowBranching.UsageVector.MergeChildren): Make
7962         finally blocks actually work.
7963         (Try.Resolve): We don't need to create a sibling for `finally' if
7964         there is no finally block.
7965
7966 2002-10-04  Martin Baulig  <martin@gnome.org>
7967
7968         * class.cs (Constructor.Define): The default accessibility for a
7969         non-default constructor is private, not public.
7970
7971 2002-10-04  Miguel de Icaza  <miguel@ximian.com>
7972
7973         * class.cs (Constructor): Make AllowedModifiers public, add
7974         EXTERN.
7975
7976         * cs-parser.jay: Perform the modifiers test here, as the
7977         constructor for the Constructor class usually receives a zero
7978         because of the way we create it (first we create, later we
7979         customize, and we were never checking the modifiers).
7980
7981         * typemanager.cs (Typemanager.LookupTypeDirect): This new function
7982         is a version of LookupTypeReflection that includes the type-name
7983         cache.  This can be used as a fast path for functions that know
7984         the fully qualified name and are only calling into *.GetType() to
7985         obtain a composed type.
7986
7987         This is also used by TypeManager.LookupType during its type
7988         composition.
7989
7990         (LookupType): We now also track the real type name, as sometimes
7991         we can get a quey for the real type name from things like
7992         ComposedCast.  This fixes bug 31422.
7993
7994         * expression.cs (ComposedCast.Resolve): Since we are obtaining a
7995         complete type fullname, it does not have to go through the type
7996         resolution system to obtain the composed version of the type (for
7997         obtaining arrays or pointers).
7998
7999         (Conditional.Emit): Use the EmitBoolExpression to
8000         generate nicer code, as requested by Paolo.
8001
8002         (ArrayCreation.CheckIndices): Use the patch from
8003         hwang_rob@yahoo.ca to validate the array initializers. 
8004
8005 2002-10-03  Miguel de Icaza  <miguel@ximian.com>
8006
8007         * class.cs (ConstructorInitializer.Emit): simplify code by using
8008         Invocation.EmitCall, and at the same time, fix the bugs in calling
8009         parent constructors that took variable arguments. 
8010
8011         * ecore.cs (Expression.ConvertNumericExplicit,
8012         Expression.ImplicitNumericConversion): Remove the code that
8013         manually wrapped decimal (InternalTypeConstructor call is now gone
8014         as well).
8015
8016         * expression.cs (Cast.TryReduce): Also handle decimal types when
8017         trying to perform a constant fold on the type.
8018
8019         * typemanager.cs (IsUnmanagedtype): Partially implemented.
8020
8021         * parameter.cs: Removed ResolveAndDefine, as it was not needed, as
8022         that only turned off an error report, and did nothing else. 
8023
8024 2002-10-02  Miguel de Icaza  <miguel@ximian.com>
8025
8026         * driver.cs: Handle and ignore /fullpaths
8027
8028 2002-10-01  Miguel de Icaza  <miguel@ximian.com>
8029
8030         * expression.cs (Binary.ResolveOperator): Catch the case where
8031         DoNumericPromotions returns true, 
8032
8033         (Binary.DoNumericPromotions): Simplify the code, and the tests.
8034
8035 2002-09-27  Miguel de Icaza  <miguel@ximian.com>
8036
8037         * ecore.cs (EventExpr.Emit): Instead of emitting an exception,
8038         report error 70.
8039
8040 2002-09-26  Miguel de Icaza  <miguel@ximian.com>
8041
8042         * ecore.cs (ConvertNumericExplicit): It is not enough that the
8043         conversion exists, but it is also required that the conversion be
8044         performed.  This manifested in "(Type64Enum) 2".  
8045
8046         * class.cs (TypeManager.AddMethod): The fix is not to change
8047         AddEnum, because that one was using a fully qualified name (every
8048         DeclSpace derivative does), but to change the AddMethod routine
8049         that was using an un-namespaced name.  This now correctly reports
8050         the duplicated name.
8051
8052         Revert patch until I can properly fix it.  The issue
8053         is that we have a shared Type space across all namespaces
8054         currently, which is wrong.
8055
8056         Options include making the Namespace a DeclSpace, and merge
8057         current_namespace/current_container in the parser.
8058
8059 2002-09-25  Miguel de Icaza  <miguel@ximian.com>
8060
8061         * cs-parser.jay: Improve error reporting when we get a different
8062         kind of expression in local_variable_type and
8063         local_variable_pointer_type. 
8064
8065         Propagate this to avoid missleading errors being reported.
8066
8067         * ecore.cs (ImplicitReferenceConversion): treat
8068         TypeManager.value_type as a target just like object_type.   As
8069         code like this:
8070
8071         ValueType v = 1;
8072
8073         Is valid, and needs to result in the int 1 being boxed before it
8074         is assigned to the value type v.
8075
8076         * class.cs (TypeContainer.AddEnum): Use the basename, not the name
8077         to validate the enumeration name.
8078
8079         * expression.cs (ArrayAccess.EmitAssign): Mimic the same test from
8080         EmitDynamicInitializers for the criteria to use Ldelema.  Thanks
8081         to hwang_rob@yahoo.ca for finding the bug and providing a patch.
8082
8083         * ecore.cs (TryImplicitIntConversion): When doing an
8084         implicit-enumeration-conversion, check if the type is 64-bits and
8085         perform a conversion before passing to EnumConstant.
8086
8087 2002-09-23  Miguel de Icaza  <miguel@ximian.com>
8088
8089         * decl.cs (Error_AmbiguousTypeReference); New routine used to
8090         report ambiguous type references.  Unlike the MS version, we
8091         report what the ambiguity is.   Innovation at work ;-)
8092
8093         (DeclSpace.FindType): Require a location argument to
8094         display when we display an ambiguous error.
8095
8096         * ecore.cs: (SimpleName.DoResolveType): Pass location to FindType.
8097
8098         * interface.cs (GetInterfaceTypeByName): Pass location to FindType.
8099
8100         * expression.cs (EmitDynamicInitializers): Apply patch from
8101         hwang_rob@yahoo.ca that fixes the order in which we emit our
8102         initializers. 
8103
8104 2002-09-21  Martin Baulig  <martin@gnome.org>
8105
8106         * delegate.cs (Delegate.VerifyApplicability): Make this work if the
8107         delegate takes no arguments.
8108
8109 2002-09-20  Miguel de Icaza  <miguel@ximian.com>
8110
8111         * constant.cs: Use Conv_U8 instead of Conv_I8 when loading longs
8112         from integers.
8113
8114         * expression.cs: Extract the underlying type.
8115
8116         * ecore.cs (StoreFromPtr): Use TypeManager.IsEnumType instad of IsEnum
8117
8118         * decl.cs (FindType): Sorry about this, fixed the type lookup bug.
8119
8120 2002-09-19  Miguel de Icaza  <miguel@ximian.com>
8121
8122         * class.cs (TypeContainer.DefineType): We can not use the nice
8123         PackingSize with the size set to 1 DefineType method, because it
8124         will not allow us to define the interfaces that the struct
8125         implements.
8126
8127         This completes the fixing of bug 27287
8128
8129         * ecore.cs (Expresion.ImplicitReferenceConversion): `class-type S'
8130         means also structs.  This fixes part of the problem. 
8131         (Expresion.ImplicitReferenceConversionExists): ditto.
8132
8133         * decl.cs (DeclSparce.ResolveType): Only report the type-not-found
8134         error if there were no errors reported during the type lookup
8135         process, to avoid duplicates or redundant errors.  Without this
8136         you would get an ambiguous errors plus a type not found.  We have
8137         beaten the user enough with the first error.  
8138
8139         (DeclSparce.FindType): Emit a warning if we have an ambiguous
8140         reference. 
8141
8142         * ecore.cs (SimpleName.DoResolveType): If an error is emitted
8143         during the resolution process, stop the lookup, this avoids
8144         repeated error reports (same error twice).
8145
8146         * rootcontext.cs: Emit a warning if we have an ambiguous reference.
8147
8148         * typemanager.cs (LookupType): Redo the type lookup code to match
8149         the needs of System.Reflection.  
8150
8151         The issue is that System.Reflection requires references to nested
8152         types to begin with a "+" sign instead of a dot.  So toplevel
8153         types look like: "NameSpace.TopLevelClass", and nested ones look
8154         like "Namespace.TopLevelClass+Nested", with arbitrary nesting
8155         levels. 
8156
8157 2002-09-19  Martin Baulig  <martin@gnome.org>
8158
8159         * codegen.cs (EmitContext.EmitTopBlock): If control flow analysis
8160         says that a method always returns or always throws an exception,
8161         don't report the CS0161.
8162
8163         * statement.cs (FlowBranching.UsageVector.MergeChildren): Always
8164         set `Returns = new_returns'.
8165
8166 2002-09-19  Martin Baulig  <martin@gnome.org>
8167
8168         * expression.cs (MemberAccess.ResolveMemberAccess): When resolving
8169         to an enum constant, check for a CS0176.
8170
8171 2002-09-18  Miguel de Icaza  <miguel@ximian.com>
8172
8173         * class.cs (TypeContainer.CheckPairedOperators): Now we check
8174         for operators that must be in pairs and report errors.
8175
8176         * ecore.cs (SimpleName.DoResolveType): During the initial type
8177         resolution process, when we define types recursively, we must
8178         check first for types in our current scope before we perform
8179         lookups in the enclosing scopes.
8180
8181         * expression.cs (MakeByteBlob): Handle Decimal blobs.
8182
8183         (Invocation.VerifyArgumentsCompat): Call
8184         TypeManager.TypeToCoreType on the parameter_type.GetElementType.
8185         I thought we were supposed to always call this, but there are a
8186         few places in the code where we dont do it.
8187
8188 2002-09-17  Miguel de Icaza  <miguel@ximian.com>
8189
8190         * driver.cs: Add support in -linkres and -resource to specify the
8191         name of the identifier.
8192
8193 2002-09-16  Miguel de Icaza  <miguel@ximian.com>
8194
8195         * ecore.cs (StandardConversionExists): Sync with the conversion
8196         code: allow anything-* to void* conversions.
8197
8198         (FindMostSpecificSource): Use an Expression argument
8199         instead of a Type, because we might be handed over a Literal which
8200         gets a few more implicit conversions that plain types do not.  So
8201         this information was being lost.
8202
8203         Also, we drop the temporary type-holder expression when not
8204         required.
8205
8206 2002-09-17  Martin Baulig  <martin@gnome.org>
8207
8208         * class.cs (PropertyBase.CheckBase): Don't check the base class if
8209         this is an explicit interface implementation.
8210
8211 2002-09-17  Martin Baulig  <martin@gnome.org>
8212
8213         * class.cs (PropertyBase.CheckBase): Make this work for indexers with
8214         different `IndexerName' attributes.
8215
8216         * expression.cs (BaseIndexerAccess): Rewrote this class to use IndexerAccess.
8217         (IndexerAccess): Added special protected ctor for BaseIndexerAccess and
8218         virtual CommonResolve().
8219
8220 2002-09-16  Miguel de Icaza  <miguel@ximian.com>
8221
8222         * enum.cs (LookupEnumValue): Use the EnumConstant declared type,
8223         and convert that to the UnderlyingType.
8224
8225         * statement.cs (Foreach.Resolve): Indexers are just like variables
8226         or PropertyAccesses.
8227
8228         * cs-tokenizer.cs (consume_string): Track line numbers and columns
8229         inside quoted strings, we were not doing this before.
8230
8231 2002-09-16  Martin Baulig  <martin@gnome.org>
8232
8233         * ecore.cs (MethodGroupExpr.DoResolve): If we have an instance expression,
8234         resolve it.  This is needed for the definite assignment check of the
8235         instance expression, fixes bug #29846.
8236         (PropertyExpr.DoResolve, EventExpr.DoResolve): Likewise.
8237
8238 2002-09-16  Nick Drochak  <ndrochak@gol.com>
8239
8240         * parameter.cs: Fix compile error.  Cannot reference static member
8241         from an instance object.  Is this an mcs bug?
8242
8243 2002-09-14  Martin Baulig  <martin@gnome.org>
8244
8245         * decl.cs (MemberCache.SetupCacheForInterface): Don't add an interface
8246         multiple times.  Fixes bug #30295, added test-166.cs.
8247
8248 2002-09-14  Martin Baulig  <martin@gnome.org>
8249
8250         * statement.cs (Block.Emit): Don't emit unreachable code.
8251         (Switch.SimpleSwitchEmit, Switch.TableSwitchEmit): Check for missing
8252         `break' statements.
8253         (Goto.Emit, Continue.Emit): Set ec.Breaks = true.
8254
8255 2002-09-14  Martin Baulig  <martin@gnome.org>
8256
8257         * parameter.cs (Parameter.Attributes): Make this work if Modifier.ISBYREF
8258         is set.
8259
8260 2002-09-14  Martin Baulig  <martin@gnome.org>
8261
8262         * typemanager.cs (TypeManager.IsNestedChildOf): This must return false
8263         if `type == parent' since in this case `type.IsSubclassOf (parent)' will
8264         be false on the ms runtime.
8265
8266 2002-09-13  Martin Baulig  <martin@gnome.org>
8267
8268         * ecore.cs (SimpleName.SimpleNameResolve): Include the member name in
8269         the CS0038 error message.
8270
8271 2002-09-12  Miguel de Icaza  <miguel@ximian.com>
8272
8273         * expression.cs (CheckedExpr, UnCheckedExpr): If we have a
8274         constant inside, return it.
8275
8276 2002-09-12  Martin Baulig  <martin@gnome.org>
8277
8278         * cfold.cs (ConstantFold.DoConstantNumericPromotions): Check whether an
8279         implicit conversion can be done between enum types.
8280
8281         * enum.cs (Enum.LookupEnumValue): If the value is an EnumConstant,
8282         check whether an implicit conversion to the current enum's UnderlyingType
8283         exists and report an error if not.
8284
8285         * codegen.cs (CodeGen.Init): Delete the symbol file when compiling
8286         without debugging support.
8287
8288         * delegate.cs (Delegate.CloseDelegate): Removed, use CloseType instead.
8289         Fixes bug #30235.  Thanks to Ricardo Fernández Pascual.
8290
8291 2002-09-12  Martin Baulig  <martin@gnome.org>
8292
8293         * typemanager.cs (TypeManager.IsNestedChildOf): New method.
8294
8295         * ecore.cs (IMemberExpr.DeclaringType): New property.
8296         (SimpleName.SimpleNameResolve): Check whether we're accessing a
8297         nonstatic member of an outer type (CS0038).
8298
8299 2002-09-11  Miguel de Icaza  <miguel@ximian.com>
8300
8301         * driver.cs: Activate the using-error detector at warning level
8302         4 (at least for MS-compatible APIs).
8303
8304         * namespace.cs (VerifyUsing): Small buglett fix.
8305
8306         * pending.cs (PendingImplementation): pass the container pointer. 
8307
8308         * interface.cs (GetMethods): Allow for recursive definition.  Long
8309         term, I would like to move every type to support recursive
8310         definitions, not the current ordering mechanism that we have right
8311         now.
8312
8313         The situation is this: Attributes are handled before interfaces,
8314         so we can apply attributes to interfaces.  But some attributes
8315         implement interfaces, we will now handle the simple cases
8316         (recursive definitions will just get an error).  
8317
8318         * parameter.cs: Only invalidate types at the end if we fail to
8319         lookup all types.  
8320
8321 2002-09-09  Martin Baulig  <martin@gnome.org>
8322
8323         * ecore.cs (PropertyExpr.Emit): Also check for
8324         TypeManager.system_int_array_get_length so this'll also work when
8325         compiling corlib.  Fixes #30003.
8326
8327 2002-09-09  Martin Baulig  <martin@gnome.org>
8328
8329         * expression.cs (ArrayCreation.MakeByteBlob): Added support for enums
8330         and throw an exception if we can't get the type's size.  Fixed #30040,
8331         added test-165.cs.
8332
8333 2002-09-09  Martin Baulig  <martin@gnome.org>
8334
8335         * ecore.cs (PropertyExpr.DoResolve): Added check for static properies.
8336
8337         * expression.cs (SizeOf.DoResolve): Sizeof is only allowed in unsafe
8338         context.  Fixes bug #30027.
8339
8340         * delegate.cs (NewDelegate.Emit): Use OpCodes.Ldvirtftn for
8341         virtual functions.  Fixes bug #30043, added test-164.cs.
8342
8343 2002-09-08  Ravi Pratap  <ravi@ximian.com>
8344
8345         * attribute.cs : Fix a small NullRef crash thanks to my stupidity.
8346
8347 2002-09-08  Nick Drochak  <ndrochak@gol.com>
8348
8349         * driver.cs: Use an object to get the windows codepage since it's not a
8350         static property.
8351
8352 2002-09-08  Miguel de Icaza  <miguel@ximian.com>
8353
8354         * statement.cs (For.Emit): for infinite loops (test == null)
8355         return whether there is a break inside, not always "true".
8356
8357         * namespace.cs (UsingEntry): New struct to hold the name of the
8358         using definition, the location where it is defined, and whether it
8359         has been used in a successful type lookup.
8360
8361         * rootcontext.cs (NamespaceLookup): Use UsingEntries instead of
8362         strings.
8363
8364         * decl.cs: ditto.
8365
8366 2002-09-06  Ravi Pratap  <ravi@ximian.com>
8367
8368         * attribute.cs : Fix incorrect code which relied on catching
8369         a NullReferenceException to detect a null being passed in
8370         where an object was expected.
8371
8372 2002-09-06  Miguel de Icaza  <miguel@ximian.com>
8373
8374         * statement.cs (Try): flag the catch variable as assigned
8375
8376         * expression.cs (Cast): Simplified by using ResolveType instead of
8377         manually resolving.
8378
8379         * statement.cs (Catch): Fix bug by using ResolveType.
8380
8381 2002-09-06  Ravi Pratap  <ravi@ximian.com>
8382
8383         * expression.cs (BetterConversion): Special case for when we have
8384         a NullLiteral as the argument and we have to choose between string
8385         and object types - we choose string the way csc does.
8386
8387         * attribute.cs (Attribute.Resolve): Catch the
8388         NullReferenceException and report error #182 since the Mono
8389         runtime no more has the bug and having this exception raised means
8390         we tried to select a constructor which takes an object and is
8391         passed a null.
8392
8393 2002-09-05  Ravi Pratap  <ravi@ximian.com>
8394
8395         * expression.cs (Invocation.OverloadResolve): Flag a nicer error
8396         message (1502, 1503) when we can't locate a method after overload
8397         resolution. This is much more informative and closes the bug
8398         Miguel reported.
8399
8400         * interface.cs (PopulateMethod): Return if there are no argument
8401         types. Fixes a NullReferenceException bug.
8402
8403         * attribute.cs (Attribute.Resolve): Ensure we allow TypeOf
8404         expressions too. Previously we were checking only in one place for
8405         positional arguments leaving out named arguments.
8406
8407         * ecore.cs (ImplicitNumericConversion): Conversion from underlying
8408         type to the enum type is not allowed. Remove code corresponding to
8409         that.
8410
8411         (ConvertNumericExplicit): Allow explicit conversions from
8412         the underlying type to enum type. This precisely follows the spec
8413         and closes a bug filed by Gonzalo.
8414
8415 2002-09-04  Gonzalo Paniagua Javier <gonzalo@ximian.com>
8416
8417         * compiler.csproj:
8418         * compiler.csproj.user: patch from Adam Chester (achester@bigpond.com).
8419
8420 2002-09-03  Miguel de Icaza  <miguel@ximian.com>
8421
8422         * statement.cs (SwitchLabel.ResolveAndReduce): In the string case,
8423         it was important that we stored the right value after the
8424         reduction in `converted'.
8425
8426 2002-09-04  Martin Baulig  <martin@gnome.org>
8427
8428         * location.cs (Location.SymbolDocument): Use full pathnames for the
8429         source files.
8430
8431 2002-08-30  Miguel de Icaza  <miguel@ximian.com>
8432
8433         * expression.cs (ComposedCast): Use DeclSparce.ResolveType instead
8434         of the expression resolve mechanism, because that will catch the
8435         SimpleName error failures.
8436
8437         (Conditional): If we can not resolve the
8438         expression, return, do not crash.
8439
8440 2002-08-29  Gonzalo Paniagua Javier <gonzalo@ximian.com>
8441
8442         * cs-tokenizer.cs:
8443         (location): display token name instead of its number.
8444
8445 2002-08-28  Martin Baulig  <martin@gnome.org>
8446
8447         * expression.cs (Binary.ResolveOperator): Don't silently return
8448         but return an error if an operator cannot be applied between two
8449         enum types.
8450
8451 2002-08-28  Martin Baulig  <martin@gnome.org>
8452
8453         * class.cs (Constructor.Define): Set the permission attributes
8454         correctly instead of making all constructors public.
8455
8456 2002-08-28  Martin Baulig  <martin@gnome.org>
8457
8458         * ecore.cs (Expression.DoResolve): Do a TypeManager.MemberLook
8459         for private members before reporting a CS0103; if we find anything,
8460         it's a CS0122.
8461
8462 2002-08-28  Martin Baulig  <martin@gnome.org>
8463
8464         * typemanager.cs (TypeManager.FilterWithClosure): It's not enough
8465         to check whether `closure_start_type == closure_invocation_type',
8466         we also need to check whether `m.DeclaringType == closure_invocation_type'
8467         before bypassing the permission checks.  We might be accessing
8468         protected/private members from the base class.
8469         (TypeManager.RealMemberLookup): Only set private_ok if private
8470         members were requested via BindingFlags.NonPublic.
8471
8472         * ecore.cs (MethodGroupExpr.IsExplicitImpl): New property.
8473
8474         * expression.cs (MemberAccess.ResolveMemberAccess): Set
8475         MethodGroupExpr.IsExplicitImpl if appropriate.
8476         (Invocation.DoResolve): Don't report the CS0120 for explicit
8477         interface implementations.
8478
8479 2002-08-27  Martin Baulig  <martin@gnome.org>
8480
8481         * expression.cs (Invocation.DoResolve): If this is a static
8482         method and we don't have an InstanceExpression, we must report
8483         a CS0120.
8484
8485 2002-08-25  Martin Baulig  <martin@gnome.org>
8486
8487         * expression.cs (Binary.ResolveOperator): Don't allow `!=' and
8488         `==' between a valuetype and an object.
8489
8490 2002-08-25  Miguel de Icaza  <miguel@ximian.com>
8491
8492         * ecore.cs (TypeExpr): Provide a ToString method.
8493
8494 2002-08-24  Martin Baulig  <martin@gnome.org>
8495
8496         * codegen.cs (CodeGen.InitMonoSymbolWriter): The symbol file is
8497         now called proggie.dbg and it's a binary file.
8498
8499 2002-08-23  Martin Baulig  <martin@gnome.org>
8500
8501         * decl.cs (MemberCache.AddMethods): Ignore varargs methods.
8502
8503 2002-08-23  Martin Baulig  <martin@gnome.org>
8504
8505         * struct.cs (MyStructInfo.ctor): Make this work with empty
8506         structs; it's not allowed to use foreach() on null.
8507
8508 2002-08-23  Martin Baulig  <martin@gnome.org>
8509
8510         * codegen.cs (CodeGen.InitMonoSymbolWriter): Tell the symbol
8511         writer the full pathname of the generated assembly.
8512
8513 2002-08-23  Martin Baulig  <martin@gnome.org>
8514
8515         * statements.cs (FlowBranching.UsageVector.MergeChildren):
8516         A `finally' block never returns or breaks; improved handling of
8517         unreachable code.
8518
8519 2002-08-23  Martin Baulig  <martin@gnome.org>
8520
8521         * statement.cs (Throw.Resolve): Allow `throw null'.
8522
8523 2002-08-23  Martin Baulig  <martin@gnome.org>
8524
8525         * expression.cs (MemberAccess.ResolveMemberAccess): If this is an
8526         EventExpr, don't do a DeclaredOnly MemberLookup, but check whether
8527         `ee.EventInfo.DeclaringType == ec.ContainerType'.  The
8528         MemberLookup would return a wrong event if this is an explicit
8529         interface implementation and the class has an event with the same
8530         name.
8531
8532 2002-08-23  Martin Baulig  <martin@gnome.org>
8533
8534         * statement.cs (Block.AddChildVariableNames): New public method.
8535         (Block.AddChildVariableName): Likewise.
8536         (Block.IsVariableNameUsedInChildBlock): Likewise.
8537         (Block.AddVariable): Check whether a variable name has already
8538         been used in a child block.
8539
8540         * cs-parser.jay (declare_local_variables): Mark all variable names
8541         from the current block as being used in a child block in the
8542         implicit block.
8543
8544 2002-08-23  Martin Baulig  <martin@gnome.org>
8545
8546         * codegen.cs (CodeGen.InitializeSymbolWriter): Abort if we can't
8547         find the symbol writer.
8548
8549         * driver.cs: csc also allows the arguments to /define being
8550         separated by commas, not only by semicolons.
8551
8552 2002-08-23  Martin Baulig  <martin@gnome.org>
8553
8554         * interface.cs (Interface.GetMembers): Added static check for events.
8555
8556 2002-08-15  Martin Baulig  <martin@gnome.org>
8557
8558         * class.cs (MethodData.EmitDestructor): In the Expression.MemberLookup
8559         call, use ec.ContainerType.BaseType as queried_type and invocation_type.
8560
8561         * ecore.cs (Expression.MemberLookup): Added documentation and explained
8562         why the MethodData.EmitDestructor() change was necessary.
8563
8564 2002-08-20  Martin Baulig  <martin@gnome.org>
8565
8566         * class.cs (TypeContainer.FindMembers): Added static check for events.
8567
8568         * decl.cs (MemberCache.AddMembers): Handle events like normal members.
8569
8570         * typemanager.cs (TypeHandle.GetMembers): When queried for events only,
8571         use Type.GetEvents(), not Type.FindMembers().
8572
8573 2002-08-20  Martin Baulig  <martin@gnome.org>
8574
8575         * decl.cs (MemberCache): Added a special method cache which will
8576         be used for method-only searched.  This ensures that a method
8577         search will return a MethodInfo with the correct ReflectedType for
8578         inherited methods.      
8579
8580 2002-08-20  Martin Baulig  <martin@gnome.org>
8581
8582         * decl.cs (DeclSpace.FindMembers): Made this public.
8583
8584 2002-08-20  Gonzalo Paniagua Javier <gonzalo@ximian.com>
8585
8586         * delegate.cs: fixed build on windows.
8587         [FIXME:  Filed as bug #29150: MCS must report these errors.]
8588
8589 2002-08-19  Ravi Pratap  <ravi@ximian.com>
8590
8591         * ecore.cs (StandardConversionExists): Return a false
8592         if we are trying to convert the void type to anything else
8593         since that is not allowed.
8594
8595         * delegate.cs (DelegateInvocation.DoResolve): Ensure that
8596         we flag error 70 in the event an event is trying to be accessed
8597         directly from outside the declaring type.
8598
8599 2002-08-20  Martin Baulig  <martin@gnome.org>
8600
8601         * typemanager.cs, decl.cs: Moved MemberList, IMemberContainer and
8602         MemberCache from typemanager.cs to decl.cs.
8603
8604 2002-08-19  Martin Baulig  <martin@gnome.org>
8605
8606         * class.cs (TypeContainer): Implement IMemberContainer.
8607         (TypeContainer.DefineMembers): Create the MemberCache.
8608         (TypeContainer.FindMembers): Do better BindingFlags checking; only
8609         return public members if BindingFlags.Public was given, check
8610         whether members are static.
8611
8612 2002-08-16  Martin Baulig  <martin@gnome.org>
8613
8614         * decl.cs (DeclSpace.Define): Splitted this in Define and
8615         DefineMembers.  DefineMembers is called first and initializes the
8616         MemberCache.
8617
8618         * rootcontext.cs (RootContext.DefineMembers): New function.  Calls
8619         DefineMembers() on all our DeclSpaces.
8620
8621         * class.cs (TypeContainer.Define): Moved all code to DefineMembers(),
8622         but call DefineMembers() on all nested interfaces.  We call their
8623         Define() in our new Define() function.
8624
8625         * interface.cs (Interface): Implement IMemberContainer.
8626         (Interface.Define): Moved all code except the attribute stuf to
8627         DefineMembers().
8628         (Interface.DefineMembers): Initialize the member cache.
8629
8630         * typemanager.cs (IMemberFinder): Removed this interface, we don't
8631         need this anymore since we can use MemberCache.FindMembers directly.
8632
8633 2002-08-19  Martin Baulig  <martin@gnome.org>
8634
8635         * typemanager.cs (MemberCache): When creating the cache for an
8636         interface type, add all inherited members.
8637         (TypeManager.MemberLookup_FindMembers): Changed `ref bool searching'
8638         to `out bool used_cache' and documented it.
8639         (TypeManager.MemberLookup): If we already used the cache in the first
8640         iteration, we don't need to do the interfaces check.
8641
8642 2002-08-19  Martin Baulig  <martin@gnome.org>
8643
8644         * decl.cs (DeclSpace.FindMembers): New abstract method.  Moved this
8645         here from IMemberFinder and don't implement this interface anymore.
8646         (DeclSpace.MemberCache): Moved here from IMemberFinder.
8647
8648         * typemanager.cs (IMemberFinder): This interface is now only used by
8649         classes which actually support the member cache.
8650         (TypeManager.builder_to_member_finder): Renamed to builder_to_declspace
8651         since we only put DeclSpaces into this Hashtable.
8652         (MemberLookup_FindMembers): Use `builder_to_declspace' if the type is
8653         a dynamic type and TypeHandle.GetTypeHandle() otherwise.
8654
8655 2002-08-16  Martin Baulig  <martin@gnome.org>
8656
8657         * typemanager.cs (ICachingMemberFinder): Removed.
8658         (IMemberFinder.MemberCache): New property.
8659         (TypeManager.FindMembers): Merged this with RealFindMembers().
8660         This function will never be called from TypeManager.MemberLookup()
8661         so we can't use the cache here, just the IMemberFinder.
8662         (TypeManager.MemberLookup_FindMembers): Check whether the
8663         IMemberFinder has a MemberCache and call the cache's FindMembers
8664         function.
8665         (MemberCache): Rewrote larger parts of this yet another time and
8666         cleaned it up a bit.
8667
8668 2002-08-15  Miguel de Icaza  <miguel@ximian.com>
8669
8670         * driver.cs (LoadArgs): Support quoting.
8671
8672         (Usage): Show the CSC-like command line arguments.
8673
8674         Improved a few error messages.
8675
8676 2002-08-15  Martin Baulig  <martin@gnome.org>
8677
8678         * typemanager.cs (IMemberContainer.Type): New property.
8679         (IMemberContainer.IsInterface): New property.
8680
8681         The following changes are conditional to BROKEN_RUNTIME, which is
8682         defined at the top of the file.
8683
8684         * typemanager.cs (MemberCache.MemberCache): Don't add the base
8685         class'es members, but add all members from TypeHandle.ObjectType
8686         if we're an interface.
8687         (MemberCache.AddMembers): Set the Declared flag if member.DeclaringType
8688         is the current type.
8689         (MemberCache.CacheEntry.Container): Removed this field.
8690         (TypeHandle.GetMembers): Include inherited members.
8691
8692 2002-08-14  Gonzalo Paniagua Javier <gonzalo@ximian.com>
8693
8694         * typemanager.cs: fixed compilation and added a comment on a field that
8695         is never used.
8696
8697 2002-08-15  Martin Baulig  <martin@gnome.org>
8698
8699         * class.cs (ConstructorInitializer.Resolve): In the
8700         Expression.MemberLookup call, use the queried_type as
8701         invocation_type.
8702
8703         * typemanager.cs (IMemberContainer.GetMembers): Removed the `bool
8704         declared' attribute, it's always true.
8705         (IMemberContainer.Parent, IMemberContainer.Name): New properties.
8706         (TypeManager.MemberLookup_FindMembers): [FIXME FIXME FIXME] Added
8707         temporary wrapper for FindMembers which tells MemberLookup whether
8708         members from the base classes are included in the return value.
8709         This will go away soon.
8710         (TypeManager.MemberLookup): Use this temporary hack here; once the
8711         new MemberCache is completed, we don't need to do the DeclaredOnly
8712         looping here anymore since the MemberCache will take care of this.
8713         (TypeManager.IsSubclassOrNestedChildOf): Allow `type == parent'.
8714         (MemberCache): When creating the MemberCache for a class, get
8715         members from the current class and all its base classes.
8716         (MemberCache.CacheEntry.Container): New field.  This is a
8717         temporary hack until the Mono runtime is fixed to distinguish
8718         between ReflectedType and DeclaringType.  It allows us to use MCS
8719         with both the MS runtime and the unfixed Mono runtime without
8720         problems and without accecting performance.
8721         (MemberCache.SearchMembers): The DeclaredOnly looping from
8722         TypeManager.MemberLookup is now done here.      
8723
8724 2002-08-14  Martin Baulig  <martin@gnome.org>
8725
8726         * statement.cs (MyStructInfo.MyStructInfo): Don't call
8727         Type.GetFields on dynamic types but get the fields from the
8728         corresponding TypeContainer.
8729         (MyStructInfo.GetStructInfo): Added check for enum types.
8730
8731         * typemanager.cs (MemberList.IsSynchronized): Implemented.
8732         (MemberList.SyncRoot): Implemented.
8733         (TypeManager.FilterWithClosure): No need to check permissions if
8734         closure_start_type == closure_invocation_type, don't crash if
8735         closure_invocation_type is null.
8736
8737 2002-08-13  Martin Baulig  <martin@gnome.org>
8738
8739         Rewrote TypeContainer.FindMembers to use a member cache.  This
8740         gives us a speed increase of about 35% for the self-hosting MCS
8741         build and of about 15-20% for the class libs (both on GNU/Linux).
8742
8743         * report.cs (Timer): New class to get enhanced profiling.  This
8744         whole class is "TIMER" conditional since it remarkably slows down
8745         compilation speed.
8746
8747         * class.cs (MemberList): New class.  This is an IList wrapper
8748         which we're now using instead of passing MemberInfo[]'s around to
8749         avoid copying this array unnecessarily.
8750         (IMemberFinder.FindMember): Return a MemberList, not a MemberInfo [].
8751         (ICachingMemberFinder, IMemberContainer): New interface.
8752         (TypeManager.FilterWithClosure): If `criteria' is null, the name
8753         has already been checked, otherwise use it for the name comparision.
8754         (TypeManager.FindMembers): Renamed to RealMemberFinder and
8755         provided wrapper which tries to use ICachingMemberFinder.FindMembers
8756         if possible.  Returns a MemberList, not a MemberInfo [].
8757         (TypeHandle): New class, implements IMemberContainer.  We create
8758         one instance of this class per type, it contains a MemberCache
8759         which is used to do the member lookups.
8760         (MemberCache): New class.  Each instance of this class contains
8761         all members of a type and a name-based hash table.
8762         (MemberCache.FindMembers): This is our new member lookup
8763         function.  First, it looks up all members of the requested name in
8764         the hash table.  Then, it walks this list and sorts out all
8765         applicable members and returns them.
8766
8767 2002-08-13  Martin Baulig  <martin@gnome.org>
8768
8769         In addition to a nice code cleanup, this gives us a performance
8770         increase of about 1.4% on GNU/Linux - not much, but it's already
8771         half a second for the self-hosting MCS compilation.
8772
8773         * typemanager.cs (IMemberFinder): New interface.  It is used by
8774         TypeManager.FindMembers to call FindMembers on a TypeContainer,
8775         Enum, Delegate or Interface.
8776         (TypeManager.finder_to_member_finder): New PtrHashtable.
8777         (TypeManager.finder_to_container): Removed.
8778         (TypeManager.finder_to_delegate): Removed.
8779         (TypeManager.finder_to_interface): Removed.
8780         (TypeManager.finder_to_enum): Removed.
8781
8782         * interface.cs (Interface): Implement IMemberFinder.
8783
8784         * delegate.cs (Delegate): Implement IMemberFinder.
8785
8786         * enum.cs (Enum): Implement IMemberFinder.
8787
8788         * class.cs (TypeContainer): Implement IMemberFinder.
8789
8790 2002-08-12  Martin Baulig  <martin@gnome.org>
8791
8792         * ecore.cs (TypeExpr.DoResolveType): Mark this as virtual.
8793
8794 2002-08-12  Martin Baulig  <martin@gnome.org>
8795
8796         * ecore.cs (ITypeExpression): New interface for expressions which
8797         resolve to a type.
8798         (TypeExpression): Renamed to TypeLookupExpression.
8799         (Expression.DoResolve): If we're doing a types-only lookup, the
8800         expression must implement the ITypeExpression interface and we
8801         call DoResolveType() on it.
8802         (SimpleName): Implement the new ITypeExpression interface.
8803         (SimpleName.SimpleNameResolve): Removed the ec.OnlyLookupTypes
8804         hack, the situation that we're only looking up types can't happen
8805         anymore when this method is called.  Moved the type lookup code to
8806         DoResolveType() and call it.
8807         (SimpleName.DoResolveType): This ITypeExpression interface method
8808         is now doing the types-only lookup.
8809         (TypeExpr, TypeLookupExpression): Implement ITypeExpression.
8810         (ResolveFlags): Added MaskExprClass.
8811
8812         * expression.cs (MemberAccess): Implement the ITypeExpression
8813         interface.
8814         (MemberAccess.DoResolve): Added support for a types-only lookup
8815         when we're called via ITypeExpression.DoResolveType().
8816         (ComposedCast): Implement the ITypeExpression interface.
8817
8818         * codegen.cs (EmitContext.OnlyLookupTypes): Removed.  Call
8819         Expression.Resolve() with ResolveFlags.Type instead.
8820
8821 2002-08-12  Martin Baulig  <martin@gnome.org>
8822
8823         * interface.cs (Interface.Define): Apply attributes.
8824
8825         * attribute.cs (Attribute.ApplyAttributes): Added support for
8826         interface attributes.
8827
8828 2002-08-11  Martin Baulig  <martin@gnome.org>
8829
8830         * statement.cs (Block.Emit): Only check the "this" variable if we
8831         do not always throw an exception.
8832
8833         * ecore.cs (PropertyExpr.DoResolveLValue): Implemented, check
8834         whether the property has a set accessor.
8835
8836 2002-08-11  Martin Baulig  <martin@gnome.org>
8837
8838         Added control flow analysis support for structs.
8839
8840         * ecore.cs (ResolveFlags): Added `DisableFlowAnalysis' to resolve
8841         with control flow analysis turned off.
8842         (IVariable): New interface.
8843         (SimpleName.SimpleNameResolve): If MemberAccess.ResolveMemberAccess
8844         returns an IMemberExpr, call DoResolve/DoResolveLValue on it.
8845         (FieldExpr.DoResolve): Resolve the instance expression with flow
8846         analysis turned off and do the definite assignment check after the
8847         resolving when we know what the expression will resolve to.
8848
8849         * expression.cs (LocalVariableReference, ParameterReference):
8850         Implement the new IVariable interface, only call the flow analysis
8851         code if ec.DoFlowAnalysis is true.
8852         (This): Added constructor which takes a Block argument.  Implement
8853         the new IVariable interface.
8854         (MemberAccess.DoResolve, MemberAccess.DoResolveLValue): Call
8855         DoResolve/DoResolveLValue on the result of ResolveMemberLookup().
8856         This does the definite assignment checks for struct members.
8857
8858         * class.cs (Constructor.Emit): If this is a non-static `struct'
8859         constructor which doesn't have any initializer, call
8860         Block.AddThisVariable() to tell the flow analysis code that all
8861         struct elements must be initialized before control returns from
8862         the constructor.
8863
8864         * statement.cs (MyStructInfo): New public class.
8865         (UsageVector.this [VariableInfo vi]): Added `int field_idx'
8866         argument to this indexer.  If non-zero, check an individual struct
8867         member, not the whole struct.
8868         (FlowBranching.CheckOutParameters): Check struct members.
8869         (FlowBranching.IsVariableAssigned, SetVariableAssigned): Added
8870         overloaded versions of these methods which take an additional
8871         `int field_idx' argument to check struct members.
8872         (FlowBranching.IsParameterAssigned, SetParameterAssigned): Added
8873         overloaded versions of these methods which take an additional
8874         `string field_name' argument to check struct member.s
8875         (VariableInfo): Implement the IVariable interface.
8876         (VariableInfo.StructInfo): New public property.  Returns the
8877         MyStructInfo instance of the variable if it's a struct or null.
8878         (Block.AddThisVariable): New public method.  This is called from
8879         Constructor.Emit() for non-static `struct' constructor which do
8880         not have any initializer.  It creates a special variable for the
8881         "this" instance variable which will be checked by the flow
8882         analysis code to ensure that all of the struct's fields are
8883         initialized before control returns from the constructor.
8884         (UsageVector): Added support for struct members.  If a
8885         variable/parameter is a struct with N members, we reserve a slot
8886         in the usage vector for each member.  A struct is considered fully
8887         initialized if either the struct itself (slot 0) or all its
8888         members are initialized.
8889
8890 2002-08-08  Martin Baulig  <martin@gnome.org>
8891
8892         * driver.cs (Driver.MainDriver): Only report an error CS5001
8893         if there were no compilation errors.
8894
8895         * codegen.cs (EmitContext.EmitContext): Use the DeclSpace's
8896         `UnsafeContext' property to determine whether the parent is in
8897         unsafe context rather than checking the parent's ModFlags:
8898         classes nested in an unsafe class are unsafe as well.
8899
8900 2002-08-08  Martin Baulig  <martin@gnome.org>
8901
8902         * statement.cs (UsageVector.MergeChildren): Distinguish between
8903         `Breaks' and `Returns' everywhere, don't set `Breaks' anymore if
8904         we return.  Added test17() and test18() to test-154.cs.
8905
8906 2002-08-08  Martin Baulig  <martin@gnome.org>
8907
8908         * typemanager.cs (TypeManager.FilterWithClosure): If we have
8909         Family access, make sure the invoking type isn't a subclass of the
8910         queried type (that'd be a CS1540).
8911
8912         * ecore.cs (Expression.MemberLookup): Added overloaded version of
8913         this method which takes an additional `Type invocation_type'.
8914
8915         * expression.cs (BaseAccess.DoResolve): Use the base type as
8916         invocation and query type.
8917         (MemberAccess.DoResolve): If the lookup failed and we're about to
8918         report a CS0122, try a lookup with the ec.ContainerType - if this
8919         succeeds, we must report a CS1540.
8920
8921 2002-08-08  Martin Baulig  <martin@gnome.org>
8922
8923         * ecore.cs (IMemberExpr): Added `bool IsInstance' property.
8924         (MethodGroupExpr): Implement the IMemberExpr interface.
8925
8926         * expression (MemberAccess.ResolveMemberAccess): No need to have
8927         any special code for MethodGroupExprs anymore, they're now
8928         IMemberExprs.   
8929
8930 2002-08-08  Martin Baulig  <martin@gnome.org>
8931
8932         * typemanager.cs (TypeManager.FilterWithClosure): Check Assembly,
8933         Family, FamANDAssem and FamORAssem permissions.
8934         (TypeManager.IsSubclassOrNestedChildOf): New public method.
8935
8936 2002-08-08  Martin Baulig  <martin@gnome.org>
8937
8938         * statement.cs (FlowBranchingType): Added LOOP_BLOCK.
8939         (UsageVector.MergeChildren): `break' breaks unless we're in a switch
8940         or loop block.
8941
8942 Thu Aug 8 10:28:07 CEST 2002 Paolo Molaro <lupus@ximian.com>
8943
8944         * driver.cs: implemented /resource option to embed managed resources.
8945
8946 2002-08-07  Martin Baulig  <martin@gnome.org>
8947
8948         * class.cs (FieldBase.Initializer): Renamed to `init' and made private.
8949         (FieldBase.HasFieldInitializer): New public property.
8950         (FieldBase.GetInitializerExpression): New public method.  Resolves and
8951         returns the field initializer and makes sure it is only resolved once.
8952         (TypeContainer.EmitFieldInitializers): Call
8953         FieldBase.GetInitializerExpression to get the initializer, this ensures
8954         that it isn't resolved multiple times.
8955
8956         * codegen.cs (EmitContext): Added `bool IsFieldInitialier'.  This tells
8957         the resolving process (SimpleName/MemberLookup) that we're currently
8958         emitting a field initializer (which must not access any instance members,
8959         this is an error CS0236).
8960
8961         * ecore.cs (SimpleName.Error_ObjectRefRequired): Added EmitContext
8962         argument, if the `IsFieldInitializer' flag is set, we must report and
8963         error CS0236 and not an error CS0120.   
8964
8965 2002-08-07  Martin Baulig  <martin@gnome.org>
8966
8967         * ecore.cs (IMemberExpr): New public interface.
8968         (FieldExpr, PropertyExpr, EventExpr): Implement IMemberExpr.
8969         (SimpleName.SimpleNameResolve): Call MemberAccess.ResolveMemberAccess
8970         if the expression is an IMemberExpr.
8971
8972         * expression.cs (MemberAccess.ResolveMemberAccess): Allow `left'
8973         to be null, implicitly default to `this' if we're non-static in
8974         this case.  Simplified the code a lot by using the new IMemberExpr
8975         interface.  Also fixed bug #28176 here.
8976
8977 2002-08-06  Martin Baulig  <martin@gnome.org>
8978
8979         * cs-parser.jay (SimpleLookup): Removed.  We need to create
8980         ParameterReferences during semantic analysis so that we can do a
8981         type-only search when resolving Cast, TypeOf and SizeOf.
8982         (block): Pass the `current_local_parameters' to the Block's
8983         constructor.
8984
8985         * class.cs (ConstructorInitializer): Added `Parameters parameters'
8986         argument to the constructor.
8987         (ConstructorInitializer.Resolve): Create a temporary implicit
8988         block with the parameters.
8989
8990         * ecore.cs (SimpleName.SimpleNameResolve): Resolve parameter
8991         references here if we aren't doing a type-only search.
8992
8993         * statement.cs (Block): Added constructor which takes a
8994         `Parameters parameters' argument.
8995         (Block.Parameters): New public property.
8996
8997         * support.cs (InternalParameters.Parameters): Renamed `parameters'
8998         to `Parameters' and made it public readonly.
8999
9000 2002-08-06  Martin Baulig  <martin@gnome.org>
9001
9002         * ecore.cs (Expression.Warning): Made this public as well.
9003
9004         * report.cs (Report.Debug): Print the contents of collections.
9005
9006 2002-08-06  Martin Baulig  <martin@gnome.org>
9007
9008         * ecore.cs (Expression.ResolveFlags): New [Flags] enum.  This is
9009         used to tell Resolve() which kinds of expressions it may return.
9010         (Expression.Resolve): Added overloaded version of this method which
9011         takes a `ResolveFlags flags' argument.  This can be used to tell
9012         Resolve() which kinds of expressions it may return.  Reports a
9013         CS0118 on error.
9014         (Expression.ResolveWithSimpleName): Removed, use Resolve() with
9015         ResolveFlags.SimpleName.
9016         (Expression.Error118): Added overloaded version of this method which
9017         takes a `ResolveFlags flags' argument.  It uses the flags to determine
9018         which kinds of expressions are allowed.
9019
9020         * expression.cs (Argument.ResolveMethodGroup): New public method.
9021         Resolves an argument, but allows a MethodGroup to be returned.
9022         This is used when invoking a delegate.
9023
9024         * TODO: Updated a bit.
9025
9026 2002-08-06  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9027
9028         Fixed compilation with csc.
9029
9030         * ecore.cs: Expression.Error made public. Is this correct? Should
9031         Warning be made public too?
9032
9033         * expression.cs: use ea.Location instead of ea.loc.
9034         [FIXME:  Filed as bug #28607: MCS must report these errors.]
9035
9036 2002-08-06  Martin Baulig  <martin@gnome.org>
9037
9038         * ecore.cs (Expression.loc): Moved the location here instead of
9039         duplicating it in all derived classes.
9040         (Expression.Location): New public property.
9041         (Expression.Error, Expression.Warning): Made them non-static and
9042         removed the location argument.
9043         (Expression.Warning): Added overloaded version which takes an
9044         `int level' argument.
9045         (Expression.Error118): Make this non-static and removed the
9046         expression and location arguments.
9047         (TypeExpr): Added location argument to the constructor.
9048
9049         * expression.cs (StaticCallExpr): Added location argument to
9050         the constructor.
9051         (Indirection, PointerArithmetic): Likewise.
9052         (CheckedExpr, UnCheckedExpr): Likewise.
9053         (ArrayAccess, IndexerAccess, UserCast, ArrayPtr): Likewise.
9054         (StringPtr): Likewise.
9055
9056
9057 2002-08-05  Martin Baulig  <martin@gnome.org>
9058
9059         * expression.cs (BaseAccess.DoResolve): Actually report errors.
9060
9061         * assign.cs (Assign.DoResolve): Check whether the source
9062         expression is a value or variable.
9063
9064         * statement.cs (Try.Resolve): Set ec.InTry/InCatch/InFinally
9065         while resolving the corresponding blocks.
9066
9067         * interface.cs (Interface.GetInterfaceTypeByName): Actually report
9068         an error, don't silently return null.
9069
9070         * statement.cs (Block.AddVariable): Do the error reporting here
9071         and distinguish between CS0128 and CS0136.
9072         (Block.DoResolve): Report all unused labels (warning CS0164).
9073         (LabeledStatement): Pass the location to the constructor.
9074         (LabeledStatement.HasBeenReferenced): New property.
9075         (LabeledStatement.Resolve): Set it to true here.
9076
9077         * statement.cs (Return.Emit): Return success even after reporting
9078         a type mismatch error (CS0126 or CS0127), this is what csc does and
9079         it avoids confusing the users with any consecutive errors.
9080
9081 2002-08-05  Martin Baulig  <martin@gnome.org>
9082
9083         * enum.cs (Enum.LookupEnumValue): Catch circular definitions.
9084
9085         * const.cs (Const.LookupConstantValue): Catch circular definitions.
9086
9087         * expression.cs (MemberAccess.DoResolve): Silently return if an
9088         error has already been reported.
9089
9090         * ecore.cs (Expression.MemberLookupFinal): Silently return if an
9091         error has already been reported.
9092
9093 2002-08-05  Martin Baulig  <martin@gnome.org>
9094
9095         * statement.cs (UsageVector): Only initialize the `parameters'
9096         vector if we actually have any "out" parameters.
9097
9098 2002-08-05  Martin Baulig  <martin@gnome.org>
9099
9100         * expression.cs (Binary.ResolveOperator): When combining delegates,
9101         they must have the same type.
9102
9103 2002-08-05  Martin Baulig  <martin@gnome.org>
9104
9105         * typemanager.cs (TypeManager.GetArgumentTypes): Don't call
9106         PropertyInfo.GetIndexParameters() on dynamic types, this doesn't
9107         work with the ms runtime and we also don't need it: if we're a
9108         PropertyBuilder and not in the `indexer_arguments' hash, then we
9109         are a property and not an indexer.
9110
9111         * class.cs (TypeContainer.AsAccessible): Use Type.IsArray,
9112         Type.IsPointer and Type.IsByRef instead of Type.HasElementType
9113         since the latter one doesn't work with the ms runtime.
9114
9115 2002-08-03  Martin Baulig  <martin@gnome.org>
9116
9117         Fixed bugs #27998 and #22735.
9118
9119         * class.cs (Method.IsOperator): New public field.
9120         (Method.CheckBase): Report CS0111 if there's already a method
9121         with the same parameters in the current class.  Report CS0508 when
9122         attempting to change the return type of an inherited method.
9123         (MethodData.Emit): Report CS0179 if a method doesn't have a body
9124         and it's not marked abstract or extern.
9125         (PropertyBase): New abstract base class for Property and Indexer.
9126         (PropertyBase.CheckBase): Moved here from Property and made it work
9127         for indexers.
9128         (PropertyBase.Emit): Moved here from Property.Emit, Indexer.Emit is
9129         the same so we can reuse it there.
9130         (Property, Indexer): Derive from PropertyBase.
9131         (MethodSignature.inheritable_property_signature_filter): New delegate
9132         to find properties and indexers.
9133
9134         * decl.cs (MemberCore.CheckMethodAgainstBase): Added `string name'
9135         argument and improved error reporting.
9136
9137         * parameter.cs (Parameters.GetEmptyReadOnlyParameters): Renamed to
9138         EmptyReadOnlyParameters and made it a property.
9139
9140         * typemanager.cs (TypeManager.GetArgumentTypes): Added overloaded
9141         version of this method which takes a `PropertyInfo indexer'.
9142         (TypeManager.RegisterIndexer): New method.
9143
9144         * class.cs: Added myself as author of this file :-)
9145
9146 2002-08-03  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9147
9148         * class.cs: fixed compilation on windoze.
9149
9150 2002-08-03  Martin Baulig  <martin@gnome.org>
9151
9152         * interface.cs (Interface.GetInterfaceBases): Check whether all
9153         base interfaces are at least as accessible than the current one.
9154
9155         * class.cs (TypeContainer.GetClassBases): Check whether base types
9156         are at least as accessible than the current type.
9157         (TypeContainer.AsAccessible): Implemented and made non-static.
9158         (MemberBase.CheckParameters): Report errors if the accessibility
9159         checks fail.
9160
9161         * delegate.cs (Delegate.Delegate): The default visibility is
9162         internal for top-level types and private for nested types.
9163         (Delegate.Define): Report errors if the accessibility checks fail.
9164
9165         * enum.cs (Enum.Enum): The default visibility is internal for
9166         top-level types and private for nested types.
9167         (Enum.DefineType): Compute the correct visibility.
9168
9169         * modifiers.cs (Modifiers.TypeAttr): Added a version of this
9170         function which takes a `bool is_toplevel' instead of a TypeContainer.
9171
9172         * typemanager.cs (TypeManager.IsBuiltinType): `void' is also a
9173         builtin type.
9174
9175 2002-08-02  Martin Baulig  <martin@gnome.org>
9176
9177         * expression.cs (LocalVariableReferenc): Added constructor which
9178         takes additional `VariableInfo vi' and `bool is_readonly' arguments.
9179         (LocalVariableReference.IsReadOnly): New property.
9180         (LocalVariableReference.DoResolveLValue): Report a CS1604 if the
9181         variable is readonly, use our own readonly flag to do this; you can
9182         use the new constructor to get a writable reference to a read-only
9183         variable.
9184
9185         * cs-parser.jay (foreach_statement, using_statement): Get a writable
9186         reference to the local variable.
9187
9188 2002-08-01  Miguel de Icaza  <miguel@ximian.com>
9189
9190         * rootcontext.cs (ResolveCore): Also include System.Exception
9191
9192         * statement.cs (Block.Emit): Do not emit the dead-code warnings if
9193         we reach an EmptyStatement.
9194
9195         (Catch.DoResolve, Throw.DoResolve): Throwing the System.Exception
9196         is also fine.
9197
9198         * expression.cs (Binary.ResolveOperator): Check error result in
9199         two places.
9200
9201         use brtrue/brfalse directly and avoid compares to null.
9202
9203 2002-08-02  Martin Baulig  <martin@gnome.org>
9204
9205         * class.cs (TypeContainer.Define): Define all nested interfaces here.
9206         Fixes bug #28407, added test-155.cs.
9207
9208 2002-08-01  Martin Baulig  <martin@gnome.org>
9209
9210         * class.cs (Event.EmitDefaultMethod): Make this work with static
9211         events.  Fixes #28311, added verify-3.cs.
9212
9213 2002-08-01  Martin Baulig  <martin@gnome.org>
9214
9215         * statement.cs (ForeachHelperMethods): Added `enumerator_type' and
9216         `is_disposable' fields.
9217         (Foreach.GetEnumeratorFilter): Set `hm.enumerator_type' and
9218         `hm.is_disposable' if we're using the collection pattern.
9219         (Foreach.EmitCollectionForeach): Use the correct type for the
9220         enumerator's local variable, only emit the try/finally block if
9221         necessary (fixes #27713).
9222
9223 2002-08-01  Martin Baulig  <martin@gnome.org>
9224
9225         * ecore.cs (Expression.report118): Renamed to Error118 and made
9226         it public static.
9227
9228         * statement.cs (Throw.Resolve): Check whether the expression is of
9229         the correct type (CS0118) and whether the type derives from
9230         System.Exception (CS0155).
9231         (Catch.Resolve): New method.  Do the type lookup here and check
9232         whether it derives from System.Exception (CS0155).
9233         (Catch.CatchType, Catch.IsGeneral): New public properties.
9234
9235         * typemanager.cs (TypeManager.exception_type): Added.
9236
9237 2002-07-31  Miguel de Icaza  <miguel@ximian.com>
9238
9239         * driver.cs: Updated About function.
9240
9241 2002-07-31  Martin Baulig  <martin@gnome.org>
9242
9243         Implemented Control Flow Analysis.
9244
9245         * codegen.cs (EmitContext.DoFlowAnalysis): New public variable.
9246         (EmitContext.CurrentBranching): Added.
9247         (EmitContext.StartFlowBranching): Added.
9248         (EmitContext.EndFlowBranching): Added.
9249         (EmitContext.KillFlowBranching): Added.
9250         (EmitContext.IsVariableAssigned): Added.
9251         (EmitContext.SetVariableAssigned): Added.
9252         (EmitContext.IsParameterAssigned): Added.
9253         (EmitContext.SetParameterAssigned): Added.
9254         (EmitContext.EmitTopBlock): Added `InternalParameters ip' argument.
9255         Added control flow analysis stuff here.
9256
9257         * expression.cs (Unary.DoResolve): If the operator is Oper.AddressOf,
9258         resolve the expression as lvalue.
9259         (LocalVariableReference.DoResolve): Check whether the variable has
9260         already been assigned.
9261         (ParameterReference.DoResolveLValue): Override lvalue resolve to mark
9262         the parameter as assigned here.
9263         (ParameterReference.DoResolve): Check whether the parameter has already
9264         been assigned.
9265         (Argument.Resolve): If it's a `ref' or `out' argument, resolve the
9266         expression as lvalue.
9267
9268         * statement.cs (FlowBranching): New class for the flow analysis code.
9269         (Goto): Resolve the label in Resolve, not in Emit; added flow analysis.
9270         (LabeledStatement.IsDefined): New public property.
9271         (LabeledStatement.AddUsageVector): New public method to tell flow
9272         analyis that the label may be reached via a forward jump.
9273         (GotoCase): Lookup and resolve the label in Resolve, not in Emit; added
9274         flow analysis.
9275         (VariableInfo.Number): New public field.  This is used by flow analysis
9276         to number all locals of a block.
9277         (Block.CountVariables): New public property.  This is the number of
9278         local variables in this block (including the locals from all parent
9279         blocks).
9280         (Block.EmitMeta): Number all the variables.
9281
9282         * statement.cs: Added flow analysis support to all classes.
9283
9284 2002-07-31  Martin Baulig  <martin@gnome.org>
9285
9286         * driver.cs: Added "--mcs-debug" argument if MCS_DEBUG is defined.
9287         To get debugging messages, compile mcs with /define:MCS_DEBUG and
9288         then use this argument.
9289
9290         * report.cs (Report.Debug): Renamed to conditional to "MCS_DEBUG".
9291
9292         * makefile.gnu (MCS_FLAGS): Include $(MCS_DEFINES), the user may
9293         use this to specify /define options.
9294
9295 2002-07-29  Martin Baulig  <martin@gnome.org>
9296
9297         * statement.cs (Fixed): Moved all code that does variable lookups
9298         and resolvings from Emit to Resolve.
9299
9300         * statement.cs (For): Moved all code that does variable lookups
9301         and resolvings from Emit to Resolve.
9302
9303         * statement.cs (Using): Moved all code that does variable lookups
9304         and resolvings from Emit to Resolve.
9305
9306 2002-07-29  Martin Baulig  <martin@gnome.org>
9307
9308         * attribute.cs (Attribute.Resolve): Explicitly catch a
9309         System.NullReferenceException when creating the
9310         CustromAttributeBuilder and report a different warning message.
9311
9312 2002-07-29  Martin Baulig  <martin@gnome.org>
9313
9314         * support.cs (ParameterData.ParameterName): Added method to
9315         get the name of a parameter.
9316
9317         * typemanager.cs (TypeManager.IsValueType): New public method.
9318
9319 2002-07-29  Martin Baulig  <martin@gnome.org>
9320
9321         * parameter.cs (Parameter.Modifier): Added `ISBYREF = 8'.  This
9322         is a flag which specifies that it's either ref or out.
9323         (Parameter.GetParameterInfo (DeclSpace, int, out bool)): Changed
9324         the out parameter to `out Parameter.Modifier mod', also set the
9325         Parameter.Modifier.ISBYREF flag on it if it's either ref or out.
9326
9327         * support.cs (InternalParameters.ParameterModifier): Distinguish
9328         between Parameter.Modifier.OUT and Parameter.Modifier.REF, set the
9329         Parameter.Modifier.ISBYREF flag if it's either ref or out.
9330
9331         * expression.cs (Argument.GetParameterModifier): Distinguish
9332         between Parameter.Modifier.OUT and Parameter.Modifier.REF, set the
9333         Parameter.Modifier.ISBYREF flag if it's either ref or out.
9334
9335 2002-07-29  Martin Baulig  <martin@gnome.org>
9336
9337         * expression.cs (ParameterReference.ParameterReference): Added
9338         `Location loc' argument to the constructor.
9339
9340         * cs-parser.jay: Pass location to ParameterReference.
9341
9342 2002-07-28  Miguel de Icaza  <miguel@ximian.com>
9343
9344         * statement.cs (Try): Initialize the location.
9345
9346         * cs-parser.jay: pass location to Try.
9347
9348         * expression.cs (Unary.Reduce): Change the prototype to return
9349         whether a constant fold could be performed or not.  The result is
9350         returned in an out parameters.  In the case of Indirection and
9351         AddressOf, we want to perform the full tests.
9352
9353 2002-07-26  Miguel de Icaza  <miguel@ximian.com>
9354
9355         * statement.cs (Statement.Emit): Flag dead code.
9356
9357 2002-07-27  Andrew Birkett  <andy@nobugs.org>
9358
9359         * expression.cs (Unary.Reduce): Handle AddressOf and Indirection.
9360
9361 2002-07-27  Martin Baulig  <martin@gnome.org>
9362
9363         * class.cs (MethodData.Define): Put back call to
9364         TypeManager.AddMethod(), accidentally commented this out.
9365
9366         * report.cs (Debug): New public method to print debugging information,
9367         this is `[Conditional ("DEBUG")]'.
9368
9369 2002-07-26  Martin Baulig  <martin@gnome.org>
9370
9371         * cs-parser.jay (CSharpParser): Added `Stack switch_stack'.
9372         (switch_statement): Push the current_block to the switch_stack and
9373         pop it again when we're done with the switch.
9374         (switch_section): The new block is a child of the current_block.
9375         Fixes bug #24007, added test-152.cs.
9376
9377 2002-07-27  Martin Baulig  <martin@gnome.org>
9378
9379         * expression.cs (Invocation.EmitArguments): When calling a varargs
9380         function with only its fixed arguments, we need to pass an empty
9381         array.
9382
9383 2002-07-27  Martin Baulig  <martin@gnome.org>
9384
9385         Mono 0.13 has been released.
9386
9387 2002-07-25  Miguel de Icaza  <miguel@ximian.com>
9388
9389         * driver.cs: Rename --resource to --linkres, because that is what
9390         we do currently, we dont support --resource yet.
9391
9392         * cs-tokenizer.cs: Fix test for reporting endif mismatches.
9393
9394 2002-07-25  Martin Baulig  <martin@gnome.org>
9395
9396         * class.cs (MethodData): New public class.  This is a `method builder'
9397         class for a method or one accessor of a Property/Indexer/Event.
9398         (MethodData.GetMethodFlags): Moved here from MemberBase.
9399         (MethodData.ApplyAttributes): Likewise.
9400         (MethodData.ApplyObsoleteAttribute): Likewise.
9401         (MethodData.ApplyConditionalAttribute): Likewise.
9402         (MethodData.ApplyDllImportAttribute): Likewise.
9403         (MethodData.CheckAbstractAndExternal): Likewise.
9404         (MethodData.Define): Formerly knows as MemberBase.DefineMethod().
9405         (MethodData.Emit): Formerly known as Method.Emit().
9406         (MemberBase): Moved everything which was specific to a single
9407         accessor/method to MethodData.
9408         (Method): Create a new MethodData and call Define() and Emit() on it.
9409         (Property, Indexer, Event): Create a new MethodData objects for each
9410         accessor and call Define() and Emit() on them.
9411
9412 2002-07-25  Martin Baulig  <martin@gnome.org>
9413
9414         Made MethodCore derive from MemberBase to reuse the code from there.
9415         MemberBase now also checks for attributes.
9416
9417         * class.cs (MethodCore): Derive from MemberBase, not MemberCore.
9418         (MemberBase.GetMethodFlags): Moved here from class Method and marked
9419         as virtual.
9420         (MemberBase.DefineAccessor): Renamed to DefineMethod(), added
9421         `CallingConventions cc' and `Attributes opt_attrs' arguments.
9422         (MemberBase.ApplyAttributes): New virtual method; applies the
9423         attributes to a method or accessor.
9424         (MemberBase.ApplyObsoleteAttribute): New protected virtual method.
9425         (MemberBase.ApplyConditionalAttribute): Likewise.
9426         (MemberBase.ApplyDllImportAttribute): Likewise.
9427         (MemberBase.CheckAbstractAndExternal): Likewise.
9428         (MethodCore.ParameterTypes): This is now a property instead of a
9429         method, it's initialized from DoDefineParameters().
9430         (MethodCore.ParameterInfo): Removed the set accessor.
9431         (MethodCore.DoDefineParameters): New protected virtual method to
9432         initialize ParameterTypes and ParameterInfo.
9433         (Method.GetReturnType): We can now simply return the MemberType.
9434         (Method.GetMethodFlags): Override the MemberBase version and add
9435         the conditional flags.
9436         (Method.CheckBase): Moved some code from Define() here, call
9437         DoDefineParameters() here.
9438         (Method.Define): Use DoDefine() and DefineMethod() from MemberBase
9439         here to avoid some larger code duplication.
9440         (Property.Emit, Indexer.Emit): Call CheckAbstractAndExternal() to
9441         ensure that abstract and external accessors don't declare a body.
9442
9443         * attribute.cs (Attribute.GetValidPieces): Make this actually work:
9444         `System.Attribute.GetCustomAttributes (attr.Type)' does a recursive
9445         lookup in the attribute's parent classes, so we need to abort as soon
9446         as we found the first match.
9447         (Attribute.Obsolete_GetObsoleteMessage): Return the empty string if
9448         the attribute has no arguments.
9449
9450         * typemanager.cs (TypeManager.AddMethod): Now takes a MemberBase instead
9451         of a Method.
9452
9453 2002-07-24  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9454
9455         * cs-parser.jay: reverted previous patch.
9456
9457 2002-07-24  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9458
9459         * cs-parser.jay: fixed bug #22119.
9460
9461 2002-07-24  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9462
9463         * attribute.cs: fixed compilation. The error was:
9464         "attribute.cs(571,17): error CS0177: The out parameter 'is_error' must 
9465         be assigned to before control leaves the current method."
9466         [FIXME:  Filed as bug #28186: MCS must report this error.]
9467
9468 2002-07-25  Martin Baulig  <martin@gnome.org>
9469
9470         * attribute.cs (Attribute.Conditional_GetConditionName): New static
9471         method to pull the condition name ouf of a Conditional attribute.
9472         (Attribute.Obsolete_GetObsoleteMessage): New static method to pull
9473         the obsolete message and error flag out of an Obsolete attribute.
9474
9475         * class.cs (Method.GetMethodFlags): New public method to get the
9476         TypeManager.MethodFlags for this method.
9477         (Method.ApplyConditionalAttribute, Method.ApplyObsoleteAttribute): New
9478         private methods.
9479         (Method.Define): Get and apply the Obsolete and Conditional attributes;
9480         if we're overriding a virtual function, set the new private variable
9481         `parent_method'; call the new TypeManager.AddMethod().
9482
9483         * typemanager.cs (TypeManager.AddMethod): New static method.  Stores
9484         the MethodBuilder and the Method in a PtrHashtable.
9485         (TypeManager.builder_to_method): Added for this purpose.
9486         (TypeManager.MethodFlags): Added IsObsoleteError.
9487         (TypeManager.GetMethodFlags): Added `Location loc' argument.  Lookup
9488         Obsolete and Conditional arguments in MethodBuilders.  If we discover
9489         an Obsolete attribute, emit an appropriate warning 618 / error 619 with
9490         the message from the attribute.
9491
9492 2002-07-24  Martin Baulig  <martin@gnome.org>
9493
9494         * cs-tokenizer.cs: Eat up trailing whitespaces and one-line comments in
9495         preprocessor directives, ensure that the argument to #define/#undef is
9496         exactly one identifier and that it's actually an identifier.
9497
9498         Some weeks ago I did a `#define DEBUG 1' myself and wondered why this
9499         did not work ....
9500
9501 2002-07-24  Martin Baulig  <martin@gnome.org>
9502
9503         * statement.cs (Foreach.ForeachHelperMethods): Added `Type element_type',
9504         initialize it to TypeManager.object_type in the constructor.
9505         (Foreach.GetEnumeratorFilter): Set `hm.element_type' to the return type
9506         of the `hm.get_current' method if we're using the collection pattern.
9507         (Foreach.EmitCollectionForeach): Use `hm.element_type' as the source type
9508         for the explicit conversion to make it work when we're using the collection
9509         pattern and the `Current' property has a different return type than `object'.
9510         Fixes #27713.
9511
9512 2002-07-24  Martin Baulig  <martin@gnome.org>
9513
9514         * delegate.cs (Delegate.VerifyMethod): Simply return null if the method
9515         does not match, but don't report any errors.  This method is called in
9516         order for all methods in a MethodGroupExpr until a matching method is
9517         found, so we don't want to bail out if the first method doesn't match.
9518         (NewDelegate.DoResolve): If none of the methods in the MethodGroupExpr
9519         matches, report the 123.  Fixes #28070.
9520
9521 2002-07-24  Martin Baulig  <martin@gnome.org>
9522
9523         * expression.cs (ArrayAccess.EmitStoreOpcode): Moved the
9524         TypeManager.TypeToCoreType() to the top of the method so the
9525         following equality checks will work.  Fixes #28107.
9526
9527 2002-07-24  Martin Baulig  <martin@gnome.org>
9528
9529         * cfold.cs (ConstantFold.DoConstantNumericPromotions): "If either
9530         operand is of type uint, and the other operand is of type sbyte,
9531         short or int, the operands are converted to type long." -
9532         Actually do what this comment already told us.  Fixes bug #28106,
9533         added test-150.cs.
9534
9535 2002-07-24  Martin Baulig  <martin@gnome.org>
9536
9537         * class.cs (MethodBase): New abstract class.  This is now a base
9538         class for Property, Indexer and Event to avoid some code duplication
9539         in their Define() and DefineMethods() methods.
9540         (MethodBase.DoDefine, MethodBase.DefineAccessor): Provide virtual
9541         generic methods for Define() and DefineMethods().
9542         (FieldBase): Derive from MemberBase, not MemberCore.
9543         (Property): Derive from MemberBase, not MemberCore.
9544         (Property.DefineMethod): Moved all the code from this method to the
9545         new MethodBase.DefineAccessor(), just call it with appropriate
9546         argumetnts.
9547         (Property.Define): Call the new Property.DoDefine(), this does some
9548         sanity checks and we don't need to duplicate the code everywhere.
9549         (Event): Derive from MemberBase, not MemberCore.
9550         (Event.Define): Use the new MethodBase.DefineAccessor() to define the
9551         accessors, this will also make them work with interface events.
9552         (Indexer): Derive from MemberBase, not MemberCore.
9553         (Indexer.DefineMethod): Removed, call MethodBase.DefineAccessor() insstead.
9554         (Indexer.Define): Use the new MethodBase functions.
9555
9556         * interface.cs (InterfaceEvent.InterfaceEvent): Added `Location loc'
9557         argument to the constructor.
9558         (Interface.FindMembers): Added support for interface events.
9559         (Interface.PopluateEvent): Implemented.
9560
9561         Added test-149.cs for this.  This also fixes bugs #26067 and #24256.
9562
9563 2002-07-22  Miguel de Icaza  <miguel@ximian.com>
9564
9565         * class.cs (TypeContainer.AddMethod): Adding methods do not use IsValid,
9566         but this is required to check for a method name being the same as
9567         the containing class.  
9568
9569         Handle this now.
9570
9571 2002-07-22  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9572
9573         * interface.cs: initialize variable.
9574
9575 2002-07-23  Martin Baulig  <martin@gnome.org>
9576
9577         Implemented the IndexerName attribute in interfaces.
9578
9579         * class.cs (TypeContainer.DefineIndexers): Don't set the indexer
9580         name if this is an explicit interface implementation.
9581         (Indexer.InterfaceIndexerName): New public variable.  If we're
9582         implementing an interface indexer, this is the IndexerName in that
9583         interface.  Otherwise, it's the IndexerName.
9584         (Indexer.DefineMethod): If we're implementing interface indexer,
9585         set InterfaceIndexerName.  Use the new Pending.IsInterfaceIndexer
9586         and Pending.ImplementIndexer methods.
9587         (Indexer.Define): Also define the PropertyBuilder if we're
9588         implementing an interface indexer and this is neither an explicit
9589         interface implementation nor do the IndexerName match the one in
9590         the interface.
9591
9592         * pending.cs (TypeAndMethods): Added `MethodInfo [] need_proxy'.
9593         If a method is defined here, then we always need to create a proxy
9594         for it.  This is used when implementing interface indexers.
9595         (Pending.IsInterfaceIndexer): New public method.
9596         (Pending.ImplementIndexer): New public method.
9597         (Pending.InterfaceMethod): Added `MethodInfo need_proxy' argument.
9598         This is used when implementing interface indexers to define a proxy
9599         if necessary.
9600         (Pending.VerifyPendingMethods): Look in the `need_proxy' array and
9601         define a proxy if necessary.
9602
9603         * interface.cs (Interface.IndexerName): New public variable.
9604         (Interface.PopulateIndexer): Set the IndexerName.
9605         (Interface.DefineIndexers): New private method.  Populate all the
9606         indexers and make sure their IndexerNames match.
9607
9608         * typemanager.cs (IndexerPropertyName): Added support for interface
9609         indexers.
9610
9611 2002-07-22  Martin Baulig  <martin@gnome.org>
9612
9613         * codegen.cs (EmitContext.HasReturnLabel): New public variable.
9614         (EmitContext.EmitTopBlock): Always mark the ReturnLabel and emit a
9615         ret if HasReturnLabel.
9616         (EmitContext.TryCatchLevel, LoopBeginTryCatchLevel): New public
9617         variables.
9618
9619         * statement.cs (Do.Emit, While.Emit, For.Emit, Foreach.Emit): Save
9620         and set the ec.LoopBeginTryCatchLevel.
9621         (Try.Emit): Increment the ec.TryCatchLevel while emitting the block.
9622         (Continue.Emit): If the ec.LoopBeginTryCatchLevel is smaller than
9623         the current ec.TryCatchLevel, the branch goes out of an exception
9624         block.  In this case, we need to use Leave and not Br.
9625
9626 2002-07-22  Martin Baulig  <martin@gnome.org>
9627
9628         * statement.cs (Try.Emit): Emit an explicit ret after the end of the
9629         block unless the block does not always return or it is contained in
9630         another try { ... } catch { ... } block.  Fixes bug #26506.
9631         Added verify-1.cs to the test suite.
9632
9633 2002-07-22  Martin Baulig  <martin@gnome.org>
9634
9635         * statement.cs (Switch.TableSwitchEmit): If we don't have a default,
9636         then we do not always return.  Fixes bug #24985.
9637
9638 2002-07-22  Martin Baulig  <martin@gnome.org>
9639
9640         * expression.cs (Invocation.OverloadedResolve): Do the BetterFunction()
9641         lookup on a per-class level; ie. walk up the class hierarchy until we
9642         found at least one applicable method, then choose the best among them.
9643         Fixes bug #24463 and test-29.cs.
9644
9645 2002-07-22  Martin Baulig  <martin@gnome.org>
9646
9647         * typemanager.cs (TypeManager.ArrayContainsMethod): Don't check the
9648         return types of the methods.  The return type is not part of the
9649         signature and we must not check it to make the `new' modifier work.
9650         Fixes bug #27999, also added test-147.cs.
9651         (TypeManager.TypeToCoreType): Added TypeManager.type_type.
9652
9653         * expression.cs (Invocation.DoResolve): Call TypeManager.TypeToCoreType()
9654         on the method's return type.
9655
9656 2002-07-21  Martin Baulig  <martin@gnome.org>
9657
9658         * assign.cs: Make this work if the rightmost source is a constant and
9659         we need to do an implicit type conversion.  Also adding a few more tests
9660         to test-38.cs which should have caught this.
9661
9662         * makefile.gnu: Disable debugging, there's already the mcs-mono2.exe
9663         target in the makefile for this.  The makefile.gnu is primarily intended
9664         for end-users who don't want to debug the compiler.
9665
9666 2002-07-21  Martin Baulig  <martin@gnome.org>
9667
9668         * assign.cs: Improved the Assign class so it can now handle embedded
9669         assignments (X = Y = Z = something).  As a side-effect this'll now also
9670         consume less local variables.  test-38.cs now passes with MCS, added
9671         a few new test cases to that test.
9672
9673 2002-07-20  Martin Baulig  <martin@gnome.org>
9674
9675         * expression.cs (Binary.EmitBranchable): Emit correct unsigned branch
9676         instructions.  Fixes bug #27977, also added test-146.cs.
9677
9678 2002-07-19  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9679
9680         * cs-tokenizer.cs: fixed getHex ().
9681
9682 2002-07-19  Martin Baulig  <martin@gnome.org>
9683
9684         * expression.cs (Invocation.EmitParams): Use TypeManager.LookupType(),
9685         not Type.GetType() to lookup the array type.  This is needed when
9686         we're constructing an array of a user-defined type.
9687         (ArrayAccess.EmitDynamicInitializers): Only emit the Ldelema for
9688         single-dimensional arrays, but also for single-dimensial arrays of
9689         type decimal.
9690
9691 2002-07-19  Martin Baulig  <martin@gnome.org>
9692
9693         * expression.cs (New.DoEmit): Create a new LocalTemporary each time
9694         this function is called, it's not allowed to share LocalBuilders
9695         among ILGenerators.
9696
9697 2002-07-19  Martin Baulig  <martin@gnome.org>
9698
9699         * expression.cs (Argument.Resolve): Report an error 118 when trying
9700         to pass a type as argument.
9701
9702 2002-07-18  Martin Baulig  <martin@gnome.org>
9703
9704         * ecore.cs (Expression.ImplicitNumericConversion): Don't emit a
9705         Conv_R_Un for the signed `long' type.
9706
9707 2002-07-15  Miguel de Icaza  <miguel@ximian.com>
9708
9709         * expression.cs (MemberAccess.DoResolve): Do not reuse the field
9710         `expr' for the temporary result, as that will fail if we do
9711         multiple resolves on the same expression.
9712
9713 2002-07-05  Miguel de Icaza  <miguel@ximian.com>
9714
9715         * ecore.cs (SimpleNameResolve): Use ec.DeclSpace instead of
9716         ec.TypeContainer for looking up aliases. 
9717
9718         * class.cs (TypeContainer): Remove LookupAlias from here.
9719
9720         * decl.cs (DeclSpace); Move here.
9721
9722 2002-07-01  Miguel de Icaza  <miguel@ximian.com>
9723
9724         * class.cs (FindMembers): Only call filter if the constructor
9725         bulider is not null.
9726
9727         Also handle delegates in `NestedTypes' now.  Now we will perform
9728         type lookups using the standard resolution process.  This also
9729         fixes a bug.
9730
9731         * decl.cs (DeclSpace.ResolveType): New type resolution routine.
9732         This uses Expressions (the limited kind that can be parsed by the
9733         tree) instead of strings.
9734
9735         * expression.cs (ComposedCast.ToString): Implement, used to flag
9736         errors since now we have to render expressions.
9737
9738         (ArrayCreation): Kill FormElementType.  Use ComposedCasts in
9739         FormArrayType. 
9740
9741         * ecore.cs (SimpleName.ToString): ditto.
9742
9743         * cs-parser.jay: Instead of using strings to assemble types, use
9744         Expressions to assemble the type (using SimpleName, ComposedCast,
9745         MemberAccess).  This should fix the type lookups in declarations,
9746         because we were using a different code path for this.
9747
9748         * statement.cs (Block.Resolve): Continue processing statements
9749         even when there is an error.
9750
9751 2002-07-17  Miguel de Icaza  <miguel@ximian.com>
9752
9753         * class.cs (Event.Define): Also remove the `remove' method from
9754         the list of pending items.
9755
9756         * expression.cs (ParameterReference): Use ldarg.N (0..3) to
9757         generate more compact code. 
9758
9759 2002-07-17  Martin Baulig  <martin@gnome.org>
9760
9761         * const.cs (Const.LookupConstantValue): Add support for constant
9762         `unchecked' and `checked' expressions.
9763         Also adding test case test-140.cs for this.
9764
9765 2002-07-17  Martin Baulig  <martin@gnome.org>
9766
9767         * statement.cs (Foreach.GetEnumeratorFilter): When compiling corlib,
9768         check whether mi.ReturnType implements the IEnumerator interface; the
9769         `==' and the IsAssignableFrom() will fail in this situation.
9770
9771 2002-07-16  Ravi Pratap  <ravi@ximian.com>
9772
9773         * ecore.cs (SimpleName.SimpleNameResolve) : Apply Gonzalo's fix 
9774         here too.
9775
9776 2002-07-16  Gonzalo Paniagua Javier <gonzalo@ximian.com>
9777
9778         * expression.cs: fixed bug #27811.
9779
9780 2002-07-14  Miguel de Icaza  <miguel@ximian.com>
9781
9782         * expression.cs (ParameterReference.AddressOf): Patch from Paolo
9783         Molaro: when we are a ref, the value already contains a pointer
9784         value, do not take the address of it.
9785
9786 2002-07-14 Rafael Teixeira <rafaelteixeirabr@hotmail.com>
9787         * removed mb-parser.jay and mb-tokenizer.cs
9788
9789 Sat Jul 13 19:38:03 CEST 2002 Paolo Molaro <lupus@ximian.com>
9790
9791         * expression.cs: check against the building corlib void type.
9792
9793 Sat Jul 13 19:35:58 CEST 2002 Paolo Molaro <lupus@ximian.com>
9794
9795         * ecore.cs: fix for valuetype static readonly fields: when 
9796         initializing them, we need their address, not the address of a copy.
9797
9798 Sat Jul 13 17:32:53 CEST 2002 Paolo Molaro <lupus@ximian.com>
9799
9800         * typemanager.cs: register also enum_type in corlib.
9801
9802 Sat Jul 13 15:59:47 CEST 2002 Paolo Molaro <lupus@ximian.com>
9803
9804         * class.cs: allow calling this (but not base) initializers in structs.
9805
9806 Sat Jul 13 15:12:06 CEST 2002 Paolo Molaro <lupus@ximian.com>
9807
9808         * ecore.cs: make sure we compare against the building base types
9809         in GetTypeSize ().
9810
9811 Sat Jul 13 15:10:32 CEST 2002 Paolo Molaro <lupus@ximian.com>
9812
9813         * typemanager.cs: fix TypeToCoreType() to handle void and object
9814         (corlib gets no more typerefs after this change).
9815
9816 2002-07-12  Miguel de Icaza  <miguel@ximian.com>
9817
9818         * expression.cs (ArrayCreation.EmitArrayArguments): use
9819         Conv.Ovf.U4 for unsigned and Conv.Ovf.I4 for signed.
9820
9821         (ArrayAccess.LoadArrayAndArguments): Use Conv_Ovf_I and
9822         Conv_Ovf_I_Un for the array arguments.  Even if C# allows longs as
9823         array indexes, the runtime actually forbids them.
9824
9825         * ecore.cs (ExpressionToArrayArgument): Move the conversion code
9826         for array arguments here.
9827
9828         * expression.cs (EmitLoadOpcode): System.Char is a U2, use that
9829         instead of the default for ValueTypes.
9830
9831         (New.DoEmit): Use IsValueType instead of
9832         IsSubclassOf (value_type)
9833         (New.DoResolve): ditto.
9834         (Invocation.EmitCall): ditto.
9835
9836         * assign.cs (Assign): ditto.
9837
9838         * statement.cs (Unsafe): Ok, so I got the semantics wrong.
9839         Statements *are* currently doing part of their resolution during
9840         Emit.  
9841
9842         Expressions do always resolve during resolve, but statements are
9843         only required to propagate resolution to their children.
9844
9845 2002-07-11  Miguel de Icaza  <miguel@ximian.com>
9846
9847         * driver.cs (CSCParseOption): Finish the /r: and /lib: support.
9848
9849         (LoadAssembly): Do not add the dll if it is already specified
9850
9851         (MainDriver): Add the System directory to the link path at the end,
9852         after all the other -L arguments. 
9853
9854         * expression.cs (ArrayAccess.EmitLoadOpcode): I was using the
9855         wrong opcode for loading bytes and bools (ldelem.i1 instead of
9856         ldelem.u1) and using the opposite for sbytes.
9857
9858         This fixes Digger, and we can finally run it.
9859
9860         * driver.cs (UnixParseOption): Move the option parsing here.  
9861         (CSCParseOption): Implement CSC-like parsing of options.
9862
9863         We now support both modes of operation, the old Unix way, and the
9864         new CSC-like way.  This should help those who wanted to make cross
9865         platform makefiles.
9866
9867         The only thing broken is that /r:, /reference: and /lib: are not
9868         implemented, because I want to make those have the same semantics
9869         as the CSC compiler has, and kill once and for all the confussion
9870         around this.   Will be doing this tomorrow.
9871
9872         * statement.cs (Unsafe.Resolve): The state is checked during
9873         resolve, not emit, so we have to set the flags for IsUnsfe here.
9874
9875 2002-07-10  Miguel de Icaza  <miguel@ximian.com>
9876
9877         * expression.cs (MemberAccess.ResolveMemberAccess): Since we can
9878         not catch the Error_ObjectRefRequired in SimpleName (as it is
9879         possible to have a class/instance variable name that later gets
9880         deambiguated), we have to check this here.      
9881
9882 2002-07-10  Ravi Pratap  <ravi@ximian.com>
9883
9884         * class.cs (TypeContainer.GetFieldFromEvent): Move away from here,
9885         make static and put into Expression.
9886
9887         (Event.Define): Register the private field of the event with the 
9888         TypeManager so that GetFieldFromEvent can get at it.
9889
9890         (TypeManager.RegisterPrivateFieldOfEvent): Implement to
9891         keep track of the private field associated with an event which
9892         has no accessors.
9893
9894         (TypeManager.GetPrivateFieldOfEvent): Implement to get at the
9895         private field.
9896
9897         * ecore.cs (GetFieldFromEvent): RE-write to use the above methods.
9898
9899 2002-07-10  Miguel de Icaza  <miguel@ximian.com>
9900
9901         * expression.cs (Binary.EmitBranchable): this routine emits the
9902         Binary expression in a branchable context.  This basically means:
9903         we need to branch somewhere, not just get the value on the stack.
9904
9905         This works together with Statement.EmitBoolExpression.
9906
9907         * statement.cs (Statement.EmitBoolExpression): Use
9908         EmitBranchable. 
9909
9910 2002-07-09  Miguel de Icaza  <miguel@ximian.com>
9911
9912         * statement.cs (For): Reduce the number of jumps in loops.
9913
9914         (For): Implement loop inversion for the For statement.
9915
9916         (Break): We can be breaking out of a Try/Catch controlled section
9917         (foreach might have an implicit try/catch clause), so we need to
9918         use Leave instead of Br.
9919
9920         * ecore.cs (FieldExpr.AddressOf): Fix for test-139 (augmented
9921         now).  If the instace expression supports IMemoryLocation, we use
9922         the AddressOf method from the IMemoryLocation to extract the
9923         address instead of emitting the instance.
9924
9925         This showed up with `This', as we were emitting the instance
9926         always (Emit) instead of the Address of This.  Particularly
9927         interesting when This is a value type, as we dont want the Emit
9928         effect (which was to load the object).
9929
9930 2002-07-08  Miguel de Icaza  <miguel@ximian.com>
9931
9932         * attribute.cs: Pass the entry point to the DefinePInvokeMethod
9933
9934         * statement.cs (Checked): Set the CheckedState during the resolve
9935         process too, as the ConvCast operations track the checked state on
9936         the resolve process, and not emit.
9937
9938         * cs-parser.jay (namespace_member_declaration): Flag that we have
9939         found a declaration when we do.  This is used to flag error 1529
9940
9941         * driver.cs: Report ok when we display the help only.
9942
9943 2002-07-06  Andrew Birkett  <adb@tardis.ed.ac.uk>
9944
9945         * cs-tokenizer.cs (xtoken): Improve handling of string literals.
9946
9947 2002-07-04  Miguel de Icaza  <miguel@ximian.com>
9948
9949         * cs-tokenizer.cs (define): We also have to track locally the
9950         defines.  AllDefines is just used for the Conditional Attribute,
9951         but we also need the local defines for the current source code. 
9952
9953 2002-07-03  Miguel de Icaza  <miguel@ximian.com>
9954
9955         * statement.cs (While, For, Do): These loops can exit through a
9956         Break statement, use this information to tell whether the
9957         statement is the last piece of code.
9958
9959         (Break): Flag that we break.
9960
9961         * codegen.cs (EmitContexts): New `Breaks' state variable.
9962
9963 2002-07-03  Martin Baulig  <martin@gnome.org>
9964
9965         * class.cs (TypeContainer.MethodModifiersValid): Allow override
9966         modifiers in method declarations in structs.  Otherwise, you won't
9967         be able to override things like Object.Equals().
9968
9969 2002-07-02  Miguel de Icaza  <miguel@ximian.com>
9970
9971         * class.cs (Method, Property, Indexer): Do not allow the public
9972         modifier to be used in explicit interface implementations.
9973
9974         (TypeContainer.MethodModifiersValid): Catch virtual, abstract and
9975         override modifiers in method declarations in structs
9976
9977 2002-07-02   Andrew Birkett <adb@tardis.ed.ac.uk>
9978
9979         * cs-tokenizer.cs (adjust_int, adjust_real): Do not abort on
9980         integer or real overflow, report an error
9981
9982 2002-07-02  Martin Baulig  <martin@gnome.org>
9983
9984         * typemanager.cs (TypeManager.InitCoreTypes): When compiling
9985         corlib, dynamically call AssemblyBuilder.SetCorlibTypeBuilders()
9986         to tell the runtime about our newly created System.Object and
9987         System.ValueType types.
9988
9989 2002-07-02  Miguel de Icaza  <miguel@ximian.com>
9990
9991         * expression.cs (This): Use Stobj/Ldobj when we are a member of a
9992         struct instead of Ldarg/Starg.
9993
9994 2002-07-02  Martin Baulig  <martin@gnome.org>
9995
9996         * expression.cs (Indirection.Indirection): Call
9997         TypeManager.TypeToCoreType() on `expr.Type.GetElementType ()'.
9998
9999 2002-07-02  Martin Baulig  <martin@gnome.org>
10000
10001         * expression.cs (ArrayAccess.EmitStoreOpcode): If the type is a
10002         ValueType, call TypeManager.TypeToCoreType() on it.
10003         (Invocations.EmitParams): Call TypeManager.TypeToCoreType() on
10004         the OpCodes.Newarr argument.
10005
10006 2002-07-02  Martin Baulig  <martin@gnome.org>
10007
10008         * expression.cs (Invocation.EmitCall): When compiling corlib,
10009         replace all calls to the system's System.Array type to calls to
10010         the newly created one.
10011
10012         * typemanager.cs (TypeManager.InitCodeHelpers): Added a few more
10013         System.Array methods.
10014         (TypeManager.InitCoreTypes): When compiling corlib, get the methods
10015         from the system's System.Array type which must be replaced.
10016
10017 Tue Jul 2 19:05:05 CEST 2002 Paolo Molaro <lupus@ximian.com>
10018
10019         * typemanager.cs: load unverifiable_code_ctor so we can build
10020         corlib using the correct type. Avoid using GetTypeCode() with
10021         TypeBuilders.
10022         * rootcontext.cs: uses TypeManager.unverifiable_code_ctor and
10023         TypeManager.object_type to allow building corlib.
10024
10025 Tue Jul 2 19:03:19 CEST 2002 Paolo Molaro <lupus@ximian.com>
10026
10027         * ecore.cs: handle System.Enum separately in LoadFromPtr().
10028
10029 2002-07-01  Martin Baulig  <martin@gnome.org>
10030
10031         * class.cs: Make the last change actually work, we need to check
10032         whether `ifaces != null' to avoid a crash.
10033
10034 Mon Jul 1 16:15:03 CEST 2002 Paolo Molaro <lupus@ximian.com>
10035
10036         * class.cs: when we build structs without fields that implement
10037         interfaces, we need to add the interfaces separately, since there is
10038         no API to both set the size and add the interfaces at type creation
10039         time.
10040
10041 Mon Jul 1 14:50:47 CEST 2002 Paolo Molaro <lupus@ximian.com>
10042
10043         * expression.cs: the dimension arguments to the array constructors
10044         need to be converted if they are a long.
10045
10046 Mon Jul 1 12:26:12 CEST 2002 Paolo Molaro <lupus@ximian.com>
10047
10048         * class.cs: don't emit ldarg.0 if there is no parent constructor
10049         (fixes showstopper for corlib).
10050
10051 2002-06-29  Martin Baulig  <martin@gnome.org>
10052
10053         MCS now compiles corlib on GNU/Linux :-)
10054
10055         * attribute.cs (Attribute.ApplyAttributes): Treat Accessors like Method,
10056         ie. check for MethodImplOptions.InternalCall.
10057
10058         * class.cs (TypeContainer.DefineType): When compiling corlib, both parent
10059         and TypeManager.attribute_type are null, so we must explicitly check
10060         whether parent is not null to find out whether it's an attribute type.
10061         (Property.Emit): Always call Attribute.ApplyAttributes() on the GetBuilder
10062         and SetBuilder, not only if the property is neither abstract nor external.
10063         This is necessary to set the MethodImplOptions on the accessor methods.
10064         (Indexer.Emit): Call Attribute.ApplyAttributes() on the GetBuilder and
10065         SetBuilder, see Property.Emit().
10066
10067         * rootcontext.cs (RootContext.PopulateTypes): When compiling corlib, don't
10068         populate "System.Object", "System.ValueType" and "System.Attribute" since
10069         they've already been populated from BootCorlib_PopulateCoreTypes().
10070
10071 2002-06-29  Martin Baulig  <martin@gnome.org>
10072
10073         * ecore.cs (Expression.ImplicitReferenceConversionExists): If expr
10074         is the NullLiteral, we also need to make sure that target_type is not
10075         an enum type.   
10076
10077 2002-06-29  Martin Baulig  <martin@gnome.org>
10078
10079         * rootcontext.cs (RootContext.ResolveCore): We must initialize
10080         `TypeManager.multicast_delegate_type' and `TypeManager.delegate_type'
10081         before calling BootstrapCorlib_ResolveDelegate ().
10082
10083 2002-06-27  Gonzalo Paniagua Javier <gonzalo@ximian.com>
10084
10085         * statement.cs: fixed build-breaker. All tests passed ok.
10086
10087 2002-06-27  Martin Baulig  <martin@gnome.org>
10088
10089         * typemanager.cs (TypeManager.VerifyUnManaged): Added explicit check
10090         for System.Decimal when compiling corlib.
10091
10092 2002-06-27  Martin Baulig  <martin@gnome.org>
10093
10094         * statement.cs (Switch.TableSwitchEmit): Make this work with empty
10095         switch blocks which contain nothing but a default clause.
10096
10097 2002-06-26  Andrew  <adb@tardis.ed.ac.uk>
10098
10099        * ../errors/cs1501-3.cs: Added new test for struct ctr typechecks.
10100
10101 2002-06-27  Martin Baulig  <martin@gnome.org>
10102
10103         * ecore.cs (PropertyExpr.PropertyExpr): Call
10104         TypeManager.TypeToCoreType() on the `pi.PropertyType'.
10105
10106         * typemanager.cs (TypeManager.TypeToCoreType): Return if the type
10107         is already a TypeBuilder.
10108
10109 2002-06-27  Martin Baulig  <martin@gnome.org>
10110
10111         * ecore.cs (Expression.ImplicitReferenceConversionExists): Use
10112         `target_type == TypeManager.array_type', not IsAssignableFrom() in
10113         the "from an array-type to System.Array" case.  This makes it work
10114         when compiling corlib.
10115
10116 2002-06-27  Martin Baulig  <martin@gnome.org>
10117
10118         * ecore.cs (Expression.SimpleNameResolve): If the expression is a
10119         non-static PropertyExpr, set its InstanceExpression.  This makes
10120         the `ICollection.Count' property work in System/Array.cs.
10121
10122 2002-06-25  Andrew Birkett  <adb@tardis.ed.ac.uk>
10123
10124         * driver.cs: Made error handling more consistent.  Errors now
10125         tracked by Report class, so many methods which used to return int
10126         now return void.  Main() now prints success/failure and 
10127         errors/warnings message.
10128
10129         Renamed '--probe' compiler argument to '--expect-error'.  Removed
10130         the magic number return values (123 and 124).  Now, if the
10131         expected error occurs, the compiler exits with success (exit value
10132         0).  If the compilation completes without seeing that particular
10133         error, the compiler exits with failure (exit value 1).  The
10134         makefile in mcs/errors has been changed to handle the new behaviour.
10135
10136         * report.cs: Made 'expected error' number a property and renamed
10137         it from 'Probe' to 'ExpectedError'.
10138
10139         * genericparser.cs: Removed error handling support, since it is
10140         now all done by Report class.
10141
10142         * cs-parser.jay, mb-parser.jay: Errors are tracked by Report
10143         class, so parse() no longer returns an int.
10144
10145         * namespace.cs: Use Report.Error instead of GenericParser.error
10146
10147 2002-06-22  Miguel de Icaza  <miguel@ximian.com>
10148
10149         * class.cs (TypeContainer.AddMethod, TypeContainer.AddIndexer,
10150         TypeContainer.AddOperator): At the front of the list put the
10151         explicit implementations, so they get resolved/defined first. 
10152
10153 2002-06-21  Miguel de Icaza  <miguel@ximian.com>
10154
10155         * class.cs (TypeContainer.VerifyImplements): Verifies that a given
10156         interface type is implemented by this TypeContainer.  Used during
10157         explicit interface implementation.
10158
10159         (Property.Define, Indexer.Define, Method.Define): Validate that
10160         the given interface in the explicit implementation is one of the
10161         base classes for the containing type.
10162
10163         Also if we are explicitly implementing an interface, but there is
10164         no match in the pending implementation table, report an error.
10165
10166         (Property.Define): Only define the property if we are
10167         not explicitly implementing a property from an interface.  Use the
10168         correct name also for those properties (the same CSC uses,
10169         although that is really not needed).
10170
10171         (Property.Emit): Do not emit attributes for explicitly implemented
10172         properties, as there is no TypeBuilder.
10173
10174         (Indexer.Emit): ditto.
10175
10176         Hiding then means that we do not really *implement* a pending
10177         implementation, which makes code fail.
10178
10179 2002-06-22  Martin Baulig  <martin@gnome.org>
10180
10181         * ecore.cs (Expression.Constantify): Call TypeManager.TypeToCoreType() on
10182         the return value of Object.GetType().  [FIXME: we need to do this whenever
10183         we get a type back from the reflection library].
10184
10185 Fri Jun 21 13:37:57 CEST 2002 Paolo Molaro <lupus@ximian.com>
10186
10187         * typemanager.cs: make ExpandInterfaces() slip duplicated interfaces.
10188
10189 2002-06-20  Miguel de Icaza  <miguel@ximian.com>
10190
10191         * attribute.cs: Return null if we can not look up the type.
10192
10193         * class.cs (TypeContainer.GetClassBases): Use ExpandInterfaces on
10194         the interface types found.
10195
10196         * interface.cs (Interface.GetInterfaceBases): Use ExpandInterfaces on the
10197         interface types found.
10198
10199         * typemanager.cs (GetInterfaces): Make this routine returns alll
10200         the interfaces and work around the lame differences between
10201         System.Type and System.Reflection.Emit.TypeBuilder in the results
10202         result for GetInterfaces.
10203
10204         (ExpandInterfaces): Given an array of interface types, expand and
10205         eliminate repeated ocurrences of an interface.  This expands in
10206         context like: IA; IB : IA; IC : IA, IB; the interface "IC" to
10207         be IA, IB, IC.
10208
10209 2002-06-21  Martin Baulig  <martin@gnome.org>
10210
10211         * typemanager.cs (TypeManager.EnumToUnderlying): It's now safe to call this function
10212         on System.Enum.
10213
10214 2002-06-21  Martin Baulig  <martin@gnome.org>
10215
10216         * typemanager.cs (TypeManager.TypeToCoreType): New function.  When compiling corlib
10217         and called with one of the core types, return the corresponding typebuilder for
10218         that type.
10219
10220         * expression.cs (ArrayAccess.DoResolve): Call TypeManager.TypeToCoreType() on the
10221         element type.
10222
10223 2002-06-21  Martin Baulig  <martin@gnome.org>
10224
10225         * ecore.cs (Expression.ExplicitReferenceConversionExists): Use
10226         `target_type.IsArray' instead of `target_type.IsSubclassOf (TypeManager.array_type)'.
10227         (Expression.ConvertReferenceExplicit): Likewise.
10228
10229         * expression.cs (ElementAccess.DoResolve): Likewise.
10230         (ElementAccess.DoResolveLValue): Likewise.
10231
10232 2002-06-10  Martin Baulig  <martin@gnome.org>
10233
10234         * interface.cs (Interface.PopulateIndexer): When creating the setter, we need to
10235         add the "value" parameter to the parameter list.
10236
10237         * statement.cs (Fixed.Emit): Pass the return value of the child block's Emit()
10238         to our caller.
10239
10240 2002-06-19  Miguel de Icaza  <miguel@ximian.com>
10241
10242         * expression.cs (ArrayCreation.ExpressionToArrayArgument): Convert
10243         the argument to an int, uint, long or ulong, per the spec.  Also
10244         catch negative constants in array creation.
10245
10246 Thu Jun 20 17:56:48 CEST 2002 Paolo Molaro <lupus@ximian.com>
10247
10248         * class.cs: do not allow the same interface to appear twice in
10249         the definition list.
10250
10251 Wed Jun 19 22:33:37 CEST 2002 Paolo Molaro <lupus@ximian.com>
10252
10253         * ecore.cs: don't use ldlen with System.Array.
10254
10255 Wed Jun 19 20:57:40 CEST 2002 Paolo Molaro <lupus@ximian.com>
10256
10257         * ecore.cs: stobj requires a type argument. Handle indirect stores on enums.
10258
10259 Wed Jun 19 20:17:59 CEST 2002 Paolo Molaro <lupus@ximian.com>
10260
10261         * modifiers.cs: produce correct field attributes for protected
10262         internal. Easy fix so miguel can work on ther harder stuff:-)
10263
10264 2002-06-18  Miguel de Icaza  <miguel@ximian.com>
10265
10266         * pending.cs: New file.  Move the code from class.cs here.
10267         Support clearning the pending flag for all methods (when not doing
10268         explicit interface implementation).
10269
10270 Tue Jun 18 10:36:22 CEST 2002 Paolo Molaro <lupus@ximian.com>
10271
10272         * rootcontext.cs: added a couple more types needed to bootstrap.
10273
10274 2002-06-17  Miguel de Icaza  <miguel@ximian.com>
10275
10276         * typemanager.cs (GetConstructor): Use DeclaredOnly to look the
10277         constructor in the type, instead of any constructor in the type
10278         hierarchy.  Thanks to Paolo for finding this bug (it showed up as
10279         a bug in the Mono runtime when applying the params attribute). 
10280
10281 2002-06-16  Rafael Teixeira  <rafaelteixeirabr@hotmail.com>
10282         * changed namespace.cs to use "GenericParser.error(...)" instead of "CSharpParser.error(...)"
10283
10284 2002-06-14  Rachel Hestilow  <hestilow@ximian.com>
10285
10286         * expression.cs (Unary.ResolveOperator): Use TypeManager
10287         to resolve the type.
10288
10289 2002-06-13  Ravi Pratap  <ravi@ximian.com>
10290
10291         * cs-parser.jay (enum_member_declaration): Pass in the attributes
10292         attached.
10293
10294         * enum.cs (AddEnumMember): Add support to store the attributes associated 
10295         with each member too.
10296
10297         * attribute.cs (CheckAttribute, ApplyAttributes): Update to handle
10298         field builders too - this takes care of the enum member case.
10299
10300 2002-06-10  Rachel Hestilow  <hestilow@ximian.com>
10301
10302         * typemanager.cs (TypeManager.VerifyUnManaged): Allow
10303         address-of operator on both value types and pointers.
10304
10305 2002-06-10  Martin Baulig  <martin@gnome.org>
10306
10307         * interface.cs (Interface.PopulateIndexer): Add the indexer's
10308         PropertyBuilder to the `property_builders' list.
10309
10310         * expression.cs (Indexers.GetIndexersForTypeOrInterface): New private method.
10311         (Indexers.GetIndexersForType): Call GetIndexersForTypeOrInterface() on the
10312         `lookup_type' and all its interfaces.  Unfortunately, Type.FindMembers() won't
10313         find any indexers which are inherited from an interface.
10314
10315 2002-06-09  Martin Baulig  <martin@gnome.org>
10316
10317         * const.cs (Const.LookupConstantValue): Convert `Expr' to a literal of
10318         the same type as the constant if necessary.  There's also a test-130.cs
10319         for this.
10320
10321         * enum.cs (Enum.ChangeEnumType): Moved to typemanager.cs and made public.
10322
10323         * typemanager.cs (TypeManager.ChangeType): Previously known as
10324         Enum.ChangeEnumType().
10325
10326 2002-06-09  Martin Baulig  <martin@gnome.org>
10327
10328         * expression.cs (Cast.TryReduce): Added support for consts.
10329
10330 2002-06-08  Ravi Pratap  <ravi@ximian.com>
10331
10332         * class.cs (Accessor): Hold attributes information so we can pass
10333         it along.
10334
10335         * cs-parser.jay (get_accessor_declaration, set_accessor_declaration):
10336         Modify to pass in attributes attached to the methods.
10337
10338         (add_accessor_declaration, remove_accessor_declaration): Ditto.
10339
10340         * attribute.cs (ApplyAttributes, CheckAttribute): Update accordingly
10341         to handle the Accessor kind :-)
10342
10343         * class.cs (Property.Emit, Event.Emit): Apply attributes to the accessors
10344
10345 2002-06-08  Martin Baulig  <martin@gnome.org>
10346
10347         * expression.cs (Unary.TryReduceNegative): Added support for
10348         ULongConstants.
10349
10350 2002-06-08  Martin Baulig  <martin@gnome.org>
10351
10352         * enum.cs (Enum.LookupEnumValue): Don't report an error if the
10353         name can't be found in the `defined_names' - the caller will do a
10354         MemberLookup in this case and thus find methods in System.Enum
10355         such as Enum.IsDefined().
10356
10357 2002-06-08  Martin Baulig  <martin@gnome.org>
10358
10359         * enum.cs (Enum.ChangeEnumType): This is a custom version of
10360         Convert.ChangeType() which works with TypeBuilder created types.
10361         (Enum.LookupEnumValue, Enum.Define): Use it here.
10362
10363         * class.cs (TypeContainer.RegisterRequiredImplementations): Added
10364         `TypeBuilder.BaseType != null' check.
10365         (TypeContainer.FindMembers): Only lookup parent members if we
10366         actually have a parent.
10367         (Method.EmitDestructor): Added `ec.ContainerType.BaseType != null' check.
10368         (ConstructorInitializer.Resolve): Likewise.
10369
10370         * interface.cs (Interface.FindMembers): Added
10371         `TypeBuilder.BaseType != null' check.
10372
10373         * rootcontext.cs (RootContext.ResolveCore): Added
10374         "System.Runtime.CompilerServices.IndexerNameAttribute" to
10375         classes_second_stage.
10376
10377         * typemanager.cs (TypeManager.InitCoreTypes): Don't initialize
10378         debug_type and trace_type when compiling with --nostdlib.       
10379
10380 2002-06-07  Martin Baulig  <martin@gnome.org>
10381
10382         * class.cs (TypeContainer): Added `have_nonstatic_fields' field.
10383         (AddField): Set it to true when adding a non-static field.
10384         (DefineType): Use `have_nonstatic_fields' to find out whether we
10385         have non-static fields, not `Fields != null'.
10386
10387 2002-06-02  Miguel de Icaza  <miguel@ximian.com>
10388
10389         * ecore.cs (SimpleNameResolve): Removed simple bug (we were
10390         dereferencing a null on the static-field code path)
10391
10392 2002-05-30  Martin Baulig  <martin@gnome.org>
10393
10394         * codegen.cs (InitMonoSymbolWriter): Added `string[] args' argument
10395         to take command line arguments.  Use reflection to call the new
10396         custom `Initialize' function on the symbol writer and pass it the
10397         command line arguments.
10398
10399         * driver.cs (--debug-args): New command line argument to pass command
10400         line arguments to the symbol writer.
10401
10402 2002-05-28  Miguel de Icaza  <miguel@ximian.com>
10403
10404         * assign.cs (DoResolve): Forgot to do the implicit conversion to
10405         the target type for indexers and properties.  Thanks to Joe for
10406         catching this.
10407
10408 2002-05-27  Miguel de Icaza  <miguel@ximian.com>
10409
10410         * typemanager.cs (MethodFlags): returns the method flags
10411         (Obsolete/ShouldIgnore) that control warning emission and whether
10412         the invocation should be made, or ignored. 
10413
10414         * expression.cs (Invocation.Emit): Remove previous hack, we should
10415         not do this on matching a base type, we should do this based on an attribute
10416
10417         Only emit calls to System.Diagnostics.Debug and
10418         System.Diagnostics.Trace if the TRACE and DEBUG defines are passed
10419         on the command line.
10420
10421         * rootcontext.cs: Global settings for tracing and debugging.
10422
10423         * cs-tokenizer.cs (define): New utility function to track
10424         defines.   Set the global settings for TRACE and DEBUG if found.
10425
10426 2002-05-25  Ravi Pratap  <ravi@ximian.com>
10427
10428         * interface.cs (Populate*): Pass in the TypeContainer as well as
10429         the DeclSpace as parameters so that we can create EmitContexts and
10430         then use that to apply attributes etc.
10431
10432         (PopulateMethod, PopulateEvent, PopulateProperty)
10433         (PopulateIndexer): Apply attributes everywhere.
10434
10435         * attribute.cs (CheckAttribute): Include InterfaceMethod, InterfaceEvent
10436         etc.
10437
10438         (ApplyAttributes): Update accordingly.
10439
10440         We now apply interface attributes for all members too.
10441
10442 2002-05-26  Miguel de Icaza  <miguel@ximian.com>
10443
10444         * class.cs (Indexer.Define); Correctly check if we are explicit
10445         implementation (instead of checking the Name for a ".", we
10446         directly look up if the InterfaceType was specified).
10447
10448         Delay the creation of the PropertyBuilder.
10449
10450         Only create the PropertyBuilder if we are not an explicit
10451         interface implementation.   This means that explicit interface
10452         implementation members do not participate in regular function
10453         lookups, and hence fixes another major ambiguity problem in
10454         overload resolution (that was the visible effect).
10455
10456         (DefineMethod): Return whether we are doing an interface
10457         implementation. 
10458
10459         * typemanager.cs: Temporary hack until we get attributes in
10460         interfaces (Ravi is working on that) and we get IndexerName
10461         support in interfaces.
10462
10463         * interface.cs: Register the indexers as properties.
10464
10465         * attribute.cs (Attribute.Resolve): Catch the error, and emit a
10466         warning, I have verified that this is a bug in the .NET runtime
10467         (JavaScript suffers of the same problem).
10468
10469         * typemanager.cs (MemberLookup): When looking up members for
10470         interfaces, the parent of an interface is the implicit
10471         System.Object (so we succeed in searches of Object methods in an
10472         interface method invocation.  Example:  IEnumerable x;  x.ToString
10473         ()) 
10474
10475 2002-05-25  Miguel de Icaza  <miguel@ximian.com>
10476
10477         * class.cs (Event): Events should also register if they do
10478         implement the methods that an interface requires.
10479
10480         * typemanager.cs (MemberLookup); use the new GetInterfaces
10481         method. 
10482
10483         (GetInterfaces): The code used to lookup interfaces for a type is
10484         used in more than one place, factor it here. 
10485
10486         * driver.cs: Track the errors at the bottom of the file, we kept
10487         on going.
10488
10489         * delegate.cs (NewDelegate.Emit): We have to emit a null as the
10490         instance if the method we are calling is static!
10491
10492 2002-05-24  Miguel de Icaza  <miguel@ximian.com>
10493
10494         * attribute.cs (ApplyAttributes): Make this function filter out
10495         the IndexerName attribute (as that attribute in reality is never
10496         applied) and return the string constant for the IndexerName
10497         attribute. 
10498
10499         * class.cs (TypeContainer.Emit): Validate that all the indexers
10500         have the same IndexerName attribute, and if so, set the
10501         DefaultName attribute on the class. 
10502
10503         * typemanager.cs: The return value might contain other stuff (not
10504         only methods).  For instance, consider a method with an "Item"
10505         property and an Item method.
10506
10507         * class.cs: If there is a problem with the parameter types,
10508         return. 
10509
10510 2002-05-24  Ravi Pratap  <ravi@ximian.com>
10511
10512         * ecore.cs (ImplicitConversionExists): Wrapper function which also
10513         looks at user defined conversion after making a call to 
10514         StandardConversionExists - we need this for overload resolution.
10515
10516         * expression.cs : Update accordingly the various method calls.
10517
10518         This fixes 2 bugs filed against implicit user defined conversions 
10519
10520 2002-05-22  Miguel de Icaza  <miguel@ximian.com>
10521
10522         * statement.cs: Track the result of the assignment.
10523
10524 2002-05-21  Miguel de Icaza  <miguel@ximian.com>
10525
10526         * expression.cs (MemberAccess): Improved error reporting for
10527         inaccessible members.
10528
10529 2002-05-22  Martin Baulig  <martin@gnome.org>
10530
10531         * makefile (mcs-mono2.exe): New target.  This is mcs compiled with
10532         itself with debugging support.
10533
10534 2002-05-22  Martin Baulig  <martin@gnome.org>
10535
10536         * typemanager.cs ("System.Runtime.InteropServices.StructLayoutAttribute"):
10537         Removed, this isn't needed anymore.
10538
10539 2002-05-20  Martin Baulig  <martin@gnome.org>
10540
10541         * typemanager.cs (InitEnumUnderlyingTypes): "System.Char" can't
10542         be underlying type for an enum.
10543
10544 2002-05-20  Miguel de Icaza  <miguel@ximian.com>
10545
10546         * typemanager.cs (InitEnumUnderlyingTypes): New helper function
10547         that splits out the loading of just the core types.
10548
10549         * rootcontext.cs (ResolveCore): Split the struct resolution in
10550         two, so we can load the enumeration underlying types before any
10551         enums are used.
10552
10553         * expression.cs (Is): Bandaid until we fix properly Switch (see
10554         bug #24985 for details).
10555
10556         * typemanager.cs (ImplementsInterface): The hashtable will contain
10557         a null if there are no interfaces implemented.
10558
10559 2002-05-18  Miguel de Icaza  <miguel@ximian.com>
10560
10561         * cs-parser.jay (indexer_declarator): It is fine to have array
10562         parameters
10563
10564 2002-05-17  Miguel de Icaza  <miguel@ximian.com>
10565
10566         * typemanager.cs: (RegisterBuilder): New function used to register
10567         TypeBuilders that implement interfaces.  Since
10568         TypeBuilder.GetInterfaces (as usual) does not work with lame
10569         Reflection.Emit. 
10570         (AddUserType): register interfaces.
10571
10572         (ImplementsInterface): Use the builder_to_ifaces hash if we are
10573         dealing with TypeBuilder.  Also, arrays are showing up as
10574         SymbolTypes, which are not TypeBuilders, but whose GetInterfaces
10575         methods can not be invoked on them!
10576
10577         * ecore.cs (ExplicitReferenceConversionExists): Made public.
10578         (ImplicitReferenceConversionExists): Split out from
10579         StandardConversionExists. 
10580
10581         * expression.cs (As): We were only implementing one of the three
10582         cases for the as operator.  We now implement them all.
10583         (Is): Implement the various other cases for Is as well.
10584
10585         * typemanager.cs (CACHE): New define used to control if we want or
10586         not the FindMembers cache.  Seems to have a negative impact on
10587         performance currently
10588
10589         (MemberLookup): Nested types have full acess to
10590         enclosing type members
10591
10592         Remove code that coped with instance/static returns for events, we
10593         now catch this in RealFindMembers.
10594
10595         (RealFindMembers): only perform static lookup if the instance
10596         lookup did not return a type or an event.  
10597
10598 2002-05-17  Miguel de Icaza  <miguel@ximian.com>
10599
10600         * assign.cs (CompoundAssign): We pass more semantic information
10601         now to Compound Assignments than we did before: now we have all
10602         the information at hand, and now we resolve the target *before* we
10603         do the expression expansion, which allows the "CacheValue" method
10604         to have the effect we intended (before, a [x] += 1 would generate
10605         two differen ArrayAccess expressions from the ElementAccess,
10606         during the resolution process).
10607
10608         (CompoundAssign.DoResolve): Resolve target and original_source here.
10609
10610 2002-05-16  Miguel de Icaza  <miguel@ximian.com>
10611
10612         * expression.cs (ArrayAccess): dropped debugging information. 
10613
10614         * typemanager.cs: Small bug fix: I was always returning i_members,
10615         instead of one of i_members or s_members (depending on which had
10616         the content).
10617
10618         * assign.cs (IAssignMethod.CacheTemporaries): New method.  This
10619         method is invoked before any code generation takes place, and it
10620         is a mechanism to inform that the expression will be invoked more
10621         than once, and that the method should use temporary values to
10622         avoid having side effects
10623
10624         (Assign.Emit): Call CacheTemporaries in the IAssignMethod.
10625
10626         * ecore.cs (Expression.CacheTemporaries): Provide empty default
10627         implementation.
10628
10629         * expression.cs (Indirection, ArrayAccess): Add support for
10630         CacheTemporaries in these two bad boys. 
10631
10632         * ecore.cs (LoadFromPtr): figure out on our own if we need to use
10633         ldobj or ldind_ref.  
10634         (StoreFromPtr): Handle stobj as well.
10635
10636         * expression.cs (UnaryMutator): Share more code.
10637
10638         * typemanager.cs (FindMembers): Thanks to Paolo for tracking this
10639         down: I was not tracking the Filter function as well, which
10640         was affecting the results of the cache.
10641
10642 2002-05-15  Miguel de Icaza  <miguel@ximian.com>
10643
10644         * attribute.cs: Remove the hack to handle the CharSet property on
10645         StructLayouts. 
10646
10647 2002-05-14  Miguel de Icaza  <miguel@ximian.com>
10648
10649         * attribute.cs (DoResolve): More uglyness, we now only try to
10650         resolve the attribute partially, to extract the CharSet
10651         information (only if we are a StructLayout attribute).  Otherwise 
10652
10653         (GetExtraTypeInfo): Add some code to conditionally kill in the
10654         future this.   I am more and more convinced that the .NET
10655         framework has special code to handle the attribute setting on
10656         certain elements.
10657
10658         * expression.cs (IsParamsMethodApplicable): Revert my previous
10659         foreach change here, it was wrong.
10660
10661 2002-05-13  Miguel de Icaza  <miguel@ximian.com>
10662
10663         * cs-tokenizer.cs: (pp_primary): Eat the ')' at the end.
10664         (pp_expr): do not abort on unknown input, just return.
10665         (eval): abort if there are pending chars.
10666
10667         * attribute.cs (Attribute.Resolve): Positional parameters are
10668         optional.  Deal with that case.
10669
10670         * class.cs (DefineType): Call Attribute.GetExtraTypeInfo to fetch
10671         the Ansi/Unicode/Auto information for the type.
10672
10673         (TypeContainer.DefineType): instantiate the EmitContext here, as
10674         we will be using it during the type definition (to resolve
10675         attributes) and during the emit phase.
10676
10677         * attribute.cs (Attribute.GetExtraTypeInfo): This routine is used
10678         to pull type information out of the attributes
10679
10680         (Attribute.Resolve): track the constructor builder, and allow for
10681         multiple invocations (structs and classes will use this).
10682
10683         * ecore.cs (MemberLookupFinal): new version with all the
10684         parameters customizable.
10685
10686         * expression.cs (New.DoResolve): Use MemberLookupFinal to locate
10687         constructors.  Return if the result value is null (as the error
10688         would have been flagged already by MemberLookupFinal)
10689
10690         Do not allow instances of abstract classes or interfaces to be
10691         created.
10692
10693         * class.cs: (MethodSignature.InheritableMemberSignatureCompare):
10694         We have to compare the assembly property here when dealing with
10695         FamANDAssem and Assembly access modifiers, because we might be
10696         creating an assembly from *modules* (that means that we are not
10697         getting TypeBuilders for types defined in other modules that are
10698         part of this assembly).
10699
10700         (Method.Emit): If the method is marked abstract and has a body,
10701         emit an error. 
10702
10703         (TypeContainer.DefineMembers): If both the defined member and the
10704         parent name match are methods, then do not emit any warnings: let
10705         the Method.Define routine take care of flagging warnings.  But if
10706         there is a mismatch (method overrides something else, or method is
10707         overriwritten by something, then emit warning).
10708
10709         (MethodSignature.MemberSignatureCompare): If the sig.ret_type is
10710         set to null, this means `do not check for the return type on the
10711         signature'. 
10712
10713         (Method.Define): set the return type for the method signature to
10714         null, so that we get methods with the same name and parameters and
10715         different return types.  This is used to flag warning 114 (you are
10716         hiding a method, and you probably want to use the new/override
10717         keywords instead).
10718
10719         * typemanager.cs (MemberLookup): Implemented proper access
10720         control, closing a long standing set of bug reports.  The problem
10721         was that the Framework only has two bits: Public and NonPublic,
10722         and NonPublic includes private and protected methods, but we need
10723         to enforce the FamANDAssem, FamOrAssem and Family. 
10724
10725 2002-05-11  Miguel de Icaza  <miguel@ximian.com>
10726
10727         * statement.cs (GotoCase): Return true: Ammounts to giving up
10728         knowledge on whether we return or not, and letting the other case
10729         be responsible for it.
10730
10731 2002-05-10  Miguel de Icaza  <miguel@ximian.com>
10732
10733         * driver.cs: Do not load directories for each file processed, only
10734         do it if there is a pattern.
10735
10736         * ecore.cs: Report readonly assigns here as well, as we might have
10737         been resolved only by MemberAccess.
10738
10739         (SimpleName.SimpleNameResolve): Also be useful for LValue
10740         resolution.   We need this to propagate assign to local readonly variables
10741
10742         * typemanager.cs: Use a ptrhashtable for the criteria, because we
10743         do not want to reuse potential criteria memory.
10744
10745         * class.cs (MyEventBuilder): Set reflected_type;
10746
10747         * ecore.cs (Constantify): Added support for constifying bools.
10748
10749         (RootContext.LookupType): Added a cache for values looked up in
10750         the declaration space.
10751
10752         * typemanager.cs (FindMembers): Now is a front-end to
10753         RealFindMembers, and provides a two-level hashtable-based cache to
10754         the request.  
10755
10756         15% performance improvement: from 22.5 to 19.2 seconds.
10757
10758         * expression.cs (IsParamsMethodApplicable): use foreach.
10759         (Invocation.DoResolve): ditto.
10760         (New.DoResolve): ditto.
10761         (ArrayCreation.DoResolve): ditto.
10762
10763         * ecore.cs (FindMostEncompassingType): use foreach.
10764
10765         * delegate.cs (NewDelegate.DoResolve): Use foreach
10766
10767         * ecore.cs (Expression.FindMostSpecificSource): Use foreach.
10768         (RemoveMethods): use foreach.
10769
10770         * expression.cs (Invocation.MakeUnionSet): Optimization: Use two
10771         nested foreach statements instead of for, and also break out of
10772         the inner loop once a match is found.
10773
10774         (Invocation.OverloadResolve): Use foreach, simplify the code. 
10775
10776 2002-05-08  Miguel de Icaza  <miguel@ximian.com>
10777
10778         * cfold.cs (BinaryFold): During an enumeration evaluation context,
10779         we actually unwrap the expression to allow for extra information
10780         to be extracted. 
10781
10782         * expression.cs: Use Shr_Un on unsigned operations. 
10783
10784 2002-05-08  Ravi Pratap  <ravi@ximian.com>
10785
10786         * ecore.cs (FindMostEncompass*): Fix trivial bug where the set of 
10787         applicable operators was not being considered correctly. This closes
10788         the bug Miguel reported.
10789
10790 Wed May 8 16:40:50 CEST 2002 Paolo Molaro <lupus@ximian.com>
10791
10792         * attribute.cs: check that the type derives from System.Attribute
10793         and report the correct error in that case (moved the duplicate code to
10794         its own method, too).
10795
10796 Wed May 8 11:50:31 CEST 2002 Paolo Molaro <lupus@ximian.com>
10797
10798         * attribute.cs: lookup attribute type name as the spec says: first the
10799         bare attribute name and then name + "Attribute" (nant compiles with
10800         mcs after this fix).
10801
10802 2002-05-07  Miguel de Icaza  <miguel@ximian.com>
10803
10804         * expression.cs (Unary.TryReduceNegative): Ah!  Tricky!  Tricky!
10805         Because of the way we parse things, we should try to see if a
10806         UIntConstant can fit in an integer.
10807
10808 2002-05-07  Ravi Pratap  <ravi@ximian.com>
10809
10810         * ecore.cs (GetConversionOperators): Do not pick up op_True operators
10811         when we are in an explicit context.
10812
10813         (ConvertReferenceExplicit): When converting from Iface type S to Class
10814         T make sure the rules are implemented as an OR.
10815
10816         * parameter.cs (ParameterType): Make it a property for now although the
10817         purpose really isn't anything immediate.
10818
10819         * expression.cs (Is*Applicable): Do better checking on the parameter type
10820         of a ref/out parameter. The ones from the system assemblies are already 
10821         marked with the correct type so we don't need to do any correction.
10822
10823         * ecore.cs (StandardConversionExists): Conversion from Interface types to 
10824         the object type is standard too so include that.
10825
10826 2002-05-06  Miguel de Icaza  <miguel@ximian.com>
10827
10828         * ecore.cs (StandardConversionExists): Augment with missing code:
10829         deal with IntConstant, LongConstants and Enumerations.
10830
10831         * assign.cs: Report the error, instead of failing silently
10832
10833         * rootcontext.cs (AddGlobalAttributes): Track attributes on the
10834         typecontainer that they are declared, because the
10835         typecontainer/namespace will have the list of using clauses that
10836         need to be applied.
10837
10838         Assembly Attributes were escaping the normal registration
10839         mechanism. 
10840
10841         (EmitCode): Apply attributes within an EmitContext that represents
10842         the container they were declared on.
10843
10844         * cs-parser.jay: Track bases for structs.  How did I get this wrong?
10845
10846 2002-05-06  Ravi Pratap  <ravi@ximian.com>
10847
10848         * ecore.cs (FindMostEncompassingType, FindMostEncompassedType):
10849         Revamp completely - make much cleaner as we now operate only
10850         on a set of Types.
10851
10852         (FindMostSpecificSource, FindMostSpecificTarget): New methods
10853         to implement the logic detailed in the spec more correctly.
10854
10855         (UserDefinedConversion): Update accordingly.
10856
10857 2002-05-06  Miguel de Icaza  <miguel@ximian.com>
10858
10859         * statement.cs: Return flow analysis information up.
10860
10861         * cs-tokenizer.cs (adjust_real): Share code between LITERAL_DOUBLE
10862         and the default.
10863
10864         (token): Do not consume an extra character before calling
10865         decimal_digits.
10866
10867 2002-05-06  Piers Haken <piersh@friskit.com>
10868
10869         * cs-parser.jay: add 'override' attribute to System.Object.Finalize
10870
10871 2002-05-06  Miguel de Icaza  <miguel@ximian.com>
10872
10873         * class.cs (Constructor.Emit): Set the IsStatic flag in the
10874         EmitContext during the instance constructor initializer
10875         resolution, to stop access to instance variables.
10876
10877         This is mandated by the spec, last paragraph of the `constructor
10878         initializers' section. 
10879
10880 2002-05-05  Miguel de Icaza  <miguel@ximian.com>
10881
10882         * cs-parser.jay, class.cs (Accessor): new class used to represent
10883         an accessor (get or set).  In the past we used `null' to represent
10884         a missing accessor.  But this is ambiguous because there was no
10885         way to tell in abstract indexers/properties if one of them was
10886         specified.
10887
10888         Now there is a way of addressing that.
10889
10890         * expression.cs (Indexers.GetIndexersForType): Use TypeManager.MemberLookup
10891         instead of FindMembers.
10892
10893         * class.cs (TypeContainer.EmitFieldInitializer): Do not typecast
10894         the result of Assign.Resolve as Assign, but rather as ExpressionStatement.
10895
10896         * attribute.cs: Treat indexers and properties as the same in terms
10897         of applying attributes
10898
10899         * ecore.cs (FindMostEncompassedType): Use statically initialized
10900         EmptyExpressions()s like we do elsewhere to avoid creating useless
10901         objects (and we take this out of the tight loop).
10902
10903         (GetConversionOperators): Move the code to extract the actual
10904         operators to a separate routine to clean things up.
10905
10906 2002-05-04  Miguel de Icaza  <miguel@ximian.com>
10907
10908         * ecore.cs (FieldExpr): Remove un-needed tests for null, since now
10909         events are always registered FieldBuilders.
10910
10911         * class.cs (FieldBase): New class shared by Fields 
10912
10913         * delegate.cs: If we are a toplevel delegate, use our full name.
10914         If we are a nested delegate, then only use our tail name.
10915
10916 2002-05-02  Ravi Pratap  <ravi@ximian.com>
10917
10918         * expression.cs (IsApplicable): Ensure that we add the "&" to
10919         ref/out types before comparing it with the type of the argument.
10920
10921         (IsParamsMethodApplicable): Ditto.
10922
10923         (Argument.Type): Use TypeManager.LookupType instead of Type.GetType - 
10924         silly me ;-)
10925
10926         * delegate.cs : Handle the case when we have more than one applicable
10927         method. Flag an error only when we finish checking all.
10928
10929 2002-05-02  Miguel de Icaza  <miguel@ximian.com>
10930
10931         * expression.cs: Add support for boolean static initializers.
10932
10933 2002-05-01  Miguel de Icaza  <miguel@ximian.com>
10934
10935         * attribute.cs: Use proper cast for Events, since we use a MyEventBuilder.
10936
10937         * parameter.cs (ComputeParameterTypes,
10938         ComputeAndDefineParameterTypes): Better error handling: now we
10939         clear the `types' cache if we fail during any of the type lookups.
10940         We also return the status code correctly to our caller
10941
10942         * delegate.cs: If we fail to define a delegate, abort the extra
10943         steps. 
10944
10945         * expression.cs (Binary.ResolveOperator): for
10946         operator==(object,object) and operator !=(object, object) we also
10947         have to verify that there is an implicit conversion from one to
10948         the other.
10949
10950         (ArrayAccess.DoResolve): Array Access can operate on
10951         non-variables. 
10952
10953 2002-04-30  Miguel de Icaza  <miguel@ximian.com>
10954
10955         * assign.cs (CompoundAssign): A new class used as a "flag" that
10956         the assignment actually is happening as part of a compound
10957         assignment operator.
10958
10959         During compound assignment, a few new rules exist to enable things
10960         like:
10961
10962         byte b |= 1 + 2
10963
10964         From the spec:
10965
10966         x op= y can be evaluated as x = (T) (x op y) (ie, an explicit cast
10967         to the type of x) if y is implicitly convertible to the type of x,
10968         and the operator is a builtin operator and the return type of the
10969         operator is explicitly convertible to the type of x. 
10970
10971         * rootcontext.cs: Reset warning level to 2.  4 catches various
10972         "interesting" features in mcs, we must clean this up at some
10973         point, but currently am trying to kill other bugs ;-)
10974
10975         * ecore.cs (SimpleName.SimpleNameResolve): Perform member lookups
10976         in container classes as well.  
10977
10978         * expression.cs (Binary.ResolveOperator): Handle string case
10979         before anything else (as operator overloading does emit an error
10980         before doing anything else).
10981
10982         This code could go away when we move to a table driven model, but
10983         i could not come up with a good plan last night.
10984
10985 2002-04-30  Lawrence Pit <loz@cable.a2000.nl>
10986
10987         * typemanager.cs (CSharpName): reimplementation using regex.
10988         * class.cs: added null check for fields in Emit
10989         * rootcontext.cs: set warninglevel to 4
10990
10991 2002-04-29  Miguel de Icaza  <miguel@ximian.com>
10992
10993         * typemanager.cs (CSharpName): reimplemented with Lupus
10994         suggestion.
10995
10996 2002-04-28  Miguel de Icaza  <miguel@ximian.com>
10997
10998         * statement.cs (If): correclty implement Resolve, because we were
10999         not catching sem errors in there.  The same process is needed
11000         everywhere else. 
11001         (Return, StatementExpression, For, While, Do, Throw, Lock): Implement Resolve
11002
11003
11004         (Statement.Warning_DeadCodeFound): Factorize code.
11005         (While): Report dead code here too.
11006
11007         (Statement): Added Resolve virtual method to allow
11008         for resolution split from the emit code.
11009
11010 2002-04-26  Miguel de Icaza  <miguel@ximian.com>
11011
11012         * statement.cs (EmitBoolExpression): No longer try to resolve the
11013         expression here.    
11014         (MakeBoolean): New utility function that resolve, implicitly
11015         converts to boolean and tags the expression. 
11016
11017
11018         (If, Do): Implement dead code elimination.
11019         (While): Implement loop inversion
11020
11021         (Do, While, For, If): Resolve the expression prior to calling our
11022         code generation.
11023
11024 2002-04-22  Lawrence Pit <loz@cable.a2000.nl>
11025
11026         * class.cs:
11027           - added method Report28 (warning: program has more than one entry point)
11028           - added method IsEntryPoint, implements paragraph 10.1 of the spec
11029           - modified method Method.Define, the part at the end of the method
11030
11031         * rootcontext.cs: added static public Location EntryPointLocation;
11032           
11033         * ../errors/cs0028.cs : Add test case for the above warning.              
11034
11035         * typemanager.cs:
11036           - modified method CSharpName to allow arrays of primitive type to
11037             be printed nicely (e.g. instead of System.Int32[][] it now prints
11038             int[][])
11039           - added method CSharpSignature: returns the signature of a method
11040             in string format to be used in reporting errors, warnings, etc.
11041
11042         * support.cs: InternalParameters.ParameterDesc variable tmp initialized
11043         with String.Empty.
11044
11045 2002-04-26  Ravi Pratap  <ravi@ximian.com>
11046
11047         * delegate.cs (Define): Fix extremely silly bug where I was
11048         setting the type of the 'object' parameter of the BeginInvoke
11049         method to System.IAsyncResult instead of System.Object ;-)
11050
11051 2002-04-26  Miguel de Icaza  <miguel@ximian.com>
11052
11053         * class.cs (ConstructorInitializer.Resolve): Also use DeclaredOnly
11054         here. 
11055
11056         (Constructor.Emit): return if we fail to initialize the
11057         constructor.  Another door closed!  
11058
11059         * expression.cs (New.DoResolve): Improve error message (from -6 to
11060         1501).  Use DeclaredOnly lookup to find the exact constructor.
11061
11062         * typemanager.cs (MemberLookup): If DeclaredOnly is set, do not
11063         loop.  This is useful.
11064
11065         * cs-parser.jay: Adjust the default parameters so that destructors
11066         have the proper signature.
11067
11068 2002-04-26  Martin Baulig  <martin@gnome.org>
11069
11070         * driver.cs (LoadAssembly): If `assembly' contains any characters
11071         which are only valid in path names and not in assembly names
11072         (currently slash, backslash and point), use Assembly.LoadFrom ()
11073         instead of Assembly.Load () on the `assembly' (before iteration
11074         over the link_paths).
11075
11076 2002-04-26  Martin Baulig  <martin@gnome.org>
11077
11078         * cs-tokenizer.cs (is_hex): Correctly handle lowercase chars.
11079
11080 2002-04-25  Miguel de Icaza  <miguel@ximian.com>
11081
11082         * class.cs (Property): use the new typemanager.MemberLookup
11083
11084         (TypeContainer.MemberLookup): Implement using the
11085         TypeManager.MemberLookup now. 
11086
11087         * typemanager.cs: Make MemberLookup a function of the TypeManager,
11088         and return MemberInfos, so that these can be used without an
11089         EmitContext (what we had before).
11090
11091 2002-04-24  Miguel de Icaza  <miguel@ximian.com>
11092
11093         * expression.cs: Fix the case where the argument to params if the
11094         type of the params.  I omitted handling this before.   Fixed
11095
11096 2002-04-22  Miguel de Icaza  <miguel@ximian.com>
11097
11098         * driver.cs: Call BootCorlib_PopulateCoreType
11099
11100         * class.cs (Property.CheckBase): Check for properties only, not
11101         for all members. 
11102
11103         * interface.cs: Temporary hack: try/catch around the
11104         CustomAttributeBuilder, because I am getting an exception that I
11105         do not understand.
11106
11107         * rootcontext.cs (BootCorlib_PopulateCoreType): Populate some
11108         types whose definitions are required to be there (attributes are
11109         defined before standard types).
11110
11111         Compute definitions as we boot the various types, as they are used
11112         immediately (value_type class will need object_type, but if we do
11113         not initialize object_type, we will pass a null, which will let
11114         the runtime pick the System.Object from the existing corlib, which
11115         is not what we want).
11116
11117 2002-04-22  Patrik Torstensson <totte@labs2.com>
11118
11119         * cs-tokenizer.cs: fixed a number of trim() issues.
11120
11121 2002-04-22  Ravi Pratap  <ravi@ximian.com>
11122
11123         * expression.cs (Argument.Type): Ensure that we return the correct
11124         type when we have out or ref parameters [in which case we 
11125         append a "&"].
11126
11127 2002-04-22  Miguel de Icaza  <miguel@ximian.com>
11128
11129         * class.cs (Property, Indexer): Allow extern modifier in there. 
11130
11131         * typemanager.cs (InitBaseTypes): Initializes object_type and
11132         value_type, since those will be used early on during the bootstrap
11133         process to compile corlib.
11134
11135         (InitCoreTypes): Move code from here to InitBaseTypes.
11136
11137 2002-04-21  Miguel de Icaza  <miguel@ximian.com>
11138
11139         * ecore.cs (PropertyExpr): Optimize calls to Array::get_Length on
11140         single-dimension arrays as using the ldlen opcode.  
11141
11142         Daniel Lewis discovered this optimization.  
11143
11144         * typemanager.cs: Add signature for System.Array::get_Length
11145
11146 2002-04-20  Gonzalo Paniagua Javier <gonzalo@ximian.com>
11147
11148         * statement.cs: report the error when the foreach does not apply to an
11149         array nor a collection.
11150
11151 2002-04-19  Miguel de Icaza  <miguel@ximian.com>
11152
11153         * expression.cs: Add implicit conversions to the operator ~.
11154
11155         * constant.cs (DecimalConstant.Emit): Emit decimal value.
11156
11157         * typemanager.cs: Locate the decimal constructor.
11158
11159 2002-04-17  Gonzalo Paniagua Javier <gonzalo@ximian.com>
11160
11161         * attribute.cs: use the new property of TypeOf.
11162         * expression.cs: added 'get' property around typearg.
11163
11164         These changes fix a build breaker reported by NickD. Is this the
11165         correct way to fix?  If not, please, revert my changes and make it
11166         work :-).
11167
11168 2002-04-17  Miguel de Icaza  <miguel@ximian.com>
11169
11170         * attribute.cs: Add support for typeof in attribute invocations.
11171         I am not sure that this is right though.
11172
11173 2002-04-14  Duncan Mak  <duncan@ximian.com>
11174
11175         * cfold.cs (BinaryFold): Catch DivideByZeroException in the
11176         Binary.Operator.Division case.
11177
11178 2002-04-13  Ravi Pratap  <ravi@ximian.com>
11179
11180         * class.cs (DefineType): Ensure that we do a proper check on
11181         attribute types and also register it with the TypeManager.
11182
11183         (TypeContainer.Targets): The default for attribute types is
11184         AttributeTargets.All.
11185
11186         * attribute.cs (ApplyAttributes): Registering the attribute type
11187         is done elsewhere, not when we discover we have a Usage attribute.
11188
11189 2002-04-12  Ravi Pratap  <ravi@ximian.com>
11190
11191         * expression.cs (VerifyArgumentsCompat): Implement Miguel's suggestion
11192         and get rid of is_delegate parameter.
11193
11194         * everywhere : update.
11195
11196 2002-04-12  Ravi Pratap  <ravi@ximian.com>
11197
11198         * cs-parser.jay (compilation_unit): Revamp completely to use
11199         some new ideas that I got from Rhys' grammar to solve the problems
11200         with assembly level attributes.
11201
11202         (outer_declaration): New grammar production.
11203
11204         (attribute_sections): Add.
11205
11206         (opt_attributes): Base on attribute_sections
11207
11208         (namespace_declaration): Allow opt_attributes to tackle the case
11209         when we have assembly level attributes - we are clever in this
11210         regard now ;-)
11211
11212         * attribute.cs (ApplyAttributes): Do not worry about assembly 
11213         attributes in the non-global context.
11214
11215         * rootcontext.cs (AddGlobalAttributes): Go back to using this
11216         instead of SetGlobalAttributes.
11217
11218         * class.cs, rootcontext.cs : Ensure we define and generate 
11219         attribute types before anything else.
11220
11221         * attribute.cs (CheckAttribute and GetValidPlaces): Handle the exception
11222         and flag the new error -20 for the case when the attribute type
11223         does not have valid targets specified. csc does not catch this.
11224
11225         * ../errors/errors.txt : update for error # -20
11226
11227 2002-04-11  Ravi Pratap  <ravi@ximian.com>
11228
11229         * support.cs (InternalParameters.ParameterModifier): Do some null
11230         checking and return sane values.
11231
11232         * class.cs (Method.Define): If we are a PInvoke method, ensure
11233         that we are static and extern. Report error # 601
11234
11235         * ../errors/cs0601.cs : Add test case for the above error.
11236
11237 2002-04-07  Ravi Pratap  <ravi@ximian.com>
11238
11239         * rootcontext.cs (attribute_types): We need to keep type of
11240         all attribute types separately and emit code for them first.
11241
11242         (RegisterAttribute) : Implement.
11243
11244         * class.cs (DefineType): Check if the current Type is a custom
11245         attribute type and register it accordingly.
11246
11247         * rootcontext.cs (AddGlobalAttributes): Fix silly bug where we were
11248         adding the first attribute twice and rename to
11249
11250         (SetGlobalAttributes): this.
11251
11252         * rootcontext.cs (NamespaceLookup): Run through the aliases too and perform
11253         lookups.
11254
11255         * attribute.cs (ApplyAttributes): Take an additional argument telling us
11256         if we are processing global arguments. Hmm, I am unsure of this.
11257
11258 2002-04-12  Gonzalo Paniagua Javier <gonzalo@ximian.com>
11259
11260         * expression.cs: added static array of strings to avoid calling
11261         Enum.ToString () for Operator in Binary. Significant recover of
11262         performance.
11263
11264 2002-04-10  Miguel de Icaza  <miguel@ximian.com>
11265
11266         * class.cs (FindMembers): Allow the Builders of the various
11267         members to be null.  If they are skip them.  This only happens
11268         during the PInvoke declaration.
11269
11270 2002-04-09  Miguel de Icaza  <miguel@ximian.com>
11271
11272         * parameter.cs (Parameters.ComputeParameterTypes): Flag the
11273         failure, so we do not keep going afterwards.
11274
11275         * expression.cs: (Invocation.OverloadResolve): I believe Ravi
11276         wanted to pass `false' as the `is_delegate' argument.  If this is
11277         the case, why not use delegate_type == null to mean `is_delegate =
11278         false' and anything else as is_delegate = true.
11279
11280 Tue Apr  9 05:40:12  2002 Piers Haken <piersh@friskit.com>
11281
11282         * statement.cs: fixed SimpleSwitchEmit to make 'goto case' goto the
11283         code for the section, not the beginning of the tests.
11284
11285 2002-04-08  Miguel de Icaza  <miguel@ximian.com>
11286
11287         * cfold.cs: Handle operator + (Enum x, Underlying x) 
11288
11289         * expression.cs (Binary): same.  Warn about errors where we have
11290         Enum/Enum in operator + as well.
11291
11292 Mon Apr  8 06:29:03  2002 Piers Haken <piersh@friskit.com>
11293
11294         * statement.cs:
11295                 - added support for switch(bool)
11296                 - optimize loading of I8/U8 constants (ldc.i4, iconv_i8)
11297                 - add TableSwitchEmit() to handle table-based switch statements
11298
11299 2002-04-05  Ravi Pratap  <ravi@ximian.com>
11300
11301         * expression.cs (Invocation.OverloadResolve): Factor out code which
11302         does parameter compatibility checking with arguments so that we can 
11303         re-use the code even from Delegate.VerifyApplicability
11304
11305         (VerifyArgumentsCompat): Move above code here.
11306
11307         * delegate.cs (VerifyApplicability): Get rid of duplicate code
11308         and instead make a call to the above method.
11309
11310 2002-03-31  Ravi Pratap  <ravi@ximian.com>
11311
11312         * typemanager.cs (attribute_type): Corresponds to System.Attribute.
11313         We use it to keep track of classes which are attribute types.
11314
11315 2002-04-02  Miguel de Icaza  <miguel@ximian.com>
11316
11317         * delegate.cs (Delegate.Define): Correctly define the types in the
11318         presence of fixed and array parameters.
11319
11320         * class.cs (TypeContainers.FindMembers): Use NonPublic flag while
11321         doing FindMembers.
11322
11323         * ecore.cs (Expression.MemberLookup): Reset binding flags to not
11324         include NonPublic after the first iteration.
11325
11326         * class.cs (Indexer.CheckBase): Only check if both parents are
11327         non-null. 
11328
11329         * cs-parser.jay (accessor_body): If empty, set to null.
11330
11331         * ecore.cs (SimpleName.SimpleNameResolve): We did not have the
11332         same code path here to resolve constants names that we did have in
11333         MemberAccess.DoResolve.  There is too much code duplicated here.
11334
11335 2002-04-01  Miguel de Icaza  <miguel@ximian.com>
11336
11337         * statement.cs, makefile: Drop Statementcollection and just use ArrayLists
11338
11339         * ecore.cs: Optimize UserDefinedConversion by minimizing the calls
11340         to MakeUnionSet.
11341
11342         * cs-tokenizer.cs: Reuse a single StringBuilder for assembling
11343         tokens, numbers and strings.
11344
11345         * ecore.cs (MethodGroupExpr): Make Emit warn about missing
11346         parenthesis.
11347
11348         * delegate.cs: Use ComputeAndDefineParameterTypes for both the
11349         asyncronous parameters and the regular parameters.  
11350
11351         * codegen.cs (CodeGen.Init): Use the constructor that allows us to
11352         specify the target directory.
11353
11354         * expression.cs: (This.DoResolve): Simplify
11355         (As.Emit): Optimize, do not generate IsInst if the expression is
11356         always of the given type.
11357
11358         (Is.DoResolve): Bug fix, we were reporting both always/never for
11359         the is expression.
11360
11361         * (Invocation.MakeUnionSet): Simplify vastly and optimize, we were
11362         creating too many unnecessary arrays.
11363
11364 2002-03-31  Miguel de Icaza  <miguel@ximian.com>
11365
11366         * class.cs (EmitFieldInitializer): Use Assign expression to assign
11367         fields instead of rolling our own initializer.   Takes care of all
11368         implicit conversions, and drops unnecessary static checks/argument.
11369
11370 2002-03-31  Dick Porter  <dick@ximian.com>
11371
11372         * driver.cs: use the GetDirectories() return values properly, and
11373         use "/" as path separator.
11374
11375 2002-03-30  Miguel de Icaza  <miguel@ximian.com>
11376
11377         * expression.cs (Unary): Optimize - - expr into expr.
11378         (Binary): Optimize a + (-b) into a -b.
11379
11380         * codegen.cs (CodeGen): Made all methods static.
11381
11382 2002-03-29  Miguel de Icaza  <miguel@ximian.com>
11383
11384         * rootcontext.cs: 
11385
11386         * decl.cs: Rename `definition' into `TypeBuilder' and drop the
11387         TypeBuilder property.
11388
11389         * cs-parser.jay: Drop the use of RecordXXX and use RecordDecl
11390         instead. 
11391
11392         * tree.cs: Removed the various RecordXXXX, and replaced with a
11393         single RecordDecl.  Removed all the accessor methods, and just
11394         left a single access point Type 
11395
11396         * enum.cs: Rename DefineEnum to DefineType.
11397
11398         * decl.cs: New abstract method `DefineType' used to unify the
11399         Defines for Enumerations, Interfaces, TypeContainers and
11400         Delegates.
11401
11402         (FindType): Moved LookupInterfaceOrClass here.  Moved the
11403         LookupBaseClasses method that used to live in class.cs and
11404         interface.cs here, and renamed to FindType.
11405
11406         * delegate.cs: Implement DefineType.  Take advantage of the
11407         refactored pattern for locating the parent builder without taking
11408         the parent_builder argument (which we know does not work if we are
11409         nested, and triggering a toplevel definition).
11410
11411 2002-03-28  Miguel de Icaza  <miguel@ximian.com>
11412
11413         * decl.cs (MemberCore.CheckMethodAgainstBase): Test if the
11414         accessibility of a member has changed during override and report
11415         an error if so.
11416
11417         * class.cs (Method.Define, Property.Define): Only complain on
11418         overrides if the method is private, any other accessibility is
11419         fine (and since we just checked the permission is the same, we are
11420         good to go).
11421
11422         * cs-tokenizer.cs: only line, region, endregion, if, endif, else
11423         and elif are processed always.  The other pre-processing
11424         directives are only processed if we are "taking" the path
11425
11426 2002-03-29  Martin Baulig  <martin@gnome.org>
11427
11428         * class.cs (Method.Emit): Only emit symbolic debugging info if the
11429         current location is not Null.
11430
11431         * codegen.cs (CodeGen.SaveSymbols): Split out symbol writing code into
11432         a separate method so we can profile it.
11433
11434         * driver.cs (ShowTime): We need to use `(int) span.TotalSeconds' since
11435         `span.Seconds' are just seconds, but no minutes or hours.
11436         (MainDriver): Profile the CodeGen.SaveSymbols calls.
11437
11438 2002-03-28  Miguel de Icaza  <miguel@ximian.com>
11439
11440         * class.cs (Method.Define), (Property.Define), (Indexer.Define):
11441         Remove the gratuitous set of Final:
11442
11443                                 // If an interface implementation, then we can set Final.
11444                                 if (((flags & MethodAttributes.Abstract) == 0) &&
11445                                     implementing.DeclaringType.IsInterface)
11446                                         flags |= MethodAttributes.Final;
11447
11448         I do not know what I was smoking when I used that.
11449
11450
11451         * cs-parser.jay, delegate.cs: Make Delegate be a DeclSpace, first
11452         step into fixing the name resolution issues for delegates and
11453         unifying the toplevel name resolution.
11454
11455 2002-03-28  Martin Baulig  <martin@gnome.org>
11456
11457         * class.cs (Method.Emit): If we have a symbol writer, call its
11458         OpenMethod(), CloseMethod() and SetMethodSourceRange() methods to
11459         tell it about the current method.
11460
11461         * codegen.cs (EmitContext.Mark): New public method. Tell the symbol
11462         writer that we're going to emit the first byte of IL code for a new
11463         statement (a new source line).
11464         (EmitContext.EmitTopBlock): If we have a symbol writer, call
11465         EmitContext.Mark() before emitting any code.
11466
11467         * location.cs (SymbolDocument): Return null when we're Null.
11468
11469         * statement.cs (Statement): Moved the `Location loc' variable here.
11470         (Statement.EmitBoolExpression): If we have a symbol writer, call
11471         ec.Mark() before emitting any code to tell it that we're at the
11472         beginning of a new statement.
11473         (StatementExpression): Added `Location' argument to the constructor.
11474         (Block): Added public readonly variable `StartLocation' and public
11475         variable `EndLocation'.  The latter is to be set using SetEndLocation().
11476         (Block): Added constructor which takes a start and end location.
11477         (Block.SetEndLocation): New method. This sets the end location.
11478         (Block.EmitMeta): If we have a symbol writer, tell it the names of the
11479         local variables we create.
11480         (Block.Emit): If we have a symbol writer, call ec.Mark() before emitting
11481         each statement and do also mark the begin and end of the block.
11482
11483         * cs-parser.jay (block : OPEN_BRACE): Use the new `Block' constructor to
11484         tell it the current lexer.Location, use Location.Null for the end of the
11485         block.
11486         (block : OPEN_BRACE opt_statement_list CLOSE_BRACE): When closing the
11487         current block, set its end location using SetEndLocation().
11488         (statement_expression): StatementExpression constructor now takes the
11489         lexer.Location as additional argument.
11490         (for_statement, declare_local_variables): Likewise.
11491         (declare_local_variables): When creating a new implicit block, use the
11492         new Block constructor and pass it the lexer.Location.
11493
11494 2002-03-28  Miguel de Icaza  <miguel@ximian.com>
11495
11496         * ecore.cs (Expression.MemberLookup): On interfaces, lookup
11497         members also on the parent interfaces recursively.
11498
11499 2002-03-27  Miguel de Icaza  <miguel@ximian.com>
11500
11501         * report.cs: Use new formats, since Gonzalo finished the missing
11502         bits. 
11503
11504         * expression.cs (Binary.ResolveOperator): added missing operator|
11505         operator& and operator^ for bool/bool.
11506
11507         * cs-parser.jay: CheckDef now takes a Location argument that is
11508         used to report errors more precisly (instead of reporting the end
11509         of a definition, we try to track something which is a lot closer
11510         to the source of the problem).
11511
11512         * cs-tokenizer.cs: Track global token use, so we can properly flag
11513         the use of #define/#undef after the first token has been seen.
11514
11515         Also, rename the reportXXXX to Error_DescriptiveName
11516
11517         * decl.cs (DeclSpace.IsTopLevel): Move property here from
11518         TypeContainer, so that Enum and Interface can use this too.
11519
11520         * class.cs (TypeContainer.LookupInterfaceOrClass,
11521         GetInterfaceOrClass, GetClassBases, DefineType): Drop the
11522         `builder' argument.  Typically this was used to pass the parent
11523         builder (a ModuleBuilder or a TypeBuilder from whoever triggered
11524         the definition).  
11525
11526         The problem is that a nested class could trigger the definition of
11527         a toplevel class, and the builder would be obviously wrong in that
11528         case. 
11529
11530         So we drop this argument, and we compute dynamically the
11531         TypeBuilder/ModuleBuilder (the correct information was available
11532         to us anyways from DeclSpace.Parent)
11533
11534         * interface.cs (Interface.DefineInterface): Drop builder
11535         parameter cleanup like class.cs
11536
11537         * enum.cs (Enum.DefineEnum): Drop builder parameter.  Clean up
11538         like class.cs
11539
11540         * statement.cs (Switch.EmitObjectInteger): Emit short/ushort
11541         values. 
11542
11543         (Try.Emit): Propagate the returns value from the statement.
11544
11545         (Return.Emit): Even if we are leavning 
11546
11547         * driver.cs: Catch IOExpcetion for Directory.GetFiles as well.
11548
11549         * modifiers.cs: Fix the computation of MethodAttributes flags.
11550
11551 Tue Mar 26 21:14:36 CET 2002 Paolo Molaro <lupus@ximian.com>
11552
11553         * driver.cs: allow compilation of files that start with '/'.
11554         Add a default case when checking the argument of --target.
11555
11556 2002-03-25  Miguel de Icaza  <miguel@ximian.com>
11557
11558         * interface.cs: Implement the same search algorithm for types in
11559         the interface code.
11560
11561         * delegate.cs: Do not allow multiple definition.
11562
11563         * Recovered ChangeLog that got accidentally amputated
11564
11565         * interface.cs (Interface.DefineInterface): Prevent from double definitions.
11566
11567         * rootcontext.cs: Load manually enum to allow core classes to
11568         contain enumerations.
11569
11570         * enum.cs, ecore.cs, driver.cs, attribute.cs, class.cs, expression.cs:
11571         Update to new static methods in TypeManager.
11572
11573         * typemanager.cs (GetMethod, GetConstructor): Use our
11574         implementation of FindMembers to find the members, since during
11575         corlib compilation, the types are TypeBuilders and GetMethod and
11576         GetConstructor do not work.
11577
11578         Make all methods in TypeManager static.
11579
11580         (InitCodeHelpers): Split the functionality from
11581         the InitCodeTypes function.
11582
11583         * driver.cs: Call InitCodeHelpers after we have populated the
11584         types. 
11585
11586         * cs-parser.jay (delegate_declaration): we did not used to compute
11587         the delegate name correctly for void delegates.
11588
11589 2002-03-24  Miguel de Icaza  <miguel@ximian.com>
11590
11591         * rootcontext.cs (RootContext): Init the interface_resolve_order
11592         and type_container_resolve_order always.
11593
11594         (ResolveCore, BootstrapCorlib_ResolveClass,
11595         BootstrapCorlib_ResolveStruct): New functions to bootstrap the
11596         compiler when compiling with --nostdlib
11597
11598         * class.cs (TypeContainer.DefineType): Check that our parent is
11599         not null.  This test is most important when we are bootstraping
11600         the core types.
11601
11602         * codegen.cs: Split out the symbol writing code.
11603
11604 2002-03-25  Martin Baulig  <martin@gnome.org>
11605
11606         * driver.cs (-g): Made -g an alias for --debug.
11607
11608 2002-03-24  Martin Baulig  <martin@gnome.org>
11609
11610         * codegen.cs (SymbolWriter): New public variable. Returns the
11611         current symbol writer.
11612         (CodeGen): Added `bool want_debugging_support' argument to the
11613          constructor. If true, tell the ModuleBuild that we want debugging
11614         support and ask it for the ISymbolWriter.
11615         (Save): If we have a symbol writer, call it's Close() method after
11616         saving the assembly.
11617
11618         * driver.c (--debug): New command line argument to create a
11619         debugger information file.
11620
11621         * location.cs (SymbolDocument): New public property. Returns an
11622         ISymbolDocumentWriter object for the current source file or null
11623         if we don't have a symbol writer.
11624
11625 2002-03-21  Miguel de Icaza  <miguel@ximian.com>
11626
11627         * driver.cs (LoadAssembly): Correctly return when all the paths
11628         have been tried and not before.
11629
11630         * statement.cs (Switch.Emit): return the actual coverage for this
11631         statement (returns/not-returns)
11632
11633         (Switch.SimpleSwitchEmit): Do not generate jumps to the end of the
11634         switch of the statement if we are the last switch section.  That
11635         kills two problems: try/catch problems (we used to emit an empty
11636         nop at the end) and switch statements where all branches would
11637         return. 
11638
11639 2002-03-19  Miguel de Icaza  <miguel@ximian.com>
11640
11641         * driver.cs: Add default assemblies (the equivalent to the
11642         Microsoft CSC.RSP file)
11643
11644         * cs-tokenizer.cs: When updating `cols and setting it to zero,
11645         also update tokens_seen and set it to false.
11646
11647         * driver.cs: Implement --recurse for Mike.
11648
11649         * driver.cs (SplitPathAndPattern): Small bug fix, I was not
11650         correctly splitting out the paths.
11651
11652 2002-03-18  Miguel de Icaza  <miguel@ximian.com>
11653
11654         * interface.cs (Interface.PopulateProperty): Instead of using
11655         `parent' as the declaration space for the set parameters, use
11656         `this' 
11657
11658         * support.cs (InternalParameters): InternalParameters constructor
11659         takes a DeclSpace instead of a TypeContainer.
11660
11661         * expression.cs (ArrayCreation.EmitDynamicInitializers): If value
11662         types are being initialized, load the address of it before calling
11663         the function.  
11664
11665         (New): Provide a mechanism to disable the generation of local
11666         value type temporaries when the caller will be providing us with
11667         an address to store it.
11668
11669         (ArrayCreation.EmitDynamicInitializers): Use it.
11670
11671 2002-03-17  Miguel de Icaza  <miguel@ximian.com>
11672
11673         * expression.cs (Invocation.EmitArguments): Only probe for array
11674         property if there is more than one argument.  Sorry about that.
11675
11676         * class.cs (Invocation.EmitArguments): Fix to emit arguments for
11677         empty param arrays.
11678
11679         * class.cs (Method.LabelParameters): Fix incorrect code path that
11680         prevented the `ParamArrayAttribute' from being applied to the
11681         params attribute.
11682
11683 2002-03-16  Miguel de Icaza  <miguel@ximian.com>
11684
11685         * support.cs (ReflectionParameters): Correctly compute whether the
11686         last argument is a params array.  Fixes the problem with
11687         string.Split ('a')
11688
11689         * typemanager.cs: Make the assemblies array always be non-null
11690         (empty, but non-null)
11691
11692         * tree.cs (RecordDecl): New function that abstracts the recording
11693         of names.  This reports error 101, and provides a pointer to the
11694         previous declaration.  Fixes a crash in the compiler.
11695
11696         * cs-parser.jay (constructor_declaration): Update to new grammar,
11697         and provide a constructor_body that can be empty.
11698
11699 2002-03-15  Miguel de Icaza  <miguel@ximian.com>
11700
11701         * driver.cs: Add support for --resources.
11702
11703         * expression.cs: (FetchGetMethod, FetchAddressMethod, EmitAssign):
11704         Make all types for the various array helper methods be integer.
11705
11706         * ecore.cs (Expression.ConvertNumericExplicit): Pass the
11707         CheckState to ConvCast.
11708
11709         (ConvCast): Now it takes a `checked' state argument, to avoid
11710         depending on the emit context for the conversion, and just using
11711         the resolve time setting.
11712
11713         * expression.cs (ArrayCreation.EmitArrayArguments): New function,
11714         instead of Invocation.EmitArguments.  We do not emit the original
11715         arguments, instead we emit those which have been converted to
11716         unsigned int expressions.
11717
11718         * statement.cs (Block.EmitMeta): Drop tracking of indexes.
11719
11720         * codegen.cs: ditto.
11721
11722         * expression.cs (LocalVariableReference): Drop the use of the
11723         Store function that depended on the variable index.
11724
11725         * statement.cs (VariableInfo): Drop the `Idx' property from this
11726         class, as this is not taking into account the indexes for
11727         temporaries tat we generate during the execution, getting the
11728         indexes wrong.
11729
11730         * class.cs: First emit class initializers, then call the parent
11731         constructor. 
11732
11733         * expression.cs (Binary): Fix opcode emision.
11734         (UnaryMutator.EmitCode): Support checked code generation
11735
11736         * ecore.cs (MemberLookup): TypeManager.FindMembers will return
11737         matches for events for both the Static and Instance scans,
11738         pointing to the same element.   Fix that.
11739
11740 2002-03-14  Miguel de Icaza  <miguel@ximian.com>
11741
11742         * rootcontext.cs (ResolveTree): Always set the
11743         interface_resolve_order, because nested interfaces will be calling
11744         into us.
11745
11746         * class.cs (GetInterfaceOrClass): Track the same resolution
11747         process used by TypeManager.LookupType.  This fixes the nested
11748         type lookups in class declarations (separate path from
11749         LookupType). 
11750
11751         (TypeContainer.DefineType): Also define nested interfaces.
11752         (TypeContainer.RegisterOrder): New public function used to
11753         register the order in which child interfaces need to be closed.
11754
11755         Nested interfaces need to be closed after their parents have been
11756         created. 
11757
11758         * interface.cs (InterfaceAttr): Put all the logic for computing
11759         the interface attribute here. 
11760
11761         (DefineInterface): Register our interface order with the
11762         RootContext or with the TypeContainer depending on the case.
11763
11764 2002-03-12  Miguel de Icaza  <miguel@ximian.com>
11765
11766         * cs-parser.jay: rework foreach statement to work with the new
11767         changes to the policy on SimpleNames.
11768
11769         * report.cs: support Stacktrace on warnings as well.
11770
11771         * makefile: drop --unsafe and /unsafe from the compile.
11772
11773 2002-03-13  Ravi Pratap  <ravi@ximian.com>
11774
11775         * ecore.cs (StandardConversionExists): Modify to take an Expression
11776         as the first parameter. Ensure we do null -> reference type conversion
11777         checking.
11778
11779         * Everywhere : update calls accordingly, making use of MyEmptyExpr to store
11780         temporary Expression objects.
11781
11782 Wed Mar 13 12:32:40 CET 2002 Paolo Molaro <lupus@ximian.com>
11783
11784         * interface.cs: workaround bug in method overloading resolution
11785         (there is already a bugzilla bug for it).
11786
11787 2002-03-12  Miguel de Icaza  <miguel@ximian.com>
11788
11789         We could also solve this problem by having a separate path for
11790         performing type lookups, instead of DoResolve, we could have a
11791         ResolveType entry point, and only participating pieces of the
11792         production (simplename, deref, array) would implement this. 
11793
11794         * codegen.cs (EmitContext): New field OnlyLookupTypes used to
11795         signal SimpleName to only resolve type names and not attempt to
11796         resolve anything else.
11797
11798         * expression.cs (Cast): Set the flag.
11799
11800         * ecore.cs (SimpleName): Use the OnlyLookupTypes flag
11801
11802         * class.cs: Only report 108 if there is no `new' modifier.
11803
11804         * cs-parser.jay: rework foreach statement to work with the new
11805         changes to the policy on SimpleNames.
11806
11807         * report.cs: support Stacktrace on warnings as well.
11808
11809         * makefile: drop --unsafe and /unsafe from the compile.
11810
11811 2002-03-11  Miguel de Icaza  <miguel@ximian.com>
11812
11813         * ecore.cs (SimpleName.SimpleNameResolve): Perform local variable
11814         lookups here, instead of doing that at parse time.  This means
11815         that our grammar will not introduce `LocalVariableReferences' as
11816         expressions at this point.  That solves the problem of code like
11817         this:
11818
11819         class X {
11820            static void Main ()
11821            { int X = 1;
11822             { X x = null }}}
11823
11824         This is only half the fix.  The full fix requires parameters to
11825         also be handled in this way.
11826
11827         * Everywhere: Use ec.DeclSpace on calls to LookupType, as this
11828         makes the use more obvious of the DeclSpace.  The
11829         ec.TypeContainer.TypeBuilder is now only used to pull the
11830         TypeBuilder for it.
11831
11832         My theory is that I can get rid of the TypeBuilder completely from
11833         the EmitContext, and have typecasts where it is used (from
11834         DeclSpace to where it matters).  
11835
11836         The only pending problem is that the code that implements Aliases
11837         is on TypeContainer, and probably should go in DeclSpace.
11838
11839         * ecore.cs (SimpleName.SimpleNameResolve): Perform local variable
11840         lookups here, instead of doing that at parse time.  This means
11841         that our grammar will not introduce `LocalVariableReferences' as
11842         expressions at this point.  That solves the problem of code like
11843         this:
11844
11845         class X {
11846            static void Main ()
11847            { int X = 1;
11848             { X x = null }}}
11849
11850         This is only half the fix.  The full fix requires parameters to
11851         also be handled in this way.
11852
11853         * class.cs (Property.DefineMethod): When implementing an interface
11854         method, set newslot, when implementing an abstract method, do not
11855         set the flag (before we tried never setting it, or always setting
11856         it, which is the difference).
11857         (Indexer.DefineMethod): same.
11858         (Method.DefineMethod): same.
11859
11860         * ecore.cs: Only set the status used flag if we get back a Field.
11861
11862         * attribute.cs: Temporary hack, so Paolo can keep working.
11863
11864 2002-03-08  Ravi Pratap  <ravi@ximian.com>
11865
11866         * attribute.cs (Attribute.UnmanagedType): This is to keep track of
11867         the unmanaged type in the case we have a MarshalAs attribute.
11868
11869         (Resolve): Handle the case when we are parsing the special MarshalAs
11870         attribute [we need to store the unmanaged type to use later]
11871
11872         * typemanager.cs (marshal_as_attr_type): Built in type for the 
11873         MarshalAs Attribute.
11874
11875         * attribute.cs (ApplyAttributes): Recognize the MarshalAs attribute 
11876         on parameters and accordingly set the marshalling info.
11877
11878 2002-03-09  Miguel de Icaza  <miguel@ximian.com>
11879
11880         * class.cs: Optimizing slightly by removing redundant code after
11881         we switched to the `NoTypes' return value.
11882         (Property.DefineMethod): use NoTypes here too.
11883
11884         This fixes the bug I introduced in my last batch of changes.
11885
11886 2002-03-05  Ravi Pratap  <ravi@ximian.com>
11887
11888         * tree.cs (RecordEnum): Add. We now keep track of enums too.
11889
11890         * class.cs (LookupInterfaceOrClass): Check against the list of recorded
11891         Enums since those are types too. 
11892
11893         * cs-parser.jay (enum_declaration): Record enums as we parse them.
11894
11895         * enum.cs (DefineEnum): Return if the TypeBuilder has already been defined 
11896         thanks to a call during the lookup process.
11897
11898 2002-03-07  Miguel de Icaza  <miguel@ximian.com>
11899
11900         * statement.cs (Foreach): Lots of work to accomodate a particular
11901         kind of foreach statement that I had not kept in mind.  It is
11902         possible to have foreachs on classes that provide a GetEnumerator
11903         method that return objects that implement the "pattern" for using
11904         a foreach, there is no need to support GetEnumerator
11905         specifically. 
11906
11907         This is needed to compile nant.
11908
11909         * decl.cs: Only report 114 if the member is not `Finalize' and if
11910         the warning level is at least 2.
11911
11912         * class.cs: Moved the compare function from Method to
11913         MethodSignature. 
11914
11915         (MethodSignature.InheritableMemberSignatureCompare): Add new
11916         filter function that is used to extract inheritable methods from a
11917         class. 
11918
11919         (Method.Define): Use the new `inheritable_method_signature_filter'
11920         delegate
11921
11922         * cs-tokenizer.cs (get_cmd_arg): Do not add white space to the
11923         command. 
11924
11925 2002-03-06  Miguel de Icaza  <miguel@ximian.com>
11926
11927         * ecore.cs (Expression.ConvertReferenceExplicit): Removed dead code.
11928
11929         * cs-parser.jay: Add opt_semicolon to the interface declaration.
11930
11931         * expression.cs: Pass location information to
11932         ConvertImplicitStandard. 
11933
11934         * class.cs: Added debugging code to track return values from
11935         interfaces. 
11936
11937 2002-03-05  Miguel de Icaza  <miguel@ximian.com>
11938
11939         * expression.cs (Is.DoResolve): If either side of the `is' is an
11940         interface, do not flag the warning.
11941
11942         * ecore.cs (ImplicitReferenceConversion): We need a separate test
11943         for interfaces
11944
11945         * report.cs: Allow for --fatal to be used with --probe.
11946
11947         * typemanager.cs (NoTypes): Move the definition for the empty Type
11948         array here. 
11949
11950         * class.cs (TypeContainer.FindMembers): Also look for methods defined by
11951         properties. 
11952         (TypeContainer.DefineProxy): New function used to proxy to parent
11953         implementations when implementing interfaces.
11954         (TypeContainer.ParentImplements): used to lookup if our parent
11955         implements a public function that is required by an interface.
11956         (TypeContainer.VerifyPendingMethods): Hook this up.
11957
11958         * typemanager.cs (TypeManager, AddModule, AddAssembly): Make the
11959         `modules' and `assemblies' arraylists into arrays.  We only grow
11960         these are the very early start up of the program, so this improves
11961         the speedof LookupType (nicely measured).
11962
11963         * expression.cs (MakeByteBlob): Replaced unsafe code with
11964         BitConverter, as suggested by Paolo.
11965
11966         * cfold.cs (ConstantFold.Binary): Special case: perform constant
11967         folding of string concatenation, but if either side is a string,
11968         and the other is not, then return null, and let the runtime use
11969         the concatenation on the string plus the object (using
11970         `Object.ToString'). 
11971
11972 2002-03-04  Miguel de Icaza  <miguel@ximian.com>
11973
11974         Constant Folding has been implemented now.
11975
11976         * expression.cs (Unary.Reduce): Do not throw an exception, catch
11977         the error instead on types that are not supported in one's
11978         complement. 
11979
11980         * constant.cs (Constant and all children): New set of functions to
11981         perform implict and explicit conversions.
11982
11983         * ecore.cs (EnumConstant): Implement the new functions to perform
11984         conversion by proxying to the child expression.
11985
11986         * codegen.cs: (ConstantCheckState): Constant evaluation has its
11987         own separate setting that can not be turned off from the command
11988         line using --unchecked or --checked and is only controlled using
11989         the checked/unchecked statements and expressions.  This setting is
11990         used by the constant folder to flag errors.
11991
11992         * expression.cs (CheckedExpr, UncheckedExpr): Set the
11993         ConstantCheckState as well.   
11994
11995         During Resolve, they also have to flag the state, because the
11996         constant folder runs completely in the Resolve phase.
11997
11998         * statement.cs (Checked, Unchecked): Set the ConstantCheckState as
11999         well.
12000
12001 2002-03-01  Miguel de Icaza  <miguel@ximian.com>
12002
12003         * cfold.cs: New file, this file contains the constant folder.
12004
12005         * ecore.cs (IMemoryLocation.AddressOf): Now takes an extra
12006         argument to track whether we are using the resulting address to
12007         load or store a value and provide better error messages. 
12008
12009         (FieldExpr.Emit, FieldExpr.EmitAssign, FieldExpr.AddressOf): Use
12010         new AddressOf arguments.
12011
12012         * statement.cs (Foreach.EmitCollectionForeach): Update
12013
12014         * expression.cs (Argument.Emit): Call AddressOf with proper
12015         arguments to track usage.
12016
12017         (New.DoEmit): Call AddressOf with new arguments.
12018
12019         (Unary.Emit): Adjust AddressOf call.
12020
12021 2002-03-01  Ravi Pratap  <ravi@ximian.com>
12022
12023         * cs-parser.jay (member_access): Change the case for pre-defined types
12024         to use a MemberAccess instead of a SimpleName. Thanks to Felix again for 
12025         this suggestion.
12026
12027         * class.cs (Operator::Emit): If we are abstract or extern, we don't have
12028         a method body.
12029
12030         * attribute.cs (CheckAttribute, ApplyAttribute): Ensure that we treat operators
12031         essentially like methods and apply attributes like MethodImplOptions to them too.
12032
12033         * ecore.cs (SimpleName.SimpleNameResolve): Perform a check on ec.TypeContainer.TypeBuilder
12034         not being null.
12035
12036         * codegen.cs (EmitContext): The constructor now takes in an extra argument specifying the
12037         DeclSpace as the distinction is important. We provide sane defaults as usually the TypeContainer
12038         is the DeclSpace.
12039
12040         * Update code everywhere accordingly.
12041
12042         * ecore.cs : Change references to ec.TypeContainer to ec.DeclSpace where appropriate.
12043
12044         * cs-parser.jay (enum_declaration): Set the current namespace of the enum.
12045
12046 2002-02-28  Ravi Pratap  <ravi@ximian.com>
12047
12048         * rootcontext.cs (LookupType): As we cycle through the chain of namespaces
12049         try performing lookups against those instead of jumping straight into using
12050         the 'using' clauses.
12051
12052         (ImplicitParent): Add. Thanks to Felix Arrese-Igor for this idea.
12053
12054         (LookupType): Perform lookups in implicit parents too.
12055
12056         * class.cs (GetInterfaceOrClass): Modify to perform the exact same lookup
12057         sequence as RootContext.LookupType. 
12058
12059         * rootcontext.cs (NamespaceLookup): Split out code from LookupType which tries 
12060         the various cases of namespace lookups into this method.
12061
12062 2002-03-01  Miguel de Icaza  <miguel@ximian.com>
12063
12064         * cs-parser.jay: Add support for [Attribute ()] (empty arguments
12065         in positional arguments)
12066
12067         * class.cs (Operator): Update the AllowedModifiers to contain
12068         extern. 
12069
12070         * cs-parser.jay: Update operator declaration to allow for the
12071         operator body to be empty.
12072
12073         * cs-tokenizer.cs: Added '\u' unicode support in strings and hex
12074         values. 
12075
12076 2002-02-27  Miguel de Icaza  <miguel@ximian.com>
12077
12078         * class.cs (Method.Emit): Label parameters.
12079
12080         * driver.cs: Return 1 or 0 as the program exit code.
12081
12082 2002-02-26  Miguel de Icaza  <miguel@ximian.com>
12083
12084         * expression.cs: Special case the `null' object when trying to
12085         auto-compute the type, as anything can be explicitly converted to
12086         that. 
12087
12088         * ecore.cs (Expression.ConvertExplicit): Bug fix, thanks for
12089         spotting this Paolo.
12090
12091         (Expression.ImplicitNumericConversion): Perform comparissions of
12092         the type using the underlying type in the case of an enumeration
12093         rather than using the enumeration type for the compare.
12094
12095         Cope with the underlying == type case, which is not possible to
12096         catch before. 
12097
12098         (Expression.ConvertNumericExplicit): Perform comparissions of
12099         the type using the underlying type in the case of an enumeration
12100         rather than using the enumeration type for the compare.
12101
12102         * driver.cs: If the user does not supply an extension, assume .exe
12103
12104         * cs-parser.jay (if_statement): Rewrote so that we can track the
12105         location for the if statement.
12106
12107         * expression.cs (Binary.ConstantFold): Only concat strings when
12108         the operation is "+", not everything ;-)
12109
12110         * statement.cs (Statement.EmitBoolExpression): Take a location
12111         argument. 
12112         (If, While, Do): Track location.
12113
12114         * expression.cs (Binary.ResolveOperator): In the object + string
12115         case, I was missing a call to ConvertImplicit
12116
12117 2002-02-25  Ravi Pratap  <ravi@ximian.com>
12118
12119         * parameter.cs (Parameter.ExternalType): Take in extra DeclSpace and
12120         Location arguments. Ensure we use RootContext.LookupType to do our work
12121         and not try to do a direct Type.GetType and ModuleBuilder.GetType
12122
12123         * interface.cs (PopulateMethod): Handle the type of the parameter being
12124         null gracefully.
12125
12126         * expression.cs (Invocation.BetterFunction): Handle the case when we 
12127         have a params method with no fixed arguments and a call is made with no
12128         arguments.
12129
12130 2002-02-25  Miguel de Icaza  <miguel@ximian.com>
12131
12132         * cs-tokenizer.cs: Add support for the quote-escape-sequence in
12133         the verbatim-string-literal
12134
12135         * support.cs (InternalParameters.ParameterModifier): handle null
12136         fixed parameters.
12137         (InternalParameters.ParameterType): ditto.
12138
12139         * parameter.cs (VerifyArgs): Also check if the fixed parameter is
12140         duplicating the name of the variable parameter.
12141         (GetParameterByName): Fix bug where we were not looking up array
12142         paramters if they were the only present (thanks Paolo!).
12143         (GetParameterInfo): We only have an empty set of types if both
12144         fixed and array are set to null.
12145         (GetParameterInfo-idx): Handle FixedParameter == null
12146
12147         * cs-parser.jay: Handle the case where there is no catch
12148         statements (missing null test).
12149
12150 2002-02-22  Miguel de Icaza  <miguel@ximian.com>
12151
12152         * driver.cs (MainDriver): Be conservative on our command line
12153         handling.
12154
12155         Catch DirectoryNotFoundException when calling GetFiles.
12156
12157         (SplitPathAndPattern): Used to split the input specification into
12158         a path and a pattern that we can feed to Directory.GetFiles.
12159
12160 2002-02-21  Miguel de Icaza  <miguel@ximian.com>
12161
12162         * statement.cs (Fixed): Implement the last case of the Fixed
12163         statement (string handling).
12164
12165         * expression.cs (StringPtr): New class used to return a char * to
12166         a string;  Used by the Fixed statement.
12167
12168         * typemanager.cs: Add char_ptr_type.  Add get_OffsetToStringData method.
12169
12170         * expression.cs (Binary.ResolveOperator): Remove redundant
12171         MemberLookup pn parent type.
12172         Optimize union call, we do not need a union if the types are the same.
12173         (Unary.ResolveOperator): REmove redundant MemberLookup on parent
12174         type.
12175
12176         Specialize the use of MemberLookup everywhere, instead of using
12177         the default settings. 
12178
12179         (StackAlloc): Implement stackalloc keyword.
12180
12181         * cs-parser.jay: Add rule to parse stackalloc.
12182
12183         * driver.cs: Handle /h, /help, /?
12184
12185         * expression.cs (MakeByteBlob): Removed the hacks we had in place
12186         before we supported unsafe code.
12187
12188         * makefile: add --unsafe to the self compilation of mcs.
12189
12190 2002-02-20  Miguel de Icaza  <miguel@ximian.com>
12191
12192         * expression.cs (PointerArithmetic): New class that is used to
12193         perform pointer arithmetic.
12194         (Binary.Resolve): Handle pointer arithmetic
12195         Handle pointer comparission.
12196         (ArrayPtr): Utility expression class that is used to take the
12197         address of an array.
12198
12199         (ElementAccess): Implement array access for pointers
12200
12201         * statement.cs (Fixed): Implement fixed statement for arrays, we
12202         are missing one more case before we are done.
12203
12204         * expression.cs (Indirection): Implement EmitAssign and set the
12205         ExprClass to Variable.  This allows pointer dereferences to be
12206         treated as variables, and to have values assigned to them.
12207
12208         * ecore.cs (Expression.StoreFromPtr): New utility function to
12209         store values dereferencing.
12210
12211 2002-02-20  Ravi Pratap  <ravi@ximian.com>
12212
12213         * expression.cs (Binary.ResolveOperator): Ensure that we are
12214         not trying to operate on a void type - this fixes the reported
12215         bug.
12216
12217         * decl.cs (CheckMethodAgainstBase): Do not allow overriding if
12218         the parent implementation is sealed.
12219
12220         * ../errors/cs0239.cs : Add.
12221
12222         * attribute.cs (ApplyAttributes): Handle Modulebuilders too.
12223
12224         * typemanager.cs (unverifiable_code_type): Corresponds to 
12225         System.Security.UnverifiableCodeAttribute. We need to emit this for modules
12226         which have unsafe code in them.
12227
12228         * rootcontext.cs (EmitCode): Emit the above attribute when we are in an 
12229         unsafe context.
12230
12231 2002-02-19  Miguel de Icaza  <miguel@ximian.com>
12232
12233         * cs-tokenizer.cs: Add support for @"litreal strings"
12234
12235         Make tokenizer accept pre-processor directives
12236         on any column (remove the old C-like limitation). 
12237
12238         * rootcontext.cs (EmitCode): Emit any global attributes.
12239         (AddGlobalAttributes): Used to keep track of assembly attributes. 
12240
12241         * attribute.cs (ApplyAttributes): Support AssemblyAttributes.
12242
12243         * cs-parser.jay: Add support for global attributes.  
12244
12245 2002-02-17  Miguel de Icaza  <miguel@ximian.com>
12246
12247         * expression.cs (Indirection): New helper class.  Unary will
12248         create Indirection classes to be able to implement the
12249         IMemoryLocation interface on it.
12250
12251 2002-02-16  Miguel de Icaza  <miguel@ximian.com>
12252
12253         * cs-parser.jay (fixed_statement): reference the right statement.
12254
12255         * statement.cs (Fixed.Emit): Finish implementing the fixed
12256         statement for the &x case.
12257
12258 2002-02-14  Miguel de Icaza  <miguel@ximian.com>
12259
12260         * class.cs (Property.Define, Method.Define): Remove newslot when
12261         `implementing'.  
12262
12263         * modifiers.cs: My use of NewSlot when `Abstract' was set was
12264         wrong.  NewSlot should only be used if the `new' keyword is present.
12265
12266         * driver.cs (GetSystemDir): Use CodeBase instead of FullName for
12267         locating our system dir.  Sorry about this.
12268
12269 2002-02-13  Miguel de Icaza  <miguel@ximian.com>
12270
12271         * driver.cs (GetSystemDir): Compute correctly the location of our
12272         system assemblies.  I was using the compiler directory instead of
12273         the library directory.
12274
12275 2002-02-13  Ravi Pratap  <ravi@ximian.com>
12276
12277         * expression.cs (BetterFunction): Put back in what Miguel commented out
12278         since it is the correct fix. The problem is elsewhere ;-)
12279
12280         (IsParamsMethodApplicable): Fix bug where we were not checking that the fixed
12281         parameters of the parms method are themselves compatible or not !
12282
12283         (StandardConversionExists): Fix very dangerous bug where we were forgetting
12284         to check that a class implements an interface before saying that an implicit
12285         conversion was allowed. Use ImplementsInterface to do the checking.
12286
12287 2002-02-13  Miguel de Icaza  <miguel@ximian.com>
12288
12289         * class.cs (Method.Define): Track whether we are an explicit
12290         implementation or not.  And only call DefineMethodOverride if we
12291         are an explicit implementation.
12292
12293         (Property.DefineMethod): Ditto.
12294
12295 2002-02-11  Ravi Pratap  <ravi@ximian.com>
12296
12297         * expression.cs (BetterFunction): Catch hideous bug which was
12298          preventing us from detecting ambiguous calls due to implicit casts i.e
12299         cs0121.
12300
12301 2002-01-29  Miguel de Icaza  <miguel@ximian.com>
12302
12303         * support.cs (Pair): Remove un-needed method.  I figured why I was
12304         getting the error in cs-parser.jay, the variable in a foreach loop
12305         is readonly, and the compiler does not really treat this as a variable.
12306
12307         * cs-parser.jay (fixed_statement): Fix grammar.  Use ASSIGN
12308         instead of EQUALS in grammar.  
12309
12310         * typemanager.cs (VerifyUnmanaged): Report correct error (208)
12311
12312         * expression.cs (Unary.DoResolve): Check whether the argument is
12313         managed or not.
12314
12315 2002-01-28  Miguel de Icaza  <miguel@ximian.com>
12316
12317         * support.cs: Api for Pair to set a value.  Despite the fact that
12318         the variables are public the MS C# compiler refuses to compile
12319         code that accesses the field if the variable is part of a foreach
12320         statement. 
12321
12322         * statement.cs (Fixed): Begin implementation of the fixed
12323         statement.
12324
12325         (Block.AddVariable): Return the VariableInfo on success and null
12326         on failure instead of true/false. 
12327
12328         * cs-parser.jay (foreach): Catch errors on variables already
12329         defined (we were ignoring this value before) and properly unwind
12330         the block hierarchy
12331
12332         (fixed_statement): grammar for the fixed statement.
12333
12334 2002-01-25  Miguel de Icaza  <miguel@ximian.com>
12335
12336         * expression.cs (UnaryMutator.IsIncrementableNumber): Allow also
12337         pointer types to be incretemented.
12338
12339         (SizeOf): Implement.
12340
12341         * cs-parser.jay (pointer_member_access): Implement
12342         expr->IDENTIFIER production.
12343
12344         * expression.cs (IndexerAccess.DoResolve, ArrayAccess.DoResolve,
12345         MemberAccess.DoResolve, Invocation.DoResolve): Check for pointers
12346         on safe contexts.
12347
12348         (Unary): Implement indirection.
12349
12350         * ecore.cs (Expression.UnsafeError): Reports error 214 (pointer
12351         use in non-unsafe context).
12352
12353         (SimpleName.DoResolve): Check for pointers in field access on safe
12354         contexts. 
12355
12356         (Expression.LoadFromPtr): Factor the load-indirect code in this
12357         function.  This was duplicated in UnboxCast and ParameterReference
12358
12359 2002-01-24  Miguel de Icaza  <miguel@ximian.com>
12360
12361         * expression.cs (ComposedCast): report an error if a pointer cast
12362         is used in a safe region.
12363
12364         * ecore.cs (Expression.ConvertExplicit): Add rules for implicit
12365         pointer type casts in unsafe context.
12366
12367         * codegen.cs (EmitContext): Set up IsUnsafe.
12368
12369         * cs-parser.jay (non_expression_type): Add productions for pointer
12370         casts. 
12371
12372         * expression.cs (Invocation.EmitCall): Remove chunk of buggy
12373         code.  We should not use force into static mode if the method is
12374         not virtual.  Fixes bug in MIS
12375
12376         * statement.cs (Do.Emit, While.Emit, For.Emit,
12377         Statement.EmitBoolExpression): Add support to Do and While to
12378         propagate infinite loop as `I do return' semantics.
12379
12380         Improve the For case to also test for boolean constants.
12381
12382         * attribute.cs (Attribute.ApplyAttributes): Add ParameterBuilder
12383         to the list of attributes we can add.
12384
12385         Remove `EmitContext' argument.
12386
12387         * class.cs (Method.Define): Apply parameter attributes.
12388         (Constructor.Define): Apply parameter attributes.
12389         (MethodCore.LabelParameters): Move here the core of labeling
12390         parameters. 
12391
12392         * support.cs (ReflectionParameters.ParameterModifier,
12393         InternalParameters.ParameterModifier): Use IsByRef on the type and
12394         only return the OUT bit for these parameters instead of in/out/ref
12395         flags.
12396
12397         This is because I miss-understood things.  The ParameterInfo.IsIn
12398         and IsOut represent whether the parameter has the [In] and [Out]
12399         attributes set.  
12400
12401 2002-01-22  Miguel de Icaza  <miguel@ximian.com>
12402
12403         * ecore.cs (FieldExpr.Emit): Release temporaries.
12404
12405         * assign.cs (LocalTemporary.Release): new function.
12406
12407         * codegen.cs (EmitContext.GetTemporaryStorage,
12408         EmitContext.FreeTemporaryStorage): Rework the way we deal with
12409         temporary storage.  Now we can "put back" localbuilders when we
12410         are done with them
12411
12412 2002-01-21  Miguel de Icaza  <miguel@ximian.com>
12413
12414         * ecore.cs (FieldExpr.Emit): Handle initonly fields specially: we
12415         need to make a copy of the variable to generate verifiable code.
12416
12417 2002-01-19  Miguel de Icaza  <miguel@ximian.com>
12418
12419         * driver.cs: Compute dynamically the system directory.
12420
12421         * ecore.cs (CopyNewMethods): reworked, exposed, made public.
12422         Slower, but more generally useful.  Used by the abstract
12423         registering implementation. 
12424
12425         * expression.cs (ResolveMemberAccess): Reorder the way we evaluate
12426         the rules for the special rule on Type/instances.  First check if
12427         we have the same name, and if so, try that special static path
12428         rather than the instance path.
12429
12430 2002-01-18  Miguel de Icaza  <miguel@ximian.com>
12431
12432         * cs-parser.jay: Emit 642 (warning: possible empty statement) for
12433         for, while and if.
12434
12435         * class.cs (TypeBuilder.DefineType): Do not allow inheritance from
12436         Enum, ValueType, Delegate or Array for non-corlib compiles.
12437
12438         * cs-tokenizer.cs: Catch long identifiers (645)
12439
12440         * typemanager.cs (IndexerPropetyName): Ravi never tested this
12441         piece of code.
12442
12443         * class.cs (TypeContainer.RegisterRequiredImplementations): Bug
12444         fix, we were returning too early, so we were not registering
12445         pending methods from abstract classes.
12446
12447         Do not register pending methods if the class is abstract.
12448
12449         * expression.cs (Conditional.DoResolve): Report circular implicit
12450         conversions when we neecd to compute it for conditional
12451         expressions. 
12452
12453         (Is.DoResolve): If the expression is always of the provided type,
12454         flag warning 183.  If the expression can not ever be of the
12455         provided type flag warning 184.
12456
12457         * class.cs: Catch 169 as well.
12458
12459         * ecore.cs (FieldExpr): For now in AddressOf mark as assigned and
12460         read. 
12461
12462 2002-01-18  Nick Drochak  <ndrochak@gol.com>
12463
12464         * makefile: remove path to beta2 csc.exe.  path to csc.exe must be in PATH instead.
12465
12466 2002-01-17  Miguel de Icaza  <miguel@ximian.com>
12467
12468         * interface.cs: (PopulateMethod): Check for pointers being defined
12469         only if the unsafe context is active.
12470         (PopulateProperty): ditto.
12471         (PopulateIndexer): ditto.
12472
12473         * class.cs (Method, Method.Define): Allow `unsafe' modifier to be
12474         specified.  If pointers are present, make sure that they are
12475         present in an unsafe context.
12476         (Constructor, Constructor.Define): ditto.
12477         (Field, Field.Define): ditto.
12478         (Property, Property.Define): ditto.
12479         (Event, Event.Define): ditto.
12480
12481         * interface.cs (Interface.GetInterfaceTypeByName): Only lookup the
12482         hashtable if there are classes or structs defined.
12483
12484         * expression.cs (LocalVariableReference.DoResolve): Simplify this
12485         code, as the constant resolution moved.
12486
12487         * statement.cs (Block.EmitMeta): Resolve all constants as we emit
12488         the metadata, so we can flag error 133. 
12489
12490         * decl.cs (MemberCore.UnsafeOK): New function to test that a
12491         pointer is being declared in an unsafe context.
12492
12493 2002-01-16  Miguel de Icaza  <miguel@ximian.com>
12494
12495         * modifiers.cs (Modifiers.Check): Require a Location argument.
12496         Report error 227 for Unsafe use.
12497
12498         * typemanager.cs: Remove IsPointerType, we should be using Type.IsPointer
12499
12500         * statement.cs (For.Emit): If the test is null, then report that
12501         we do `return', as we wont reach anything afterwards.
12502
12503         (Switch.SwitchGoverningType): Track the expression that matched
12504         the conversion.
12505
12506         * driver.cs: Allow negative numbers as an error code to flag.
12507
12508         * cs-parser.jay: Handle 1551.
12509
12510         * namespace.cs: Add 1537 checking (repeated using alias namespaces).
12511
12512 2002-01-15  Miguel de Icaza  <miguel@ximian.com>
12513
12514         * cs-parser.jay: Report 1518 (type declaration can only contain
12515         class, struct, interface, enum or delegate)
12516
12517         (switch_label): Report 1523 (keywords `case' or `default' must
12518         preced code)
12519
12520         (opt_switch_sections): Report 1522 (empty switch)
12521
12522         * driver.cs: Report 1515 (response file specified multiple times)
12523         Report 1516 (Source file specified multiple times).
12524
12525         * expression.cs (Argument.Resolve): Signal 1510
12526
12527         (BaseAccess.Resolve, BaseIndexer.Resolve): Signal 1511 (base
12528         access not allowed in static code)
12529
12530 2002-01-11  Ravi Pratap  <ravi@ximian.com>
12531
12532         * typemanager.cs (IsPointerType): Utility method which we are going
12533         to need a lot.
12534
12535         * ecore.cs (ImplicitReferenceConversion): A pointer type cannot be cast to
12536         the object type, so we take care of that.
12537
12538         * expression.cs (FullMethodDesc): Also include the return type in descriptions.
12539
12540         * support.cs (ParameterDesc): Fix minor bug which was causing params tags to be
12541         added to non-params parameters :-)
12542
12543         * typemanager.cs (CSharpName): Include 'void' type too. 
12544
12545         (void_ptr_type): Include in the set of core types.
12546
12547         * ecore.cs (ConvertImplicit): Make use of ConvertImplicitStandard instead of 
12548         duplicating code.
12549
12550         (ConvertImplicitStandard): Handle standard implicit pointer conversions when we have 
12551         an unsafe context.
12552
12553         * cs-parser.jay (local_variable_pointer_type): Add support for 'void *' as I had 
12554         completely forgotten about it.
12555
12556 2002-01-10  Ravi Pratap  <ravi@ximian.com>
12557
12558         * cs-parser.jay (pointer_type): Add. This begins our implementation
12559         of parsing rules for unsafe code.
12560
12561         (unsafe_statement): Implement.
12562
12563         (embedded_statement): Modify to include the above.
12564
12565         * statement.cs (Unsafe): Implement new class for unsafe blocks.
12566
12567         * codegen.cs (EmitContext.InUnsafe): Add. This determines
12568         if the current context is an unsafe one.
12569
12570         * cs-parser.jay (local_variable_pointer_type): Since local variable types
12571         are handled differently, we need separate rules for them.
12572
12573         (local_variable_declaration): Update to use local_variable_pointer_type
12574         to allow variable declarations of unmanaged pointer types.
12575
12576         * expression.cs (Unary.ResolveOperator): Ensure that the '&' operator is used only
12577         in unsafe contexts.
12578
12579         * ../errors/cs0214.cs : Add.
12580
12581 2002-01-16  Nick Drochak  <ndrochak@gol.com>
12582
12583         * makefile: remove 'response' file when cleaning.
12584
12585 2002-01-15  Miguel de Icaza  <miguel@ximian.com>
12586
12587         * cs-parser.jay: Report 1524.
12588
12589 2002-01-14  Miguel de Icaza  <miguel@ximian.com>
12590
12591         * typemanager.cs (RegisterMethod): drop checking if we have
12592         registered this from here
12593
12594 2002-01-12  Miguel de Icaza  <miguel@ximian.com>
12595
12596         * class.cs (Method.EmitDestructor): Implement calling our base
12597         destructor. 
12598
12599         * statement.cs (Try.Emit): Fix to reset the InFinally to the old
12600         value of InFinally.
12601
12602         * codegen.cs (EmitContext.EmitTopBlock): Destructors will call
12603         this routine and will wrap the call in a try/catch block.  Deal
12604         with the case.
12605
12606 2002-01-11  Miguel de Icaza  <miguel@ximian.com>
12607
12608         * ecore.cs (Expression.MemberLookup): instead of taking a
12609         parameter `same_type' that was used to tell whether we could
12610         access private members we compute our containing type from the
12611         EmitContext.
12612
12613         (FieldExpr): Added partial support for volatile fields.  This does
12614         not work for volatile fields exposed from assemblies, as I can not
12615         figure out how to extract the modreq from it.
12616
12617         Updated all the source files to use this.
12618
12619         * codegen.cs (EmitContext): Compute ContainerType ahead of time,
12620         because it is referenced by MemberLookup very often. 
12621
12622 2002-01-09  Ravi Pratap  <ravi@ximian.com>
12623
12624         * typemanager.cs (IndexerPropertyName): If we have a TypeBuilder, use
12625         TypeBuilder.GetCustomAttributes to retrieve what we need.
12626
12627         Get rid of redundant default_member_attr_type as this is the same as
12628         default_member_type which already exists.
12629
12630         * interface.cs, attribute.cs : Update accordingly.
12631
12632 2002-01-08  Miguel de Icaza  <miguel@ximian.com>
12633
12634         * typemanager.cs: Enable IndexerPropertyName again.  It does not
12635         work for TYpeBuilders though.  Ravi, can you please fix this?
12636
12637         * cs-tokenizer.cs: Accept _ as a name in pp-expressions.
12638
12639         * expression.cs (Argument.Emit): Handle the case of ref objects
12640         being passed to ref functions;  
12641
12642         (ParameterReference.EmitLoad): Loads the content of the pointer
12643         without dereferencing.
12644
12645 2002-01-07  Miguel de Icaza  <miguel@ximian.com>
12646
12647         * cs-tokenizer.cs: Implemented the pre-processing expressions.
12648
12649 2002-01-08  Ravi Pratap  <ravi@ximian.com>
12650
12651         * class.cs (Indexer.DefineMethod): Incorporate the interface
12652         type in the name of the method if we are doing explicit interface
12653         implementation.
12654
12655         * expression.cs (ConversionExists): Remove as it is completely obsolete.
12656
12657         (BetterConversion): Fix extremely trivial bug where we were referring to
12658         ConversionExists instead of StandardConversionExists ! Hooray, things are fine
12659         again !
12660
12661         * ../errors/bug16.cs : Add although we have fixed it.
12662
12663 2002-01-07  Miguel de Icaza  <miguel@ximian.com>
12664
12665         * expression.cs (BaseIndexer): Begin implementation.
12666
12667         * class.cs (TypeContainer.IsInterfaceMethod): Bug fix.
12668
12669         * cs-parser.jay (indexer_declarator): Use qualified_identifier
12670         production directly to remove a shift/reduce, and implement
12671         explicit interface implementation.
12672
12673         * cs-tokenizer.cs: Fix tokenizer, it was consuming one extra char
12674         after a floating point suffix.
12675
12676         * expression.cs (DoNumericPromotions): Improved the conversion for
12677         uint/uint.  If we have a constant, we avoid doing a typecast to a
12678         larger type.
12679
12680         * class.cs (Indexer): Implement explicit interface implementation
12681         for indexers.
12682
12683 Sat Jan 5 16:08:23 CET 2002 Paolo Molaro <lupus@ximian.com>
12684
12685         * class.cs: make the default instance constructor public and hidebysig.
12686
12687 2001-01-03  Ravi Pratap  <ravi@ximian.com>
12688
12689         * interface.cs (EmitDefaultMemberAttr): Make this helper method static
12690         so we can call it from elsewhere.
12691
12692         * class.cs (TypeContainer.Emit): Emit the attribute here too. The rule is that
12693         we emit it internally if the class has a defined indexer; otherwise the user
12694         emits it by decorating the class definition with the DefaultMemberAttribute.
12695
12696         * attribute.cs (ApplyAttributes): Perform checks to see that the DefaultMember
12697         attribute is not used on a type which defines an indexer.
12698
12699         * cs-tokenizer.cs (get_cmd_arg): Ensure we trim whitespace and also include the tab
12700         character when we skip whitespace.
12701
12702         * ../errors/cs0646.cs : Add.
12703
12704 2002-01-03  Miguel de Icaza  <miguel@ximian.com>
12705
12706         * ecore.cs (SimpleName.ResolveSimpleName): Report error 120
12707         again. 
12708
12709         * makefile: Add practical target `mcs3.exe' which builds the third
12710         generation compiler. 
12711
12712         * expression.cs (New): Fix structures constructor calling.
12713
12714         * class.cs (Property, Method, Indexer): Emit Final flag on the
12715         method if we are an interface implementation and we are not
12716         abstract. 
12717
12718         * ecore.cs (PropertyExpr): New public field `IsBase', tells
12719         whether this property is referencing a `base' method.
12720
12721         * expression.cs (Invocation.EmitCall): take an extra argument:
12722         is_base, this is used to determine whether the `call' or
12723         `callvirt' opcode should be used.
12724
12725
12726         * delegate.cs: update EmitCall.
12727
12728         * class.cs (Method.Define): Set NewSlot for the cases where we are
12729         not implementing an interface method.
12730
12731         (Property.Define): ditto.
12732
12733 2002-01-02  Miguel de Icaza  <miguel@ximian.com>
12734
12735         * cs-tokenizer.cs: (Tokenizer.escape): Escape '\r' as '\r' not as
12736         'r'.  Allows mcs to parse itself fully.
12737
12738 2002-01-02  Ravi Pratap  <ravi@ximian.com>
12739
12740         * expression.cs (ArrayCreation.num_automatic_initializers): Keep track
12741         of the number of initializers that require the InitializeArray method.
12742
12743         (CheckIndices): Store the Expression in all cases - not the plain value. Also
12744         update the above field where necessary.
12745
12746         (MakeByteBlob): Update accordingly.
12747
12748         (DoEmit): Call EmitStaticInitializers only if the number of initializers is 
12749         greater than 2.
12750
12751         (EmitDynamicInitializers): Update in accordance with the new optimization.
12752
12753         (ArrayAccess.EmitStoreOpcode): Include char type along with short and ushort - the
12754         same OpCode applies.
12755
12756         * cs-parser.jay : Fix some glaring errors I introduced.
12757
12758 2002-01-01  Ravi Pratap  <ravi@ximian.com> 
12759
12760         * parameters.cs (AddVariable, AddConstant): Pass in current_local_parameters
12761         so that we can check for name clashes there too.
12762
12763         * typemanager.cs (default_member_attr_type): The attribute that we need to emit
12764         for interface indexers.
12765
12766         * interfaces.cs (Define): Emit the default member attribute.
12767
12768         * expression.cs (MakeByteBlob): Fix extremely trivial bug where the wrong
12769         variable was being referred to while setting the value ;-)
12770
12771 2002-01-01  Miguel de Icaza  <miguel@ximian.com>
12772
12773         * expression.cs (MakeByteBlob): Optimize: we do not need to fill
12774         byte-by-byte information when we know the data is zero.
12775
12776         Make the block always a multiple of 4, because
12777         DefineInitializedData has a bug.
12778
12779         * assign.cs: Fix, we should assign from the temporary, not from
12780         the source. 
12781
12782         * expression.cs (MakeByteBlob): Fix my incorrect code.
12783
12784 2001-12-31  Miguel de Icaza  <miguel@ximian.com>
12785
12786         * typemanager.cs (EnumToUnderlying): This function is used to get
12787         the underlying type from an enumeration, because it does not
12788         always work. 
12789
12790         * constant.cs: Use the I4_S form for values between -128 and 127.
12791
12792         * statement.cs (Block.LookupLabel): Looks up a label.
12793         (Block): Drop support for labeled blocks.
12794
12795         (LabeledStatement): New kind of statement that represents a label
12796         only.
12797
12798         (Goto): Finally implement this bad boy.
12799
12800         * cs-parser.jay: Update to reflect new mechanism to implement
12801         labels.
12802
12803 2001-12-30  Miguel de Icaza  <miguel@ximian.com>
12804
12805         * codegen.cs (EmitContext.This): a codegen property that keeps the
12806         a single instance of this instead of creating many different this
12807         instances. 
12808
12809         * delegate.cs (Delegate.DoResolve): Update to use the property;
12810
12811         * ecore.cs (SimpleName.SimpleNameResolve): Ditto
12812
12813         * expression.cs (BaseAccess.DoResolve): Ditto.
12814
12815 2001-12-29  Ravi Pratap  <ravi@ximian.com>
12816
12817         * typemanager.cs (methodimpl_attr_type): Add to hold the type
12818         corresponding to System.Runtime.CompilerServices.MethodImplAttribute.
12819
12820         (InitCoreTypes): Update accordingly.
12821
12822         * attribute.cs (Resolve): Remember if the attribute is a MethodImplAttribute
12823         so we can quickly store the state.
12824
12825         (ApplyAttributes): Set the correct implementation flags
12826         for InternalCall methods.
12827
12828 2001-12-29  Miguel de Icaza  <miguel@ximian.com>
12829
12830         * expression.cs (EmitCall): if a method is not virtual, then do
12831         not use callvirt on it.
12832
12833         (ArrayAccess.EmitAssign): storing non-builtin value types (ie,
12834         user defined stuff) requires the use of stobj, which takes an
12835         address on the stack instead of an array and an index.  So emit
12836         the Ldelema operation for it.
12837
12838         (EmitStoreOpcode): Use stobj for valuetypes.
12839
12840         (UnaryMutator.EmitCode): Use the right 1 value depending on
12841         whether we are dealing with int64/uint64, float or doubles.
12842
12843         * class.cs (TypeContainer.AddConstructor): Fix the logic to define
12844         constructors that I implemented last night.
12845
12846         (Constructor.IsDefault): Fix to work properly for static
12847         constructors.
12848
12849         * cs-parser.jay (CheckDef): report method signature errors.
12850         Update error number 103 to be 132.
12851
12852         * decl.cs: New AdditionResult enumeration value: MethodExists.
12853         Although we do this check for methods later on in the semantic
12854         analysis, catching repeated default constructors is so easy that
12855         we catch these here. 
12856
12857         * expression.cs (Binary.DoNumericPromotions): Fix the uint64 type
12858         promotions code.
12859
12860         (ParameterReference.EmitAssign, Emit): handle
12861         bools as bytes.
12862
12863         (ArrayAccess.EmitLoadOpcode): Handle bool type here.
12864         (ArrayAccess.EmitStoreOpcode): ditto.
12865
12866         * cs-tokenizer.cs (is_punct): Eliminated empty computation.
12867
12868         * expression.cs (MakeByteBlob): Complete all the missing types
12869         (uint, short, ushort, byte, sbyte)
12870
12871         * class.cs: Only init instance field initializers on instance
12872         constructors. 
12873
12874         Rename `constructors' to instance_constructors. 
12875
12876         (TypeContainer.AddConstructor): Only add constructors to the list
12877         if it is not static.
12878
12879         Make sure that we handle default_static_constructor independently
12880         everywhere where we handle instance_constructors
12881
12882 2001-12-28  Miguel de Icaza  <miguel@ximian.com>
12883
12884         * class.cs: Do not lookup or create a base initializer for a
12885         static constructor.
12886
12887         (ConstructorInitializer.Resolve): use the proper type to lookup
12888         for constructors.
12889
12890         * cs-parser.jay: Report error 1585 (modifiers between type and name).
12891
12892         * enum.cs, interface.cs: Remove CloseType, this is taken care by
12893         in DeclSpace. 
12894
12895         * decl.cs: CloseType is now an virtual method, the default
12896         implementation just closes this type.
12897
12898 2001-12-28  Ravi Pratap  <ravi@ximian.com>
12899
12900         * attribute.cs (DefinePInvokeMethod): Set the implementation flags
12901         to PreserveSig by default. Also emit HideBySig on such methods.
12902
12903         Basically, set the defaults to standard values.
12904
12905         * expression.cs (Invocation.BetterFunction): We need to make sure that for each
12906         argument, if candidate is better, it can't be worse than the best !
12907
12908         (Invocation): Re-write bits to differentiate between methods being
12909         applicable in their expanded form and their normal form - for params
12910         methods of course.
12911
12912         Get rid of use_standard everywhere as only standard conversions are allowed
12913         in overload resolution. 
12914
12915         More spec conformance.
12916
12917 2001-12-27  Miguel de Icaza  <miguel@ximian.com>
12918
12919         * driver.cs: Add --timestamp, to see where the compiler spends
12920         most of its time.
12921
12922         * ecore.cs (SimpleName.DoResolve): Do not create an implicit
12923         `this' in static code.
12924
12925         (SimpleName.DoResolve): Implement in terms of a helper function
12926         that allows static-references to be passed upstream to
12927         MemberAccess.
12928
12929         (Expression.ResolveWithSimpleName): Resolve specially simple
12930         names when called by MemberAccess to implement the special
12931         semantics. 
12932
12933         (Expression.ImplicitReferenceConversion): Handle conversions from
12934         Null to reference types before others, as Null's type is
12935         System.Object. 
12936
12937         * expression.cs (Invocation.EmitCall): Handle the special case of
12938         calling methods declared on a reference type from a ValueType
12939         (Base classes System.Object and System.Enum)
12940
12941         (MemberAccess.Resolve): Only perform lookups on Enumerations if
12942         the left hand side is a TypeExpr, not on every enumeration. 
12943
12944         (Binary.Resolve): If types are reference types, then do a cast to
12945         object on operators != and == of both arguments.
12946
12947         * typemanager.cs (FindMembers): Extract instance and static
12948         members if requested.
12949
12950         * interface.cs (PopulateProperty): Use void_type instead of null
12951         as the return type for the setter method.
12952
12953         (PopulateIndexer): ditto.
12954
12955 2001-12-27  Ravi Pratap  <ravi@ximian.com>
12956
12957         * support.cs (ReflectionParameters): Fix minor bug where we
12958         were examining the wrong parameter for the ParamArray attribute.
12959
12960         Cope with requests for the type of the parameter at position
12961         greater than the params parameter's. We now return the element
12962         type of the params array as that makes more sense.
12963
12964         * expression.cs (Invocation.IsParamsMethodApplicable): Update 
12965         accordingly as we no longer have to extract the element type
12966         ourselves.
12967
12968         (Invocation.OverloadResolve): Update.
12969
12970 2001-12-27  Miguel de Icaza  <miguel@ximian.com>
12971
12972         * statement.cs (Foreach.GetEnumeratorFilter): Do not compare
12973         against IEnumerator, test whether the return value is a descendant
12974         of the IEnumerator interface.
12975
12976         * class.cs (Indexer.Define): Use an auxiliary method to implement
12977         the other bits of the method definition.  Begin support for
12978         explicit interface implementation.
12979
12980         (Property.DefineMethod): Use TypeManager.void_type instead of null
12981         for an empty return value.
12982
12983 2001-12-26  Miguel de Icaza  <miguel@ximian.com>
12984
12985         * expression.cs (MemberAccess.ResolveMemberAccess): if we are
12986         dealing with a FieldExpr which is composed of a FieldBuilder, in
12987         the code path we did extract the constant, but we should have
12988         obtained the underlying value to be able to cast it (otherwise we
12989         end up in an infinite loop, this is what Ravi was running into).
12990
12991         (ArrayCreation.UpdateIndices): Arrays might be empty.
12992
12993         (MemberAccess.ResolveMemberAccess): Add support for section
12994         14.5.4.1 that deals with the special case of E.I when E is a type
12995         and something else, that I can be a reference to a static member.
12996
12997         (ArrayCreation.MakeByteBlob): It is not an error to not be able to
12998         handle a particular array type to create byte blobs, it is just
12999         something we dont generate byteblobs for.
13000
13001         * cs-tokenizer.cs (get_cmd_arg): Ignore \r in commands and
13002         arguments. 
13003
13004         * location.cs (Push): remove the key from the hashtable that we
13005         are about to add.   This happens for empty files.
13006
13007         * driver.cs: Dispose files after we have parsed them.
13008
13009         (tokenize): new function that only runs the tokenizer on its
13010         input, for speed testing.
13011
13012 2001-12-26  Ravi Pratap  <ravi@ximian.com>
13013
13014         * class.cs (Event.Define): Define the private field only if there
13015         are no accessors defined.
13016
13017         * expression.cs (ResolveMemberAccess): If there is no associated
13018         field with the event, that means we have an event defined with its
13019         own accessors and we should flag error cs0070 since transforming
13020         ourselves into a field is not valid in that case.
13021
13022         * ecore.cs (SimpleName.DoResolve): Same as above.
13023
13024         * attribute.cs (DefinePInvokeMethod): Set the default calling convention
13025         and charset to sane values.
13026
13027 2001-12-25  Ravi Pratap  <ravi@ximian.com>
13028
13029         * assign.cs (DoResolve): Perform check on events only if they 
13030         are being accessed outside the declaring type.
13031
13032         * cs-parser.jay (event_declarations): Update rules to correctly
13033         set the type of the implicit parameter etc.
13034
13035         (add_accessor, remove_accessor): Set current local parameters.
13036
13037         * expression.cs (Binary): For delegate addition and subtraction,
13038         cast the return value from the method into the appropriate delegate
13039         type.
13040
13041 2001-12-24  Ravi Pratap  <ravi@ximian.com>
13042
13043         * typemanager.cs (RegisterDelegateData, GetDelegateData): Get rid
13044         of these as the workaround is unnecessary.
13045
13046         * delegate.cs (NewDelegate.DoResolve): Get rid of bits which registered
13047         delegate data - none of that is needed at all.
13048
13049         Re-write bits to extract the instance expression and the delegate method
13050         correctly.
13051
13052         * expression.cs (Binary.ResolveOperator): Handle the '-' binary operator 
13053         on delegates too.
13054
13055         * attribute.cs (ApplyAttributes): New method to take care of common tasks
13056         of attaching attributes instead of duplicating code everywhere.
13057
13058         * everywhere : Update code to do attribute emission using the above method.
13059
13060 2001-12-23  Miguel de Icaza  <miguel@ximian.com>
13061
13062         * expression.cs (IsParamsMethodApplicable): if there are not
13063         parameters, return immediately.
13064
13065         * ecore.cs: The 0 literal can be implicity converted to an enum
13066         type. 
13067
13068         (SimpleName.DoResolve): First lookup the type, then lookup the
13069         members. 
13070
13071         (FieldExpr.Emit): If the InstanceExpression is a ValueType, we
13072         want to get its address.  If the InstanceExpression is not
13073         addressable, store the result in a temporary variable, then get
13074         the address of it.
13075
13076         * codegen.cs: Only display 219 errors on warning level or above. 
13077
13078         * expression.cs (ArrayAccess): Make it implement the
13079         IMemoryLocation interface.
13080
13081         (Binary.DoResolve): handle the operator == (object a, object b)
13082         and operator != (object a, object b) without incurring into a
13083         BoxedCast (because 5 != o should never be performed).
13084
13085         Handle binary enumerator operators.
13086
13087         (EmitLoadOpcode): Use Ldelema if the object we are loading is a
13088         value type, otherwise use Ldelem_ref.
13089
13090         Use precomputed names;
13091
13092         (AddressOf): Implement address of
13093
13094         * cs-parser.jay (labeled_statement): Fix recursive block
13095         addition by reworking the production.
13096
13097         * expression.cs (New.DoEmit): New has a special case:
13098                 
13099                  If we are dealing with a ValueType, we have a few
13100                  situations to deal with:
13101                 
13102                     * The target of New is a ValueType variable, that is
13103                       easy, we just pass this as the variable reference
13104                 
13105                     * The target of New is being passed as an argument,
13106                       to a boxing operation or a function that takes a
13107                       ValueType.
13108                 
13109                       In this case, we need to create a temporary variable
13110                       that is the argument of New.
13111
13112
13113 2001-12-23  Ravi Pratap  <ravi@ximian.com>
13114
13115         * rootcontext.cs (LookupType): Check that current_type is not null before
13116         going about looking at nested types.
13117
13118         * ecore.cs (EventExpr.EmitAddOrRemove): Rename from EmitAssign as we do
13119         not implement the IAssignMethod interface any more.
13120
13121         * expression.cs (MemberAccess.ResolveMemberAccess): Handle EventExprs specially
13122         where we tranform them into FieldExprs if they are being resolved from within
13123         the declaring type.
13124
13125         * ecore.cs (SimpleName.DoResolve): Do the same here.
13126
13127         * assign.cs (DoResolve, Emit): Clean up code considerably. 
13128
13129         * ../errors/bug10.cs : Add.
13130
13131         * ../errors/cs0070.cs : Add.
13132
13133         * typemanager.cs : Use PtrHashtable for Delegate data hashtable etc.
13134
13135         * assign.cs : Get rid of EventIsLocal everywhere.
13136
13137 2001-12-23  Miguel de Icaza  <miguel@ximian.com>
13138
13139         * ecore.cs (ConvertIntLiteral): finished the implementation.
13140
13141         * statement.cs (SwitchLabel): Convert the value we are using as a
13142         key before looking up the table.
13143
13144 2001-12-22  Miguel de Icaza  <miguel@ximian.com>
13145
13146         * codegen.cs (EmitTopBlock): Require a Location argument now.
13147
13148         * cs-parser.jay (constructor_declarator): We need to setup
13149         current_local_parameters before we parse the
13150         opt_constructor_initializer, to allow the variables to be bound
13151         to the constructor arguments.
13152
13153         * rootcontext.cs (LookupType): First lookup nested classes in our
13154         class and our parents before we go looking outside our class.
13155
13156         * expression.cs (ConstantFold): Extract/debox the values at the
13157         beginnning. 
13158
13159         * rootcontext.cs (EmitCode): Resolve the constants first before we
13160         resolve the types.  This is not really needed, but it helps debugging.
13161
13162         * statement.cs: report location.
13163
13164         * cs-parser.jay: pass location to throw statement.
13165
13166         * driver.cs: Small bug fix.
13167
13168         * report.cs: Updated format to be 4-zero filled digits.
13169
13170 2001-12-22  Ravi Pratap  <ravi@ximian.com>
13171
13172         * expression.cs (CheckIndices): Fix minor bug where the wrong
13173         variable was being referred to ;-)
13174
13175         (DoEmit): Do not call EmitStaticInitializers when the 
13176         underlying type is System.Object.
13177
13178 2001-12-21  Ravi Pratap  <ravi@ximian.com>
13179
13180         * ecore.cs (EventExpr.Resolve): Implement to correctly set the type
13181         and do the usual workaround for SRE.
13182
13183         * class.cs (MyEventBuilder.EventType): New member to get at the type
13184         of the event, quickly.
13185
13186         * expression.cs (Binary.ResolveOperator): Handle delegate addition.
13187
13188         * assign.cs (Assign.DoResolve): Handle the case when the target
13189         is an EventExpr and perform the necessary checks.
13190
13191         * ecore.cs (EventExpr.EmitAssign): Implement the IAssignMethod
13192         interface.
13193
13194         (SimpleName.MemberStaticCheck): Include check for EventExpr.
13195
13196         (EventExpr): Set the type in the constructor itself since we 
13197         are meant to be born fully resolved.
13198
13199         (EventExpr.Define): Revert code I wrote earlier.
13200                 
13201         * delegate.cs (NewDelegate.Resolve): Handle the case when the MethodGroup's
13202         instance expression is null. The instance expression is a This in that case
13203         or a null, depending on whether it is a static method or not.
13204
13205         Also flag an error if the reference to a method is ambiguous i.e the MethodGroupExpr
13206         refers to more than one method.
13207
13208         * assign.cs (DoResolve): Check whether the event belongs to the same Type container
13209         and accordingly flag errors.
13210
13211 2001-12-21  Miguel de Icaza  <miguel@ximian.com>
13212
13213         * statement.cs (Throw.Emit): Add support for re-throwing exceptions.
13214
13215 2001-12-22  Miguel de Icaza  <miguel@ximian.com>
13216
13217         * location.cs (ToString): Provide useful rutine.
13218
13219 2001-12-21  Miguel de Icaza  <miguel@ximian.com>
13220
13221         * ecore.cs (Expression.ConvertIntLiteral): Do not return Constant
13222         objects, return the actual integral boxed.
13223
13224         * statement.cs (SwitchLabel): define an ILLabel for each
13225         SwitchLabel. 
13226
13227         (Switch.CheckSwitch): If the value is a Literal, extract
13228         the underlying literal.
13229
13230         Also in the unused hashtable we had, add the SwitchLabel so we can
13231         quickly look this value up.
13232
13233         * constant.cs: Implement a bunch of new constants.  Rewrite
13234         Literal based on this.  Made changes everywhere to adapt to this.
13235
13236         * expression.cs (Expression.MakeByteBlob): Optimize routine by
13237         dereferencing array only once, and also copes with enumrations.
13238
13239         bytes are two bytes wide, not one.
13240
13241         (Cast): Perform constant conversions.
13242
13243         * ecore.cs (TryImplicitIntConversion): Return literals instead of
13244         wrappers to the literals here.
13245
13246         * expression.cs (DoNumericPromotions): long literals can converted
13247         to ulong implicity (this is taken care of elsewhere, but I was
13248         missing this spot).
13249
13250         * ecore.cs (Expression.Literalize): Make the return type Literal,
13251         to improve type checking.
13252
13253         * rootcontext.cs: Lookup for nested classes in our class hierarchy.
13254
13255 2001-12-20  Miguel de Icaza  <miguel@ximian.com>
13256
13257         * literal.cs: Revert code from ravi that checked the bounds.  The
13258         bounds are sane by the definition of the type itself. 
13259
13260         * typemanager.cs: Fix implementation of ImplementsInterface.  We
13261         need to actually look up in our parent hierarchy for interfaces
13262         implemented. 
13263
13264         * const.cs: Use the underlying type for enumerations
13265
13266         * delegate.cs: Compute the basename for the delegate creation,
13267         that should fix the delegate test case, and restore the correct
13268         Type Lookup semantics in rootcontext
13269
13270         * rootcontext.cs: Revert Ravi's last patch.  The correct way of
13271         referencing a nested type with the Reflection API is using the "+"
13272         sign. 
13273
13274         * cs-parser.jay: Do not require EOF token at the end.
13275
13276 2001-12-20  Ravi Pratap  <ravi@ximian.com>
13277
13278         * rootcontext.cs (LookupType): Concatenate type names with
13279         a '.' instead of a '+' The test suite passes again.
13280
13281         * enum.cs (Enum.DefineEnum): Set RTSpecialName on the 'value__'
13282         field of the enumeration.
13283
13284         * expression.cs (MemberAccess.ResolveMemberAccess): Add support for
13285         the case when the member is an EventExpr.
13286
13287         * ecore.cs (EventExpr.InstanceExpression): Every event which is not
13288         static has an associated instance expression.
13289
13290         * typemanager.cs (RegisterEvent): The usual workaround, now for events.
13291
13292         (GetAddMethod, GetRemoveMethod): Workarounds, as usual.
13293
13294         * class.cs (Event.Define): Register event and perform appropriate checks
13295         for error #111.
13296
13297         We define the Add and Remove methods even if the use provides none because
13298         in that case, we provide default implementations ourselves.
13299
13300         Define a private field of the type of the event. This is done by the CSC compiler
13301         and we should be doing it too ;-)
13302
13303         * typemanager.cs (delegate_combine_delegate_delegate, delegate_remove_delegate_delegate):
13304         More methods we use in code we generate.
13305
13306         (multicast_delegate_type, delegate_type): Two separate types since the distinction
13307         is important.
13308
13309         (InitCoreTypes): Update accordingly for the above.
13310
13311         * class.cs (Event.Emit): Generate code for default accessors that we provide
13312
13313         (EmitDefaultMethod): Do the job in the above.
13314
13315         * delegate.cs (DefineDelegate): Use TypeManager.multicast_delegate_type in the 
13316         appropriate place.
13317
13318 2001-12-20  Miguel de Icaza  <miguel@ximian.com>
13319
13320         * class.cs (Indexer.Define): Fix bug, we were setting both Get/Set
13321         builders even if we were missing one.
13322
13323         * interface.cs, class.cs, enum.cs: When calling DefineNestedType
13324         pass the Basename as our class name instead of the Name.  The
13325         basename will be correctly composed for us.
13326
13327         * parameter.cs (Paramters): Now takes a Location argument.
13328
13329         * decl.cs (DeclSpace.LookupType): Removed convenience function and
13330         make all the code call directly LookupType in RootContext and take
13331         this chance to pass the Location information everywhere.
13332
13333         * Everywhere: pass Location information.
13334
13335 2001-12-19  Miguel de Icaza  <miguel@ximian.com>
13336
13337         * class.cs (Constructor.Define): Updated way of detecting the
13338         length of the parameters.
13339
13340         (TypeContainer.DefineType): Use basename as the type name for
13341         nested types.
13342
13343         (TypeContainer.Define): Do not recursively define types here, as
13344         definition is taken care in order by the RootContext.
13345
13346         * tree.cs: Keep track of namespaces in a per-file basis.
13347
13348         * parameter.cs (Parameter.ComputeSignature): Update to use
13349         DeclSpace. 
13350
13351         (Parameters.GetSignature): ditto.
13352
13353         * interface.cs (InterfaceMethod.GetSignature): Take a DeclSpace
13354         instead of a TypeContainer.
13355
13356         (Interface.SemanticAnalysis): Use `this' instead of our parent to
13357         resolve names.  Because we need to be resolve in our context, not
13358         our parents.
13359
13360         * driver.cs: Implement response files.
13361
13362         * class.cs (TypeContainer.DefineType): If we are defined, do not
13363         redefine ourselves.
13364
13365         (Event.Emit): Emit the code for add/remove handlers.
13366         (Event.Define): Save the MethodBuilders for add/remove.
13367
13368         * typemanager.cs: Use pair here too.
13369
13370         * cs-parser.jay: Replaced use of DictionaryEntry for Pair because
13371         DictionaryEntry requires the first argument to be non-null.  
13372
13373         (enum_declaration): Compute full name for registering the
13374         enumeration.
13375
13376         (delegate_declaration): Instead of using
13377         formal_parameter_list, use opt_formal_parameter_list as the list
13378         can be empty.
13379
13380         * cs-tokenizer.cs (PropertyParsing): renamed from `properties'
13381         (EventParsing): New property that controls whether `add' and
13382         `remove' are returned as tokens or identifiers (for events);
13383
13384 2001-12-19  Ravi Pratap  <ravi@ximian.com>
13385
13386         * class.cs (Event.Define): Revamp use of EventBuilder completely. We now
13387         use MyEventBuilder only and let it wrap the real builder for us.
13388
13389         (MyEventBuilder): Revamp constructor etc.
13390
13391         Implement all operations that we perform on EventBuilder in precisely the same
13392         way here too.
13393
13394         (FindMembers): Update to use the EventBuilder member.
13395
13396         (Event.Emit): Update accordingly.
13397
13398 2001-12-18  Ravi Pratap  <ravi@ximian.com>
13399
13400         * class.cs (MyEventBuilder.Set*): Chain to the underlying builder
13401         by calling the appropriate methods.
13402
13403         (GetCustomAttributes): Make stubs as they cannot possibly do anything
13404         useful.
13405
13406         (Event.Emit): Use MyEventBuilder everywhere - even to set attributes.
13407
13408 2001-12-17  Ravi Pratap  <ravi@ximian.com>
13409
13410         * delegate.cs (Delegate.Populate): Check that the return type
13411         and various parameters types are indeed accessible.
13412
13413         * class.cs (Constructor.Define): Same here.
13414
13415         (Field.Define): Ditto.
13416
13417         (Event.Define): Ditto.
13418
13419         (Operator.Define): Check that the underlying Method defined itself
13420         correctly - so it's MethodBuilder should not be null.
13421
13422         * delegate.cs (DelegateInvocation.DoResolve): Bale out if the type of the Instance
13423         expression happens to be null.
13424
13425         * class.cs (MyEventBuilder): Workaround for SRE lameness. Implement various abstract
13426         members but as of now we don't seem to be able to do anything really useful with it.
13427
13428         (FindMembers): Handle events separately by returning the MyEventBuilder of the event,
13429         not the EventBuilder.
13430
13431 2001-12-18  Miguel de Icaza  <miguel@ximian.com>
13432
13433         * cs-tokenizer.cs: Add support for defines.
13434         Add support for #if, #elif, #else, #endif
13435
13436         (eval_var): evaluates a variable.
13437         (eval): stubbed for evaluating functions.
13438
13439         * cs-parser.jay: Pass the defines information
13440
13441         * driver.cs: Add --define command line option.
13442
13443         * decl.cs: Move MemberCore here.
13444
13445         Make it the base class for DeclSpace.  This allows us to catch and
13446         report 108 and 109 for everything now.
13447
13448         * class.cs (TypeContainer.Define): Extract all the members
13449         before populating and emit the warning 108 (new keyword required
13450         to override) instead of having each member implement this.
13451
13452         (MemberCore.Define): New abstract method, we will be using this in
13453         the warning reporting engine in Populate.
13454
13455         (Operator.Define): Adjust to new MemberCore protocol. 
13456
13457         * const.cs (Const): This does not derive from Expression, it is a
13458         temporary object we use to create fields, it is a MemberCore. 
13459
13460         * class.cs (Method.Define): Allow the entry point to be in a
13461         specific class.
13462
13463         * driver.cs: Rewrite the argument handler to clean it up a bit.
13464
13465         * rootcontext.cs: Made it just an auxiliary namespace feature by
13466         making everything static.
13467
13468         * driver.cs: Adapt code to use RootContext type name instead of
13469         instance variable.
13470
13471         * delegate.cs: Remove RootContext argument.
13472
13473         * class.cs: (Struct, TypeContainer, Class): Remove RootContext
13474         argument. 
13475
13476         * class.cs (Event.Define): The lookup can fail.
13477
13478         * cs-tokenizer.cs: Begin implementation of pre-procesor. 
13479
13480         * expression.cs: Resolve the this instance before invoking the code.
13481
13482 2001-12-17  Miguel de Icaza  <miguel@ximian.com>
13483
13484         * cs-parser.jay: Add a production in element_access that allows
13485         the thing to become a "type" reference.  This way we can parse
13486         things like "(string [])" as a type.
13487
13488         Note that this still does not handle the more complex rules of
13489         casts. 
13490
13491
13492         * delegate.cs (Delegate.Populate): Register the delegage constructor builder here. 
13493
13494         * ecore.cs: (CopyNewMethods): new utility function used to
13495         assemble the list of methods from running FindMembers.
13496
13497         (MemberLookup): Rework FindMembers so that 
13498
13499 2001-12-16  Miguel de Icaza  <miguel@ximian.com>
13500
13501         * class.cs (TypeContainer): Remove Delegates who fail to be
13502         defined.
13503
13504         * delegate.cs (Populate): Verify that we dont get null return
13505         values.   TODO: Check for AsAccessible.
13506
13507         * cs-parser.jay: Use basename to emit error 574 (destructor should
13508         have the same name as container class), not the full name.
13509
13510         * cs-tokenizer.cs (adjust_int): Fit the integer in the best
13511         possible representation.  
13512
13513         Also implements integer type suffixes U and L.
13514
13515 2001-12-15  Miguel de Icaza  <miguel@ximian.com>
13516
13517         * expression.cs (ArrayCreation.DoResolve): We need to do the
13518         argument resolution *always*.
13519
13520         * decl.cs: Make this hold the namespace.  Hold the root context as
13521         well.
13522         (LookupType): Move here.
13523
13524         * enum.cs, class.cs, interface.cs: Adapt to new hierarchy.
13525
13526         * location.cs (Row, Name): Fixed the code, it was always returning
13527         references to the first file.
13528
13529         * interface.cs: Register properties defined through interfaces.
13530
13531         * driver.cs: Add support for globbing on the command line
13532
13533         * class.cs (Field): Make it derive from MemberCore as well.
13534         (Event): ditto.
13535
13536 2001-12-15  Ravi Pratap  <ravi@ximian.com>
13537
13538         * class.cs (Event::Define): Check that the type of the event is a delegate
13539         type else flag error #66.
13540
13541         Also, re-use TypeContainer.MethodModifiersValid here too as the rules are the
13542         same.
13543
13544         * attribute.cs (DefinePInvokeMethod): Handle named arguments and process
13545         values of EntryPoint, CharSet etc etc.
13546
13547         Pass in the values to TypeBuilder.DefinePInvokeMethod; determine Type etc neatly.
13548
13549         * class.cs (FindMembers): If a method is in transit, its MethodBuilder will
13550         be null and we should ignore this. I am not sure if this is really clean. Apparently,
13551         there's no way of avoiding hitting this because the call is coming from SimpleName.DoResolve,
13552         which needs this to do its work.
13553
13554         * ../errors/cs0066.cs : Add.
13555
13556 2001-12-14  Miguel de Icaza  <miguel@ximian.com>
13557
13558         * typemanager.cs: (GetPropertyGetter, GetPropertyGetter): New
13559         helper functions.
13560
13561         * class.cs: (MethodSignature.MethodSignature): Removed hack that
13562         clears out the parameters field.
13563         (MemberSignatureCompare): Cleanup
13564
13565         (MemberCore): New base class used to share code between MethodCore
13566         and Property.
13567
13568         (RegisterRequiredImplementations) BindingFlags.Public requires
13569         either BindingFlags.Instace or Static.  Use instance here.
13570
13571         (Property): Refactored code to cope better with the full spec.
13572
13573         * parameter.cs (GetParameterInfo): Return an empty array instead
13574         of null on error.
13575
13576         * class.cs (Property): Abstract or extern properties have no bodies.
13577
13578         * parameter.cs (GetParameterInfo): return a zero-sized array.
13579
13580         * class.cs (TypeContainer.MethodModifiersValid): Move all the
13581         method modifier validation to the typecontainer so we can reuse
13582         this on properties.
13583
13584         (MethodCore.ParameterTypes): return an empty sized array of types.
13585
13586         (Property.Define): Test property modifier validity.
13587
13588         Add tests for sealed/override too.
13589
13590         (Method.Emit): abstract or extern methods have no bodies.
13591
13592 2001-12-14  Ravi Pratap  <ravi@ximian.com>
13593
13594         * class.cs (Method.IsPInvoke): Get rid of it as it is an expensive
13595         thing.
13596
13597         (Method::Define, ::Emit): Modify accordingly.
13598
13599         * expression.cs (Invocation::OverloadResolve): Handle error # 121.
13600
13601         (ArrayCreation::MakeByteBlob): Handle floats and doubles.
13602
13603         * makefile: Pass in /unsafe.
13604
13605 2001-12-13  Miguel de Icaza  <miguel@ximian.com>
13606
13607         * class.cs (MakeKey): Kill routine.
13608
13609         * class.cs (TypeContainer.Define): Correctly define explicit
13610         method implementations (they require the full interface name plus
13611         the method name).
13612
13613         * typemanager.cs: Deply the PtrHashtable here and stop using the
13614         lame keys.  Things work so much better.
13615
13616         This of course broke everyone who depended on `RegisterMethod' to
13617         do the `test for existance' test.  This has to be done elsewhere.
13618
13619         * support.cs (PtrHashtable): A hashtable that avoid comparing with
13620         the object stupid Equals method (because, that like fails all over
13621         the place).  We still do not use it.
13622
13623         * class.cs (TypeContainer.SetRequiredInterface,
13624         TypeContainer.RequireMethods): Killed these two routines and moved
13625         all the functionality to RegisterRequiredImplementations.
13626
13627         (TypeContainer.RegisterRequiredImplementations): This routine now
13628         registers all the implementations required in an array for the
13629         interfaces and abstract methods.  We use an array of structures
13630         which can be computed ahead of time to reduce memory usage and we
13631         also assume that lookups are cheap as most classes will not
13632         implement too many interfaces.
13633
13634         We also avoid creating too many MethodSignatures.
13635
13636         (TypeContainer.IsInterfaceMethod): Update and optionally does not
13637         clear the "pending" bit if we find that there are problems with
13638         the declaration.
13639
13640         (TypeContainer.VerifyPendingMethods): Update to report errors of
13641         methods that look like implementations but are not.
13642
13643         (TypeContainer.Define): Add support for explicit interface method
13644         implementation. 
13645
13646 2001-12-12  Miguel de Icaza  <miguel@ximian.com>
13647
13648         * typemanager.cs: Keep track of the parameters here instead of
13649         being a feature of the TypeContainer.
13650
13651         * class.cs: Drop the registration of parameters here, as
13652         InterfaceMethods are also interface declarations.
13653
13654         * delegate.cs: Register methods with the TypeManager not only with
13655         the TypeContainer.  This code was buggy.
13656
13657         * interface.cs: Full registation here.
13658
13659 2001-12-11  Miguel de Icaza  <miguel@ximian.com>
13660
13661         * expression.cs: Remove reducer for binary expressions, it can not
13662         be done this way.
13663
13664         * const.cs: Put here the code that used to go into constant.cs
13665
13666         * constant.cs: Put here the code for constants, this is a new base
13667         class for Literals.
13668
13669         * literal.cs: Make Literal derive from Constant.
13670
13671 2001-12-09  Miguel de Icaza  <miguel@ximian.com>
13672
13673         * statement.cs (Return.Emit): Report error 157 if the user
13674         attempts to return from a finally block.
13675
13676         (Return.Emit): Instead of emitting a return, jump to the end of
13677         the function.
13678
13679         * codegen.cs (EmitContext): ReturnValue, ReturnLabel: new
13680         LocalBuilder to store the result of the function.  ReturnLabel is
13681         the target where we jump.
13682
13683
13684 2001-12-09  Radek Doulik  <rodo@ximian.com>
13685
13686         * cs-parser.jay: remember alias in current namespace
13687
13688         * ecore.cs (SimpleName::DoResolve): use aliases for types or
13689         namespaces
13690
13691         * class.cs (LookupAlias): lookup alias in my_namespace
13692
13693         * namespace.cs (UsingAlias): add alias, namespace_or_type pair to
13694         aliases hashtable
13695         (LookupAlias): lookup alias in this and if needed in parent
13696         namespaces
13697
13698 2001-12-08  Miguel de Icaza  <miguel@ximian.com>
13699
13700         * support.cs: 
13701
13702         * rootcontext.cs: (ModuleBuilder) Made static, first step into
13703         making things static.  I need this to avoid passing the
13704         TypeContainer when calling ParameterType.
13705
13706         * support.cs (InternalParameters.ParameterType): Remove ugly hack
13707         that did string manipulation to compute the type and then call
13708         GetType.  Use Parameter.ParameterType instead.
13709
13710         * cs-tokenizer.cs: Consume the suffix for floating values.
13711
13712         * expression.cs (ParameterReference): figure out whether this is a
13713         reference parameter or not.  Kill an extra variable by computing
13714         the arg_idx during emission.
13715
13716         * parameter.cs (Parameters.GetParameterInfo): New overloaded
13717         function that returns whether a parameter is an out/ref value or not.
13718
13719         (Parameter.ParameterType): The type of the parameter (base,
13720         without ref/out applied).
13721
13722         (Parameter.Resolve): Perform resolution here.
13723         (Parameter.ExternalType): The full type (with ref/out applied).
13724
13725         * statement.cs (Using.Emit, Using.EmitExpression): Implement
13726         support for expressions on the using statement.
13727
13728 2001-12-07  Miguel de Icaza  <miguel@ximian.com>
13729
13730         * statement.cs (Using.EmitLocalVariableDecls): Split the
13731         localvariable handling of the using statement.
13732
13733         (Block.EmitMeta): Keep track of variable count across blocks.  We
13734         were reusing slots on separate branches of blocks.
13735
13736         (Try.Emit): Emit the general code block, we were not emitting it. 
13737
13738         Check the type of the declaration to be an IDisposable or
13739         something that can be implicity converted to it. 
13740
13741         Emit conversions if required.
13742
13743         * ecore.cs (EmptyExpression): New utility class.
13744         (Expression.ImplicitConversionExists): New utility function.
13745
13746 2001-12-06  Miguel de Icaza  <miguel@ximian.com>
13747
13748         * statement.cs (Using): Implement.
13749
13750         * expression.cs (LocalVariableReference): Support read only variables.
13751
13752         * statement.cs: Remove the explicit emit for the Leave opcode.
13753         (VariableInfo): Add a readonly field.
13754
13755 2001-12-05  Miguel de Icaza  <miguel@ximian.com>
13756
13757         * ecore.cs (ConvCast): new class used to encapsulate the various
13758         explicit integer conversions that works in both checked and
13759         unchecked contexts.
13760
13761         (Expression.ConvertNumericExplicit): Use new ConvCast class to
13762         properly generate the overflow opcodes.
13763
13764 2001-12-04  Miguel de Icaza  <miguel@ximian.com>
13765
13766         * statement.cs: The correct type for the EmptyExpression is the
13767         element_type, not the variable type.  Ravi pointed this out.
13768
13769 2001-12-04  Ravi Pratap  <ravi@ximian.com>
13770
13771         * class.cs (Method::Define): Handle PInvoke methods specially
13772         by using DefinePInvokeMethod instead of the usual one.
13773
13774         * attribute.cs (DefinePInvokeMethod): Implement as this is what is called
13775         above to do the task of extracting information and defining the method.
13776
13777 2001-12-04  Ravi Pratap  <ravi@ximian.com>
13778
13779         * expression.cs (ArrayCreation::EmitStaticInitializers): Get rid
13780         of the condition for string type.
13781
13782         (Emit): Move that here. 
13783
13784         (ArrayCreation::CheckIndices): Keep string literals in their expression
13785         form.
13786
13787         (EmitDynamicInitializers): Handle strings appropriately.
13788
13789 2001-12-04  Miguel de Icaza  <miguel@ximian.com>
13790
13791         * codegen.cs (EmitContext): Replace multiple variables with a
13792         single pointer to the current Switch statement.
13793
13794         * statement.cs (GotoDefault, Switch): Adjust to cleaned up
13795         EmitContext.
13796
13797 2001-12-03  Miguel de Icaza  <miguel@ximian.com>
13798
13799         * statement.cs 
13800
13801         * statement.cs (GotoDefault), cs-parser.jay: Implement `goto
13802         default'.
13803
13804         (Foreach.Emit): Foreach on arrays was not setting
13805         up the loop variables (for break/continue).
13806
13807         (GotoCase): Semi-implented.
13808
13809 2001-12-03  Ravi Pratap  <ravi@ximian.com>
13810
13811         * attribute.cs (CheckAttribute): Handle system attributes by using
13812         Attribute.GetAttributes to examine information we need.
13813
13814         (GetValidPlaces): Same here.
13815
13816         * class.cs (Method::Define): Catch invalid use of extern and abstract together.
13817
13818         * typemanager.cs (dllimport_type): Core type for System.DllImportAttribute.
13819
13820         * class.cs (Method.IsPinvoke): Used to determine if we are a PInvoke method.
13821
13822         (Method::Define): Set appropriate flags if we have a DllImport attribute.
13823
13824         (Method::Emit): Handle the case when we are a PInvoke method.
13825
13826 2001-12-03  Miguel de Icaza  <miguel@ximian.com>
13827
13828         * expression.cs: Use ResolveWithSimpleName on compound names.
13829
13830 2001-12-02  Ravi Pratap  <ravi@ximian.com>
13831
13832         * constant.cs (EmitConstant): Make sure we resolve the associated expression
13833         before trying to reduce it.
13834
13835         * typemanager.cs (RegisterConstant, LookupConstant): Implement.
13836
13837         * constant.cs (LookupConstantValue): Implement.
13838
13839         (EmitConstant): Use the above in emitting the constant.
13840
13841         * expression.cs (MemberAccess::ResolveMemberAccess): Handle constants
13842         that are user-defined by doing a LookupConstantValue on them.
13843
13844         (SimpleName::DoResolve): When we have a FieldExpr, cope with constants
13845         too, like above.
13846
13847 2001-11-29  Miguel de Icaza  <miguel@ximian.com>
13848
13849         * expression.cs (BaseAccess, BaseIndexer): Also split this out.
13850
13851         (BaseAccess.DoResolve): Implement.
13852
13853         (MemberAccess.DoResolve): Split this routine into a
13854         ResolveMemberAccess routine that can be used independently
13855
13856 2001-11-28  Miguel de Icaza  <miguel@ximian.com>
13857
13858         * expression.cs (Probe, Is, As): Split Probe in two classes Is and
13859         As that share bits of the implementation.  Is returns a boolean,
13860         while As returns the Type that is being probed.
13861
13862 2001-12-01  Ravi Pratap  <ravi@ximian.com>
13863
13864         * enum.cs (LookupEnumValue): Re-write various bits, return an object value
13865         instead of a Literal - much easier.
13866
13867         (EnumInTransit): Remove - utterly useless :-)
13868
13869         (Populate): Re-write bits - remove duplicate code etc. The code is much neater now.
13870
13871         * expression.cs (MemberLookup): Cope with user-defined enums when they are in transit.
13872
13873         * enum.cs (LookupEnumValue): Auto-compute next values by going down the dependency
13874         chain when we have no associated expression.
13875
13876 2001-11-30  Ravi Pratap  <ravi@ximian.com>
13877
13878         * constant.cs (Define): Use Location while reporting the errror.
13879
13880         Also emit a warning when 'new' is used and there is no inherited
13881         member to hide.
13882
13883         * enum.cs (EnumInTransit): Used to tell if an enum type is in the process of being 
13884         populated.
13885
13886         (LookupEnumValue): Implement to lookup an enum member's value and define it
13887         if necessary.
13888
13889         (Populate): Re-write accordingly to use the above routine.
13890
13891 2001-11-27  Miguel de Icaza  <miguel@ximian.com>
13892
13893         * expression.cs (This): Fix prototype for DoResolveLValue to
13894         override the base class DoResolveLValue.
13895
13896         * cs-parser.cs: Report errors cs574 and cs575 (destructor
13897         declarations) 
13898
13899         * ecore.cs (FieldExpr.EmitAssign): Handle value types specially
13900         (we need to load the address of the field here).  This fixes
13901         test-22. 
13902
13903         (FieldExpr.DoResolveLValue): Call the DoResolve
13904         function to initialize the Instance expression.
13905
13906         * statement.cs (Foreach.Emit): Fix the bug where we did not invoke
13907         correctly the GetEnumerator operation on a value type.
13908
13909         * cs-parser.jay: Add more simple parsing error catches.
13910
13911         * statement.cs (Switch): Add support for string switches.
13912         Handle null specially.
13913
13914         * literal.cs (NullLiteral): Make NullLiteral objects singletons. 
13915
13916 2001-11-28  Ravi Pratap  <ravi@ximian.com>
13917
13918         * cs-parser.jay (local_constant_declaration): Use declare_local_constant.
13919
13920         (declare_local_constant): New helper function.
13921
13922         * statement.cs (AddConstant): Keep a separate record of constants
13923
13924         (IsConstant): Implement to determine if a variable is a constant.
13925
13926         (GetConstantExpression): Implement.
13927
13928         * expression.cs (LocalVariableReference): Handle the case when it is a constant.
13929
13930         * statement.cs (IsVariableDefined): Re-write.
13931
13932 2001-11-27  Ravi Pratap  <ravi@ximian.com>
13933
13934         * class.cs (TypeContainer::FindMembers): Look for constants
13935         in the case when we are looking for MemberTypes.Field
13936
13937         * expression.cs (MemberAccess::DoResolve): Check that in the
13938         case we are a FieldExpr and a Literal, we are not being accessed
13939         by an instance reference.
13940
13941         * cs-parser.jay (local_constant_declaration): Implement.
13942
13943         (declaration_statement): Implement for constant declarations.
13944
13945 2001-11-26  Miguel de Icaza  <miguel@ximian.com>
13946
13947         * statement.cs (Switch): Catch double defaults.
13948
13949         (Switch): More work on the switch() statement
13950         implementation.  It works for integral values now, need to finish
13951         string support.
13952
13953
13954 2001-11-24  Miguel de Icaza  <miguel@ximian.com>
13955
13956         * ecore.cs (Expression.ConvertIntLiteral): New function to convert
13957         integer literals into other integer literals.  To be used by
13958         switch. 
13959
13960 2001-11-24  Ravi Pratap  <ravi@ximian.com>
13961
13962         * expression.cs (ArrayCreation): Get rid of ArrayExprs : we save
13963         some memory.
13964
13965         (EmitDynamicInitializers): Cope with the above since we extract data
13966         directly from ArrayData now.
13967
13968         (ExpectInitializers): Keep track of whether initializers are mandatory
13969         or not.
13970
13971         (Bounds): Make it a hashtable to prevent the same dimension being 
13972         recorded for every element in that dimension.
13973
13974         (EmitDynamicInitializers): Fix bug which prevented the Set array method
13975         from being found.
13976
13977         Also fix bug which was causing the indices to be emitted in the reverse
13978         order.
13979
13980 2001-11-24  Miguel de Icaza  <miguel@ximian.com>
13981
13982         * expression.cs (ArrayCreation): Implement the bits that Ravi left
13983         unfinished.  They do not work, because the underlying code is
13984         sloppy.
13985
13986 2001-11-22  Miguel de Icaza  <miguel@ximian.com>
13987
13988         * cs-parser.jay: Remove bogus fixme.
13989
13990         * statement.cs (Switch, SwitchSection, SwithLabel): Started work
13991         on Switch statement.
13992
13993 2001-11-23  Ravi Pratap  <ravi@ximian.com>
13994
13995         * typemanager.cs (IsDelegateType, IsEnumType): Fix logic to determine
13996         the same. 
13997
13998         * expression.cs (ArrayCreation::CheckIndices): Get rid of the require_constant
13999         parameter. Apparently, any expression is allowed. 
14000
14001         (ValidateInitializers): Update accordingly.
14002
14003         (CheckIndices): Fix some tricky bugs thanks to recursion.
14004
14005         * delegate.cs (NewDelegate::DoResolve): Re-write large portions as 
14006         I was being completely brain-dead.
14007
14008         (VerifyMethod, VerifyApplicability, VerifyDelegate): Make static
14009         and re-write acordingly.
14010
14011         (DelegateInvocation): Re-write accordingly.
14012
14013         * expression.cs (ArrayCreation::Emit): Handle string initialization separately.
14014
14015         (MakeByteBlob): Handle types more correctly.
14016
14017         * expression.cs (ArrayCreation:Emit): Write preliminary code to do
14018         initialization from expressions but it is incomplete because I am a complete
14019         Dodo :-|
14020
14021 2001-11-22  Miguel de Icaza  <miguel@ximian.com>
14022
14023         * statement.cs (If.Emit): Fix a bug that generated incorrect code
14024         on If.  Basically, we have to return `true' (ie, we do return to
14025         our caller) only if both branches of the if return.
14026
14027         * expression.cs (Binary.Emit): LogicalOr and LogicalAnd are
14028         short-circuit operators, handle them as short circuit operators. 
14029
14030         (Cast.DoResolve): Resolve type.
14031         (Cast.Cast): Take an expression as the target type.
14032
14033         * cs-parser.jay (cast_expression): Remove old hack that only
14034         allowed a limited set of types to be handled.  Now we take a
14035         unary_expression and we resolve to a type during semantic
14036         analysis.
14037
14038         Use the grammar productions from Rhys to handle casts (this is
14039         not complete like Rhys syntax yet, we fail to handle that corner
14040         case that C# has regarding (-x), but we will get there.
14041
14042 2001-11-22  Ravi Pratap  <ravi@ximian.com>
14043
14044         * class.cs (EmitFieldInitializer): Take care of the case when we have a
14045         field which is an array type.
14046
14047         * cs-parser.jay (declare_local_variables): Support array initialization too.
14048
14049         * typemanager.cs (MakeKey): Implement.
14050
14051         (everywhere): Use the above appropriately.
14052
14053         * cs-parser.jay (for_statement): Update for array initialization while
14054         declaring variables.
14055
14056         * ecore.cs : The error message was correct, it's the variable's names that
14057         were misleading ;-) Make the code more readable.
14058
14059         (MemberAccess::DoResolve): Fix the code which handles Enum literals to set
14060         the correct type etc.
14061
14062         (ConvertExplicit): Handle Enum types by examining the underlying type.
14063
14064 2001-11-21  Ravi Pratap  <ravi@ximian.com>
14065
14066         * parameter.cs (GetCallingConvention): Always return
14067         CallingConventions.Standard for now.
14068
14069 2001-11-22  Miguel de Icaza  <miguel@ximian.com>
14070
14071         * expression.cs (Binary.ResolveOperator): Update the values of `l'
14072         and `r' after calling DoNumericPromotions.
14073
14074         * ecore.cs: Fix error message (the types were in the wrong order).
14075
14076         * statement.cs (Foreach.ProbeCollectionType): Need to pass
14077         BindingFlags.Instance as well 
14078
14079         * ecore.cs (Expression.TryImplicitIntConversion): Wrap the result
14080         implicit int literal conversion in an empty cast so that we
14081         propagate the right type upstream.
14082
14083         (UnboxCast): new class used to unbox value types.
14084         (Expression.ConvertExplicit): Add explicit type conversions done
14085         by unboxing.
14086
14087         (Expression.ImplicitNumericConversion): Oops, forgot to test for
14088         the target type before applying the implicit LongLiterals to ULong
14089         literal cast.
14090
14091 2001-11-21  Miguel de Icaza  <miguel@ximian.com>
14092
14093         * cs-parser.jay (for_statement): Reworked the way For works: now
14094         we declare manually any variables that are introduced in
14095         for_initializer to solve the problem of having out-of-band code
14096         emition (that is what got for broken).
14097
14098         (declaration_statement): Perform the actual variable declaration
14099         that used to be done in local_variable_declaration here.
14100
14101         (local_variable_declaration): Do not declare anything, just pass
14102         the information on a DictionaryEntry
14103
14104 2001-11-20  Ravi Pratap  <ravi@ximian.com>
14105
14106         * expression.cs (ArrayCreation::CheckIndices): The story continues :-) Complete
14107         re-write of the logic to now make it recursive.
14108
14109         (UpdateIndices): Re-write accordingly.
14110
14111         Store element data in a separate ArrayData list in the above methods.
14112
14113         (MakeByteBlob): Implement to dump the array data into a byte array.
14114
14115 2001-11-19  Ravi Pratap  <ravi@ximian.com>
14116
14117         * expression.cs (ArrayCreation): Factor out some code from ValidateInitializers
14118         into CheckIndices.
14119
14120         * constant.cs (Define): Implement.
14121
14122         (EmitConstant): Re-write fully.
14123
14124         Pass in location info.
14125
14126         * class.cs (Populate, Emit): Call Constant::Define and Constant::EmitConstant
14127         respectively.
14128
14129         * cs-parser.jay (constant_declarator): Use VariableDeclaration instead of
14130         DictionaryEntry since we need location info too.
14131
14132         (constant_declaration): Update accordingly.
14133
14134         * expression.cs (ArrayCreation): Make ValidateInitializers simpler by factoring
14135         code into another method : UpdateIndices.
14136
14137 2001-11-18  Ravi Pratap  <ravi@ximian.com>
14138
14139         * expression.cs (ArrayCreation::ValidateInitializers): Update to perform
14140         some type checking etc.
14141
14142 2001-11-17  Ravi Pratap  <ravi@ximian.com>
14143
14144         * expression.cs (ArrayCreation::ValidateInitializers): Implement
14145         bits to provide dimension info if the user skips doing that.
14146
14147         Update second constructor to store the rank correctly.
14148
14149 2001-11-16  Ravi Pratap  <ravi@ximian.com>
14150
14151         * expression.cs (ArrayCreation::ValidateInitializers): Poke around
14152         and try to implement.
14153
14154         * ../errors/cs0150.cs : Add.
14155
14156         * ../errors/cs0178.cs : Add.
14157
14158 2001-11-16  Miguel de Icaza  <miguel@ximian.com>
14159
14160         * statement.cs: Implement foreach on multi-dimensional arrays. 
14161
14162         * parameter.cs (Parameters.GetParameterByName): Also lookup the
14163         name of the params argument.
14164
14165         * expression.cs: Use EmitStoreOpcode to get the right opcode while
14166         initializing the array.
14167
14168         (ArrayAccess.EmitStoreOpcode): move the opcode generation here, so
14169         we can use this elsewhere.
14170
14171         * statement.cs: Finish implementation of foreach for single
14172         dimension arrays.
14173
14174         * cs-parser.jay: Use an out-of-band stack to pass information
14175         around, I wonder why I need this.
14176
14177         foreach_block: Make the new foreach_block the current_block.
14178
14179         * parameter.cs (Parameters.GetEmptyReadOnlyParameters): New
14180         function used to return a static Parameters structure.  Used for
14181         empty parameters, as those are created very frequently.
14182
14183         * cs-parser.jay, class.cs: Use GetEmptyReadOnlyParameters
14184
14185 2001-11-15  Ravi Pratap  <ravi@ximian.com>
14186
14187         * interface.cs : Default modifier is private, not public. The
14188         make verify test passes again.
14189
14190 2001-11-15  Ravi Pratap  <ravi@ximian.com>
14191
14192         * support.cs (ReflectionParameters): Fix logic to determine
14193         whether the last parameter is a params one. Test 9 passes again.
14194
14195         * delegate.cs (Populate): Register the builders we define with
14196         RegisterParameterForBuilder. Test 19 passes again.
14197
14198         * cs-parser.jay (property_declaration): Reference $6 instead
14199         of $$ to get at the location.
14200
14201         (indexer_declaration): Similar stuff.
14202
14203         (attribute): Ditto.
14204
14205         * class.cs (Property): Register parameters for the Get and Set methods
14206         if they exist. Test 23 passes again.
14207
14208         * expression.cs (ArrayCreation::Emit): Pass null for the method in the
14209         call to EmitArguments as we are sure there aren't any params arguments. 
14210         Test 32 passes again.
14211
14212         * suppor.cs (ParameterDesc, ParameterModifier): Fix trivial bug causing
14213         IndexOutOfRangeException. 
14214
14215         * class.cs (Property::Define): Register property using TypeManager.RegisterProperty
14216         Test 33 now passes again.
14217
14218 2001-11-15  Miguel de Icaza  <miguel@ximian.com>
14219
14220         * cs-parser.jay: Kill horrendous hack ($??? = lexer.Location) that
14221         broke a bunch of things.  Will have to come up with a better way
14222         of tracking locations.
14223
14224         * statement.cs: Implemented foreach for single dimension arrays.
14225
14226 2001-11-09  Miguel de Icaza  <miguel@ximian.com>
14227
14228         * enum.cs (Enum.Emit): Delay the lookup of loc until we run into
14229         an error.  This removes the lookup from the critical path.
14230
14231         * cs-parser.jay: Removed use of temporary_loc, which is completely
14232         broken. 
14233
14234 2001-11-14  Miguel de Icaza  <miguel@ximian.com>
14235
14236         * support.cs (ReflectionParameters.ParameterModifier): Report
14237         whether the argument is a PARAMS argument or not.
14238
14239         * class.cs: Set the attribute `ParamArrayAttribute' on the
14240         parameter argument.
14241
14242         * typemanager.cs: Define param_array_type (ParamArrayAttribute)
14243         and cons_param_array_attribute (ConstructorInfo for
14244         ParamArrayAttribute)., 
14245
14246         * codegen.cs: Emit the return using the `Return' statement, that
14247         way we can report the error correctly for missing return values. 
14248
14249         * class.cs (Method.Emit): Clean up.
14250
14251         * expression.cs (Argument.Resolve): Take another argument: the
14252         location where this argument is used.  Notice that this is not
14253         part of the "Argument" class as to reduce the size of the
14254         structure (we know the approximate location anyways).
14255
14256         Test if the argument is a variable-reference, if not, then
14257         complain with a 206.
14258
14259         (Argument.Emit): Emit addresses of variables.
14260
14261         (Argument.FullDesc): Simplify.
14262
14263         (Invocation.DoResolve): Update for Argument.Resolve.
14264
14265         (ElementAccess.DoResolve): ditto.
14266
14267         * delegate.cs (DelegateInvocation.Emit): Invocation of Invoke
14268         method should be virtual, as this method is always virtual.
14269
14270         (NewDelegate.DoResolve): Update for Argument.Resolve.
14271
14272         * class.cs (ConstructorInitializer.DoResolve): ditto.
14273
14274         * attribute.cs (Attribute.Resolve): ditto.
14275
14276 2001-11-13  Miguel de Icaza  <miguel@ximian.com>
14277
14278         * statement.cs (Foreach.Emit): Use EmitAssign instead of Store.
14279
14280         * expression.cs (ParameterReference): Drop IStackStorage and implement
14281         IAssignMethod instead. 
14282
14283         (LocalVariableReference): ditto.
14284
14285         * ecore.cs (FieldExpr): Drop IStackStorage and implement
14286         IAssignMethod instead. 
14287
14288 2001-11-13  Miguel de Icaza <miguel@ximian.com>
14289
14290         * parameter.cs, expression.cs, class.cs, ecore.cs: Made all
14291         enumerations that are used in heavily used structures derive from
14292         byte in a laughable and pathetic attempt to reduce memory usage.
14293         This is the kind of pre-optimzations that you should not do at
14294         home without adult supervision.
14295
14296         * expression.cs (UnaryMutator): New class, used to handle ++ and
14297         -- separatedly from the other unary operators.  Cleans up the
14298         code, and kills the ExpressionStatement dependency in Unary.
14299
14300         (Unary): Removed `method' and `Arguments' from this class, making
14301         it smaller, and moving it all to SimpleCall, so I can reuse this
14302         code in other locations and avoid creating a lot of transient data
14303         strucutres when not required.
14304
14305         * cs-parser.jay: Adjust for new changes.
14306
14307 2001-11-11  Miguel de Icaza  <miguel@ximian.com>
14308
14309         * enum.cs (Enum.Populate): If there is a failure during
14310         definition, return
14311
14312         * cs-parser.jay (opt_enum_base): we used to catch type errors
14313         here, but this is really incorrect.  The type error should be
14314         catched during semantic analysis.
14315
14316 2001-12-11  Ravi Pratap  <ravi@ximian.com>
14317
14318         * cs-parser.jay (operator_declarator, conversion_operator_declarator): Set
14319         current_local_parameters as expected since I, in my stupidity, had forgotten
14320         to do this :-)
14321
14322         * attribute.cs (GetValidPlaces): Fix stupid bug.
14323
14324         * class.cs (Method::Emit): Perform check on applicability of attributes.
14325
14326         (Constructor::Emit): Ditto.
14327
14328         (Field::Emit): Ditto.
14329
14330         (Field.Location): Store location information.
14331
14332         (Property, Event, Indexer, Operator): Ditto.
14333
14334         * cs-parser.jay (field_declaration): Pass in location for each field.
14335
14336         * ../errors/cs0592.cs : Add.
14337
14338 2001-11-12  Ravi Pratap  <ravi@ximian.com>
14339
14340         * typemanager.cs (attribute_usage_type): New static member for System.AttributeUsage.
14341
14342         (InitCoreTypes): Update accordingly.
14343
14344         (RegisterAttrType, LookupAttr): Implement.
14345
14346         * attribute.cs (Attribute.Targets, AllowMultiple, Inherited): New fields to hold
14347         info about the same.
14348
14349         (Resolve): Update to populate the above as necessary.
14350
14351         (Error592): Helper.
14352
14353         (GetValidPlaces): Helper to the above.
14354
14355         (CheckAttribute): Implement to perform validity of attributes on declarative elements.
14356
14357         * class.cs (TypeContainer::Emit): Update attribute emission code to perform checking etc.
14358
14359 2001-11-12  Ravi Pratap  <ravi@ximian.com>
14360
14361         * attribute.cs (Attribute::Resolve): Expand to handle named arguments too.
14362
14363         * ../errors/cs0617.cs : Add.
14364
14365 2001-11-11  Ravi Pratap  <ravi@ximian.com>
14366
14367         * enum.cs (Emit): Rename to Populate to be more consistent with what
14368         we expect it to do and when exactly it is called.
14369
14370         * class.cs, rootcontext.cs : Update accordingly.
14371
14372         * typemanager.cs (RegisterField, GetValue): Workarounds for the fact that
14373         FieldInfo.GetValue does not work on dynamic types ! S.R.E lameness strikes again !
14374
14375         * enum.cs (Populate): Register fields with TypeManager.RegisterField.
14376
14377         * expression.cs (MemberAccess.DoResolve): Adjust code to obtain the value
14378         of a fieldinfo using the above, when dealing with a FieldBuilder.
14379
14380 2001-11-10  Ravi Pratap  <ravi@ximian.com>
14381
14382         * ../errors/cs0031.cs : Add.
14383
14384         * ../errors/cs1008.cs : Add.
14385
14386         * ../errrors/cs0543.cs : Add.
14387
14388         * enum.cs (DefineEnum): Check the underlying type and report an error if not a valid
14389         enum type.
14390
14391         (FindMembers): Implement.
14392
14393         * typemanager.cs (FindMembers): Re-write to call the appropriate methods for
14394         enums and delegates too.
14395
14396         (enum_types): Rename to builder_to_enum.
14397
14398         (delegate_types): Rename to builder_to_delegate.
14399
14400         * delegate.cs (FindMembers): Implement.
14401
14402 2001-11-09  Ravi Pratap  <ravi@ximian.com>
14403
14404         * typemanager.cs (IsEnumType): Implement.
14405
14406         * enum.cs (Emit): Re-write parts to account for the underlying type
14407         better and perform checking etc.
14408
14409         (GetNextDefaultValue): Helper to ensure we don't overshoot max value
14410         of the underlying type.
14411
14412         * literal.cs (GetValue methods everywhere): Perform bounds checking and return
14413         value
14414
14415         * enum.cs (error31): Helper to report error #31.
14416
14417         * cs-parser.jay (enum_declaration): Store location of each member too.
14418
14419         * enum.cs (member_to_location): New hashtable. 
14420
14421         (AddEnumMember): Update location hashtable.
14422
14423         (Emit): Use the location of each member while reporting errors.
14424
14425 2001-11-09  Miguel de Icaza  <miguel@ximian.com>
14426
14427         * cs-parser.jay: A for_initializer if is a
14428         local_variable_declaration really ammount to have an implicit
14429         block with the variable declaration and no initializer for for.
14430
14431         * statement.cs (For.Emit): Cope with null initializers.
14432
14433         This fixes the infinite loop on for initializers.
14434
14435 2001-11-08  Miguel de Icaza  <miguel@ximian.com>
14436
14437         * enum.cs: More cleanup.
14438
14439         * ecore.cs: Remove dead code.
14440
14441         * class.cs (Property.Emit): More simplification.
14442         (Event.Emit): ditto.
14443
14444         Reworked to have less levels of indentation.
14445
14446 2001-11-08  Ravi Pratap  <ravi@ximian.com>
14447
14448         * class.cs (Property): Emit attributes.
14449
14450         (Field): Ditto.
14451
14452         (Event): Ditto.
14453
14454         (Indexer): Ditto.
14455
14456         (Operator): Ditto.
14457
14458         * enum.cs (Emit): Ditto.
14459
14460         * rootcontext.cs (ResolveTree, EmitCode, CloseTypes): Do the same for
14461         Enums too.
14462
14463         * class.cs (Field, Event, etc.): Move attribute generation into the
14464         Emit method everywhere.
14465
14466         * enum.cs (Enum): Revamp to use the same definition semantics as delegates so
14467         we have a DefineEnum, CloseEnum etc. The previous way of doing things was not right
14468         as we had no way of defining nested enums !
14469
14470         * rootcontext.cs : Adjust code accordingly.
14471
14472         * typemanager.cs (AddEnumType): To keep track of enum types separately.
14473
14474 2001-11-07  Ravi Pratap  <ravi@ximian.com>
14475
14476         * expression.cs (EvalConstantExpression): Move into ecore.cs
14477
14478         * enum.cs (Enum): Rename some members and make them public and readonly
14479         according to our convention.
14480
14481         * modifiers.cs (EnumAttr): Implement as we need to set only visibility flags,
14482         nothing else.
14483
14484         * enum.cs (Enum::Define): Use the above instead of TypeAttr.
14485
14486         (Enum::Emit): Write a simple version for now which doesn't try to compute
14487         expressions. I shall modify this to be more robust in just a while.
14488
14489         * class.cs (TypeContainer::Emit): Make sure we include Enums too.
14490
14491         (TypeContainer::CloseType): Create the Enum types too.
14492
14493         * attribute.cs (Resolve): Use the new Reduce method instead of EvalConstantExpression.
14494
14495         * expression.cs (EvalConstantExpression): Get rid of completely.
14496
14497         * enum.cs (Enum::Emit): Use the new expression reducer. Implement assigning
14498         user-defined values and other cases.
14499
14500         (IsValidEnumLiteral): Helper function.
14501
14502         * expression.cs (ExprClassfromMemberInfo): Modify to not do any literalizing 
14503         out there in the case we had a literal FieldExpr.
14504
14505         (MemberAccess:DoResolve): Do the literalizing of the FieldExpr here.
14506
14507         (Literalize): Revamp a bit to take two arguments.
14508
14509         (EnumLiteral): New class which derives from Literal to wrap enum literals.
14510
14511 2001-11-06  Ravi Pratap  <ravi@ximian.com>
14512
14513         * cs-parser.jay (compilation_unit): Remove extra opt_attributes for now.
14514
14515         * expression.cs (ArrayCreation::ValidateInitializers): Implement.
14516
14517         (Resolve): Use the above to ensure we have proper initializers.
14518
14519 2001-11-05  Ravi Pratap  <ravi@ximian.com>
14520
14521         * expression.cs (Expression::EvalConstantExpression): New method to 
14522         evaluate constant expressions.
14523
14524         * attribute.cs (Attribute::Resolve): Modify bits to use the above function.
14525
14526 2001-11-07  Miguel de Icaza  <miguel@ximian.com>
14527
14528         * expression.cs (ArrayCreation.Emit): Some bits to initialize data
14529         in an array.
14530
14531         (Binary.ResolveOperator): Handle operator != (object a, object b)
14532         and operator == (object a, object b);
14533
14534         (Binary.DoNumericPromotions): Indicate whether the numeric
14535         promotion was possible.
14536
14537         (ArrayAccess.DoResolve, ArrayAccess.Emit, ArrayAccess.EmitAssign):
14538         Implement.  
14539
14540         Made the ArrayAccess implement interface IAssignMethod instead of
14541         IStackStore as the order in which arguments are passed reflects
14542         this.
14543
14544         * assign.cs: Instead of using expr.ExprClass to select the way of
14545         assinging, probe for the IStackStore/IAssignMethod interfaces.
14546
14547         * typemanager.cs: Load InitializeArray definition.
14548
14549         * rootcontext.cs (RootContext.MakeStaticData): Used to define
14550         static data that can be used to initialize arrays. 
14551
14552 2001-11-05  Miguel de Icaza  <miguel@ximian.com>
14553
14554         * expression.cs: Handle operator== and operator!= for booleans.
14555
14556         (Conditioal.Reduce): Implement reducer for the ?: operator.
14557
14558         (Conditional.Resolve): Implement dead code elimination.
14559
14560         (Binary.Resolve): Catch string literals and return a new
14561         concatenated string.
14562
14563         (Unary.Reduce): Implement reduction of unary expressions.
14564
14565         * ecore.cs: Split out the expression core handling here.
14566
14567         (Expression.Reduce): New method used to perform constant folding
14568         and CSE.  This is needed to support constant-expressions. 
14569
14570         * statement.cs (Statement.EmitBoolExpression): Pass true and false
14571         targets, and optimize for !x.
14572
14573 2001-11-04  Ravi Pratap  <ravi@ximian.com>
14574
14575         * attribute.cs (Attribute::Resolve): Implement guts. Note that resolution
14576         of an attribute gives us a CustomAttributeBuilder which we use accordingly to
14577         set custom atttributes.
14578
14579         * literal.cs (Literal::GetValue): New abstract method to return the actual
14580         value of the literal, cast as an object.
14581
14582         (*Literal): Implement GetValue method.
14583
14584         * cs-parser.jay (positional_argument_list, named_argument_list): Add not just plain
14585         expressions to the arraylist but objects of type Argument.
14586
14587         * class.cs (TypeContainer::Emit): Emit our attributes too.
14588
14589         (Method::Emit, Constructor::Emit): Ditto.
14590
14591         * cs-parser.jay (constructor_declaration): Set attributes too, which we seemed
14592         to be ignoring earlier.
14593
14594 2001-11-03  Ravi Pratap  <ravi@ximian.com>
14595
14596         * attribute.cs (AttributeSection::Define): Implement to do the business
14597         of constructing a CustomAttributeBuilder.
14598
14599         (Attribute): New trivial class. Increases readability of code.  
14600
14601         * cs-parser.jay : Update accordingly.
14602
14603         (positional_argument_list, named_argument_list, named_argument): New rules
14604
14605         (attribute_arguments): Use the above so that we are more correct.
14606
14607 2001-11-02  Ravi Pratap  <ravi@ximian.com>
14608
14609         * expression.cs (Invocation::IsParamsMethodApplicable): Implement
14610         to perform all checks for a method with a params parameter.
14611
14612         (Invocation::OverloadResolve): Update to use the above method and therefore
14613         cope correctly with params method invocations.
14614
14615         * support.cs (InternalParameters::ParameterDesc): Provide a desc for 
14616         params too.
14617
14618         * class.cs (ConstructorInitializer::Resolve): Make sure we look for Non-public
14619         constructors in our parent too because we can't afford to miss out on 
14620         protected ones ;-)
14621
14622         * attribute.cs (AttributeSection): New name for the class Attribute
14623
14624         Other trivial changes to improve readability.
14625
14626         * cs-parser.jay (opt_attributes, attribute_section etc.): Modify to
14627         use the new class names.
14628
14629 2001-11-01  Ravi Pratap  <ravi@ximian.com>
14630
14631         * class.cs (Method::Define): Complete definition for params types too
14632
14633         (Indexer::Define): Ditto.
14634
14635         * support.cs (InternalParameters::ParameterType, ParameterDesc, ParameterModifier):
14636         Cope everywhere with a request for info about the array parameter.
14637
14638 2001-11-01  Ravi Pratap  <ravi@ximian.com>
14639
14640         * tree.cs (RecordNamespace): Fix up to check for the correct key.
14641
14642         * cs-parser.jay (GetQualifiedIdentifier): New Helper method used in 
14643         local_variable_type to extract the string corresponding to the type.
14644
14645         (local_variable_type): Fixup the action to use the new helper method.
14646
14647         * codegen.cs : Get rid of RefOrOutParameter, it's not the right way to 
14648         go.
14649
14650         * expression.cs : Clean out code which uses the above.
14651
14652 2001-10-31  Ravi Pratap  <ravi@ximian.com>
14653
14654         * typemanager.cs (RegisterMethod): Check if we already have an existing key
14655         and bale out if necessary by returning a false.
14656
14657         (RegisterProperty): Ditto.
14658
14659         * class.cs (everywhere): Check the return value from TypeManager.RegisterMethod
14660         and print out appropriate error messages.
14661
14662         * interface.cs (everywhere): Ditto.
14663
14664         * cs-parser.jay (property_declaration, event_declaration, indexer_declaration): Pass
14665         location to constructor.
14666
14667         * class.cs (Property, Event, Indexer): Update accordingly.
14668
14669         * ../errors/cs111.cs : Added.
14670
14671         * expression.cs (Invocation::IsApplicable): New static method to determine applicability
14672         of a method, as laid down by the spec.
14673
14674         (Invocation::OverloadResolve): Use the above method.
14675
14676 2001-10-31  Ravi Pratap  <ravi@ximian.com>
14677
14678         * support.cs (InternalParameters): Get rid of crap taking in duplicate info. We
14679         now take a TypeContainer and a Parameters object.
14680
14681         (ParameterData): Modify return type of ParameterModifier method to be 
14682         Parameter.Modifier and not a string.
14683
14684         (ReflectionParameters, InternalParameters): Update accordingly.
14685
14686         * expression.cs (Argument::GetParameterModifier): Same here.
14687
14688         * support.cs (InternalParameters::ParameterType): Find a better way of determining
14689         if we are a ref/out parameter. Actually, the type shouldn't be holding the '&'
14690         symbol in it at all so maybe this is only for now.
14691
14692 2001-10-30  Ravi Pratap  <ravi@ximian.com>
14693
14694         * support.cs (InternalParameters): Constructor now takes an extra argument 
14695         which is the actual Parameters class.
14696
14697         (ParameterDesc): Update to provide info on ref/out modifiers.
14698
14699         * class.cs (everywhere): Update call to InternalParameters to pass in
14700         the second argument too.
14701
14702         * support.cs (ParameterData): Add ParameterModifier, which is a method 
14703         to return the modifier info [ref/out etc]
14704
14705         (InternalParameters, ReflectionParameters): Implement the above.
14706
14707         * expression.cs (Argument::ParameterModifier): Similar function to return
14708         info about the argument's modifiers.
14709
14710         (Invocation::OverloadResolve): Update to take into account matching modifiers 
14711         too.
14712
14713         * class.cs (Indexer::Define): Actually define a Parameter object and put it onto
14714         a new SetFormalParameters object which we pass to InternalParameters.
14715
14716 2001-10-30  Ravi Pratap  <ravi@ximian.com>
14717
14718         * expression.cs (NewArray): Merge into the ArrayCreation class.
14719
14720 2001-10-29  Ravi Pratap  <ravi@ximian.com>
14721
14722         * expression.cs (NewArray): Merge classes NewBuiltinArray and 
14723         NewUserdefinedArray into one as there wasn't much of a use in having
14724         two separate ones.
14725
14726         * expression.cs (Argument): Change field's name to ArgType from Type.
14727
14728         (Type): New readonly property which returns the proper type, taking into 
14729         account ref/out modifiers.
14730
14731         (everywhere): Adjust code accordingly for the above.
14732
14733         * codegen.cs (EmitContext.RefOrOutParameter): New field to determine
14734         whether we are emitting for a ref or out parameter.
14735
14736         * expression.cs (Argument::Emit): Use the above field to set the state.
14737
14738         (LocalVariableReference::Emit): Update to honour the flag and emit the
14739         right stuff.
14740
14741         * parameter.cs (Attributes): Set the correct flags for ref parameters.
14742
14743         * expression.cs (Argument::FullDesc): New function to provide a full desc.
14744
14745         * support.cs (ParameterData): Add method ParameterDesc to the interface.
14746
14747         (ReflectionParameters, InternalParameters): Implement the above method.
14748
14749         * expression.cs (Invocation::OverloadResolve): Use the new desc methods in
14750         reporting errors.
14751
14752         (Invocation::FullMethodDesc): Ditto. 
14753
14754 2001-10-29  Miguel de Icaza  <miguel@ximian.com>
14755
14756         * cs-parser.jay: Add extra production for the second form of array
14757         creation. 
14758
14759         * expression.cs (ArrayCreation): Update to reflect the above
14760         change. 
14761
14762         * Small changes to prepare for Array initialization.
14763
14764 2001-10-28  Miguel de Icaza  <miguel@ximian.com>
14765
14766         * typemanager.cs (ImplementsInterface): interface might be null;
14767         Deal with this problem;
14768
14769         Also, we do store negative hits on the cache (null values), so use
14770         this instead of calling t.GetInterfaces on the type everytime.
14771
14772 2001-10-28  Ravi Pratap  <ravi@ximian.com>
14773
14774         * typemanager.cs (IsBuiltinType): New method to help determine the same.
14775
14776         * expression.cs (New::DoResolve): Get rid of array creation code and instead
14777         split functionality out into different classes.
14778
14779         (New::FormArrayType): Move into NewBuiltinArray.
14780
14781         (Invocation::EmitArguments): Get rid of the MethodBase argument. Appears
14782         quite useless.
14783
14784         (NewBuiltinArray): New class to handle creation of built-in arrays.
14785
14786         (NewBuiltinArray::DoResolve): Implement guts of array creation. Also take into
14787         account creation of one-dimensional arrays.
14788
14789         (::Emit): Implement to use Newarr and Newobj opcodes accordingly.
14790
14791         (NewUserdefinedArray::DoResolve): Implement.
14792
14793         * cs-parser.jay (local_variable_type): Fix up to add the rank to the variable too.
14794
14795         * typemanager.cs (AddModule): Used to add a ModuleBuilder to the list of modules
14796         we maintain inside the TypeManager. This is necessary to perform lookups on the
14797         module builder.
14798
14799         (LookupType): Update to perform GetType on the module builders too.     
14800
14801         * driver.cs (Driver): Add the ModuleBuilder to the list maintained by the TypeManager.
14802
14803         * exprssion.cs (NewUserdefinedArray::Emit): Implement.
14804
14805 2001-10-23  Ravi Pratap  <ravi@ximian.com>
14806
14807         * expression.cs (New::DoResolve): Implement guts of array creation.
14808
14809         (New::FormLookupType): Rename to FormArrayType and modify ever so slightly.
14810
14811 2001-10-27  Miguel de Icaza  <miguel@ximian.com>
14812
14813         * expression.cs: Fix bug I introduced lsat night that broke
14814         Delegates. 
14815
14816         (Expression.Resolve): Report a 246 error (can not resolve name)
14817         if we find a SimpleName in the stream.
14818
14819         (Expression.ResolveLValue): Ditto.
14820
14821         (Expression.ResolveWithSimpleName): This function is a variant of
14822         ResolveName, this one allows SimpleNames to be returned without a
14823         warning.  The only consumer of SimpleNames is MemberAccess
14824
14825 2001-10-26  Miguel de Icaza  <miguel@ximian.com>
14826
14827         * expression.cs (Invocation::DoResolve): Catch SimpleNames that
14828         might arrive here.  I have my doubts that this is correct.
14829
14830         * statement.cs (Lock): Implement lock statement.
14831
14832         * cs-parser.jay: Small fixes to support `lock' and `using'
14833
14834         * cs-tokenizer.cs: Remove extra space
14835
14836         * driver.cs: New flag --checked, allows to turn on integer math
14837         checking. 
14838
14839         * typemanger.cs: Load methodinfos for Threading.Monitor.Enter and
14840         Threading.Monitor.Exit 
14841
14842 2001-10-23  Miguel de Icaza  <miguel@ximian.com>
14843
14844         * expression.cs (IndexerAccess::DoResolveLValue): Set the
14845         Expression Class to be IndexerAccess.
14846
14847         Notice that Indexer::DoResolve sets the eclass to Value.
14848
14849 2001-10-22  Miguel de Icaza  <miguel@ximian.com>
14850
14851         * class.cs (TypeContainer::Emit): Emit code for indexers.
14852
14853         * assign.cs (IAssignMethod): New interface implemented by Indexers
14854         and Properties for handling assignment.
14855
14856         (Assign::Emit): Simplify and reuse code. 
14857
14858         * expression.cs (IndexerAccess, PropertyExpr): Implement
14859         IAssignMethod, clean up old code. 
14860
14861 2001-10-22  Ravi Pratap  <ravi@ximian.com>
14862
14863         * typemanager.cs (ImplementsInterface): New method to determine if a type
14864         implements a given interface. Provides a nice cache too.
14865
14866         * expression.cs (ImplicitReferenceConversion): Update checks to use the above
14867         method.
14868
14869         (ConvertReferenceExplicit): Ditto.
14870
14871         * delegate.cs (Delegate::Populate): Update to define the parameters on the 
14872         various methods, with correct names etc.
14873
14874         * class.cs (Operator::OpType): New members Operator.UnaryPlus and 
14875         Operator.UnaryNegation.
14876
14877         * cs-parser.jay (operator_declarator): Be a little clever in the case where
14878         we have a unary plus or minus operator.
14879
14880         * expression.cs (Unary): Rename memebers of Operator enum to UnaryPlus and 
14881         UnaryMinus.
14882
14883         * everywhere : update accordingly.
14884
14885         * everywhere : Change Negate and BitComplement to LogicalNot and OnesComplement
14886         respectively.
14887
14888         * class.cs (Method::Define): For the case where we are implementing a method
14889         inherited from an interface, we need to set the MethodAttributes.Final flag too. 
14890         Also set MethodAttributes.NewSlot and MethodAttributes.HideBySig.
14891
14892 2001-10-21  Ravi Pratap  <ravi@ximian.com>
14893
14894         * interface.cs (FindMembers): Implement to work around S.R.E
14895         lameness.
14896
14897         * typemanager.cs (IsInterfaceType): Implement.
14898
14899         (FindMembers): Update to handle interface types too.
14900
14901         * expression.cs (ImplicitReferenceConversion): Re-write bits which
14902         use IsAssignableFrom as that is not correct - it doesn't work.
14903
14904         * delegate.cs (DelegateInvocation): Derive from ExpressionStatement
14905         and accordingly override EmitStatement.
14906
14907         * expression.cs (ConvertReferenceExplicit): Re-write similary, this time
14908         using the correct logic :-)
14909
14910 2001-10-19  Ravi Pratap  <ravi@ximian.com>
14911
14912         * ../errors/cs-11.cs : Add to demonstrate error -11 
14913
14914 2001-10-17  Miguel de Icaza  <miguel@ximian.com>
14915
14916         * assign.cs (Assign::Resolve): Resolve right hand side first, and
14917         then pass this as a hint to ResolveLValue.
14918
14919         * expression.cs (FieldExpr): Add Location information
14920
14921         (FieldExpr::LValueResolve): Report assignment to readonly
14922         variable. 
14923
14924         (Expression::ExprClassFromMemberInfo): Pass location information.
14925
14926         (Expression::ResolveLValue): Add new method that resolves an
14927         LValue. 
14928
14929         (Expression::DoResolveLValue): Default invocation calls
14930         DoResolve. 
14931
14932         (Indexers): New class used to keep track of indexers in a given
14933         Type. 
14934
14935         (IStackStore): Renamed from LValue, as it did not really describe
14936         what this did.  Also ResolveLValue is gone from this interface and
14937         now is part of Expression.
14938
14939         (ElementAccess): Depending on the element access type
14940
14941         * typemanager.cs: Add `indexer_name_type' as a Core type
14942         (System.Runtime.CompilerServices.IndexerNameAttribute)
14943
14944         * statement.cs (Goto): Take a location.
14945
14946 2001-10-18  Ravi Pratap  <ravi@ximian.com>
14947
14948         * delegate.cs (Delegate::VerifyDelegate): New method to verify
14949         if two delegates are compatible.
14950
14951         (NewDelegate::DoResolve): Update to take care of the case when
14952         we instantiate a delegate from another delegate.
14953
14954         * typemanager.cs (FindMembers): Don't even try to look up members
14955         of Delegate types for now.
14956
14957 2001-10-18  Ravi Pratap  <ravi@ximian.com>
14958
14959         * delegate.cs (NewDelegate): New class to take care of delegate
14960         instantiation.
14961
14962         * expression.cs (New): Split the delegate related code out into 
14963         the NewDelegate class.
14964
14965         * delegate.cs (DelegateInvocation): New class to handle delegate 
14966         invocation.
14967
14968         * expression.cs (Invocation): Split out delegate related code into
14969         the DelegateInvocation class.
14970
14971 2001-10-17  Ravi Pratap  <ravi@ximian.com>
14972
14973         * expression.cs (New::DoResolve): Implement delegate creation fully
14974         and according to the spec.
14975
14976         (New::DoEmit): Update to handle delegates differently.
14977
14978         (Invocation::FullMethodDesc): Fix major stupid bug thanks to me
14979         because of which we were printing out arguments in reverse order !
14980
14981         * delegate.cs (VerifyMethod): Implement to check if the given method
14982         matches the delegate.
14983
14984         (FullDelegateDesc): Implement.
14985
14986         (VerifyApplicability): Implement.
14987
14988         * expression.cs (Invocation::DoResolve): Update to accordingly handle
14989         delegate invocations too.
14990
14991         (Invocation::Emit): Ditto.
14992
14993         * ../errors/cs1593.cs : Added.
14994
14995         * ../errors/cs1594.cs : Added.
14996
14997         * delegate.cs (InstanceExpression, TargetMethod): New properties.
14998
14999 2001-10-16  Ravi Pratap  <ravi@ximian.com>
15000
15001         * typemanager.cs (intptr_type): Core type for System.IntPtr
15002
15003         (InitCoreTypes): Update for the same.
15004
15005         (iasyncresult_type, asynccallback_type): Ditto.
15006
15007         * delegate.cs (Populate): Fix to use System.Intptr as it is indeed
15008         correct.
15009
15010         * typemanager.cs (AddDelegateType): Store a pointer to the Delegate class
15011         too.
15012
15013         * delegate.cs (ConstructorBuilder, InvokeBuilder, ...): New members to hold
15014         the builders for the 4 members of a delegate type :-)
15015
15016         (Populate): Define the BeginInvoke and EndInvoke methods on the delegate
15017         type.
15018
15019         * expression.cs (New::DoResolve): Implement guts for delegate creation.
15020
15021         * ../errors/errors.txt : Update for an error (-11) which only we catch :-)
15022
15023 2001-10-15  Miguel de Icaza  <miguel@ximian.com>
15024
15025         * statement.cs (Break::Emit): Implement.   
15026         (Continue::Emit): Implement.
15027
15028         (For::Emit): Track old being/end loops;  Set Begin loop, ack end loop
15029         (While::Emit): Track old being/end loops;  Set Begin loop, ack end loop
15030         (Do::Emit): Track old being/end loops;  Set Begin loop, ack end loop
15031         (Foreach::Emit): Track old being/end loops;  Set Begin loop, ack
15032         end loop
15033
15034         * codegen.cs (EmitContext::LoopEnd, EmitContext::LoopBegin): New
15035         properties that track the label for the current loop (begin of the
15036         loop and end of the loop).
15037
15038 2001-10-15  Ravi Pratap  <ravi@ximian.com>
15039
15040         * delegate.cs (Emit): Get rid of it as there doesn't seem to be any ostensible
15041         use of emitting anything at all.
15042
15043         * class.cs, rootcontext.cs : Get rid of calls to the same.
15044
15045         * delegate.cs (DefineDelegate): Make sure the class we define is also sealed.
15046
15047         (Populate): Define the constructor correctly and set the implementation
15048         attributes.
15049
15050         * typemanager.cs (delegate_types): New hashtable to hold delegates that
15051         have been defined.
15052
15053         (AddDelegateType): Implement.
15054
15055         (IsDelegateType): Implement helper method.
15056
15057         * delegate.cs (DefineDelegate): Use AddDelegateType instead of AddUserType.
15058
15059         * expression.cs (New::DoResolve): Check if we are trying to instantiate a delegate type
15060         and accordingly handle it.
15061
15062         * delegate.cs (Populate): Take TypeContainer argument.
15063         Implement bits to define the Invoke method. However, I still haven't figured out
15064         how to take care of the native int bit :-(
15065
15066         * cs-parser.jay (delegate_declaration): Fixed the bug that I had introduced :-) 
15067         Qualify the name of the delegate, not its return type !
15068
15069         * expression.cs (ImplicitReferenceConversion): Implement guts of implicit array
15070         conversion.
15071
15072         (StandardConversionExists): Checking for array types turns out to be recursive.
15073
15074         (ConvertReferenceExplicit): Implement array conversion.
15075
15076         (ExplicitReferenceConversionExists): New method to determine precisely that :-)
15077
15078 2001-10-12  Ravi Pratap  <ravi@ximian.com>
15079
15080         * cs-parser.jay (delegate_declaration): Store the fully qualified
15081         name as it is a type declaration.
15082
15083         * delegate.cs (ReturnType, Name): Rename members to these. Make them 
15084         readonly.
15085
15086         (DefineDelegate): Renamed from Define. Does the same thing essentially,
15087         as TypeContainer::DefineType.
15088
15089         (Populate): Method in which all the definition of the various methods (Invoke)
15090         etc is done.
15091
15092         (Emit): Emit any code, if necessary. I am not sure about this really, but let's
15093         see.
15094
15095         (CloseDelegate): Finally creates the delegate.
15096
15097         * class.cs (TypeContainer::DefineType): Update to define delegates.
15098         (Populate, Emit and CloseType): Do the same thing here too.
15099
15100         * rootcontext.cs (ResolveTree, PopulateTypes, EmitCode, CloseTypes): Include
15101         delegates in all these operations.
15102
15103 2001-10-14  Miguel de Icaza  <miguel@ximian.com>
15104
15105         * expression.cs: LocalTemporary: a new expression used to
15106         reference a temporary that has been created.
15107
15108         * assign.cs: Handle PropertyAccess back here, so that we can
15109         provide the proper semantic access to properties.
15110
15111         * expression.cs (Expression::ConvertReferenceExplicit): Implement
15112         a few more explicit conversions. 
15113
15114         * modifiers.cs: `NEW' modifier maps to HideBySig.
15115
15116         * expression.cs (PropertyExpr): Make this into an
15117         ExpressionStatement, and support the EmitStatement code path. 
15118
15119         Perform get/set error checking, clean up the interface.
15120
15121         * assign.cs: recognize PropertyExprs as targets, and if so, turn
15122         them into toplevel access objects.
15123
15124 2001-10-12  Miguel de Icaza  <miguel@ximian.com>
15125
15126         * expression.cs: PropertyExpr::PropertyExpr: use work around the
15127         SRE.
15128
15129         * typemanager.cs: Keep track here of our PropertyBuilders again to
15130         work around lameness in SRE.
15131
15132 2001-10-11  Miguel de Icaza  <miguel@ximian.com>
15133
15134         * expression.cs (LValue::LValueResolve): New method in the
15135         interface, used to perform a second resolution pass for LValues. 
15136
15137         (This::DoResolve): Catch the use of this in static methods.
15138
15139         (This::LValueResolve): Implement.
15140
15141         (This::Store): Remove warning, assigning to `this' in structures
15142         is 
15143
15144         (Invocation::Emit): Deal with invocation of
15145         methods on value types.  We need to pass the address to structure
15146         methods rather than the object itself.  (The equivalent code to
15147         emit "this" for structures leaves the entire structure on the
15148         stack instead of a pointer to it). 
15149
15150         (ParameterReference::DoResolve): Compute the real index for the
15151         argument based on whether the method takes or not a `this' pointer
15152         (ie, the method is static).
15153
15154         * codegen.cs (EmitContext::GetTemporaryStorage): Used to store
15155         value types returned from functions when we need to invoke a
15156         method on the sturcture.
15157
15158
15159 2001-10-11  Ravi Pratap  <ravi@ximian.com>
15160
15161         * class.cs (TypeContainer::DefineType): Method to actually do the business of
15162         defining the type in the Modulebuilder or Typebuilder. This is to take
15163         care of nested types which need to be defined on the TypeBuilder using
15164         DefineNestedMethod.
15165
15166         (TypeContainer::GetClassBases): Implement. Essentially the code from the 
15167         methods in RootContext, only ported to be part of TypeContainer.
15168
15169         (TypeContainer::GetInterfaceOrClass): Ditto.
15170
15171         (TypeContainer::LookupInterfaceOrClass, ::MakeFQN): Ditto.
15172
15173         * interface.cs (Interface::DefineInterface): New method. Does exactly
15174         what RootContext.CreateInterface did earlier, only it takes care of nested types 
15175         too.
15176
15177         (Interface::GetInterfaces): Move from RootContext here and port.
15178
15179         (Interface::GetInterfaceByName): Same here.
15180
15181         * rootcontext.cs (ResolveTree): Re-write.
15182
15183         (PopulateTypes): Re-write.
15184
15185         * class.cs (TypeContainer::Populate): Populate nested types too.
15186         (TypeContainer::Emit): Emit nested members too.
15187
15188         * typemanager.cs (AddUserType): Do not make use of the FullName property,
15189         instead just use the name argument passed in as it is already fully
15190         qualified.
15191
15192         (FindMembers): Check in the Builders to TypeContainer mapping instead of the name
15193         to TypeContainer mapping to see if a type is user-defined.
15194
15195         * class.cs (TypeContainer::CloseType): Implement. 
15196
15197         (TypeContainer::DefineDefaultConstructor): Use Basename, not Name while creating
15198         the default constructor.
15199
15200         (TypeContainer::Populate): Fix minor bug which led to creating default constructors
15201         twice.
15202
15203         (Constructor::IsDefault): Fix up logic to determine if it is the default constructor
15204
15205         * interface.cs (CloseType): Create the type here.
15206
15207         * rootcontext.cs (CloseTypes): Re-write to recursively close types by running through
15208         the hierarchy.
15209
15210         Remove all the methods which are now in TypeContainer.
15211
15212 2001-10-10  Ravi Pratap  <ravi@ximian.com>
15213
15214         * delegate.cs (Define): Re-write bits to define the delegate
15215         correctly.
15216
15217 2001-10-10  Miguel de Icaza  <miguel@ximian.com>
15218
15219         * makefile: Renamed the compiler to `mcs.exe' instead of compiler.exe
15220
15221         * expression.cs (ImplicitReferenceConversion): handle null as well
15222         as a source to convert to any reference type.
15223
15224         * statement.cs (Return): Perform any implicit conversions to
15225         expected return type.  
15226
15227         Validate use of return statement.  
15228
15229         * codegen.cs (EmitContext): Pass the expected return type here.
15230
15231         * class.cs (Method, Constructor, Property): Pass expected return
15232         type to EmitContext.
15233
15234 2001-10-09  Miguel de Icaza  <miguel@ximian.com>
15235
15236         * expression.cs: Make DoResolve take an EmitContext instead of a
15237         TypeContainer.
15238
15239         Replaced `l' and `location' for `loc', for consistency.
15240
15241         (Error, Warning): Remove unneeded Tc argument.
15242
15243         * assign.cs, literal.cs, constant.cs: Update to new calling
15244         convention. 
15245
15246         * codegen.cs: EmitContext now contains a flag indicating whether
15247         code is being generated in a static method or not.
15248
15249         * cs-parser.jay: DecomposeQI, new function that replaces the old
15250         QualifiedIdentifier.  Now we always decompose the assembled
15251         strings from qualified_identifier productions into a group of
15252         memberaccesses.
15253
15254 2001-10-08  Miguel de Icaza  <miguel@ximian.com>
15255
15256         * rootcontext.cs: Deal with field-less struct types correctly now
15257         by passing the size option to Define Type.
15258
15259         * class.cs: Removed hack that created one static field. 
15260
15261 2001-10-07  Miguel de Icaza  <miguel@ximian.com>
15262
15263         * statement.cs: Moved most of the code generation here. 
15264
15265 2001-10-09  Ravi Pratap  <ravi@ximian.com>
15266
15267         * expression.cs (New::DoResolve): Revert changes for array creation, doesn't
15268         seem very right.
15269
15270         (ElementAccess): Remove useless bits for now - keep checks as the spec
15271         says.
15272
15273 2001-10-08  Ravi Pratap  <ravi@ximian.com>
15274
15275         * expression.cs (ElementAccess::DoResolve): Remove my crap code
15276         and start performing checks according to the spec.
15277
15278 2001-10-07  Ravi Pratap  <ravi@ximian.com>
15279
15280         * cs-parser.jay (type_suffix*): Remove - they are redundant. Use
15281         rank_specifiers instead.
15282
15283         (rank_specifiers): Change the order in which the rank specifiers are stored
15284
15285         (local_variable_declaration): Use opt_rank_specifier instead of type_suffixes.
15286
15287         * expression.cs (ElementAccess): Implement the LValue interface too.
15288
15289 2001-10-06  Ravi Pratap  <ravi@ximian.com>
15290
15291         * expression.cs (ConvertExplicitStandard): Add. Same as ConvertExplicit
15292         except that user defined conversions are not included.
15293
15294         (UserDefinedConversion): Update to use the ConvertExplicitStandard to 
15295         perform the conversion of the return type, if necessary.
15296
15297         (New::DoResolve): Check whether we are creating an array or an object
15298         and accordingly do the needful.
15299
15300         (New::Emit): Same here.
15301
15302         (New::DoResolve): Implement guts of array creation.
15303
15304         (New::FormLookupType): Helper function.
15305
15306 2001-10-07  Miguel de Icaza  <miguel@ximian.com>
15307
15308         * codegen.cs: Removed most of the code generation here, and move the
15309         corresponding code generation bits to the statement classes. 
15310
15311         Added support for try/catch/finalize and throw.
15312
15313         * cs-parser.jay: Added support for try/catch/finalize.
15314
15315         * class.cs: Catch static methods having the flags override,
15316         virtual or abstract.
15317
15318         * expression.cs (UserCast): This user cast was not really doing
15319         what it was supposed to do.  Which is to be born in fully resolved
15320         state.  Parts of the resolution were being performed at Emit time! 
15321
15322         Fixed this code.
15323
15324 2001-10-05  Miguel de Icaza  <miguel@ximian.com>
15325
15326         * expression.cs: Implicity convert the result from UserCast.
15327
15328 2001-10-05  Ravi Pratap  <ravi@ximian.com>
15329
15330         * expression.cs (Expression::FindMostEncompassingType): Fix bug which
15331         prevented it from working correctly. 
15332
15333         (ConvertExplicit): Make the first try, a call to ConvertImplicitStandard, not
15334         merely ConvertImplicit.
15335
15336 2001-10-05  Miguel de Icaza  <miguel@ximian.com>
15337
15338         * typemanager.cs: Make the LookupTypeContainer function static,
15339         and not per-instance.  
15340
15341         * class.cs: Make static FindMembers (the one that takes a Type
15342         argument). 
15343
15344         * codegen.cs: Add EmitForeach here.
15345
15346         * cs-parser.jay: Make foreach a toplevel object instead of the
15347         inline expansion, as we need to perform semantic analysis on it. 
15348
15349 2001-10-05  Ravi Pratap  <ravi@ximian.com>
15350
15351         * expression.cs (Expression::ImplicitUserConversion): Rename to
15352         UserDefinedConversion.
15353
15354         (Expression::UserDefinedConversion): Take an extra argument specifying 
15355         whether we look for explicit user conversions too.
15356
15357         (Expression::ImplicitUserConversion): Make it a call to UserDefinedConversion.
15358
15359         (UserDefinedConversion): Incorporate support for user defined explicit conversions.
15360
15361         (ExplicitUserConversion): Make it a call to UserDefinedConversion
15362         with the appropriate arguments.
15363
15364         * cs-parser.jay (cast_expression): Record location too.
15365
15366         * expression.cs (Cast): Record location info.
15367
15368         (Expression::ConvertExplicit): Take location argument.
15369
15370         (UserImplicitCast): Change name to UserCast. Take an extra constructor argument
15371         to determine if we are doing explicit conversions.
15372
15373         (UserCast::Emit): Update accordingly.
15374
15375         (Expression::ConvertExplicit): Report an error if everything fails.
15376
15377         * ../errors/cs0030.cs : Add.
15378
15379 2001-10-04  Miguel de Icaza  <miguel@ximian.com>
15380
15381         * modifiers.cs: If the ABSTRACT keyword is present, also set the
15382         virtual and newslot bits. 
15383
15384         * class.cs (TypeContainer::RegisterRequiredImplementations):
15385         Record methods we need.
15386
15387         (TypeContainer::MakeKey): Helper function to make keys for
15388         MethodBases, since the Methodbase key is useless.
15389
15390         (TypeContainer::Populate): Call RegisterRequiredImplementations
15391         before defining the methods.   
15392
15393         Create a mapping for method_builders_to_methods ahead of time
15394         instead of inside a tight loop.
15395
15396         (::RequireMethods):  Accept an object as the data to set into the
15397         hashtable so we can report interface vs abstract method mismatch.
15398
15399 2001-10-03  Miguel de Icaza  <miguel@ximian.com>
15400
15401         * report.cs: Make all of it static.
15402
15403         * rootcontext.cs: Drop object_type and value_type computations, as
15404         we have those in the TypeManager anyways.
15405
15406         Drop report instance variable too, now it is a global.
15407
15408         * driver.cs: Use try/catch on command line handling.
15409
15410         Add --probe option to debug the error reporting system with a test
15411         suite. 
15412
15413         * report.cs: Add support for exiting program when a probe
15414         condition is reached.
15415
15416 2001-10-03  Ravi Pratap  <ravi@ximian.com>
15417
15418         * expression.cs (Binary::DoNumericPromotions): Fix the case when
15419         we do a forcible conversion regardless of type, to check if 
15420         ForceConversion returns a null.
15421
15422         (Binary::error19): Use location to report error.
15423
15424         (Unary::error23): Use location here too.
15425
15426         * ../errors/cs0019.cs : Check in.
15427
15428         * ../errors/cs0023.cs : Check in.
15429
15430         * expression.cs (Expression.MemberLookup): Return null for a rather esoteric
15431         case of a non-null MethodInfo object with a length of 0 !
15432
15433         (Binary::ResolveOperator): Flag error if overload resolution fails to find
15434         an applicable member - according to the spec :-)
15435         Also fix logic to find members in base types.
15436
15437         (Unary::ResolveOperator): Same here.
15438
15439         (Unary::report23): Change name to error23 and make first argument a TypeContainer
15440         as I was getting thoroughly confused between this and error19 :-)
15441
15442         * expression.cs (Expression::ImplicitUserConversion): Re-write fully
15443         (::FindMostEncompassedType): Implement.
15444         (::FindMostEncompassingType): Implement.
15445         (::StandardConversionExists): Implement.
15446
15447         (UserImplicitCast): Re-vamp. We now need info about most specific
15448         source and target types so that we can do the necessary conversions.
15449
15450         (Invocation::MakeUnionSet): Completely re-write to make sure we form a proper
15451         mathematical union with no duplicates.
15452
15453 2001-10-03  Miguel de Icaza  <miguel@ximian.com>
15454
15455         * rootcontext.cs (RootContext::PopulateTypes): Populate containers
15456         in order from base classes to child classes, so that we can in
15457         child classes look up in our parent for method names and
15458         attributes (required for handling abstract, virtual, new, override
15459         constructs: we need to instrospect our base class, and if we dont
15460         populate the classes in order, the introspection might be
15461         incorrect.  For example, a method could query its parent before
15462         the parent has any methods and would determine that the parent has
15463         no abstract methods (while it could have had them)).
15464
15465         (RootContext::CreateType): Record the order in which we define the
15466         classes.
15467
15468 2001-10-02  Miguel de Icaza  <miguel@ximian.com>
15469
15470         * class.cs (TypeContainer::Populate): Also method definitions can
15471         fail now, keep track of this.
15472
15473         (TypeContainer::FindMembers): Implement support for
15474         DeclaredOnly/noDeclaredOnly flag.
15475
15476         (Constructor::Emit) Return the ConstructorBuilder.
15477
15478         (Method::Emit) Return the MethodBuilder. 
15479         Check for abstract or virtual methods to be public.
15480
15481         * rootcontext.cs (RootContext::CreateType): Register all the
15482         abstract methods required for the class to be complete and the
15483         interface methods that must be implemented. 
15484
15485         * cs-parser.jay: Report error 501 (method requires body if it is
15486         not marked abstract or extern).
15487
15488         * expression.cs (TypeOf::Emit): Implement.
15489
15490         * typemanager.cs: runtime_handle_type, new global type.
15491
15492         * class.cs (Property::Emit): Generate code for properties.
15493
15494 2001-10-02  Ravi Pratap  <ravi@ximian.com>
15495
15496         * expression.cs (Unary::ResolveOperator): Find operators on base type
15497         too - we now conform exactly to the spec.
15498
15499         (Binary::ResolveOperator): Same here.
15500
15501         * class.cs (Operator::Define): Fix minor quirk in the tests.
15502
15503         * ../errors/cs0215.cs : Added.
15504
15505         * ../errors/cs0556.cs : Added.
15506
15507         * ../errors/cs0555.cs : Added.
15508
15509 2001-10-01  Miguel de Icaza  <miguel@ximian.com>
15510
15511         * cs-tokenizer.cs: Reimplemented Location to be a struct with a
15512         single integer which is really efficient
15513
15514 2001-10-01  Ravi Pratap  <ravi@ximian.com>
15515
15516         *  expression.cs (Expression::ImplicitUserConversion): Use location
15517         even in the case when we are examining True operators.
15518  
15519         * class.cs (Operator::Define): Perform extensive checks to conform
15520         with the rules for operator overloading in the spec.
15521
15522         * expression.cs (Expression::ImplicitReferenceConversion): Implement
15523         some of the other conversions mentioned in the spec.
15524
15525         * typemanager.cs (array_type): New static member for the System.Array built-in
15526         type.
15527
15528         (cloneable_interface): For System.ICloneable interface.
15529
15530         * driver.cs (Driver::Driver): Initialize TypeManager's core types even before
15531         we start resolving the tree and populating types.
15532
15533         * ../errors/errors.txt : Update for error numbers -7, -8, -9, -10
15534  
15535 2001-10-01  Miguel de Icaza  <miguel@ximian.com>
15536
15537         * expression.cs (Expression::ExprClassFromMemberInfo,
15538         Expression::Literalize): Create literal expressions from
15539         FieldInfos which are literals.
15540
15541         (ConvertNumericExplicit, ImplicitNumericConversion): Fix a few
15542         type casts, because they were wrong.  The test suite in tests
15543         caught these ones.
15544
15545         (ImplicitNumericConversion): ushort to ulong requires a widening
15546         cast. 
15547
15548         Int32 constant to long requires widening cast as well.
15549
15550         * literal.cs (LongLiteral::EmitLong): Do not generate i4 constants
15551         for integers because the type on the stack is not i4.
15552
15553 2001-09-30  Miguel de Icaza  <miguel@ximian.com>
15554
15555         * expression.cs (report118): require location argument. 
15556
15557         * parameter.cs: Do not dereference potential null value.
15558
15559         * class.cs: Catch methods that lack the `new' keyword when
15560         overriding a name.  Report warnings when `new' is used without
15561         anything being there to override.
15562
15563         * modifiers.cs: Handle `NEW' as MethodAttributes.NewSlot.
15564
15565         * class.cs: Only add constructor to hashtable if it is non-null
15566         (as now constructors can fail on define).
15567
15568         (TypeManager, Class, Struct): Take location arguments.
15569
15570         Catch field instance initialization in structs as errors.
15571
15572         accepting_filter: a new filter for FindMembers that is static so
15573         that we dont create an instance per invocation.
15574
15575         (Constructor::Define): Catch errors where a struct constructor is
15576         parameterless 
15577
15578         * cs-parser.jay: Pass location information for various new
15579         constructs. 
15580
15581         * delegate.cs (Delegate): take a location argument.
15582
15583         * driver.cs: Do not call EmitCode if there were problesm in the
15584         Definition of the types, as many Builders wont be there. 
15585
15586         * decl.cs (Decl::Decl): Require a location argument.
15587
15588         * cs-tokenizer.cs: Handle properly hex constants that can not fit
15589         into integers, and find the most appropiate integer for it.
15590
15591         * literal.cs: Implement ULongLiteral.
15592
15593         * rootcontext.cs: Provide better information about the location of
15594         failure when CreateType fails.
15595
15596 2001-09-29  Miguel de Icaza  <miguel@ximian.com>
15597
15598         * rootcontext.cs (RootContext::PopulateTypes): Populates structs
15599         as well.
15600
15601         * expression.cs (Binary::CheckShiftArguments): Add missing type
15602         computation.
15603         (Binary::ResolveOperator): Add type to the logical and and logical
15604         or, Bitwise And/Or and Exclusive Or code paths, it was missing
15605         before.
15606
15607         (Binary::DoNumericPromotions): In the case where either argument
15608         is ulong (and most signed types combined with ulong cause an
15609         error) perform implicit integer constant conversions as well.
15610
15611 2001-09-28  Miguel de Icaza  <miguel@ximian.com>
15612
15613         * expression.cs (UserImplicitCast): Method should always be
15614         non-null. 
15615         (Invocation::BetterConversion): Simplified test for IntLiteral.
15616
15617         (Expression::ImplicitNumericConversion): Split this routine out.
15618         Put the code that performs implicit constant integer conversions
15619         here. 
15620
15621         (Expression::Resolve): Become a wrapper around DoResolve so we can
15622         check eclass and type being set after resolve.
15623
15624         (Invocation::Badness): Remove this dead function
15625
15626         (Binary::ResolveOperator): Do not compute the expensive argumnets
15627         unless we have a union for it.
15628
15629         (Probe::Emit): Is needs to do an isinst and then
15630         compare against null.
15631
15632         (::CanConvert): Added Location argument.  If the Location argument
15633         is null (Location.Null), then we do not report errors.  This is
15634         used by the `probe' mechanism of the Explicit conversion.  We do
15635         not want to generate an error for something that the user
15636         explicitly requested to be casted.  But the pipeline for an
15637         explicit cast first tests for potential implicit casts.
15638
15639         So for now, if the Location is null, it means `Probe only' to
15640         avoid adding another argument.   Might have to revise this
15641         strategy later.
15642
15643         (ClassCast): New class used to type cast objects into arbitrary
15644         classes (used in Explicit Reference Conversions).
15645
15646         Implement `as' as well.
15647
15648         Reverted all the patches from Ravi below: they were broken:
15649
15650                 * The use of `level' as a mechanism to stop recursive
15651                   invocations is wrong.  That was there just to catch the
15652                   bug with a strack trace but not as a way of addressing
15653                   the problem.
15654
15655                   To fix the problem we have to *understand* what is going
15656                   on and the interactions and come up with a plan, not
15657                   just get things going.
15658
15659                 * The use of the type conversion cache that I proposed
15660                   last night had an open topic: How does this work across
15661                   protection domains.  A user defined conversion might not
15662                   be public in the location where we are applying the
15663                   conversion, a different conversion might be selected
15664                   (ie, private A->B (better) but public B->A (worse),
15665                   inside A, A->B applies, but outside it, B->A will
15666                   apply).
15667
15668                 * On top of that (ie, even if the above is solved),
15669                   conversions in a cache need to be abstract.  Ie, `To
15670                   convert from an Int to a Short use an OpcodeCast', not
15671                   `To convert from an Int to a Short use the OpcodeCast on
15672                   the variable 5' (which is what this patch was doing).
15673
15674 2001-09-28  Ravi Pratap  <ravi@ximian.com>
15675
15676         * expression.cs (Invocation::ConversionExists): Re-write to use
15677         the conversion cache
15678
15679         (Expression::ConvertImplicit): Automatic bailing out if level != 0. Also
15680         cache all conversions done, not just user-defined ones.
15681
15682         (Invocation::BetterConversion): The real culprit. Use ConversionExists
15683         to determine if a conversion exists instead of acutually trying to 
15684         perform the conversion. It's faster too.
15685
15686         (Expression::ConvertExplicit): Modify to use ConversionExists to check
15687         and only then attempt the implicit conversion.
15688
15689 2001-09-28  Ravi Pratap  <ravi@ximian.com>
15690
15691         * expression.cs (ConvertImplicit): Use a cache for conversions
15692         already found. Check level of recursion and bail out if necessary.
15693
15694 2001-09-28  Miguel de Icaza  <miguel@ximian.com>
15695
15696         * typemanager.cs (string_concat_string_string, string_concat_object_object):
15697         Export standard methods that we expect for string operations.
15698
15699         * statement.cs (Block::UsageWarning): Track usage of variables and
15700         report the errors for not used variables.
15701
15702         * expression.cs (Conditional::Resolve, ::Emit): Implement ?:
15703         operator. 
15704
15705 2001-09-27  Miguel de Icaza  <miguel@ximian.com>
15706
15707         * codegen.cs: remove unnneded code 
15708
15709         * expression.cs: Removed BuiltinTypeAccess class
15710
15711         Fix the order in which implicit conversions are
15712         done.  
15713
15714         The previous fixed dropped support for boxed conversions (adding a
15715         test to the test suite now)
15716
15717         (UserImplicitCast::CanConvert): Remove test for source being null,
15718         that code is broken.  We should not feed a null to begin with, if
15719         we do, then we should track the bug where the problem originates
15720         and not try to cover it up here.
15721
15722         Return a resolved expression of type UserImplicitCast on success
15723         rather than true/false.  Ravi: this is what I was talking about,
15724         the pattern is to use a static method as a "constructor" for
15725         objects. 
15726
15727         Also, do not create arguments until the very last minute,
15728         otherwise we always create the arguments even for lookups that
15729         will never be performed. 
15730
15731         (UserImplicitCast::Resolve): Eliminate, objects of type
15732         UserImplicitCast are born in a fully resolved state. 
15733
15734         * typemanager.cs (InitCoreTypes): Init also value_type
15735         (System.ValueType). 
15736
15737         * expression.cs (Cast::Resolve): First resolve the child expression.
15738
15739         (LValue): Add new method AddressOf to be used by
15740         the `&' operator.  
15741
15742         Change the argument of Store to take an EmitContext instead of an
15743         ILGenerator, because things like FieldExpr need to be able to call
15744         their children expression to generate the instance code. 
15745
15746         (Expression::Error, Expression::Warning): Sugar functions for
15747         reporting errors.
15748
15749         (Expression::MemberLookup): Accept a TypeContainer instead of a
15750         Report as the first argument.
15751
15752         (Expression::ResolvePrimary): Killed.  I still want to improve
15753         this as currently the code is just not right.
15754
15755         (Expression::ResolveMemberAccess): Simplify, but it is still
15756         wrong. 
15757
15758         (Unary::Resolve): Catch errors in AddressOf operators.
15759
15760         (LocalVariableReference::Emit, ::Store, ::AddressOf): typecast
15761         index to a byte for the short-version, or the compiler will choose
15762         the wrong Emit call, which generates the wrong data.
15763
15764         (ParameterReference::Emit, ::Store): same.
15765
15766         (FieldExpr::AddressOf): Implement.
15767
15768         * typemanager.cs: TypeManager: made public variable instead of
15769         property.
15770
15771         * driver.cs: document --fatal.
15772
15773         * report.cs (ErrorMessage, WarningMessage): new names for the old
15774         Error and Warning classes.
15775
15776         * cs-parser.jay (member_access): Turn built-in access to types
15777         into a normal simplename
15778
15779 2001-09-27  Ravi Pratap  <ravi@ximian.com>
15780
15781         * expression.cs (Invocation::BetterConversion): Fix to cope
15782         with q being null, since this was introducing a bug.
15783
15784         * expression.cs (ConvertImplicit): Do built-in conversions first.
15785
15786 2001-09-27  Ravi Pratap  <ravi@ximian.com>
15787
15788         * expression.cs (UserImplicitCast::Resolve): Fix bug.
15789
15790 2001-09-27  Ravi Pratap  <ravi@ximian.com>
15791
15792         * class.cs (TypeContainer::AddConstructor): Fix a stupid bug
15793         I had introduced long ago (what's new ?).
15794
15795         * expression.cs (UserImplicitCast::CanConvert): Static method to do 
15796         the work of all the checking. 
15797         (ConvertImplicit): Call CanConvert and only then create object if necessary.
15798         (UserImplicitCast::CanConvert, ::Resolve): Re-write.
15799
15800         (Unary::Operator): Rename Add and Subtract to Addition and Subtraction because
15801         that is the right way. 
15802
15803         (Invocation::MakeUnionSet): Convenience function to make unions of sets for 
15804         overloading resolution. Use everywhere instead of cutting and pasting code.
15805
15806         (Binary::ResolveOperator): Use MakeUnionSet.
15807
15808         (UserImplicitCast::CanConvert, ::Resolve): Update to take care of the case when 
15809         we have to convert to bool types. Not complete yet.
15810
15811 2001-09-27  Miguel de Icaza  <miguel@ximian.com>
15812
15813         * typemanager.cs (TypeManager::CSharpName): support ushort.
15814
15815         * expression.cs (Expression::TryImplicitIntConversion): Attempts
15816         to provide an expression that performsn an implicit constant int
15817         conversion (section 6.1.6).
15818         (Expression::ConvertImplicitRequired): Reworked to include
15819         implicit constant expression conversions.
15820
15821         (Expression::ConvertNumericExplicit): Finished.
15822
15823         (Invocation::Emit): If InstanceExpression is null, then it means
15824         that we perform a call on this.
15825
15826 2001-09-26  Miguel de Icaza  <miguel@ximian.com>
15827
15828         * expression.cs (Unary::Emit): Remove some dead code.
15829         (Probe): Implement Resolve and Emit for `is'.
15830         (Expression::ConvertImplicitRequired): Attempt to do constant
15831         expression conversions here.  Maybe should be moved to
15832         ConvertImplicit, but I am not sure.
15833         (Expression::ImplicitLongConstantConversionPossible,
15834         Expression::ImplicitIntConstantConversionPossible): New functions
15835         that tell whether is it possible to apply an implicit constant
15836         expression conversion.
15837
15838         (ConvertNumericExplicit): Started work on explicit numeric
15839         conversions.
15840
15841         * cs-parser.jay: Update operator constants.
15842
15843         * parameter.cs (Parameters::GetParameterInfo): Hook up VerifyArgs
15844         (Parameters::GetSignature): Hook up VerifyArgs here.
15845         (Parameters::VerifyArgs): Verifies that no two arguments have the
15846         same name. 
15847
15848         * class.cs (Operator): Update the operator names to reflect the
15849         ones that the spec expects (as we are just stringizing the
15850         operator names).
15851
15852         * expression.cs (Unary::ResolveOperator): Fix bug: Use
15853         MethodInfo's ReturnType instead of LookupMethodByBuilder as the
15854         previous usage did only work for our methods.
15855         (Expression::ConvertImplicit): Handle decimal implicit numeric
15856         conversions as well.
15857         (Expression::InternalTypeConstructor): Used to invoke constructors
15858         on internal types for default promotions.
15859
15860         (Unary::Emit): Implement special handling for the pre/post
15861         increment/decrement for overloaded operators, as they need to have
15862         the same semantics as the other operators.
15863
15864         (Binary::ResolveOperator): ditto.
15865         (Invocation::ConversionExists): ditto.
15866         (UserImplicitCast::Resolve): ditto.
15867
15868 2001-09-26  Ravi Pratap  <ravi@ximian.com>
15869
15870         * expression.cs (Unary::Emit and Binary::Emit): If we have an overloaded
15871         operator, return after emitting body. Regression tests pass again !
15872
15873         * expression.cs (ConvertImplicit): Take TypeContainer as first argument
15874         (Unary::ForceConversion, Binary::ForceConversion): Ditto.
15875         (Invocation::OverloadResolve): Ditto.
15876         (Invocation::BetterFunction, BetterConversion, ConversionExists): Ditto.
15877
15878         * everywhere : update calls to the above methods accordingly.
15879
15880 2001-09-26  Miguel de Icaza  <miguel@ximian.com>
15881
15882         * assign.cs (Assign): Make it inherit from ExpressionStatement.
15883
15884         * expression.cs (ExpressionStatement): New base class used for
15885         expressions that can appear in statements, so that we can provide
15886         an alternate path to generate expression that do not leave a value
15887         on the stack.
15888
15889         (Expression::Emit, and all the derivatives): We no longer return
15890         whether a value is left on the stack or not.  Every expression
15891         after being emitted leaves a single value on the stack.
15892
15893         * codegen.cs (EmitContext::EmitStatementExpression): Use the
15894         facilties of ExpressionStatement if possible.
15895
15896         * cs-parser.jay: Update statement_expression.
15897
15898 2001-09-25  Miguel de Icaza  <miguel@ximian.com>
15899
15900         * driver.cs: Change the wording of message
15901
15902 2001-09-25  Ravi Pratap  <ravi@ximian.com>
15903
15904         * expression.cs (Binary::ResolveOperator): Had forgottten to set 
15905         the type of the expression to the return type of the method if
15906         we have an overloaded operator match ! The regression tests pass again !
15907         (Unary::ResolveOperator): Ditto.
15908
15909         * expression.cs (Invocation::ConversionExists): Correct the member lookup
15910         to find "op_Implicit", not "implicit" ;-)
15911         (UserImplicitCast): New class to take care of user-defined implicit conversions.
15912         (ConvertImplicit, ForceConversion): Take TypeContainer argument
15913
15914         * everywhere : Correct calls to the above accordingly.
15915
15916         * expression.cs (UserImplicitCast::Resolve, ::Emit): Implement.
15917         (ConvertImplicit): Do user-defined conversion if it exists.
15918
15919 2001-09-24  Miguel de Icaza  <miguel@ximian.com>
15920
15921         * assign.cs: track location.
15922         (Resolve): Use implicit conversions on assignment.
15923
15924         * literal.cs: Oops.  Not good, Emit of short access values should
15925         pass (Bytes) or the wrong argument will be selected.
15926
15927         * expression.cs (Unary::Emit): Emit code for -expr.
15928
15929         (Unary::ResolveOperator): Handle `Substract' for non-constants
15930         (substract from zero from the non-constants).
15931         Deal with Doubles as well. 
15932
15933         (Expression::ConvertImplicitRequired): New routine that reports an
15934         error if no implicit conversion exists. 
15935
15936         (Invocation::OverloadResolve): Store the converted implicit
15937         expressions if we make them
15938
15939 2001-09-24  Ravi Pratap  <ravi@ximian.com>
15940
15941         * class.cs (ConstructorInitializer): Take a Location argument.
15942         (ConstructorBaseInitializer): Same here.
15943         (ConstructorThisInitializer): Same here.
15944
15945         * cs-parser.jay : Update all calls accordingly.
15946
15947         * expression.cs (Unary, Binary, New): Take location argument.
15948         Update accordingly everywhere.
15949
15950         * cs-parser.jay : Update all calls to the above to take a location
15951         argument.
15952
15953         * class.cs : Ditto.
15954
15955 2001-09-24  Ravi Pratap  <ravi@ximian.com>
15956
15957         * expression.cs (Invocation::BetterFunction): Take TypeContainer argument
15958         (Invocation::BetterConversion): Same here
15959         (Invocation::ConversionExists): Ditto.
15960
15961         (Invocation::ConversionExists): Implement.
15962
15963 2001-09-22  Ravi Pratap  <ravi@ximian.com>
15964
15965         * expression.cs (OverloadResolve): Improve some more to catch errors 1502 and 1503
15966         Also take an additional TypeContainer argument.
15967
15968         * All over : Pass in TypeContainer as argument to OverloadResolve.
15969
15970         * typemanager.cs (CSharpName): Update to check for the string type and return
15971         that too.
15972
15973         * expression.cs (Invocation::FullMethodDesc): New static method to return a string fully describing
15974         a given method.
15975
15976 2001-09-21  Ravi Pratap  <ravi@ximian.com>
15977
15978         * expression.cs (Invocation::OverloadResolve): Re-write to conform more to the spec.
15979         (Invocation::BetterFunction): Implement.
15980         (Invocation::BetterConversion): Implement.
15981         (Invocation::ConversionExists): Skeleton, no implementation yet.
15982
15983         Okay, things work fine !
15984
15985 2001-09-21  Miguel de Icaza  <miguel@ximian.com>
15986
15987         * typemanager.cs: declare and load enum_type, delegate_type and
15988         void_type. 
15989
15990         * expression.cs (Expression::Emit): Now emit returns a value that
15991         tells whether a value is left on the stack or not.  This strategy
15992         might be reveted tomorrow with a mechanism that would address
15993         multiple assignments.
15994         (Expression::report118): Utility routine to report mismatches on
15995         the ExprClass.
15996
15997         (Unary::Report23): Report impossible type/operator combination
15998         utility function.
15999
16000         (Unary::IsIncrementableNumber): Whether the type can be
16001         incremented or decremented with add.
16002         (Unary::ResolveOperator): Also allow enumerations to be bitwise
16003         complemented. 
16004         (Unary::ResolveOperator): Implement ++, !, ~,
16005
16006         (Invocation::Emit): Deal with new Emit convetion.
16007
16008         * All Expression derivatives: Updated their Emit method to return
16009         whether they leave values on the stack or not.
16010
16011         * codegen.cs (CodeGen::EmitStatement): Pop values left on the
16012         stack for expressions that are statements. 
16013
16014 2001-09-20  Miguel de Icaza  <miguel@ximian.com>
16015
16016         * expression.cs (LValue): New interface.  Must be implemented by
16017         LValue objects.
16018         (LocalVariableReference, ParameterReference, FieldExpr): Implement
16019         LValue interface.
16020
16021         * assign.cs (Assign::Emit, Assign::Resolve): Use new LValue
16022         interface for generating code, simplifies the code.
16023
16024 2001-09-20  Ravi Pratap  <ravi@ximian.com>
16025
16026         * expression.cs (everywhere): Comment out return statements in ::Resolve
16027         methods to avoid the warnings.
16028
16029 2001-09-20  Miguel de Icaza  <miguel@ximian.com>
16030
16031         * driver.cs (parse): Report error 2001 if we can not open the
16032         source file.
16033
16034         * expression.cs (SimpleName::ResolveSimpleName): Error if we can
16035         not resolve it.
16036
16037         * cs-parser.jay (QualifierIdentifier): Pass location to SimpleName
16038         object. 
16039
16040         * statement.cs (Block::EmitMeta): Reuse the count across all the variables,
16041         otherwise nested blocks end up with the same index.
16042
16043         * codegen.cs (CodeGen::EmitTopBlock): Pass initial sequence
16044
16045         * expression.cs:  Instead of having FIXMEs in the Resolve
16046         functions, throw exceptions so it is obvious that we are facing a
16047         bug. 
16048
16049         * cs-parser.jay (invocation_expression): Pass Location information.
16050
16051         * codegen.cs (CodeGen::Save, CodeGen::CodeGen, CodeGen::Basename):
16052         Use a basename for those routines because .NET does not like paths
16053         on them. 
16054
16055         * class.cs (TypeContainer::AddMethod): Do not call DefineName if the name was
16056         already defined.
16057
16058 2001-09-19  Miguel de Icaza  <miguel@ximian.com>
16059
16060         * typemanager.cs (TypeManager::CoreLookupType): A function to make sure that we
16061         are loading the correct data types (throws an exception if not).
16062         (TypeManager::InitCoreTypes): Use CoreLookupType
16063
16064         * expression.cs (Unary::ResolveOperator): return the child
16065         expression for expressions which are just +expr.
16066         (Unary::ResolveOperator): Return negative literals for -LITERAL
16067         expressions (otherwise they are Unary {Literal}).
16068         (Invocation::Badness): Take into account `Implicit constant
16069         expression conversions'.
16070
16071         * literal.cs (LongLiteral): Implement long literal class.
16072         (IntLiteral): export the `Value' of the intliteral. 
16073
16074 2001-09-19  Ravi Pratap  <ravi@ximian.com>
16075
16076         * expression.cs (Binary::Emit): Finally get the emission right ! Woo!
16077
16078         * class.cs (Operator::Define): Change the methodname prefix to 'op_' 
16079         instead of 'Operator'
16080
16081         * expression.cs (Binary::ResolveOperator): Update accordingly.
16082         (Unary::Operator): Change names to 'Add' and 'Subtract' instead 'Plus'
16083         and 'Minus'
16084
16085         * cs-parser.jay (unary_expression): Update to use the new names.
16086
16087         * gen-treedump.cs (GetUnary): Same here.
16088
16089         * expression.cs (Unary::Resolve): Implement.
16090         (Binary::ResolveOperator): Re-write bits to quietly continue if no overloaded 
16091         operators are found instead of making noise ;-)
16092         (Unary::ResolveOperator): New method to do precisely the same thing which
16093         Binary::ResolveOperator does for Binary expressions.
16094         (Unary.method, .Arguments): Add.
16095         (Unary::OperName): Implement.   
16096         (Unary::ForceConversion): Copy and Paste !
16097
16098         * class.cs (Operator::Define): Fix a small bug for the case when we have 
16099         a unary operator.
16100
16101         * expression.cs (Unary::Emit): Implement. Need to find the right Opcodes
16102         for the inbuilt operators. Only overloading works for now ;-)
16103
16104 2001-09-18  Miguel de Icaza  <miguel@ximian.com>
16105
16106         * expression.cs (CheckedExpr::Resolve, CheckedExpr::Emit,
16107         UnCheckedExpr::Resolve, UnCheckedExpr::Emit): Implement.
16108
16109         * expression.cs (This::Emit): Implement. 
16110         (This::Resolve): Implement.
16111         (TypeOf:Resolve): Implement.
16112         (Expression::ResolveSimpleName): Add an implicit this to instance
16113         field references. 
16114         (MemberAccess::Resolve): Deal with Parameters and Fields. 
16115         Bind instance variable to Field expressions.
16116         (FieldExpr::Instance): New field used to track the expression that
16117         represents the object instance.
16118         (FieldExpr::Resolve): Track potential errors from MemberLookup not
16119         binding 
16120         (FieldExpr::Emit): Implement.
16121
16122         * codegen.cs (EmitIf, EmitStatement, EmitBlock): Propagate whether
16123         the last instruction contains a return opcode to avoid generating
16124         the last `ret' instruction (this generates correct code, and it is
16125         nice to pass the peverify output).
16126
16127         * class.cs (TypeContainer::EmitFieldInitializers): Implement field
16128         initializer for static and instance variables.
16129         (Constructor::Emit): Allow initializer to be null in the case of
16130         static constructors.  Only emit initializer for instance
16131         constructors. 
16132
16133         (TypeContainer::FindMembers): Return a null array if there are no
16134         matches.
16135
16136         Also fix the code for the MemberTypes.Method branch, as it was not
16137         scanning that for operators (or tried to access null variables before).
16138
16139         * assign.cs (Assign::Emit): Handle instance and static fields. 
16140
16141         * TODO: Updated.
16142
16143         * driver.cs: Stop compilation if there are parse errors.
16144
16145         * cs-parser.jay (constructor_declaration): Provide default base
16146         initializer for non-static constructors.
16147         (constructor_declarator): Do not provide a default base
16148         initializers if none was specified.
16149         Catch the fact that constructors should not have parameters.
16150
16151         * class.cs: Do not emit parent class initializers for static
16152         constructors, that should be flagged as an error.
16153
16154 2001-09-18  Ravi Pratap  <ravi@ximian.com>
16155
16156         * class.cs (RegisterMethodBuilder): Remove : it's unnecessary.
16157         Move back code into TypeContainer::Populate.
16158
16159 2001-09-18  Ravi Pratap  <ravi@ximian.com>
16160
16161         * class.cs (TypeContainer::AddConstructor): Fix the check to
16162         compare against Name, not Basename. 
16163         (Operator::OpType): Change Plus and Minus to Add and Subtract.
16164
16165         * cs-parser.jay : Update accordingly.
16166
16167         * class.cs (TypeContainer::FindMembers): For the case where we are searching
16168         for methods, don't forget to look into the operators too.
16169         (RegisterMethodBuilder): Helper method to take care of this for
16170         methods, constructors and operators.
16171         (Operator::Define): Completely revamp.
16172         (Operator.OperatorMethod, MethodName): New fields.
16173         (TypeContainer::Populate): Move the registering of builders into
16174         RegisterMethodBuilder.
16175         (Operator::Emit): Re-write.
16176
16177         * expression.cs (Binary::Emit): Comment out code path to emit method
16178         invocation stuff for the case when we have a user defined operator. I am
16179         just not able to get it right !
16180
16181 2001-09-17  Miguel de Icaza  <miguel@ximian.com>
16182
16183         * expression.cs (Expression::OverloadResolve): Drop TypeContainer
16184         argument. 
16185
16186         (Expression::MemberLookup): Provide a version that allows to
16187         specify the MemberTypes and BindingFlags. 
16188
16189         * statement.cs (Block::GetVariableInfo): Forgot to recurse here,
16190         so it was not fetching variable information from outer blocks.
16191
16192         * modifiers.cs: (Modifiers::TypeAttr): Invert condition on
16193         Beforefieldinit as it was buggy.
16194
16195         * rootcontext.cs (::LookupInterfaceOrClass): Removed an Error -200
16196         that Ravi put here.  
16197
16198         * class.cs (Constructor::Emit): Only emit if block is not null.
16199         (TypeContainer::EmitDefaultConstructor): Removed routine, now we
16200         deal with this by semantically definining it as if the user had
16201         done it.
16202
16203         (TypeContainer::FindMembers): Removed ad-hoc hack to deal with
16204         constructors as we now "emit" them at a higher level.
16205
16206         (TypeContainer::DefineDefaultConstructor): Used to define the
16207         default constructors if none was provided.
16208
16209         (ConstructorInitializer): Add methods Resolve and Emit. 
16210
16211         * expression.cs: Cast to ConstructorInfo instead of MethodInfo
16212
16213 2001-09-17  Ravi Pratap  <ravi@ximian.com>
16214
16215         * class.cs (TypeContainer::EmitDefaultConstructor): Register
16216         the default constructor builder with our hashtable for methodbuilders
16217         to methodcores.
16218
16219         * expression.cs (Invocation::OverloadResolve): Add a check for pd == null
16220         and argument_count is 0 in which case we have a match.
16221         (Binary::ResolveOperator): More null checking and miscellaneous coding
16222         style cleanup.
16223
16224 2001-09-17  Ravi Pratap  <ravi@ximian.com>
16225
16226         * rootcontext.cs (IsNameSpace): Compare against null.
16227
16228         * everywhere : Correct spelling to 'Greater' and to 'Subtract'
16229
16230         * class.cs (Operator::OpType): Change names to match the ones in Binary::Operator
16231         and Unary::Operator.
16232
16233         * cs-parser.jay (operator_declaration, CheckBinaryOperator, CheckUnaryOperator): Update
16234         accordingly.
16235
16236         * expression.cs (Binary::method): New member to hold the MethodBase for the case when
16237         we have overloaded operators.
16238         (Binary::ResolveOperator): Implement the part which does the operator overload
16239         resolution.
16240
16241         * class.cs (Operator::Emit): Implement.
16242         (TypeContainer::Emit): Emit the operators we have too.
16243
16244         * expression.cs (Binary::Emit): Update to emit the appropriate code for
16245         the case when we have a user-defined operator.
16246
16247 2001-09-17  Miguel de Icaza  <miguel@ximian.com>
16248
16249         * rootcontext.cs: Fix bug: tree.Namespaces might be null.
16250
16251 2001-09-16  Ravi Pratap  <ravi@ximian.com>
16252
16253         * class.cs (EmitStaticFieldInitializers, EmitFieldInitializers): Make public.
16254         (TypeContainer::EmitConstructor): Remove and move code into Contructor::Emit.
16255         (Constructor::Emit): Implement.
16256         (EmitStaticFieldInitializers, EmitFieldInitializers): Ensure we return immediately
16257         if we have no work to do. 
16258         (TypeContainer::Emit): Pass in TypeContainer as argument to the constructor's 
16259         Emit method.
16260
16261         * interface.cs (Interface::InterfaceAttr): Re-write to be more correct and complete.
16262         (Interface::IsTopLevel): Add. Same as TypeContainer::IsTopLevel.
16263
16264         * class.cs (TypeContainer::IsTopLevel): Modify to use parent.Parent instead
16265         of parent.parent.
16266
16267 2001-09-15  Ravi Pratap  <ravi@ximian.com>
16268
16269         * tree.cs (Tree::namespaces): New hashtable to keep track of namespaces
16270         in the source.
16271         (Tree::RecordNamespace): Method to do what the name says ;-)
16272         (Tree::Namespaces): Property to get at the namespaces hashtable.
16273
16274         * cs-parser.jay (namespace_declaration): Call RecordNamespace to 
16275         keep track.
16276
16277         * rootcontext.cs (IsNamespace): Fixed it :-)
16278
16279 2001-09-14  Miguel de Icaza  <miguel@ximian.com>
16280
16281         * class.cs (TypeContainer::FindMembers): Add support for
16282         constructors. 
16283         (MethodCore): New class that encapsulates both the shared aspects
16284         of a Constructor and a Method.  
16285         (Method, Constructor): Factored pieces into MethodCore.
16286
16287         * driver.cs: Added --fatal which makes errors throw exceptions.
16288         Load System assembly as well as part of the standard library.
16289
16290         * report.cs: Allow throwing exceptions on errors for debugging.
16291
16292         * modifiers.cs: Do not use `parent', instead use the real type
16293         container to evaluate permission settings.
16294
16295         * class.cs: Put Ravi's patch back in.  He is right, and we will
16296         have to cope with the
16297
16298 2001-09-14  Ravi Pratap  <ravi@ximian.com>
16299
16300         * modifiers.cs (TypeAttr, MethodAttr, FieldAttr): Map protected internal to
16301         FamORAssem, not FamANDAssem.
16302
16303 2001-09-14  Miguel de Icaza  <miguel@ximian.com>
16304
16305         * driver.cs: Added --parse option that only parses its input files
16306         and terminates.
16307
16308         * class.cs: Reverted last change from Ravi to IsTopLevel.  That is
16309         incorrect.  IsTopLevel is not used to tell whether an object is
16310         root_types or not (that can be achieved by testing this ==
16311         root_types).  But to see if this is a top-level *class* (not
16312         necessarly our "toplevel" container). 
16313
16314 2001-09-14  Ravi Pratap  <ravi@ximian.com>
16315
16316         * enum.cs (Enum::Define): Modify to call the Lookup method on the
16317         parent instead of a direct call to GetType.
16318
16319 2001-09-14  Ravi Pratap  <ravi@ximian.com>
16320
16321         * class.cs (TypeContainer::TypeAttr): Remove property code and move it into
16322         Modifiers.TypeAttr. This should just be a call to that method.
16323
16324         * modifiers.cs (TypeAttr): Re-write and take an extra argument, the TypeContainer
16325         object so that we can determine if we are top-level or not.
16326
16327         * delegate.cs (Delegate::Define): Update call to TypeAttr method to pass in the 
16328         TypeContainer too.
16329
16330         * enum.cs (Enum::Define): Ditto.
16331
16332         * modifiers.cs (FieldAttr): Re-write.
16333
16334         * class.cs (TypeContainer::IsTopLevel): Change accessibility to public.
16335         (TypeContainer::HaveStaticConstructor): New property to provide access
16336         to precisely that info.
16337
16338         * modifiers.cs (MethodAttr): Re-write.
16339         (EventAttr): Remove altogether as there seems to be no ostensible use for it.
16340
16341         * class.cs (TypeContainer::IsTopLevel): Re-write. root_types doesn't seem to be the parent
16342         of top-level types as claimed.
16343
16344 2001-09-13  Miguel de Icaza  <miguel@ximian.com>
16345
16346         * expression.cs (MemberLookup): Fruitless attempt to lookup
16347         constructors.  Maybe I need to emit default constructors?  That
16348         might be it (currently .NET emits this for me automatically).
16349         (Invocation::OverloadResolve): Cope with Arguments == null.
16350         (Invocation::EmitArguments): new function, shared by the new
16351         constructor and us.
16352         (Invocation::Emit): Handle static and instance methods.  Emit
16353         proper call instruction for virtual or non-virtual invocations.
16354         (New::Emit): Implement.
16355         (New::Resolve): Implement.
16356         (MemberAccess:Resolve): Implement.
16357         (MethodGroupExpr::InstanceExpression): used conforming to the spec
16358         to track instances.
16359         (FieldExpr::Resolve): Set type.
16360
16361         * support.cs: Handle empty arguments.
16362                 
16363         * cs-parser.jay (CompositeLookup, QualifierIdentifier,
16364         SimpleLookup): Auxiliary routines to help parse a qualifier
16365         identifier.  
16366
16367         Update qualifier_identifier rule.
16368
16369         * codegen.cs: Removed debugging messages.
16370
16371         * class.cs: Make this a global thing, this acts just as a "key" to
16372         objects that we might have around.
16373
16374         (Populate): Only initialize method_builders_to_methods once.
16375
16376         * expression.cs (PropertyExpr): Initialize type from the
16377         PropertyType. 
16378
16379         * codegen.cs (EmitContext::EmitBoolExpression): Use propper
16380         Resolve pattern.  Attempt to implicitly convert value to boolean.
16381         Emit code.
16382
16383         * expression.cs: Set the type for the int32/int32 argument case.
16384         (Binary::ResolveOperator): Set the return type to boolean for
16385         comparission operators
16386
16387         * typemanager.cs: Remove debugging print code.
16388
16389         (Invocation::Resolve): resolve type.
16390
16391         * class.cs: Allocate a MemberInfo of the correct size, as the code
16392         elsewhere depends on the test to reflect the correct contents.
16393
16394         (Method::) Keep track of parameters, due to System.Reflection holes
16395
16396         (TypeContainer::Populate): Keep track of MethodBuilders to Method
16397         mapping here.
16398
16399         (TypeContainer::FindMembers): Use ArrayList and then copy an array
16400         of the exact size and return that.
16401
16402         (Class::LookupMethodByBuilder): New function that maps
16403         MethodBuilders to its methods.  Required to locate the information
16404         on methods because System.Reflection bit us again.
16405
16406         * support.cs: New file, contains an interface ParameterData and
16407         two implementations: ReflectionParameters and InternalParameters
16408         used to access Parameter information.  We will need to grow this
16409         as required.
16410
16411         * expression.cs (Invocation::GetParameterData): implement a cache
16412         and a wrapper around the ParameterData creation for methods. 
16413         (Invocation::OverloadResolve): Use new code.
16414
16415 2001-09-13  Ravi Pratap  <ravi@ximian.com>
16416
16417         * class.cs (TypeContainer::EmitField): Remove and move into 
16418         (Field::Define): here and modify accordingly.
16419         (Field.FieldBuilder): New member.
16420         (TypeContainer::Populate): Update accordingly.
16421         (TypeContainer::FindMembers): Implement.
16422
16423 2001-09-13  Miguel de Icaza  <miguel@ximian.com>
16424
16425         * statement.cs: (VariableInfo::VariableType): New field to be
16426         initialized with the full type once it is resolved. 
16427
16428 2001-09-12  Miguel de Icaza  <miguel@ximian.com>
16429
16430         * parameter.cs (GetParameterInfo): Use a type cache to compute
16431         things only once, and to reuse this information
16432
16433         * expression.cs (LocalVariableReference::Emit): Implement.
16434         (OpcodeCast::Emit): fix.
16435
16436         (ParameterReference::Resolve): Implement.
16437         (ParameterReference::Emit): Implement.
16438
16439         * cs-parser.jay: Fix bug introduced by Ravi, variable initializers
16440         that are expressions need to stay as Expressions.
16441
16442         * typemanager.cs (CSharpName): Returns the C# name of a type if
16443         possible. 
16444
16445         * expression.cs (Expression::ConvertImplicit): New function that
16446         implements implicit type conversions.
16447
16448         (Expression::ImplicitReferenceConversion): Implements implicit
16449         reference conversions.
16450
16451         (EmptyCast): New type for transparent casts.
16452
16453         (OpcodeCast): New type for casts of types that are performed with
16454         a sequence of bytecodes.
16455
16456         (BoxedCast): New type used for casting value types into reference
16457         types.  Emits a box opcode.
16458
16459         (Binary::DoNumericPromotions): Implements numeric promotions of
16460         and computation of the Binary::Type.
16461
16462         (Binary::EmitBranchable): Optimization.
16463
16464         (Binary::Emit): Implement code emission for expressions.
16465
16466         * typemanager.cs (TypeManager): Added two new core types: sbyte
16467         and byte.
16468
16469 2001-09-12  Ravi Pratap  <ravi@ximian.com>
16470
16471         * class.cs (TypeContainer::FindMembers): Method which does exactly
16472         what Type.FindMembers does, only we don't have to use reflection. No
16473         implementation yet.
16474
16475         * typemanager.cs (typecontainers): New hashtable to hold the corresponding
16476         typecontainer objects as we need to get at them.
16477         (TypeManager::AddUserType): Overload to take an extra argument, the TypeContainer.
16478
16479         * rootcontext.cs : Correspondingly modify called to AddUserType to pass the
16480         typecontainer object.
16481
16482         * expression.cs (MemberLookup): Modify signature to take a RootContext object instead
16483         of just a Report object.
16484
16485 2001-09-11  Ravi Pratap  <ravi@ximian.com>
16486
16487         * class.cs (Event::Define): Go back to using the prefixes "add_" and
16488         "remove_"
16489         (TypeContainer::Populate): Now define the delegates of the type too.
16490         (TypeContainer.Delegates): Property to access the list of delegates defined
16491         in the type.
16492
16493         * delegates.cs (Delegate::Define): Implement partially.
16494
16495         * modifiers.cs (TypeAttr): Handle more flags.
16496
16497 2001-09-11  Ravi Pratap  <ravi@ximian.com>
16498
16499         * class.cs (Indexer::Define): Fix for loop iteration condition to be just <
16500         and not <=
16501         (Operator::Define): Re-write logic to get types by using the LookupType method
16502         instead of blindly doing a Type.GetType ! How stupid can I get ;-) ?
16503         (Indexer::Define): Ditto.
16504         (Event::Define): Ditto.
16505         (Property::Define): Ditto.
16506
16507 2001-09-10  Ravi Pratap  <ravi@ximian.com>
16508
16509         * class.cs (TypeContainer::Populate): Now define operators too. 
16510         (TypeContainer.Operators): New property to access the list of operators
16511         in a type.
16512         (Operator.OperatorMethodBuilder): New member to hold the method builder
16513         for the operator we are defining.
16514         (Operator::Define): Implement.
16515
16516 2001-09-10  Ravi Pratap  <ravi@ximian.com>
16517
16518         * class.cs (Event::Define): Make the prefixes of the accessor methods
16519         addOn_ and removeOn_ 
16520
16521         * genericparser.cs (GenericParser::error): Overloaded method to handle the case
16522         of the location being passed in too. Ideally, this should go later since all
16523         error reporting should be done through the Report object.
16524
16525         * class.cs (TypeContainer.Indexers): New property to access the list of indexers.
16526         (Populate): Iterate thru the indexers we have and define them too.
16527         (Indexer.GetMethodBuilder, .SetMethodBuilder): New members to hold the method builders
16528         for the get and set accessors.
16529         (Indexer::Define): Implement.
16530
16531 2001-09-09  Miguel de Icaza  <miguel@ximian.com>
16532
16533         * expression.cs (Binary::Resolve): Beginning of it.  I scratched
16534         my previous implementation, did not work.
16535
16536         * typemanager.cs: Add a couple of missing types (the longs).
16537
16538         * literal.cs: Use TypeManager.bool_type instead of getting it.
16539
16540         * expression.cs (EventExpr): New kind of expressions.
16541         (Expressio::ExprClassFromMemberInfo): finish
16542
16543 2001-09-08  Miguel de Icaza  <miguel@ximian.com>
16544
16545         * assign.cs: Emit stores to static fields differently.
16546
16547 2001-09-08  Ravi Pratap  <ravi@ximian.com>
16548
16549         * Merge in changes and adjust code to tackle conflicts. Backed out my
16550         code in Assign::Resolve ;-) 
16551
16552 2001-09-08  Ravi Pratap  <ravi@ximian.com>
16553
16554         * cs-parser.jay (CheckAttributeTarget): Modify call to error to use
16555         instead Report.Error and also pass in the location.
16556         (CSharpParser::Lexer): New readonly property to return the reference
16557         to the Tokenizer object.
16558         (declare_local_variables): Use Report.Error with location instead of plain 
16559         old error.
16560         (CheckDef): Ditto.
16561
16562         * class.cs (Operator::CheckUnaryOperator): Move into cs-parser.jay.
16563         (Operator.CheckBinaryOperator): Ditto.
16564
16565         * cs-parser.jay (operator_declarator): Update accordingly.
16566
16567         * cs-parser.jay (CheckUnaryOperator): Modify to use Report.Error
16568         (CheckBinaryOperator): Same here.
16569
16570         * rootcontext.cs (LookupType): Add an extra lookup which simply does a lookup
16571         on the name without any prefixes of namespace names etc. This is because we
16572         already might have something already fully qualified like 
16573         'System.Console.WriteLine'
16574
16575         * assign.cs (Resolve): Begin implementation. Stuck ;-)
16576
16577 2001-09-07  Ravi Pratap  <ravi@ximian.com>
16578
16579         * cs-tokenizer.cs (location): Return a string which also contains
16580         the file name.
16581
16582         * expression.cs (ElementAccess): New class for expressions of the
16583         type 'element access.'
16584         (BaseAccess): New class for expressions of the type 'base access.'
16585         (CheckedExpr, UnCheckedExpr): New classes for Checked and Unchecked expressions
16586         respectively.
16587
16588         * cs-parser.jay (element_access): Implement action.
16589         (base_access): Implement actions.
16590         (checked_expression, unchecked_expression): Implement.
16591
16592         * cs-parser.jay (local_variable_type): Correct and implement.
16593         (type_suffixes, type_suffix_list, type_suffix): Implement actions.
16594
16595         * cs-tokenizer.cs (real_type_suffix): Comment out the extra getchar.
16596
16597         * cs-parser.jay (rank_specifiers): Remove space while concatenating the type's
16598         name and the specifiers.
16599
16600         * interface.cs (InterfaceAttr): New property to return the corresponding TypeAttributes
16601
16602         * rootcontext.cs (CreateInterface): Use the InterfaceAttr property instead of 
16603         making them all public ;-)
16604
16605         * cs-parser.jay (error): Remove entirely as we have an implementation in the base
16606         class anyways.
16607
16608 2001-09-07  Miguel de Icaza  <miguel@ximian.com>
16609
16610         * expression.cs (ExprClassFromMemberInfo): Return FieldExpr and
16611         PropertyExprs.
16612         (FieldExpr, PropertyExprs): New resolved expressions.
16613         (SimpleName::MemberStaticCheck): Perform static checks for access
16614         to non-static fields on static methods. Maybe this should be
16615         generalized for MemberAccesses. 
16616         (SimpleName::ResolveSimpleName): More work on simple name
16617         resolution. 
16618
16619         * cs-parser.jay (primary_expression/qualified_identifier): track
16620         the parameter index.
16621
16622         * codegen.cs (CodeGen::Save): Catch save exception, report error.
16623         (EmitContext::EmitBoolExpression): Chain to expression generation
16624         instead of temporary hack.
16625         (::EmitStatementExpression): Put generic expression code generation.
16626
16627         * assign.cs (Assign::Emit): Implement variable assignments to
16628         local variables, parameters and fields.
16629
16630 2001-09-06  Miguel de Icaza  <miguel@ximian.com>
16631
16632         * statement.cs (Block::GetVariableInfo): New method, returns the
16633         VariableInfo for a variable name in a block.
16634         (Block::GetVariableType): Implement in terms of GetVariableInfo
16635
16636         * literal.cs (IntLiteral::Emit, FloatLiteral::Emit,
16637         DoubleLiteral::Emit, CharLiteral::Emit, BoolLiteral::Emit): Implement
16638
16639 2001-09-06  Ravi Pratap  <ravi@ximian.com>
16640
16641         * cs-parser.jay (operator_declaration): Continue on my quest : update
16642         to take attributes argument.
16643         (event_declaration): Ditto.
16644         (enum_declaration): Ditto.
16645         (indexer_declaration): Ditto.
16646
16647         * class.cs (Operator::Operator): Update constructor accordingly.
16648         (Event::Event): Ditto.
16649
16650         * delegate.cs (Delegate::Delegate): Same here.
16651
16652         * enum.cs (Enum::Enum): Same here.
16653
16654 2001-09-05  Ravi Pratap  <ravi@ximian.com>
16655
16656         * cs-parser.jay (CheckAttributeTarget): Update to use the right error number.
16657
16658         * ../tests/cs0658.cs : New file to demonstrate error 0658.
16659
16660         * attribute.cs (Attributes): New class to encapsulate all attributes which were
16661         being passed around as an arraylist.
16662         (Attributes::AddAttribute): Method to add attribute sections.
16663
16664         * cs-parser.jay (opt_attributes): Modify actions to use the new Attributes class.
16665         (struct_declaration): Update accordingly.
16666         (constant_declaration): Update.
16667         (field_declaration): Update.
16668         (method_header): Update.
16669         (fixed_parameter): Update.
16670         (parameter_array): Ditto.
16671         (property_declaration): Ditto.
16672         (destructor_declaration): Ditto.
16673
16674         * class.cs (Struct::Struct): Update constructors accordingly.
16675         (Class::Class): Ditto.
16676         (Field::Field): Ditto.
16677         (Method::Method): Ditto.
16678         (Property::Property): Ditto.
16679         (TypeContainer::OptAttribute): update property's return type.
16680
16681         * interface.cs (Interface.opt_attributes): New member.
16682         (Interface::Interface): Update to take the extra Attributes argument.
16683
16684         * parameter.cs (Parameter::Parameter): Ditto.
16685
16686         * constant.cs (Constant::Constant): Ditto.
16687
16688         * interface.cs (InterfaceMemberBase): New OptAttributes field.
16689         (InterfaceMemberBase::InterfaceMemberBase): Update constructor to take 
16690         the attributes as a parameter.
16691         (InterfaceProperty): Update constructor call.
16692         (InterfaceEvent): Ditto.
16693         (InterfaceMethod): Ditto.
16694         (InterfaceIndexer): Ditto.
16695
16696         * cs-parser.jay (interface_indexer_declaration): Update call to constructor to 
16697         pass the attributes too.
16698         (interface_event_declaration): Ditto.
16699         (interface_property_declaration): Ditto.
16700         (interface_method_declaration): Ditto.
16701         (interface_declaration): Ditto.
16702
16703 2001-09-05  Miguel de Icaza  <miguel@ximian.com>
16704
16705         * class.cs (Method::Define): Track the "static Main" definition to
16706         create an entry point. 
16707
16708         * rootcontext.cs (RootContext::EntryPoint): MethodInfo that holds the
16709         EntryPoint if we find it. 
16710
16711         * codegen.cs (EmitContext::EmitInvocation): Emit invocations.
16712         (EmitContext::ig): Make this variable public.
16713
16714         * driver.cs: Make the default output file be the first file name
16715         with the .exe extension.  
16716
16717         Detect empty compilations
16718
16719         Handle various kinds of output targets.  Handle --target and
16720         rename -t to --dumper.
16721
16722         * expression.cs, literal.cs, assign.cs, constant.cs: All `Resolve'
16723         methods inherited from Expression return now an Expression.  This
16724         will is used during the tree rewriting as we resolve them during
16725         semantic analysis.
16726
16727         (Expression::MemberLookup): Implements the MemberLookup (7.3) from
16728         the spec.  Missing entirely is the information about
16729         accessability of elements of it.
16730
16731         (Expression::ExprClassFromMemberInfo): New constructor for
16732         Expressions that creates a fully initialized Expression based on
16733         a MemberInfo that is one of Eventinfo, FieldINfo, PropertyInfo or
16734         a Type.
16735
16736         (Invocation::Resolve): Begin implementing resolution of invocations.
16737
16738         * literal.cs (StringLiteral):  Implement Emit.
16739
16740 2001-09-05  Ravi Pratap  <ravi@ximian.com>
16741
16742         * cs-parser.jay (error): Add new modifier because we are hiding an inherited
16743         member.
16744
16745 2001-09-04  Ravi Pratap  <ravi@ximian.com>
16746
16747         * cs-parser.jay (attribute_arguments): Implement actions.
16748         (attribute): Fix bug in production. Implement action.
16749         (attribute_list): Implement.
16750         (attribute_target): Implement.
16751         (attribute_target_specifier, opt_target_specifier): Implement
16752         (CheckAttributeTarget): New method to check if the attribute target
16753         is valid.
16754         (attribute_section): Implement.
16755         (opt_attributes): Implement.
16756
16757         * attribute.cs : New file to handle attributes.
16758         (Attribute): Class to hold attribute info.
16759
16760         * cs-parser.jay (opt_attribute_target_specifier): Remove production
16761         (attribute_section): Modify production to use 2 different rules to 
16762         achieve the same thing. 1 s/r conflict down !
16763         Clean out commented, useless, non-reducing dimension_separator rules.
16764
16765         * class.cs (TypeContainer.attributes): New member to hold list
16766         of attributes for a type.
16767         (Struct::Struct): Modify to take one more argument, the attribute list.
16768         (Class::Class): Ditto.
16769         (Field::Field): Ditto.
16770         (Method::Method): Ditto.
16771         (Property::Property): Ditto.
16772
16773         * cs-parser.jay (struct_declaration): Update constructor call to
16774         pass in the attributes too.
16775         (class_declaration): Ditto.
16776         (constant_declaration): Ditto.
16777         (field_declaration): Ditto.
16778         (method_header): Ditto.
16779         (fixed_parameter): Ditto.
16780         (parameter_array): Ditto.
16781         (property_declaration): Ditto.
16782
16783         * constant.cs (Constant::Constant): Update constructor similarly.
16784         Use System.Collections.
16785
16786         * parameter.cs (Parameter::Parameter): Update as above.
16787
16788 2001-09-02  Ravi Pratap  <ravi@ximian.com>
16789
16790         * class.cs (TypeContainer::AddDelegate): New method to add a delegate.
16791         (TypeContainer.delegates): New member to hold list of delegates.
16792
16793         * cs-parser.jay (delegate_declaration): Implement the action correctly 
16794         this time as I seem to be on crack ;-)
16795
16796 2001-09-02  Miguel de Icaza  <miguel@ximian.com>
16797
16798         * rootcontext.cs (RootContext::IsNamespace): new function, used to
16799         tell whether an identifier represents a namespace.
16800
16801         * expression.cs (NamespaceExpr): A namespace expression, used only
16802         temporarly during expression resolution.
16803         (Expression::ResolveSimpleName, ::ResolvePrimary, ::ResolveName):
16804         utility functions to resolve names on expressions.
16805
16806 2001-09-01  Miguel de Icaza  <miguel@ximian.com>
16807
16808         * codegen.cs: Add hook for StatementExpressions. 
16809
16810         * class.cs: Fix inverted test for static flag in methods.
16811
16812 2001-09-02  Ravi Pratap  <ravi@ximian.com>
16813
16814         * class.cs (Operator::CheckUnaryOperator): Correct error number used
16815         to make it coincide with MS' number.
16816         (Operator::CheckBinaryOperator): Ditto.
16817
16818         * ../errors/errors.txt : Remove error numbers added earlier.
16819
16820         * ../errors/cs1019.cs : Test case for error # 1019
16821
16822         * ../errros/cs1020.cs : Test case for error # 1020
16823
16824         * cs-parser.jay : Clean out commented cruft.
16825         (dimension_separators, dimension_separator): Comment out. Ostensibly not
16826         used anywhere - non-reducing rule.
16827         (namespace_declarations): Non-reducing rule - comment out.
16828
16829         * enum.cs (Enum::AddEnum): Rename to AddEnumMember as I was getting confused
16830         with TypeContainer::AddEnum.
16831
16832         * delegate.cs : New file for delegate handling classes.
16833         (Delegate): Class for declaring delegates.
16834
16835         * makefile : Update.
16836
16837         * cs-parser.jay (delegate_declaration): Implement.
16838
16839 2001-09-01  Ravi Pratap  <ravi@che.iitm.ac.in>
16840
16841         * class.cs (Event::Define): Implement.
16842         (Event.EventBuilder): New member.
16843
16844         * class.cs (TypeContainer::Populate): Update to define all enums and events
16845         we have.
16846         (Events): New property for the events arraylist we hold. Shouldn't we move to using
16847         readonly fields for all these cases ?
16848
16849 2001-08-31  Ravi Pratap  <ravi@che.iitm.ac.in>
16850
16851         * class.cs (Property): Revamp to use the convention of making fields readonly.
16852         Accordingly modify code elsewhere.
16853
16854         * class.cs : Apply patch from Mr. Mandar <go_mono@hotmail.com> for implementing
16855         the Define method of the Property class.
16856
16857         * class.cs : Clean up applied patch and update references to variables etc. Fix 
16858         trivial bug.
16859         (TypeContainer::Populate): Update to define all the properties we have. Also
16860         define all enumerations.
16861
16862         * enum.cs (Define): Implement.
16863
16864 2001-08-31  Ravi Pratap  <ravi@che.iitm.ac.in>
16865
16866         * cs-parser.jay (overloadable_operator): The semantic value is an
16867         enum of the Operator class.
16868         (operator_declarator): Implement actions.
16869         (operator_declaration): Implement.
16870
16871         * class.cs (Operator::CheckUnaryOperator): New static method to help in checking
16872         validity of definitions.
16873         (Operator::CheckBinaryOperator): Static method to check for binary operators
16874         (TypeContainer::AddOperator): New method to add an operator to a type.
16875
16876         * cs-parser.jay (indexer_declaration): Added line to actually call the
16877         AddIndexer method so it gets added ;-)
16878
16879         * ../errors/errors.txt : Update to include new error numbers. Are these numbers 
16880         already taken care of by the MS compiler ?  
16881
16882 2001-08-29  Ravi Pratap  <ravi@che.iitm.ac.in>
16883
16884         * class.cs (Operator): New class for operator declarations.
16885         (Operator::OpType): Enum for the various operators.
16886
16887 2001-08-29  Ravi Pratap  <ravi@che.iitm.ac.in>
16888
16889         * class.cs (TypeContainer::AddIndexer): Remove FIXME comment. We
16890         ostensibly handle this in semantic analysis.
16891
16892         * cs-parser.jay (general_catch_clause): Comment out
16893         (specific_catch_clauses, specific_catch_clause): Ditto.
16894         (opt_general_catch_clause, opt_specific_catch_clauses): Ditto
16895         (catch_args, opt_catch_args): New productions.
16896         (catch_clause): Rewrite to use the new productions above
16897         (catch_clauses): Modify accordingly.
16898         (opt_catch_clauses): New production to use in try_statement
16899         (try_statement): Revamp. Basically, we get rid of one unnecessary rule
16900         and re-write the code in the actions to extract the specific and
16901         general catch clauses by being a little smart ;-)
16902
16903         * ../tests/try.cs : Fix. It's not 'finalize' my friend, it's 'finally' !
16904         Hooray, try and catch statements parse fine !
16905
16906 2001-08-28  Ravi Pratap  <ravi@che.iitm.ac.in>
16907
16908         * statement.cs (Block::GetVariableType): Fix logic to extract the type
16909         string from the hashtable of variables.
16910
16911         * cs-parser.jay (event_accessor_declarations): Trivial fix. Man, how did
16912         I end up making that mistake ;-)
16913         (catch_clauses): Fixed gross error which made Key and Value of the 
16914         DictionaryEntry the same : $1 !!
16915
16916 2001-08-28  Ravi Pratap  <ravi@che.iitm.ac.in>
16917
16918         * cs-tokenizer.cs (initTokens): Add keywords 'add' and 'remove'
16919
16920         * cs-parser.jay (event_declaration): Correct to remove the semicolon
16921         when the add and remove accessors are specified. 
16922
16923 2001-08-28  Ravi Pratap  <ravi@che.iitm.ac.in>
16924
16925         * cs-parser.jay (IndexerDeclaration): New helper class to hold
16926         information about indexer_declarator.
16927         (indexer_declarator): Implement actions.
16928         (parsing_indexer): New local boolean used to keep track of whether
16929         we are parsing indexers or properties. This is necessary because 
16930         implicit_parameters come into picture even for the get accessor in the 
16931         case of an indexer.
16932         (get_accessor_declaration, set_accessor_declaration): Correspondingly modified.
16933
16934         * class.cs (Indexer): New class for indexer declarations.
16935         (TypeContainer::AddIndexer): New method to add an indexer to a type.
16936         (TypeContainer::indexers): New member to hold list of indexers for the
16937         type.
16938
16939 2001-08-27  Ravi Pratap  <ravi@che.iitm.ac.in>
16940
16941         * cs-parser.jay (add_accessor_declaration): Implement action.
16942         (remove_accessor_declaration): Implement action.
16943         (event_accessors_declaration): Implement
16944         (variable_declarators): swap statements for first rule - trivial.
16945
16946         * class.cs (Event): New class to hold information about event
16947         declarations.
16948         (TypeContainer::AddEvent): New method to add an event to a type
16949         (TypeContainer::events): New member to hold list of events.
16950
16951         * cs-parser.jay (event_declaration): Implement actions.
16952
16953 2001-08-27  Ravi Pratap  <ravi@che.iitm.ac.in>
16954
16955         * cs-parser.jay (dim_separators): Implement. Make it a string
16956         concatenating all the commas together, just as they appear.
16957         (opt_dim_separators): Modify accordingly
16958         (rank_specifiers): Update accordingly. Basically do the same
16959         thing - instead, collect the brackets here.
16960         (opt_rank_sepcifiers): Modify accordingly.
16961         (array_type): Modify to actually return the complete type string
16962         instead of ignoring the rank_specifiers.
16963         (expression_list): Implement to collect the expressions
16964         (variable_initializer): Implement. We make it a list of expressions
16965         essentially so that we can handle the array_initializer case neatly too.
16966         (variable_initializer_list): Implement.
16967         (array_initializer): Make it a list of variable_initializers
16968         (opt_array_initializer): Modify accordingly.
16969
16970         * expression.cs (New::NType): Add enumeration to help us
16971         keep track of whether we have an object/delegate creation
16972         or an array creation.
16973         (New:NewType, New::Rank, New::Indices, New::Initializers): New
16974         members to hold data about array creation.
16975         (New:New): Modify to update NewType
16976         (New:New): New Overloaded contructor for the array creation
16977         case.
16978
16979         * cs-parser.jay (array_creation_expression): Implement to call
16980         the overloaded New constructor.
16981
16982 2001-08-26  Ravi Pratap  <ravi@che.iitm.ac.in>
16983
16984         * class.cs (TypeContainer::Constructors): Return member
16985         constructors instead of returning null.
16986
16987 2001-08-26  Miguel de Icaza  <miguel@ximian.com>
16988
16989         * typemanager.cs (InitCoreTypes): Initialize the various core
16990         types after we have populated the type manager with the user
16991         defined types (this distinction will be important later while
16992         compiling corlib.dll)
16993
16994         * expression.cs, literal.cs, assign.cs, constant.cs: Started work
16995         on Expression Classification.  Now all expressions have a method
16996         `Resolve' and a method `Emit'.
16997
16998         * codegen.cs, cs-parser.jay: Fixed the bug that stopped code
16999         generation from working.     Also add some temporary debugging
17000         code. 
17001
17002 2001-08-24  Miguel de Icaza  <miguel@ximian.com>
17003
17004         * codegen.cs: Lots of code generation pieces.  This is only the
17005         beginning, will continue tomorrow with more touches of polish.  We
17006         handle the fundamentals of if, while, do, for, return.  Others are
17007         trickier and I need to start working on invocations soon.
17008
17009         * gen-treedump.cs: Bug fix, use s.Increment here instead of
17010         s.InitStatement. 
17011
17012         * codegen.cs (EmitContext): New struct, used during code
17013         emission to keep a context.   Most of the code generation will be
17014         here. 
17015
17016         * cs-parser.jay: Add embedded blocks to the list of statements of
17017         this block.  So code generation proceeds in a top down fashion.
17018
17019 2001-08-23  Miguel de Icaza  <miguel@ximian.com>
17020
17021         * statement.cs: Add support for multiple child blocks.
17022
17023 2001-08-22  Miguel de Icaza  <miguel@ximian.com>
17024
17025         * codegen.cs (EmitCode): New function, will emit the code for a
17026         Block of code given a TypeContainer and its ILGenerator. 
17027
17028         * statement.cs (Block): Standard public readonly optimization.
17029         (Block::Block constructors): Link children. 
17030         (Block::Child): Child Linker.
17031         (Block::EmitVariables): Emits IL variable declarations.
17032
17033         * class.cs: Drop support for MethodGroups here, delay until
17034         Semantic Analysis.
17035         (Method::): Applied the same simplification that I did before, and
17036         move from Properties to public readonly fields.
17037         (Method::ParameterTypes): Returns the parameter types for the
17038         function, and implements a cache that will be useful later when I
17039         do error checking and the semantic analysis on the methods is
17040         performed.
17041         (Constructor::GetCallingConvention): Renamed from CallingConvetion
17042         and made a method, optional argument tells whether this is a class
17043         or a structure to apply the `has-this' bit.
17044         (Method::GetCallingConvention): Implement, returns the calling
17045         convention. 
17046         (Method::Define): Defines the type, a second pass is performed
17047         later to populate the methods.
17048
17049         (Constructor::ParameterTypes): implement a cache similar to the
17050         one on Method::ParameterTypes, useful later when we do semantic
17051         analysis. 
17052
17053         (TypeContainer::EmitMethod):  New method.  Emits methods.
17054
17055         * expression.cs: Removed MethodGroup class from here.
17056
17057         * parameter.cs (Parameters::GetCallingConvention): new method.
17058
17059 2001-08-21  Miguel de Icaza  <miguel@ximian.com>
17060
17061         * class.cs (TypeContainer::Populate): Drop RootContext from the
17062         argument. 
17063
17064         (Constructor::CallingConvention): Returns the calling convention.
17065         (Constructor::ParameterTypes): Returns the constructor parameter
17066         types. 
17067
17068         (TypeContainer::AddConstructor): Keep track of default constructor
17069         and the default static constructor.
17070
17071         (Constructor::) Another class that starts using `public readonly'
17072         instead of properties. 
17073
17074         (Constructor::IsDefault): Whether this is a default constructor. 
17075
17076         (Field::) use readonly public fields instead of properties also.
17077
17078         (TypeContainer::TypeAttr, TypeContainer::AddConstructor): Keep
17079         track of static constructors;  If none is used, turn on
17080         BeforeFieldInit in the TypeAttributes. 
17081
17082         * cs-parser.jay (opt_argument_list): now the return can be null
17083         for the cases where there are no arguments. 
17084
17085         (constructor_declarator): If there is no implicit `base' or
17086         `this', then invoke the default parent constructor. 
17087
17088         * modifiers.cs (MethodAttr): New static function maps a set of
17089         modifiers flags into a MethodAttributes enum
17090         (FieldAttr): renamed from `Map'.  So now we have FieldAttr,
17091         MethodAttr, TypeAttr to represent the various mappings where the
17092         modifiers are used.
17093         (FieldAttr): Map also `readonly' to `FieldAttributes.InitOnly'  
17094
17095 2001-08-19  Miguel de Icaza  <miguel@ximian.com>
17096
17097         * parameter.cs (GetParameterInfo): Fix bug where there would be no
17098         method arguments.
17099
17100         * interface.cs (PopulateIndexer): Implemented the code generator
17101         for interface indexers.
17102
17103 2001-08-17  Miguel de Icaza  <miguel@ximian.com>
17104
17105         * interface.cs (InterfaceMemberBase): Now we track the new status
17106         here.  
17107
17108         (PopulateProperty): Implement property population.  Woohoo!  Got
17109         Methods and Properties going today. 
17110
17111         Removed all the properties for interfaces, and replaced them with
17112         `public readonly' fields. 
17113
17114 2001-08-16  Miguel de Icaza  <miguel@ximian.com>
17115
17116         * interface.cs (AddEvent, AddMethod, AddIndexer, AddProperty):
17117         initialize their hashtables/arraylists only when they are needed
17118         instead of doing this always.
17119
17120         * parameter.cs: Handle refs and out parameters.
17121
17122         * cs-parser.jay: Use an ArrayList to construct the arguments
17123         instead of the ParameterCollection, and then cast that to a
17124         Parameter[] array.
17125
17126         * parameter.cs: Drop the use of ParameterCollection and use
17127         instead arrays of Parameters.
17128
17129         (GetParameterInfo): Use the Type, not the Name when resolving
17130         types. 
17131
17132 2001-08-13  Miguel de Icaza  <miguel@ximian.com>
17133
17134         * parameter.cs: Eliminate the properties Name, Type and ModFlags,
17135         and instead use public readonly fields.
17136
17137         * class.cs: Put back walking code for type containers.
17138
17139 2001-08-11  Miguel de Icaza  <miguel@ximian.com>
17140
17141         * class.cs (MakeConstant): Code to define constants.
17142
17143         * rootcontext.cs (LookupType): New function.  Used to locate types 
17144
17145
17146 2001-08-08  Miguel de Icaza  <miguel@ximian.com>
17147
17148         * rootcontext.cs: OH MY!  My trick works!   It is amazing how nice
17149         this System.Reflection code is.  Kudos to Microsoft
17150
17151         * typemanager.cs: Implement a type cache and avoid loading all
17152         types at boot time.  Wrap in LookupType the internals.  This made
17153         the compiler so much faster.  Wow.  I rule!
17154
17155         * driver.cs: Make sure we always load mscorlib first (for
17156         debugging purposes, nothing really important).
17157
17158         * Renamespaced things that were on `CSC' to `CIR'.  Maybe I should
17159         have moved to `CSC' rather than `CIR'.  Oh man!  The confussion!  
17160
17161         * rootcontext.cs: Lookup types on their namespace;  Lookup types
17162         on namespaces that have been imported using the `using' keyword.
17163
17164         * class.cs (TypeContainer::TypeAttr): Virtualize.
17165         (Class::TypeAttr): Return attributes suitable for this bad boy.
17166         (Struct::TypeAttr): ditto.
17167         Handle nested classes.
17168         (TypeContainer::) Remove all the type visiting code, it is now
17169         replaced with the rootcontext.cs code
17170
17171         * rootcontext.cs (GetClassBases): Added support for structs. 
17172
17173 2001-08-06  Miguel de Icaza  <miguel@ximian.com>
17174
17175         * interface.cs, statement.cs, class.cs, parameter.cs,
17176         rootcontext.cs, gen-treedump.cs, enum.cs, cs-parse.jay:
17177         Drop use of TypeRefs, and use strings instead.
17178
17179 2001-08-04  Miguel de Icaza  <miguel@ximian.com>
17180
17181         * rootcontext.cs: 
17182
17183         * class.cs (Struct::Struct): set the SEALED flags after
17184         checking the modifiers.
17185         (TypeContainer::TypeAttr): new property, returns the
17186         TypeAttributes for a class.  
17187
17188         * cs-parser.jay (type_list): Oops, list production was creating a
17189         new list of base types.
17190
17191         * rootcontext.cs (StdLib): New property.
17192         (GetInterfaceTypeByName): returns an interface by type name, and
17193         encapsulates error handling here.
17194         (GetInterfaces): simplified.
17195         (ResolveTree): Encapsulated all the tree resolution here.
17196         (CreateClass, GetClassBases, GetInterfaceOrClass): Create class
17197         types. 
17198
17199         * driver.cs: Add support for --nostdlib, to avoid loading the
17200         default assemblies.
17201         (Main): Do not put tree resolution here. 
17202
17203         * rootcontext.cs: Beginning of the class resolution.
17204
17205 2001-08-03  Miguel de Icaza  <miguel@ximian.com>
17206
17207         * rootcontext.cs: Provide better error reporting. 
17208
17209         * cs-parser.jay (interface_base): set our $$ to be interfaces.
17210
17211         * rootcontext.cs (CreateInterface): Handle the case where there
17212         are no parent interfaces.
17213
17214         (CloseTypes): Routine to flush types at the end.
17215         (CreateInterface): Track types.
17216         (GetInterfaces): Returns an array of Types from the list of
17217         defined interfaces.
17218
17219         * typemanager.c (AddUserType): Mechanism to track user types (puts
17220         the type on the global type hash, and allows us to close it at the
17221         end). 
17222
17223 2001-08-02  Miguel de Icaza  <miguel@ximian.com>
17224
17225         * tree.cs: Removed RecordType, added RecordClass, RecordStruct and
17226         RecordInterface instead.
17227
17228         * cs-parser.jay: Updated to reflect changes above.
17229
17230         * decl.cs (Definition): Keep track of the TypeBuilder type that
17231         represents this type here.  Not sure we will use it in the long
17232         run, but wont hurt for now.
17233
17234         * driver.cs: Smaller changes to accomodate the new code.
17235
17236         Call ResolveInterfaceBases, Call ResolveClassBases, Save assembly
17237         when done. 
17238
17239         * rootcontext.cs (CreateInterface):  New method, used to create
17240         the System.TypeBuilder type for interfaces.
17241         (ResolveInterfaces): new entry point to resolve the interface
17242         hierarchy. 
17243         (CodeGen): Property, used to keep track of the code generator.
17244
17245 2001-07-26  Miguel de Icaza  <miguel@ximian.com>
17246
17247         * cs-parser.jay: Add a second production for delegate_declaration
17248         with `VOID'.
17249
17250         (enum_body): Put an opt_comma here instead of putting it on
17251         enum_body or enum_member_declarations so we can handle trailing
17252         commas on enumeration members.  Gets rid of a shift/reduce.
17253
17254         (type_list): Need a COMMA in the middle.
17255
17256         (indexer_declaration): Tell tokenizer to recognize get/set
17257
17258         * Remove old targets.
17259
17260         * Re-add the parser target.
17261
17262 2001-07-13  Simon Cozens <simon@simon-cozens.org>
17263
17264         * cs-parser.jay: Add precendence rules for a number of operators
17265         ot reduce the number of shift/reduce conflicts in the grammar.
17266
17267 2001-07-17  Miguel de Icaza  <miguel@ximian.com>
17268
17269         * tree.cs: moved IGenerator interface and renamed it to ITreeDump
17270         and put it here.
17271
17272         Get rid of old crufty code.
17273
17274         * rootcontext.cs: Use this to keep track of the parsed
17275         representation and the defined types available to the program. 
17276
17277         * gen-treedump.cs: adjust for new convention.
17278
17279         * type.cs: Split out the type manager, and the assembly builder
17280         from here. 
17281
17282         * typemanager.cs: the type manager will live here now.
17283
17284         * cil-codegen.cs: And the code generator here. 
17285
17286 2001-07-14  Sean MacIsaac  <macisaac@ximian.com>
17287
17288         * makefile: Fixed up for easy making.
17289
17290 2001-07-13  Simon Cozens <simon@simon-cozens.org>
17291
17292         * cs-parser.jay (rank_specifier): Remove a conflict by reordering
17293         the 
17294
17295         (unary_expression): Expand pre_increment_expression and
17296         post_decrement_expression to reduce a shift/reduce.
17297
17298 2001-07-11  Simon Cozens
17299
17300         * cs-tokenizer.cs: Hex numbers should begin with a 0.
17301
17302         Improve allow_keyword_as_indent name.
17303
17304 2001-06-19  Miguel de Icaza  <miguel@ximian.com>
17305
17306         * Adjustments for Beta2. 
17307
17308 2001-06-13  Miguel de Icaza  <miguel@ximian.com>
17309
17310         * decl.cs: Added `Define' abstract method.
17311         (InTransit): new property, used to catch recursive definitions. 
17312
17313         * interface.cs: Implement `Define'. 
17314
17315         * modifiers.cs: Map Modifiers.constants to
17316         System.Reflection.TypeAttribute flags.
17317
17318         * class.cs: Keep track of types and user-defined types.
17319         (BuilderInit): New method for creating an assembly
17320         (ResolveType): New function to launch the resolution process, only
17321         used by interfaces for now.
17322
17323         * cs-parser.jay: Keep track of Classes, Structs and Interfaces
17324         that are inserted into the name space. 
17325
17326 2001-06-08  Miguel de Icaza  <miguel@ximian.com>
17327
17328         * ARGH.  I have screwed up my tree so many times due to the use of
17329         rsync rather than using CVS.  Going to fix this at once. 
17330
17331         * driver.cs: Objetify driver.  Load assemblies, use assemblies to
17332         load types.
17333
17334 2001-06-07  Miguel de Icaza  <miguel@ximian.com>
17335
17336         * Experiment successful: Use System.Type rather that our own
17337         version of Type.  
17338
17339 2001-05-25  Miguel de Icaza  <miguel@ximian.com>
17340
17341         * cs-parser.jay: Removed nsAliases from here.
17342
17343         Use new namespaces, handle `using XXX;' 
17344
17345         * namespace.cs: Reimplemented namespace handling, use a recursive
17346         definition of the class.  Now we can keep track of using clauses
17347         and catch invalid using clauses.
17348
17349 2001-05-24  Miguel de Icaza  <miguel@ximian.com>
17350
17351         * gen-treedump.cs: Adapted for all the renaming.
17352
17353         * expression.cs (Expression): this class now has a Type property
17354         which returns an expression Type.
17355
17356         (Probe::, New::, TypeOf::, SizeOf::, Constant::): renamed from
17357         `Type', as this has a different meaning now in the base
17358
17359 2001-05-22  Miguel de Icaza  <miguel@ximian.com>
17360
17361         * interface.cs, class.cs: Removed from all the sources the
17362         references to signature computation, as we can not do method
17363         signature computation during the parsing time, as we are not
17364         trying to solve at that point distinguishing:
17365
17366         class X {
17367                 void a (Blah x) {}
17368                 void a (NS.Blah x) {}
17369         }
17370
17371         Which depending on the context might be valid or not, as we do not
17372         know if Blah is the same thing as NS.Blah at that point.
17373
17374         * Redid everything so the code uses TypeRefs now instead of
17375         Types.  TypeRefs are just temporary type placeholders, that need
17376         to be resolved.  They initially have a pointer to a string and the
17377         current scope in which they are used.  This is used later by the
17378         compiler to resolve the reference to an actual Type. 
17379
17380         * DeclSpace is no longer a CIR.Type, and neither are
17381         TypeContainers (Class and Struct) nor Interfaces nor Enums.  They
17382         are all DeclSpaces, but no Types. 
17383
17384         * type.cs (TypeRefManager): This implements the TypeRef manager,
17385         which keeps track of all the types that need to be resolved after
17386         the parsing has finished. 
17387
17388 2001-05-13  Miguel de Icaza  <miguel@ximian.com>
17389
17390         * ARGH.  We are going to have to store `foreach' as a class rather
17391         than resolving it, as we need to verify error 1579 after name
17392         resolution.   *OR* we could keep a flag that says `This request to
17393         IEnumerator comes from a foreach statement' which we can then use
17394         to generate the error.
17395
17396 2001-05-10  Miguel de Icaza  <miguel@ximian.com>
17397
17398         * class.cs (TypeContainer.AddMethod): we now add methods to the
17399         MethodGroup instead of the method hashtable.  
17400
17401         * expression.cs: Add MethodGroup abstraction, which gets us one
17402         step closer to the specification in the way we handle method
17403         declarations.  
17404
17405         * cs-parser.jay (primary_expression): qualified_identifier now
17406         tried to match up an identifier to a local variable reference or
17407         to a parameter reference.
17408
17409         current_local_parameters is now a parser global variable that
17410         points to the current parameters for the block, used during name
17411         lookup.
17412
17413         (property_declaration): Now creates an implicit `value' argument to
17414         the set accessor.
17415
17416 2001-05-09  Miguel de Icaza  <miguel@ximian.com>
17417
17418         * parameter.cs: Do not use `param' arguments as part of the
17419         signature, per the spec.
17420
17421 2001-05-08  Miguel de Icaza  <miguel@ximian.com>
17422
17423         * decl.cs: Base class for classes, structs and interfaces.  This
17424         is the "Declaration Space" 
17425
17426         * cs-parser.jay: Use CheckDef for checking declaration errors
17427         instead of having one on each function.
17428
17429         * class.cs: Factor out some code for handling error handling in
17430         accordance to the "Declarations" section in the "Basic Concepts"
17431         chapter in the ECMA C# spec.
17432
17433         * interface.cs: Make all interface member classes derive from
17434         InterfaceMemberBase.
17435
17436 2001-05-07  Miguel de Icaza  <miguel@ximian.com>
17437
17438         * Many things: all interfaces are parsed and generated in
17439         gen-treedump.  Support for member variables, constructors,
17440         destructors, properties, constants is there.
17441
17442         Beginning of the IL backend, but very little done, just there for
17443         testing purposes. 
17444
17445 2001-04-29  Miguel de Icaza  <miguel@ximian.com>
17446
17447         * cs-parser.jay: Fix labeled statement.
17448
17449         * cs-tokenizer.cs (escape): Escape " and ' always.
17450         ref_line, ref_name: keep track of the line/filename as instructed
17451         by #line by the compiler.
17452         Parse #line.
17453
17454 2001-04-27  Miguel de Icaza  <miguel@ximian.com>
17455
17456         * System.CodeDOM/CodeBinaryOperatorExpression.cs: Rearrange enum
17457         to match the values in System.CodeDOM.
17458
17459         Divid renamed to Divide.
17460
17461         * System.CodeDOM/CodeForLoopStatement.cs: Always have valid
17462         statements. 
17463         (Statements.set): remove.
17464
17465         * System.CodeDOM/CodeCatchClause.cs: always have a valid
17466         statements. 
17467
17468         * System.CodeDOM/CodeIfStatement.cs: trueStatements and
17469         falseStatements always have valid values. 
17470
17471         * cs-parser.jay: Use System.CodeDOM now.
17472