major source structure and module name changes
This commit is contained in:
36
common/Makefile.am
Normal file
36
common/Makefile.am
Normal file
@@ -0,0 +1,36 @@
|
||||
#######################################################################
|
||||
#
|
||||
# Copyright (C) 2006 Novell, Inc.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU General Public
|
||||
# License as published by the Free Software Foundation; either
|
||||
# version 2 of the License, or (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public
|
||||
# License along with this program; if not, write to the Free
|
||||
# Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#
|
||||
#######################################################################
|
||||
|
||||
SUBDIRS = $(TARGET_OS)
|
||||
|
||||
DIST_SUBDIRS = linux
|
||||
|
||||
CFILES =
|
||||
|
||||
EXTRA_DIST = $(CFILES)
|
||||
|
||||
.PHONY: package package-clean package-install package-uninstall
|
||||
package package-clean package-install package-uninstall:
|
||||
$(MAKE) -C $(TARGET_OS) $@
|
||||
|
||||
maintainer-clean-local:
|
||||
rm -f Makefile.in
|
||||
|
||||
114
common/linux/Makefile.am
Normal file
114
common/linux/Makefile.am
Normal file
@@ -0,0 +1,114 @@
|
||||
#######################################################################
|
||||
#
|
||||
# Copyright (C) 2006 Novell, Inc.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU General Public
|
||||
# License as published by the Free Software Foundation; either
|
||||
# version 2 of the License, or (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public
|
||||
# License along with this program; if not, write to the Free
|
||||
# Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#
|
||||
#######################################################################
|
||||
|
||||
if DEBUG
|
||||
TARGET_CFG = Debug
|
||||
CFLAGS += -v -w
|
||||
else
|
||||
TARGET_CFG = Release
|
||||
endif
|
||||
|
||||
SUBDIRS =
|
||||
DIST_SUBDIRS =
|
||||
|
||||
EXTRA_DIST = $(CFILES)
|
||||
|
||||
CASAROOT = ../..
|
||||
|
||||
CASALIBDIR = $(CASAROOT)/$(LIB)
|
||||
|
||||
# handle Mono secondary dependencies
|
||||
export MONO_PATH := $(MONO_PATH)
|
||||
|
||||
PLATFORMINDEPENDENTSOURCEDIR = ..
|
||||
PLATFORMDEPENDENTSOURCEDIR = .
|
||||
|
||||
MODULE_NAME =sscs_ll
|
||||
MODULE_EXT =o
|
||||
|
||||
CFILES = ../sscs_ll.c
|
||||
|
||||
CSFILES_CSC :=
|
||||
INCLUDES = -I. -I.. -I$(CASAROOT)/include -I/opt/gnome/include/gnome-keyring-1/
|
||||
EXTRA_CFLAGS =
|
||||
RESOURCES =
|
||||
CFLAGS += $(EXTRA_CFLAGS) $(INCLUDES) $(DEFINES)
|
||||
LIBS = -lpthread -ldl
|
||||
LDFLAGS = -Bsymbolic -shared -Wl,-soname=$(MODULE_NAME).$(MODULE_EXT)
|
||||
|
||||
OBJDIR = ./$(TARGET_CFG)/$(LIB)
|
||||
|
||||
|
||||
|
||||
OBJS = $(addprefix $(OBJDIR)/, $(CFILES:%.c=%.o))
|
||||
|
||||
CUR_DIR := $(shell pwd)
|
||||
|
||||
all: $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
|
||||
#
|
||||
# Pattern based rules.
|
||||
#
|
||||
vpath %.c $(PLATFORMDEPENDENTSOURCEDIR) $(PLATFORMINDEPENDENTSOURCEDIR)
|
||||
vpath %.cpp $(PLATFORMDEPENDENTSOURCEDIR) $(PLATFORMINDEPENDENTSOURCEDIR)
|
||||
|
||||
$(OBJDIR)/%.o: %.c
|
||||
$(CC) -c $(CFLAGS) -o $@ $<
|
||||
|
||||
$(OBJDIR)/%.o: %.cpp
|
||||
$(CC) -c $(CFLAGS) -o $@ $<
|
||||
|
||||
#$(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT): $(OBJDIR) $(OBJS)
|
||||
# @echo [======== Linking $@ ========]
|
||||
# $(LINK) -o $@ $(LDFLAGS) $(OBJS) $(LIBS)
|
||||
# cp -f $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT) $(CASALIBDIR)/$(TARGET_CFG)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
|
||||
$(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT):
|
||||
@echo [======== Creating symlink $@ ========]
|
||||
ln -f $(CFILES) $(CASAROOT)/c_micasadk
|
||||
|
||||
$(OBJDIR):
|
||||
[ -d $(OBJDIR) ] || mkdir -p $(OBJDIR)
|
||||
[ -d $(CASALIBDIR) ] || mkdir -p $(CASALIBDIR)
|
||||
[ -d $(CASALIBDIR)/$(TARGET_CFG) ] || mkdir -p $(CASALIBDIR)/$(TARGET_CFG)
|
||||
|
||||
|
||||
install-exec-local: $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
$(mkinstalldirs) $(DESTDIR)$(libdir)
|
||||
$(INSTALL_PROGRAM) $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT) $(DESTDIR)$(libdir)/
|
||||
|
||||
uninstall-local:
|
||||
cd $(DESTDIR)$(libdir); rm -f $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
rmdir $(DESTDIR)$(libdir)
|
||||
|
||||
#installcheck-local: install
|
||||
# $(mkinstalldirs) $(DESTDIR)$(libdir)
|
||||
# $(INSTALL_PROGRAM) $(DESTDIR)$(libdir)
|
||||
# cd $(DESTDIR)$(libdir); $(MONO)
|
||||
|
||||
clean-local:
|
||||
if [ -d $(TARGET_CFG) ]; then rm -rf $(TARGET_CFG); fi
|
||||
|
||||
distclean-local:
|
||||
|
||||
maintainer-clean-local:
|
||||
rm -f Makefile.in
|
||||
|
||||
452
common/sscs_ll.c
Normal file
452
common/sscs_ll.c
Normal file
@@ -0,0 +1,452 @@
|
||||
/***********************************************************************
|
||||
*
|
||||
* Copyright (C) 2005-2006 Novell, Inc. All Rights Reserved.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; version 2.1
|
||||
* of the License.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Library Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library; if not, Novell, Inc.
|
||||
*
|
||||
* To contact Novell about this file by physical or electronic mail,
|
||||
* you may find current contact information at www.novell.com.
|
||||
*
|
||||
***********************************************************************/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <memory.h>
|
||||
#include "sscs_lldefs.h"
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - _ll_CreateLink
|
||||
*
|
||||
* DESCRIPTION
|
||||
* This function will create a link to be used in a list.
|
||||
*
|
||||
*/
|
||||
LL_LINK_T *_ll_CreateLink(uint32_t itemSize)
|
||||
{ /* beginning of the call */
|
||||
/* ########################## DECLARATIONS START HERE ######################### */
|
||||
|
||||
/* allocate the new link */
|
||||
LL_LINK_T *newLink = (LL_LINK_T *)(malloc(sizeof(LL_LINK_T) + itemSize));
|
||||
|
||||
/* ############################## CODE STARTS HERE ############################ */
|
||||
|
||||
if(newLink)
|
||||
{
|
||||
/* clear out the allocated buffer */
|
||||
memset(newLink, 0 , sizeof(sizeof(LL_LINK_T)+itemSize));
|
||||
newLink->item = (((uint8_t *)newLink) + sizeof(LL_LINK_T));
|
||||
return(newLink);
|
||||
}
|
||||
|
||||
return(NULL);
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of _ll_CreateLink */
|
||||
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - ll_RemoveCurrentLink
|
||||
*
|
||||
* DESCRIPTION
|
||||
*
|
||||
*
|
||||
*/
|
||||
void ll_RemoveCurrentLink(LL_LINKLIST_T *list)
|
||||
{ /* beginning of the call */
|
||||
/* ######################## DECLARATIONS START HERE ######################## */
|
||||
|
||||
int i;
|
||||
LL_LINK_T *prev = NULL, *targetLink = NULL;
|
||||
|
||||
/* ########################### CODE STARTS HERE ############################ */
|
||||
|
||||
if(list->elemCount)
|
||||
{
|
||||
// save the link to delete
|
||||
targetLink = list->clp;
|
||||
// start at the head
|
||||
list->clp = list->head;
|
||||
|
||||
for(i = 0; i < (int)list->elemCount; i++)
|
||||
{
|
||||
if(list->clp == targetLink)
|
||||
{
|
||||
if(prev)
|
||||
{
|
||||
prev->next = list->clp->next;
|
||||
list->clp = prev;
|
||||
}
|
||||
else
|
||||
{
|
||||
list->head = list->head->next;
|
||||
list->clp = list->head;
|
||||
}
|
||||
|
||||
free(targetLink);
|
||||
list->elemCount--;
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
prev = list->clp;
|
||||
list->clp = list->clp->next;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of ll_RemoveCurrentLink */
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - ll_InsertSharedSecretLink
|
||||
*
|
||||
* DESCRIPTION
|
||||
* This function inserts a new link into the link list after the
|
||||
* CLP. If the CLP is pointing to the tail of the list the new
|
||||
* link will become the new tail for the list. The new link will
|
||||
* become the CLP and the index will be set to CLP.
|
||||
*
|
||||
*/
|
||||
int ll_InsertSharedSecretLink
|
||||
(
|
||||
LL_LINKLIST_T *list,
|
||||
uint32_t kLen,
|
||||
SS_UTF8_T *key,
|
||||
uint32_t vLen,
|
||||
uint8_t *value
|
||||
)
|
||||
{ /* beginning of the call */
|
||||
/* ########################## DECLARATIONS START HERE ######################################## */
|
||||
|
||||
uint32_t keyLen = sscs_Utf8StrSize(key);
|
||||
LL_LINK_T *newLink = _ll_CreateLink(sizeof(LL_SHSEC_KEY_VAL_T) + keyLen + vLen);
|
||||
LL_SHSEC_KEY_VAL_T *sharedLink;
|
||||
|
||||
/* ############################## CODE STARTS HERE ########################################### */
|
||||
|
||||
if(newLink)
|
||||
{
|
||||
if(list->elemCount)
|
||||
{
|
||||
list->clp = list->head;
|
||||
/* check for duplicates */
|
||||
do
|
||||
{
|
||||
// check to see if the key exists
|
||||
if(((ll_GetSHSecKeyLen(list) == kLen) &&
|
||||
(memcmp(ll_GetSHSecKey(list), key, ll_GetSHSecKeyLen(list))) == 0))
|
||||
{
|
||||
// the key exists now check for the value
|
||||
if((ll_GetSHSecValLen(list) == vLen) &&
|
||||
(memcmp(ll_GetSHSecVal(list), value, ll_GetSHSecValLen(list)) == 0))
|
||||
{
|
||||
/* element already in the list */
|
||||
free(newLink);
|
||||
return(NSSCS_LL_SUCCESS);
|
||||
}
|
||||
else
|
||||
{
|
||||
// free the link with old valude
|
||||
ll_RemoveCurrentLink(list);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* move forward one link */
|
||||
if(list->clp->next)
|
||||
{
|
||||
list->clp = list->clp->next;
|
||||
continue;
|
||||
}
|
||||
else
|
||||
{
|
||||
/* end of the list not found */
|
||||
break;
|
||||
}
|
||||
} while(TRUE);
|
||||
|
||||
if (list->clp)
|
||||
{
|
||||
list->clp->next = newLink;
|
||||
/* reset the clp to the new link */
|
||||
list->clp = newLink;
|
||||
(list->elemCount)++;
|
||||
}
|
||||
else
|
||||
{
|
||||
list->head = list->clp = newLink;
|
||||
list->elemCount = 1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
list->head = list->clp = newLink;
|
||||
list->elemCount = 1;
|
||||
}
|
||||
|
||||
/* copy linkData to the link */
|
||||
sharedLink = (LL_SHSEC_KEY_VAL_T*)list->clp->item;
|
||||
sharedLink->kLen = kLen;
|
||||
sharedLink->vLen = vLen;
|
||||
sharedLink->key = (SS_UTF8_T *)(((uint8_t *)sharedLink) + sizeof(LL_SHSEC_KEY_VAL_T));
|
||||
sharedLink->value = (((uint8_t *)sharedLink) + sizeof(LL_SHSEC_KEY_VAL_T)) + keyLen;
|
||||
|
||||
sscs_Utf8Strncpy(sharedLink->key, key, kLen);
|
||||
memcpy(sharedLink->value, value, vLen);
|
||||
|
||||
return(NSSCS_LL_SUCCESS);
|
||||
}
|
||||
else
|
||||
{
|
||||
return(NSSCS_E_LL_SYS_FAILURE);
|
||||
}
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of ll_InsertSharedSecretLink */
|
||||
|
||||
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - ll_RemoveSharedSecretLink
|
||||
*
|
||||
* DESCRIPTION
|
||||
* This function removes a Shared Secret link from the link list at the
|
||||
* CLP.
|
||||
*
|
||||
*/
|
||||
int ll_RemoveSharedSecretLink
|
||||
(
|
||||
LL_LINKLIST_T *list,
|
||||
uint32_t kLen,
|
||||
SS_UTF8_T *key
|
||||
)
|
||||
{ /* beginning of the call */
|
||||
/* ########################## DECLARATIONS START HERE ######################### */
|
||||
|
||||
LL_LINK_T *prev = NULL;
|
||||
|
||||
/* ############################## CODE STARTS HERE ############################ */
|
||||
|
||||
if(list->elemCount)
|
||||
{
|
||||
list->clp = list->head;
|
||||
/* check for duplicates */
|
||||
do
|
||||
{
|
||||
// keys should be unique
|
||||
if(((ll_GetSHSecKeyLen(list) == kLen) &&
|
||||
(memcmp(ll_GetSHSecKey(list), key, ll_GetSHSecKeyLen(list))) == 0))
|
||||
{
|
||||
/* element already in the list */
|
||||
if(prev)
|
||||
{
|
||||
prev->next = list->clp->next;
|
||||
free(list->clp);
|
||||
list->clp = prev;
|
||||
}
|
||||
else
|
||||
{
|
||||
list->head = list->head->next;
|
||||
free(list->clp);
|
||||
list->clp = list->head;
|
||||
}
|
||||
|
||||
list->elemCount--;
|
||||
return(NSSCS_LL_SUCCESS);
|
||||
}
|
||||
|
||||
/* move forward one link */
|
||||
if(list->clp->next)
|
||||
{
|
||||
prev = list->clp;
|
||||
list->clp = list->clp->next;
|
||||
continue;
|
||||
}
|
||||
else
|
||||
{
|
||||
/* end of the list item not found */
|
||||
return(NSSCS_LL_SUCCESS);
|
||||
}
|
||||
} while(TRUE);
|
||||
}
|
||||
|
||||
return(NSSCS_E_LL_SYS_FAILURE);
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of ll_RemoveSharedSecretLink */
|
||||
|
||||
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - ll_DestroyList
|
||||
*
|
||||
* DESCRIPTION
|
||||
* This function completely destroy a linked list by freeing the
|
||||
* memory for all the links.
|
||||
*
|
||||
*/
|
||||
void ll_DestroyList(LL_LINKLIST_T *list)
|
||||
{ /* beginning of the call */
|
||||
/* ############################## CODE STARTS HERE ############################ */
|
||||
|
||||
/* kill the links in the link list */
|
||||
while(list->elemCount)
|
||||
{
|
||||
list->clp = list->head;
|
||||
list->head = list->head->next;
|
||||
free(list->clp);
|
||||
list->elemCount--;
|
||||
}
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of ll_DestroyList */
|
||||
|
||||
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - ll_Next
|
||||
*
|
||||
* DESCRIPTION
|
||||
* This function moves the CLP to point to the next
|
||||
* link in the list and returns a TRUE or FALSE based on the
|
||||
* success or failure (when it reaches the end of the list) of the
|
||||
* operation.
|
||||
*
|
||||
*/
|
||||
int ll_Next(LL_LINKLIST_T *list)
|
||||
{ /* beginning of the call */
|
||||
/* ############################## CODE STARTS HERE ############################ */
|
||||
|
||||
if(list)
|
||||
{
|
||||
if(list->elemCount)
|
||||
{
|
||||
if(list->clp->next)
|
||||
{
|
||||
list->clp = list->clp->next;
|
||||
return(TRUE); /* if not at the tail of the list */
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return(FALSE); /* cannot go beyond the tail of the list */
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of ll_Next */
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - ll_InsertNewLink
|
||||
*
|
||||
* DESCRIPTION
|
||||
* Cache in a set of ds items.
|
||||
*
|
||||
*/
|
||||
void *ll_InsertNewLink
|
||||
(
|
||||
LL_LINKLIST_T *list,
|
||||
uint32_t itemSize
|
||||
)
|
||||
{ /* beginning of the call */
|
||||
/* ########################## DECLARATIONS START HERE ######################### */
|
||||
|
||||
LL_LINK_T *newLink = _ll_CreateLink(itemSize);
|
||||
|
||||
/* ############################## CODE STARTS HERE ############################ */
|
||||
|
||||
if(newLink)
|
||||
{
|
||||
if(list->elemCount)
|
||||
{
|
||||
list->clp = list->head;
|
||||
/* check for duplicates */
|
||||
while(list->clp->next)
|
||||
{
|
||||
list->clp = list->clp->next;
|
||||
}
|
||||
|
||||
list->clp->next = newLink;
|
||||
/* reset the clp to the new link */
|
||||
list->clp = newLink;
|
||||
(list->elemCount)++;
|
||||
}
|
||||
else
|
||||
{
|
||||
list->head = list->clp = newLink;
|
||||
list->elemCount = 1;
|
||||
}
|
||||
|
||||
|
||||
|
||||
return(newLink->item);
|
||||
}
|
||||
else
|
||||
{
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of ll_InsertNewLink */
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* */
|
||||
/*
|
||||
* NAME - ll_GetEntry
|
||||
*
|
||||
* DESCRIPTION
|
||||
* This function returns a pointer to the current item
|
||||
* in the list or returns NULL
|
||||
*
|
||||
*/
|
||||
void* ll_GetEntry(LL_LINKLIST_T *list)
|
||||
{ /* beginning of the call */
|
||||
/* ############################## CODE STARTS HERE ############################ */
|
||||
|
||||
if(list)
|
||||
{
|
||||
if(list->elemCount)
|
||||
{
|
||||
if(list->clp->item)
|
||||
{
|
||||
return list->clp->item;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return NULL;
|
||||
|
||||
/* ############################### CODE ENDS HERE ############################# */
|
||||
} /* end of ll_GetEntry */
|
||||
114
common/windows/Makefile.am
Executable file
114
common/windows/Makefile.am
Executable file
@@ -0,0 +1,114 @@
|
||||
#######################################################################
|
||||
#
|
||||
# Copyright (C) 2006 Novell, Inc.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU General Public
|
||||
# License as published by the Free Software Foundation; either
|
||||
# version 2 of the License, or (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public
|
||||
# License along with this program; if not, write to the Free
|
||||
# Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
#
|
||||
#
|
||||
#######################################################################
|
||||
|
||||
if DEBUG
|
||||
TARGET_CFG = Debug
|
||||
CFLAGS += -v -w
|
||||
else
|
||||
TARGET_CFG = Release
|
||||
endif
|
||||
|
||||
SUBDIRS =
|
||||
DIST_SUBDIRS =
|
||||
|
||||
EXTRA_DIST = $(CFILES)
|
||||
|
||||
CASAROOT = ../..
|
||||
|
||||
CASALIBDIR = $(CASAROOT)/$(LIB)
|
||||
|
||||
# handle Mono secondary dependencies
|
||||
export MONO_PATH := $(MONO_PATH)
|
||||
|
||||
PLATFORMINDEPENDENTSOURCEDIR = ..
|
||||
PLATFORMDEPENDENTSOURCEDIR = .
|
||||
|
||||
MODULE_NAME =sscs_ll
|
||||
MODULE_EXT =o
|
||||
|
||||
CFILES = ../sscs_ll.c
|
||||
|
||||
CSFILES_CSC :=
|
||||
INCLUDES = -I. -I.. -I$(CASAROOT)/include -I/opt/gnome/include/gnome-keyring-1/
|
||||
EXTRA_CFLAGS =
|
||||
RESOURCES =
|
||||
CFLAGS += $(EXTRA_CFLAGS) $(INCLUDES) $(DEFINES)
|
||||
LIBS = -lpthread -ldl
|
||||
LDFLAGS = -Bsymbolic -shared -Wl,-soname=$(MODULE_NAME).$(MODULE_EXT)
|
||||
|
||||
OBJDIR = ./$(TARGET_CFG)/$(LIB)
|
||||
|
||||
|
||||
|
||||
OBJS = $(addprefix $(OBJDIR)/, $(CFILES:%.c=%.o))
|
||||
|
||||
CUR_DIR := $(shell pwd)
|
||||
|
||||
all: $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
|
||||
#
|
||||
# Pattern based rules.
|
||||
#
|
||||
vpath %.c $(PLATFORMDEPENDENTSOURCEDIR) $(PLATFORMINDEPENDENTSOURCEDIR)
|
||||
vpath %.cpp $(PLATFORMDEPENDENTSOURCEDIR) $(PLATFORMINDEPENDENTSOURCEDIR)
|
||||
|
||||
$(OBJDIR)/%.o: %.c
|
||||
$(CC) -c $(CFLAGS) -o $@ $<
|
||||
|
||||
$(OBJDIR)/%.o: %.cpp
|
||||
$(CC) -c $(CFLAGS) -o $@ $<
|
||||
|
||||
#$(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT): $(OBJDIR) $(OBJS)
|
||||
# @echo [======== Linking $@ ========]
|
||||
# $(LINK) -o $@ $(LDFLAGS) $(OBJS) $(LIBS)
|
||||
# cp -f $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT) $(CASALIBDIR)/$(TARGET_CFG)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
|
||||
$(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT):
|
||||
@echo [======== Creating symlink $@ ========]
|
||||
ln -f $(CFILES) $(CASAROOT)/c_micasadk
|
||||
|
||||
$(OBJDIR):
|
||||
[ -d $(OBJDIR) ] || mkdir -p $(OBJDIR)
|
||||
[ -d $(CASALIBDIR) ] || mkdir -p $(CASALIBDIR)
|
||||
[ -d $(CASALIBDIR)/$(TARGET_CFG) ] || mkdir -p $(CASALIBDIR)/$(TARGET_CFG)
|
||||
|
||||
|
||||
install-exec-local: $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
$(mkinstalldirs) $(DESTDIR)$(libdir)
|
||||
$(INSTALL_PROGRAM) $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT) $(DESTDIR)$(libdir)/
|
||||
|
||||
uninstall-local:
|
||||
cd $(DESTDIR)$(libdir); rm -f $(OBJDIR)/$(MODULE_NAME).$(MODULE_EXT)
|
||||
rmdir $(DESTDIR)$(libdir)
|
||||
|
||||
#installcheck-local: install
|
||||
# $(mkinstalldirs) $(DESTDIR)$(libdir)
|
||||
# $(INSTALL_PROGRAM) $(DESTDIR)$(libdir)
|
||||
# cd $(DESTDIR)$(libdir); $(MONO)
|
||||
|
||||
clean-local:
|
||||
if [ -d $(TARGET_CFG) ]; then rm -rf $(TARGET_CFG); fi
|
||||
|
||||
distclean-local:
|
||||
|
||||
maintainer-clean-local:
|
||||
rm -f Makefile.in
|
||||
|
||||
Reference in New Issue
Block a user