123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273 |
-
- using System;
- using System.Runtime.InteropServices;
- using System.Text;
- namespace Kbg.NppPluginNET.PluginInfrastructure
- {
-
-
-
-
-
-
- public class Colour
- {
- public readonly int Red, Green, Blue;
- public Colour(int rgb)
- {
- Red = rgb & 0xFF;
- Green = (rgb >> 8) & 0xFF;
- Blue = (rgb >> 16) & 0xFF;
- }
-
-
-
-
-
-
- public Colour(int red, int green, int blue)
- {
- if(red > 255 || red < 0)
- throw new ArgumentOutOfRangeException("red", "must be 0-255");
- if(green > 255 || green < 0)
- throw new ArgumentOutOfRangeException("green", "must be 0-255");
- if(blue > 255 || blue < 0)
- throw new ArgumentOutOfRangeException("blue", "must be 0-255");
- Red = red;
- Green = green;
- Blue = blue;
- }
- public int Value
- {
- get { return Red + (Green << 8) + (Blue << 16); }
- }
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- public class Position : IEquatable<Position>
- {
- private readonly int pos;
- public Position(int pos)
- {
- this.pos = pos;
- }
- public int Value
- {
- get { return pos; }
- }
- public static Position operator +(Position a, Position b)
- {
- return new Position(a.pos + b.pos);
- }
- public static Position operator -(Position a, Position b)
- {
- return new Position(a.pos - b.pos);
- }
- public static bool operator ==(Position a, Position b)
- {
- if (ReferenceEquals(a, b))
- return true;
- if (ReferenceEquals(a, null))
- return false;
- if (ReferenceEquals(b, null))
- return false;
- return a.pos == b.pos;
- }
- public static bool operator !=(Position a, Position b)
- {
- return !(a == b);
- }
- public static bool operator >(Position a, Position b)
- {
- return a.Value > b.Value;
- }
- public static bool operator <(Position a, Position b)
- {
- return a.Value < b.Value;
- }
- public static Position Min(Position a, Position b)
- {
- if (a < b)
- return a;
- return b;
- }
- public static Position Max(Position a, Position b)
- {
- if (a > b)
- return a;
- return b;
- }
- public override string ToString()
- {
- return "Postion: " + pos;
- }
- public bool Equals(Position other)
- {
- if (ReferenceEquals(null, other)) return false;
- if (ReferenceEquals(this, other)) return true;
- return pos == other.pos;
- }
- public override bool Equals(object obj)
- {
- if (ReferenceEquals(null, obj)) return false;
- if (ReferenceEquals(this, obj)) return true;
- if (obj.GetType() != this.GetType()) return false;
- return Equals((Position)obj);
- }
- public override int GetHashCode()
- {
- return pos;
- }
- }
-
-
-
-
-
-
-
-
-
-
-
- public class KeyModifier
- {
- private readonly int value;
-
-
-
-
-
-
-
-
-
- public KeyModifier(SciMsg SCK_KeyCode, SciMsg SCMOD_modifier)
- {
- value = (int) SCK_KeyCode | ((int) SCMOD_modifier << 16);
- }
- public int Value
- {
- get { return Value; }
- }
- }
- [StructLayout(LayoutKind.Sequential)]
- public struct CharacterRange
- {
- public CharacterRange(int cpmin, int cpmax) { cpMin = cpmin; cpMax = cpmax; }
- public int cpMin;
- public int cpMax;
- }
- public class Cells
- {
- char[] charactersAndStyles;
- public Cells(char[] charactersAndStyles)
- {
- this.charactersAndStyles = charactersAndStyles;
- }
- public char[] Value { get { return charactersAndStyles; } }
- }
- public class TextRange : IDisposable
- {
- Sci_TextRange _sciTextRange;
- IntPtr _ptrSciTextRange;
- bool _disposed = false;
- public TextRange(CharacterRange chrRange, int stringCapacity)
- {
- _sciTextRange.chrg = chrRange;
- _sciTextRange.lpstrText = Marshal.AllocHGlobal(stringCapacity);
- }
- public TextRange(int cpmin, int cpmax, int stringCapacity)
- {
- _sciTextRange.chrg.cpMin = cpmin;
- _sciTextRange.chrg.cpMax = cpmax;
- _sciTextRange.lpstrText = Marshal.AllocHGlobal(stringCapacity);
- }
- [StructLayout(LayoutKind.Sequential)]
- struct Sci_TextRange
- {
- public CharacterRange chrg;
- public IntPtr lpstrText;
- }
- public IntPtr NativePointer { get { _initNativeStruct(); return _ptrSciTextRange; } }
- public string lpstrText { get { _readNativeStruct(); return Marshal.PtrToStringAnsi(_sciTextRange.lpstrText); } }
- public CharacterRange chrg { get { _readNativeStruct(); return _sciTextRange.chrg; } set { _sciTextRange.chrg = value; _initNativeStruct(); } }
- void _initNativeStruct()
- {
- if (_ptrSciTextRange == IntPtr.Zero)
- _ptrSciTextRange = Marshal.AllocHGlobal(Marshal.SizeOf(_sciTextRange));
- Marshal.StructureToPtr(_sciTextRange, _ptrSciTextRange, false);
- }
- void _readNativeStruct()
- {
- if (_ptrSciTextRange != IntPtr.Zero)
- _sciTextRange = (Sci_TextRange)Marshal.PtrToStructure(_ptrSciTextRange, typeof(Sci_TextRange));
- }
- public void Dispose()
- {
- if (!_disposed)
- {
- if (_sciTextRange.lpstrText != IntPtr.Zero) Marshal.FreeHGlobal(_sciTextRange.lpstrText);
- if (_ptrSciTextRange != IntPtr.Zero) Marshal.FreeHGlobal(_ptrSciTextRange);
- _disposed = true;
- }
- }
- ~TextRange()
- {
- Dispose();
- }
- }
-
-
- }
|