Sanja Gupta 342d5cae8a ChangeLog: Updated ChangeLog. 21 years ago
..
Accessibility d1c09fcc67 Add licensing info 21 years ago
ByteFX.Data 4f6a26c2a3 Gonzalo reminded me that I need to update the version number as 21 years ago
Commons.Xml.Relaxng 97553bb62e cvs ignores, sorry about the spam 21 years ago
Cscompmgd 97553bb62e cvs ignores, sorry about the spam 21 years ago
Custommarshalers bab786ade5 Add licensing info 21 years ago
I18N 456bd7f06c 2004-06-16 Atsushi Enomoto <[email protected]> 21 years ago
IBM.Data.DB2 77c26d6ab9 * Makefile (OVERRIDE_BARE_TARGETS): Remove. 21 years ago
ICSharpCode.SharpZipLib 97553bb62e cvs ignores, sorry about the spam 21 years ago
Managed.Windows.Forms 9f0c2e91a8 more menu work 21 years ago
Microsoft.JScript 9b713bba27 2004-10-06 Cesar Lopez Nataren <[email protected]> 21 years ago
Microsoft.VisualBasic 86dc532f23 small loop condition adjustment 21 years ago
Microsoft.VisualC bab786ade5 Add licensing info 21 years ago
Microsoft.Vsa bab786ade5 Add licensing info 21 years ago
Microsoft.Web.Services 590c7733ba 2004-06-03 Gonzalo Paniagua Javier <[email protected]> 21 years ago
Mono.C5 4b6893b3fc 2004-08-16 Martin Baulig <[email protected]> 21 years ago
Mono.CSharp.Debugger edc329d672 2004-09-21 Martin Baulig <[email protected]> 21 years ago
Mono.Cairo d74ee6abee Remove duplicate licenses 21 years ago
Mono.Data 75581c6a75 Flush 21 years ago
Mono.Data.DB2Client bab786ade5 Add licensing info 21 years ago
Mono.Data.MySql bab786ade5 Add licensing info 21 years ago
Mono.Data.PostgreSqlClient bab786ade5 Add licensing info 21 years ago
Mono.Data.SqliteClient c35a250ace *** empty log message *** 21 years ago
Mono.Data.SybaseClient bab786ade5 Add licensing info 21 years ago
Mono.Data.Tds 07371b2ee0 2004-08-14 Geoff Norton <[email protected]> 21 years ago
Mono.Data.TdsClient bab786ade5 Add licensing info 21 years ago
Mono.Directory.LDAP bab786ade5 Add licensing info 21 years ago
Mono.GetOptions cee315f3cf 21 years ago
Mono.Globalization 3f761fefe4 New build system from Peter Williams ([email protected]) 22 years ago
Mono.Http d1c09fcc67 Add licensing info 21 years ago
Mono.PEToolkit bab786ade5 Add licensing info 21 years ago
Mono.Posix a8c86c9457 * Syscall.cs: Add support for poll (). 21 years ago
Mono.Security 5451ab0192 2004-10-05 Sebastien Pouliot <[email protected]> 21 years ago
Mono.Security.Win32 97553bb62e cvs ignores, sorry about the spam 21 years ago
Novell.Directory.Ldap 97553bb62e cvs ignores, sorry about the spam 21 years ago
Npgsql ac979279bb 21 years ago
PEAPI 78b9c7623e 2004-07-29 Martin Baulig <[email protected]> 21 years ago
System c995669093 2004-10-07 Gonzalo Paniagua Javier <[email protected]> 21 years ago
System.Configuration.Install 97553bb62e cvs ignores, sorry about the spam 21 years ago
System.Data acaa0c7e29 2004-10-07 Atsushi Enomoto <[email protected]> 21 years ago
System.Data.ObjectSpaces bab786ade5 Add licensing info 21 years ago
System.Data.OracleClient 8b45ac3620 2004-09-14 Sebastien Pouliot <[email protected]> 21 years ago
System.Data.SqlXml 0eb8a86796 2004-09-08 Atsushi Enomoto <[email protected]> 21 years ago
System.Design bab786ade5 Add licensing info 21 years ago
System.DirectoryServices 97553bb62e cvs ignores, sorry about the spam 21 years ago
System.Drawing 17ebcc38dc insert line break 21 years ago
System.Drawing.Design bab786ade5 Add licensing info 21 years ago
System.EnterpriseServices 97553bb62e cvs ignores, sorry about the spam 21 years ago
System.Management bab786ade5 Add licensing info 21 years ago
System.Messaging 97553bb62e cvs ignores, sorry about the spam 21 years ago
System.Runtime.Remoting df381473f3 * HttpClientChannel.cs: Throw an http exception if the response is a 500, 21 years ago
System.Runtime.Serialization.Formatters.Soap 97553bb62e cvs ignores, sorry about the spam 21 years ago
System.Security 4e61e9daf2 2004-09-16 Sebastien Pouliot <[email protected]> 21 years ago
System.ServiceProcess 97553bb62e cvs ignores, sorry about the spam 21 years ago
System.Web 342d5cae8a ChangeLog: Updated ChangeLog. 21 years ago
System.Web.Mobile bab786ade5 Add licensing info 21 years ago
System.Web.Services 802e76ff67 * HttpSimpleProtocolImporter.cs: Fix import of arrays of primitive types. 21 years ago
System.Windows.Forms 97553bb62e cvs ignores, sorry about the spam 21 years ago
System.XML 6cef932eb0 2004-10-07 Atsushi Enomoto <[email protected]> 21 years ago
corlib e4bbd420a7 (GetHashCode): When culture 21 years ago
lib a6fda630b0 ignorify 21 years ago
notes 25f95f44fc More files 24 years ago
.cvsignore 5f24e03b41 NAnt build files and System.Data files moved to appropriate directory. 24 years ago
ChangeLog 5d8774e1ec 2004-07-26 Atsushi Enomoto <[email protected]> 21 years ago
LICENSE 0eed5bae7d Add MIT X11 LICENSE to the class dir 23 years ago
Makefile 5d8774e1ec 2004-07-26 Atsushi Enomoto <[email protected]> 21 years ago
README dfedf08d98 2004-04-22 Martin Baulig <[email protected]> 22 years ago
ecma.pub 558f4d0af6 2004-03-23 Sebastien Pouliot <[email protected]> 22 years ago
mono.pub 71ce0f66da Adding it again as a binary. 22 years ago
mono.snk b747124904 Add mono.snk 21 years ago
msfinal.pub 558f4d0af6 2004-03-23 Sebastien Pouliot <[email protected]> 22 years ago

README

The class libraries are grouped together in the assemblies they belong.

Each directory here represents an assembly, and inside each directory we
divide the code based on the namespace they implement.

In addition, each assembly directory contains a Test directory that holds the
NUnit tests for that assembly.

We use a new build system which is described by various README files
in mcs/build

The build process typically builds an assembly, but in some cases it
also builds special versions of the assemblies intended to be used for
testing.

* Missing implementation bits

If you implement a class and you are missing implementation bits,
please use the attribute [MonoTODO]. This attribute can be used
to programatically generate our status web pages:

[MonoTODO]
int MyFunction ()
{
throw new NotImplementedException ();
}

* Supporting .NET 1.2, .NET 1.1 and .NET 1.0 builds

The defines NET_1_1 and NET_2_0 are used to include
features. When NET_2_0 is defined, it also implies that the
NET_1_1 is defined.

To have code which is only available in an old version, use ONLY_1_0,
ONLY_1_1

* Tagging buggy code

If there is a bug in your implementation tag the problem by using
the word "FIXME" in the code, together with a description of the
problem.

Do not use XXX or obscure descriptions, because otherwise people
will not be able to understand what you mean.

* Tagging Problematic specs.

If the documentation and the Microsoft implementation do
differ (you wrote a test case to prove this), I suggest that you edit
the file `mcs/class/doc/API-notes' so we can keep track of these problems
and submit our comments to ECMA or Microsoft and seek clarification.

Sometimes the documentation might be buggy, and sometimes the implementation
might be buggy. Lets try to identify and pinpoint which one
is the correct one.

Sometimes the specification will be lame (consider Version.ToString (fieldCount)
where there is no way of knowing how many fields are available, making the API
not only stupid, but leading to unreliable code).

In those cases, use the keyword "LAMESPEC".


* Coding considerations and style.

In order to keep the code consistent, please use the following
conventions. From here on `good' and `bad' are used to attribute
things that would make the coding style match, or not match. It is not
a judgement call on your coding abilities, but more of a style and
look call. Please try to follow these guidelines to ensure prettiness.

Use 8 space tabs for writing your code (hopefully we can keep
this consistent). If you are modifying someone else's code, try
to keep the coding style similar.

Since we are using 8-space tabs, you might want to consider the Linus
Torvals trick to reduce code nesting. Many times in a loop, you will
find yourself doing a test, and if the test is true, you will nest.
Many times this can be changed. Example:


for (i = 0; i < 10; i++) {
if (something (i)) {
do_more ();
}
}

This take precious space, instead write it like this:

for (i = 0; i < 10; i++) {
if (!something (i))
continue;
do_more ();
}

A few guidelines:

* Use a space before an opening parenthesis when calling
functions, or indexing, like this:

method (a);
b [10];

* Do not put a space after the opening parenthesis and the
closing one, ie:

good: method (a); array [10];

bad: method ( a ); array[ 10 ];

* Inside a code block, put the opening brace on the same line
as the statement:

good:
if (a) {
code ();
code ();
}

bad:
if (a)
{
code ();
code ();
}

* Avoid using unecessary open/close braces, vertical space
is usually limited:

good:
if (a)
code ();

bad:
if (a) {
code ();
}

* When defining a method, use the C style for brace placement,
that means, use a new line for the brace, like this:

good:
void Method ()
{
}

bad:
void Method () {
}

* Properties and indexers are an exception, keep the
brace on the same line as the property declaration.
Rationale: this makes it visually
simple to distinguish them.

good:
int Property {
get {
return value;
}
}

bad:
int Property
{
get {
return value;
}
}

Notice how the accessor "get" also keeps its brace on the same
line.

For very small properties, you can compress things:

ok:
int Property {
get { return value; }
set { x = value; }
}

* Use white space in expressions liberally, except in the presence
of parenthesis:

good:

if (a + 5 > method (blah () + 4))

bad:
if (a+5>method(blah()+4))

* For any new files, please use a descriptive introduction, like
this:

//
// System.Comment.cs: Handles comments in System files.
//
// Author:
// Juan Perez ([email protected])
//
// (C) 2002 Address, Inc (http://www.address.com)
//

* If you are modyfing someone else's code, and your contribution
is significant, please add yourself to the Authors list.

* Switch statements have the case at the same indentation as the
switch:

switch (x) {
case 'a':
...
case 'b':
...
}

* Argument names should use the camel casing for
identifiers, like this:

good:
void Method (string myArgument)

bad:
void Method (string lpstrArgument)
void Method (string my_string)

* Empty methods: They should have the body of code using two
lines, in consistency with the rest:

good:
void EmptyMethod ()
{
}

bad:
void EmptyMethod () {}

void EmptyMethod ()
{}

* Line length: The line length for C# source code is 134 columns.


If your function declaration arguments go beyond
this point, please align your arguments to match the
opening brace, like this:

void Function (int arg, string argb,
int argc)
{
}

When invoking functions, the rule is different, the
arguments are not aligned with the previous
argument, instead they begin at the tabbed position,
like this:

void M ()
{
MethodCall ("Very long string that will force",
"Next argument on the 8-tab pos",
"Just like this one")

}

Here are a couple of examples:

class X : Y {

bool Method (int argument_1, int argument_2)
{
if (argument_1 == argument_2)
throw new Exception (Locale.GetText ("They are equal!");

if (argument_1 < argument_2) {
if (argument_1 * 3 > 4)
return true;
else
return false;
}

//
// This sample helps keep your sanity while using 8-spaces for tabs
//
VeryLongIdentifierWhichTakesManyArguments (
Argument1, Argument2, Argument3,
NestedCallHere (
MoreNested));
}

bool MyProperty {
get {
return x;
}

set {
x = value;
}
}

void AnotherMethod ()
{
if ((a + 5) != 4) {
}

while (blah) {
if (a)
continue;
b++;
}
}
}