Added the trunk/branches/tags directories at repository root, and moved previous root into trunk/
git-svn-id: https://sfml.svn.sourceforge.net/svnroot/sfml/trunk@1002 4e206d99-4929-0410-ac5d-dfc041789085
This commit is contained in:
commit
2f524481c1
974 changed files with 295448 additions and 0 deletions
102
DSFML/import/dsfml/system/linkedlist.d
Normal file
102
DSFML/import/dsfml/system/linkedlist.d
Normal file
|
@ -0,0 +1,102 @@
|
|||
/*
|
||||
* DSFML - SFML Library binding in D language.
|
||||
* Copyright (C) 2008 Julien Dagorn (sirjulio13@gmail.com)
|
||||
*
|
||||
* This software is provided 'as-is', without any express or
|
||||
* implied warranty. In no event will the authors be held
|
||||
* liable for any damages arising from the use of this software.
|
||||
*
|
||||
* Permission is granted to anyone to use this software for any purpose,
|
||||
* including commercial applications, and to alter it and redistribute
|
||||
* it freely, subject to the following restrictions:
|
||||
*
|
||||
* 1. The origin of this software must not be misrepresented;
|
||||
* you must not claim that you wrote the original software.
|
||||
* If you use this software in a product, an acknowledgment
|
||||
* in the product documentation would be appreciated but
|
||||
* is not required.
|
||||
*
|
||||
* 2. Altered source versions must be plainly marked as such,
|
||||
* and must not be misrepresented as being the original software.
|
||||
*
|
||||
* 3. This notice may not be removed or altered from any
|
||||
* source distribution.
|
||||
*/
|
||||
|
||||
module dsfml.system.linkedlist;
|
||||
|
||||
/*
|
||||
* Trivial implementation of Queue linked list (for internal use)
|
||||
*/
|
||||
class LinkedList(T)
|
||||
{
|
||||
Node!(T) head;
|
||||
Node!(T) tail;
|
||||
private size_t m_count;
|
||||
|
||||
void enqueue(T object)
|
||||
{
|
||||
if (empty)
|
||||
head = tail = new Node!(T)(object);
|
||||
else
|
||||
{
|
||||
tail.Next = new Node!(T)(object);
|
||||
tail = tail.Next;
|
||||
}
|
||||
m_count++;
|
||||
}
|
||||
|
||||
T dequeue()
|
||||
{
|
||||
T o;
|
||||
if (empty)
|
||||
o = T.init;
|
||||
else
|
||||
{
|
||||
o = head.Data;
|
||||
head = head.Next;
|
||||
m_count--;
|
||||
}
|
||||
return o;
|
||||
}
|
||||
|
||||
bool empty()
|
||||
{
|
||||
return (head is null);
|
||||
}
|
||||
|
||||
size_t getCount()
|
||||
{
|
||||
return m_count;
|
||||
}
|
||||
|
||||
void clear()
|
||||
{
|
||||
T data;
|
||||
while ((data = dequeue()) !is T.init) {}
|
||||
}
|
||||
|
||||
int opApply(int delegate(ref T) dg)
|
||||
{
|
||||
T data;
|
||||
int result;
|
||||
while ((data = dequeue) !is T.init)
|
||||
{
|
||||
if ((result = dg(data)) != 0)
|
||||
break;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
private class Node(T)
|
||||
{
|
||||
Node Next;
|
||||
T Data;
|
||||
|
||||
this(T data)
|
||||
{
|
||||
Data = data;
|
||||
}
|
||||
}
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue