aboutsummaryrefslogtreecommitdiff
path: root/pd
diff options
context:
space:
mode:
authorThomas Grill <xovo@users.sourceforge.net>2006-03-07 13:18:32 +0000
committerThomas Grill <xovo@users.sourceforge.net>2006-03-07 13:18:32 +0000
commit88ae96ff82ddc836a822a55aef17ea66ca06ac65 (patch)
tree28b5260ba5e0f2ced6f99ea5a28f49546a3322e6 /pd
parent6ef70933fef8baaf373e43b3f2a02f3a6b083171 (diff)
restructured project (MSVC can't cope well with folder/classname mismatch)
search for CLR DLLs in PD path first steps to efficient method handling svn path=/trunk/externals/clr/; revision=4656
Diffstat (limited to 'pd')
-rwxr-xr-xpd/AssemblyInfo.cs58
-rwxr-xr-xpd/Atom.cs270
-rw-r--r--pd/PureData.cs48
-rwxr-xr-xpd/README.txt3
-rwxr-xr-xpd/pd.csproj105
-rwxr-xr-xpd/pd.sln21
6 files changed, 0 insertions, 505 deletions
diff --git a/pd/AssemblyInfo.cs b/pd/AssemblyInfo.cs
deleted file mode 100755
index 93484d8..0000000
--- a/pd/AssemblyInfo.cs
+++ /dev/null
@@ -1,58 +0,0 @@
-using System.Reflection;
-using System.Runtime.CompilerServices;
-
-//
-// Le informazioni generali relative a un assembly sono controllate dal seguente
-// insieme di attributi. Per modificare le informazioni associate a un assembly
-// occorre quindi modificare i valori di questi attributi.
-//
-[assembly: AssemblyTitle("PureData")]
-[assembly: AssemblyDescription("bridge between C sharp externals and pd")]
-[assembly: AssemblyConfiguration("")]
-[assembly: AssemblyCompany("")]
-[assembly: AssemblyProduct("")]
-[assembly: AssemblyCopyright("Davide Morelli, Thomas Grill")]
-[assembly: AssemblyTrademark("")]
-[assembly: AssemblyCulture("")]
-
-//
-// Le informazioni sulla versione di un assembly sono costituite dai seguenti quattro valori:
-//
-// Numero di versione principale
-// Numero di versione secondario
-// Numero revisione
-// Numero build
-//
-// È possibile specificare tutti i valori o impostare come predefiniti i valori Numero revisione e Numero build
-// utilizzando l'asterisco (*) come illustrato di seguito:
-
-[assembly: AssemblyVersion("1.0.*")]
-
-//
-// Per firmare l'assembly è necessario specificare una chiave da utilizzare.
-// Fare riferimento alla documentazione di Microsoft .NET Framework per ulteriori informazioni sulla firma degli assembly.
-//
-// Utilizzare gli attributi elencati di seguito per verificare la chiave utilizzata per la firma.
-//
-// Note:
-// (*) Se non è specificata alcuna chiave, non sarà possibile firmare l'assembly.
-// (*) KeyName fa riferimento a una chiave installata nel provider di servizi di
-// crittografia (CSP) sul computer in uso. KeyFile fa riferimento a un file che contiene
-// una chiave.
-// (*) Se entrambi i valori KeyFile e KeyName sono specificati, si
-// verificherà il seguente processo:
-// (1) Se KeyName è presente in CSP, verrà utilizzata tale chiave.
-// (2) Se KeyName non esiste e KeyFile esiste, la chiave
-// di KeyFile verrà installata nel CSP e utilizzata.
-// (*) Per creare un KeyFile, è possibile utilizzare l'utilità sn.exe (Strong Name).
-// Quando si specifica il KeyFile, il percorso dovrà essere
-// relativo alla directory di output del progetto, ovvero
-// %Project Directory%\obj\<configuration>. Se ad esempio il KeyFile si
-// trova nella directory del progetto, occorre specificare l'attributo AssemblyKeyFile
-// come [assembly: AssemblyKeyFile("..\\..\\mykey.snk")]
-// (*) La firma ritardata è un'opzione avanzata. Vedere la documentazione di Microsoft
-// .NET Framework per ulteriori informazioni.
-//
-[assembly: AssemblyDelaySign(false)]
-[assembly: AssemblyKeyFile("")]
-[assembly: AssemblyKeyName("")]
diff --git a/pd/Atom.cs b/pd/Atom.cs
deleted file mode 100755
index d872961..0000000
--- a/pd/Atom.cs
+++ /dev/null
@@ -1,270 +0,0 @@
-using System;
-using System.Runtime.InteropServices; // for structures
-using System.Collections;
-#if NET_2_0
-using System.Collections.Generic;
-#endif
-
-namespace PureData
-{
- [StructLayout (LayoutKind.Sequential)]
- public unsafe struct Symbol
- {
- // this should NOT be public (or at least read only)
- private readonly void *sym;
-
- public Symbol(string s)
- {
- sym = Core.SymGen(s);
- }
-
- public override string ToString()
- {
- return Core.SymEval(sym);
- }
- }
-
- [StructLayout (LayoutKind.Sequential)]
- public unsafe struct Pointer
- {
- private readonly void *ptr;
-
- public override string ToString()
- {
- if(sizeof(void *) == 4)
- return ((int)ptr).ToString();
- else
- return ((long)ptr).ToString();
- }
- }
-
- [StructLayout (LayoutKind.Sequential)]
- public unsafe struct Atom
- {
- private enum AtomType {Null = 0, Float = 1, Symbol = 2, Pointer = 3};
-
- [StructLayout (LayoutKind.Explicit)]
- private struct Word
- {
- [FieldOffset(0)] public float w_float;
- [FieldOffset(0)] public Symbol w_sym;
- [FieldOffset(0)] public Pointer w_ptr;
- }
-
- private AtomType type;
- private Word word;
-
- public Atom(float f)
- {
- type = AtomType.Float;
- word = new Word();
- word.w_float = f;
- }
-
- public Atom(int i)
- {
- type = AtomType.Float;
- word = new Word();
- word.w_float = (float)i;
- }
-
- public Atom(Symbol s)
- {
- type = AtomType.Symbol;
- word = new Word();
- word.w_sym = s;
- }
-
- public Atom(string s)
- {
- type = AtomType.Symbol;
- word = new Word();
- word.w_sym = new Symbol(s);
- }
-
- public Atom(Pointer p)
- {
- type = AtomType.Pointer;
- word = new Word();
- word.w_ptr = p;
- }
-
- public bool IsFloat { get { return type == AtomType.Float; } }
- public bool IsSymbol { get { return type == AtomType.Symbol; } }
- public bool IsPointer { get { return type == AtomType.Pointer; } }
-
- public float ToFloat()
- {
- if(IsFloat)
- return word.w_float;
- else
- throw new System.InvalidCastException("Can't be cast to float.");
- }
-
- public Symbol ToSymbol()
- {
- if(IsSymbol)
- return word.w_sym;
- else
- throw new System.InvalidCastException("Can't be cast to Symbol.");
- }
-
- public Pointer ToPointer()
- {
- if(IsPointer)
- return word.w_ptr;
- else
- throw new System.InvalidCastException("Can't be cast to Pointer.");
- }
-
- override public string ToString()
- {
- if(IsFloat)
- return word.w_float.ToString();
- else if(IsSymbol)
- return word.w_sym.ToString();
- else if(IsPointer)
- return word.w_ptr.ToString();
- else
- // should never happen
- throw new System.InvalidProgramException("Internal error.");
- }
-
- public static explicit operator float(Atom a)
- {
- return a.ToFloat();
- }
-
- public static explicit operator Symbol(Atom a)
- {
- return a.ToSymbol();
- }
-
- public static explicit operator Pointer(Atom a)
- {
- return a.ToPointer();
- }
- }
-
- public class AtomListEnum
- : IEnumerator
- {
- public AtomList list;
-
- // Enumerators are positioned before the first element
- // until the first MoveNext() call.
- int position = -1;
-
- public AtomListEnum(AtomList l)
- {
- list = l;
- }
-
- public bool MoveNext()
- {
- return ++position < list.Count;
- }
-
- public void Reset()
- {
- position = -1;
- }
-
- public object Current
- {
- get
- {
- try
- {
- return list[position];
- }
- catch (IndexOutOfRangeException)
- {
- throw new InvalidOperationException();
- }
- }
- }
- }
-
-
- // attention: this is dangerous, because we could do the following
- // AtomList l2 = l;
- // with l also being an AtomList... the two private memebers will get copied, although atoms is only a temporary reference
-
- [StructLayout (LayoutKind.Sequential)]
- unsafe public struct AtomList
-#if NET_2_0
- : ICollection<Atom>
-#else
- : ICollection
-#endif
- {
- private readonly int len;
- private readonly Atom *atoms;
-
- public int Count { get { return len; } }
-#if NET_2_0
- public bool IsReadOnly { get { return false; } } // member of generic.ICollection<Atom> (C# 2.0)
-#endif
- public bool IsSynchronized { get { return false; } }
- public Object SyncRoot { get { return null; } }
-
- // protect this from being used
- private AtomList(AtomList a) { len = 0; atoms = null; }
-
-#if NET_2_0
- public void CopyTo(Atom[] array,int start)
-#else
- public void CopyTo(Array array,int start)
-#endif
- {
- if(len > array.GetUpperBound(0)+1-start)
- throw new System.ArgumentException("Destination array is not long enough.");
- int i;
- for(i = 0; i < len-start; ++i)
- array.SetValue(atoms[start+i],i);
- }
-
- public IEnumerator GetEnumerator()
- {
- return new AtomListEnum(this);
- }
-
- public Atom this[int i]
- {
- get
- {
- if(i < 0 || i >= len)
- throw new System.IndexOutOfRangeException("Index outside array bounds.");
- return atoms[i];
- }
- set
- {
- if(i < 0 || i >= len)
- throw new System.IndexOutOfRangeException("Index outside array bounds.");
- atoms[i] = value;
- }
- }
-
-#if !NET_2_0
- public static explicit operator Atom[](AtomList l)
- {
- Atom[] ret = new Atom[l.Count];
- int i;
- for(i = 0; i < l.Count; ++i) ret[i] = l.atoms[i];
- return ret;
- }
-#endif
-
- override public string ToString()
- {
- string n = "{";
- if(len > 0) {
- int i;
- for(i = 0; i < len-1; ++i) n += atoms[i].ToString()+",";
- n += atoms[i].ToString();
- }
- return n+"}";
- }
- }
-}
diff --git a/pd/PureData.cs b/pd/PureData.cs
deleted file mode 100644
index d6ad3d9..0000000
--- a/pd/PureData.cs
+++ /dev/null
@@ -1,48 +0,0 @@
-using System;
-using System.Runtime.CompilerServices; // for extern import
-using System.Runtime.InteropServices; // for structures
-
-namespace PureData
-{
- // PD core functions
- public unsafe class Core
- {
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- public extern static void Post(string message);
-
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- public extern static void PostError(string message);
-
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- public extern static void PostBug(string message);
-
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- public extern static void PostVerbose(string message);
-
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- internal extern static void *SymGen(string sym);
-
- [MethodImplAttribute (MethodImplOptions.InternalCall)]
- internal extern static string SymEval(void *sym);
- }
-
- // This is the base class for a PD/CLR external
- public unsafe class External
- : Core
- {
- // PD object pointer
- private readonly void *ptr;
-
- protected virtual void MethodBang() { throw new System.NotImplementedException("Bang handler not defined"); }
-
- protected virtual void MethodFloat(float f) { throw new System.NotImplementedException("Float handler not defined"); }
-
- protected virtual void MethodSymbol(Symbol s) { throw new System.NotImplementedException("Symbol handler not defined"); }
-
- protected virtual void MethodPointer(Pointer p) { throw new System.NotImplementedException("Pointer handler not defined"); }
-
- protected virtual void MethodList(AtomList lst) { throw new System.NotImplementedException("List handler not defined"); }
-
- protected virtual void MethodAnything(Symbol tag,AtomList lst) { throw new System.NotImplementedException("Anything handler not defined"); }
- }
-}
diff --git a/pd/README.txt b/pd/README.txt
deleted file mode 100755
index 323f00c..0000000
--- a/pd/README.txt
+++ /dev/null
@@ -1,3 +0,0 @@
-to compile PureData.dll execute this command:
-
-mcs Atom.cs pd.cs -out:PureData.dll -target:library \ No newline at end of file
diff --git a/pd/pd.csproj b/pd/pd.csproj
deleted file mode 100755
index 8dd510d..0000000
--- a/pd/pd.csproj
+++ /dev/null
@@ -1,105 +0,0 @@
-<VisualStudioProject>
- <CSHARP
- ProjectType = "Local"
- ProductVersion = "7.10.3077"
- SchemaVersion = "2.0"
- ProjectGuid = "{FFBC9D2E-1FB7-4E82-B5DC-46B31F8A58A2}"
- >
- <Build>
- <Settings
- ApplicationIcon = ""
- AssemblyKeyContainerName = ""
- AssemblyName = "PureData"
- AssemblyOriginatorKeyFile = ""
- DefaultClientScript = "JScript"
- DefaultHTMLPageLayout = "Grid"
- DefaultTargetSchema = "IE50"
- DelaySign = "false"
- OutputType = "Library"
- PreBuildEvent = ""
- PostBuildEvent = ""
- RootNamespace = "PureData"
- RunPostBuildEvent = "OnBuildSuccess"
- StartupObject = ""
- >
- <Config
- Name = "Debug"
- AllowUnsafeBlocks = "true"
- BaseAddress = "285212672"
- CheckForOverflowUnderflow = "false"
- ConfigurationOverrideFile = ""
- DefineConstants = "DEBUG;TRACE"
- DocumentationFile = ""
- DebugSymbols = "true"
- FileAlignment = "4096"
- IncrementalBuild = "false"
- NoStdLib = "false"
- NoWarn = ""
- Optimize = "false"
- OutputPath = "..\"
- RegisterForComInterop = "false"
- RemoveIntegerChecks = "false"
- TreatWarningsAsErrors = "false"
- WarningLevel = "4"
- />
- <Config
- Name = "Release"
- AllowUnsafeBlocks = "true"
- BaseAddress = "285212672"
- CheckForOverflowUnderflow = "false"
- ConfigurationOverrideFile = ""
- DefineConstants = "TRACE"
- DocumentationFile = ""
- DebugSymbols = "false"
- FileAlignment = "4096"
- IncrementalBuild = "false"
- NoStdLib = "false"
- NoWarn = ""
- Optimize = "true"
- OutputPath = "bin\Release\"
- RegisterForComInterop = "false"
- RemoveIntegerChecks = "false"
- TreatWarningsAsErrors = "false"
- WarningLevel = "4"
- />
- </Settings>
- <References>
- <Reference
- Name = "System"
- AssemblyName = "System"
- HintPath = "..\..\..\..\..\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.dll"
- />
- <Reference
- Name = "System.Data"
- AssemblyName = "System.Data"
- HintPath = "..\..\..\..\..\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.Data.dll"
- />
- <Reference
- Name = "System.XML"
- AssemblyName = "System.Xml"
- HintPath = "..\..\..\..\..\WINDOWS\Microsoft.NET\Framework\v1.1.4322\System.XML.dll"
- />
- </References>
- </Build>
- <Files>
- <Include>
- <File
- RelPath = "AssemblyInfo.cs"
- SubType = "Code"
- BuildAction = "Compile"
- />
- <File
- RelPath = "Atom.cs"
- SubType = "Code"
- BuildAction = "Compile"
- />
- <File
- RelPath = "PureData.cs"
- SubType = "Code"
- BuildAction = "Compile"
- />
- </Include>
- </Files>
- </CSHARP>
-</VisualStudioProject>
-
diff --git a/pd/pd.sln b/pd/pd.sln
deleted file mode 100755
index 2d4a44b..0000000
--- a/pd/pd.sln
+++ /dev/null
@@ -1,21 +0,0 @@
-Microsoft Visual Studio Solution File, Format Version 8.00
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "pd", "pd.csproj", "{FFBC9D2E-1FB7-4E82-B5DC-46B31F8A58A2}"
- ProjectSection(ProjectDependencies) = postProject
- EndProjectSection
-EndProject
-Global
- GlobalSection(SolutionConfiguration) = preSolution
- Debug = Debug
- Release = Release
- EndGlobalSection
- GlobalSection(ProjectConfiguration) = postSolution
- {FFBC9D2E-1FB7-4E82-B5DC-46B31F8A58A2}.Debug.ActiveCfg = Debug|.NET
- {FFBC9D2E-1FB7-4E82-B5DC-46B31F8A58A2}.Debug.Build.0 = Debug|.NET
- {FFBC9D2E-1FB7-4E82-B5DC-46B31F8A58A2}.Release.ActiveCfg = Release|.NET
- {FFBC9D2E-1FB7-4E82-B5DC-46B31F8A58A2}.Release.Build.0 = Release|.NET
- EndGlobalSection
- GlobalSection(ExtensibilityGlobals) = postSolution
- EndGlobalSection
- GlobalSection(ExtensibilityAddIns) = postSolution
- EndGlobalSection
-EndGlobal