summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorUwe Steinmann <steinm@php.net>2000-11-09 13:36:54 +0000
committerUwe Steinmann <steinm@php.net>2000-11-09 13:36:54 +0000
commiteaad937f84c8bacaa425a038b4b837686c47c1f5 (patch)
tree1edfc957305ac34ccfbb8060c6895a5fe03264cb /ext
parentd82bade81cb5d8dfa85d95918fadfa31268d401e (diff)
downloadphp-git-eaad937f84c8bacaa425a038b4b837686c47c1f5.tar.gz
- Some more comments
- Initial support to just include anchors into documents
Diffstat (limited to 'ext')
-rw-r--r--ext/hyperwave/hg_comm.c22
-rw-r--r--ext/hyperwave/hw.c67
-rw-r--r--ext/hyperwave/php_hyperwave.h1
3 files changed, 86 insertions, 4 deletions
diff --git a/ext/hyperwave/hg_comm.c b/ext/hyperwave/hg_comm.c
index 5469446a18..b56926e89b 100644
--- a/ext/hyperwave/hg_comm.c
+++ b/ext/hyperwave/hg_comm.c
@@ -326,12 +326,17 @@ int fnCmpAnchors(ANCHOR *a1, ANCHOR *a2)
/***********************************************************************
* Function fnCreateAnchorList() *
+* Uses either docofanchorrec or reldestrec to create a list of anchors *
+* depending on anchormode *
* *
* Returns a list of Anchors converted from an object record *
* Parameter: int objectID: the object for which the list is created *
* char **anchors: object records of anchors *
-* char **dest: object records of destinations *
+* char **docofanchorrec: Name of destination absolut *
+* char **reldestrec: Name of destination relativ to current *
+* object *
* int ancount: number of anchors *
+* int anchormode: 0 = use absolut dest, else rel. dest *
* Return: List of Anchors, NULL if error *
***********************************************************************/
#ifdef newlist
@@ -2112,6 +2117,7 @@ int send_gettext(int sockfd, hw_objectID objectID, int mode, int rootid, char **
DLIST *pAnchorList;
#endif
+ /* Get dest as relative and absolut path */
send_getdestforanchorsobj(sockfd, anchors, &destrec, ancount);
send_getreldestforanchorsobj(sockfd, anchors, &reldestrec, ancount, rootid, objectID);
pAnchorList = fnCreateAnchorList(objectID, anchors, destrec, reldestrec, ancount, mode);
@@ -3366,11 +3372,17 @@ int send_getdestforanchorsobj(int sockfd, char **anchorrec, char ***destrec, int
/* Now get for each anchor the object record of its destination */
for(i=0; i<count; i++) {
/* if you retrieve the anchors you sometimes get more than actually accessible.
- This happens for the object 0x29a9c. */
+ */
if((NULL != anchorrec[i]) && (NULL != (str = fnAttributeValue(anchorrec[i], "Dest")))) {
sscanf(str, "0x%x", &objectID);
efree(str);
+ /* Using send_docbyanchorobj() makes sense because the Destination can
+ be both, an anchor or a document. If it is a document you get the
+ objectrecord of that document. If it is an anchor the function
+ graps the document which belongs to the anchor
+ and you get also the objectrecord of that document.
+ */
if(0 > send_docbyanchorobj(sockfd, objectID, &objptr)) {
efree(destptr);
return -1;
@@ -3412,6 +3424,7 @@ int send_getreldestforanchorsobj(int sockfd, char **anchorrec, char ***reldestre
sscanf(str, "0x%x", &destobjectID);
efree(str);
+ /* See note in send_getdestforanchorsobj() at same position in source code */
if(0 > send_docbyanchorobj(sockfd, destobjectID, &docofanchorptr)) {
efree(reldestptr);
return -1;
@@ -4964,8 +4977,8 @@ int send_pipedocument(int sockfd, char *host, hw_objectID objectID, int mode, in
efree(retmsg);
/* passively open the data connection. The HG server is probably
- already waiting for us.
- */
+ already waiting for us.
+ */
len = sizeof(serv_addr);
if((newfd = accept(fd, (struct sockaddr *) &serv_addr, &len)) < 0) {
/* php_printf("client: can't open data connection to server\n"); */
@@ -5016,6 +5029,7 @@ int send_pipedocument(int sockfd, char *host, hw_objectID objectID, int mode, in
DLIST *pAnchorList = NULL;
#endif
+ /* Get dest as relative and absolut path */
send_getdestforanchorsobj(sockfd, anchors, &destrec, ancount);
send_getreldestforanchorsobj(sockfd, anchors, &reldestrec, ancount, rootid, objectID);
pAnchorList = fnCreateAnchorList(objectID, anchors, destrec, reldestrec, ancount, mode);
diff --git a/ext/hyperwave/hw.c b/ext/hyperwave/hw.c
index d383d30629..0351c4d7ac 100644
--- a/ext/hyperwave/hw.c
+++ b/ext/hyperwave/hw.c
@@ -108,6 +108,7 @@ function_entry hw_functions[] = {
PHP_FE(hw_insertobject, NULL)
PHP_FE(hw_insdoc, NULL)
PHP_FE(hw_getsrcbydestobj, NULL)
+ PHP_FE(hw_insertanchors, NULL)
PHP_FE(hw_getrellink, NULL)
PHP_FE(hw_who, NULL)
PHP_FE(hw_stat, NULL)
@@ -633,6 +634,28 @@ static int * make_ints_from_array(HashTable *lht) {
return objids;
}
+static char **make_strs_from_array(HashTable *arrht) {
+ char **carr = NULL;
+ zval *data, **dataptr;
+
+ zend_hash_internal_pointer_reset(arrht);
+ if(NULL == (carr = emalloc(zend_hash_num_elements(arrht) * sizeof(char *))))
+ return(NULL);
+
+ /* Iterate through hash */
+ while(zend_hash_get_current_data(arrht, (void **) &dataptr) == SUCCESS) {
+ data = *dataptr;
+ switch(data->type) {
+ case IS_STRING:
+ *carr++ = estrdup(data->value.str.val);
+ break;
+ }
+
+ zend_hash_move_forward(arrht);
+ }
+ return(carr);
+}
+
#define BUFFERLEN 30
static void php_hw_do_connect(INTERNAL_FUNCTION_PARAMETERS, int persistent)
{
@@ -3831,6 +3854,50 @@ PHP_FUNCTION(hw_getrellink) {
}
/* }}} */
+/* {{{ proto string hw_insertanchors(int hwdoc, array anchorecs, array dest)
+ Inserts only anchors into text */
+PHP_FUNCTION(hw_insertanchors) {
+ pval **arg1, **arg2, **arg3, **arg4;
+ hw_document *hwdoc;
+ int type, docid, error;
+ char *anchorstr;
+ char **anchorrecs;
+ char **dest;
+ HashTable *arrht;
+
+ if (ZEND_NUM_ARGS() != 3 || zend_get_parameters_ex(3, &arg1, &arg2, &arg3) == FAILURE) {
+ WRONG_PARAM_COUNT;
+ }
+ convert_to_long_ex(arg1);
+ convert_to_array_ex(arg2);
+ convert_to_array_ex(arg3);
+ docid=(*arg1)->value.lval;
+ hwdoc = zend_list_find(docid, &type);
+ if(!hwdoc || (type!=HwSG(le_document))) {
+ php_error(E_WARNING,"Unable to find file identifier %d",link);
+ RETURN_FALSE;
+ }
+
+ if(zend_hash_num_elements((*arg2)->value.ht) != zend_hash_num_elements((*arg3)->value.ht)) {
+ php_error(E_WARNING,"Unequal number of elments in arrays");
+ RETURN_FALSE;
+ }
+
+ /* Turn PHP-Array of strings into C-Array of strings */
+ arrht = (*arg2)->value.ht;
+ anchorrecs = make_strs_from_array(arrht);
+ arrht = (*arg3)->value.ht;
+ dest = make_strs_from_array(arrht);
+/*
+ if (0 != (error = insertanchors(hwdoc->data, anchorrecs, dest, zend_hash_num_elements(arrht)))) {
+ php_error(E_WARNING, "command (insertanchors) returned %d\n", error);
+ RETURN_FALSE;
+ }
+*/
+ RETURN_STRING(anchorstr, 0);
+}
+/* }}} */
+
PHP_MINFO_FUNCTION(hw)
{
diff --git a/ext/hyperwave/php_hyperwave.h b/ext/hyperwave/php_hyperwave.h
index 6e1be6fde1..674303bfcd 100644
--- a/ext/hyperwave/php_hyperwave.h
+++ b/ext/hyperwave/php_hyperwave.h
@@ -142,6 +142,7 @@ PHP_FUNCTION(hw_objrec2array);
PHP_FUNCTION(hw_array2objrec);
PHP_FUNCTION(hw_connection_info);
PHP_FUNCTION(hw_getsrcbydestobj);
+PHP_FUNCTION(hw_insertanchors);
PHP_FUNCTION(hw_getrellink);
PHP_FUNCTION(hw_dummy);
PHP_FUNCTION(hw_who);