[Opensrf-commits] r1371 - trunk/src/gateway

svn at svn.open-ils.org svn at svn.open-ils.org
Thu Jul 24 22:22:00 EDT 2008


Author: erickson
Date: 2008-07-24 22:21:54 -0400 (Thu, 24 Jul 2008)
New Revision: 1371

Removed:
   trunk/src/gateway/fieldmapper-c-xml-out.pl
Log:
no longer in use

Deleted: trunk/src/gateway/fieldmapper-c-xml-out.pl
===================================================================
--- trunk/src/gateway/fieldmapper-c-xml-out.pl	2008-07-25 02:16:42 UTC (rev 1370)
+++ trunk/src/gateway/fieldmapper-c-xml-out.pl	2008-07-25 02:21:54 UTC (rev 1371)
@@ -1,272 +0,0 @@
-#!/usr/bin/perl
-use strict;
-use lib '../perlmods/';
-
-my $map = {};
-eval "
-	use lib '../../../Open-ILS/src/perlmods/';
-	use OpenILS::Utils::Fieldmapper;  
-";
-$map = $Fieldmapper::fieldmap unless ($@);
-
-
-if(!$ARGV[1]) {
-	print "usage: $0 <header_file> <source_file>\n";
-	exit;
-}
-
-warn "Generating fieldmapper-c code...\n";
-
-
-print $ARGV[0] . "\n";
-print $ARGV[1] . "\n";
-
-open(HEADER, ">$ARGV[0]");
-open(SOURCE, ">$ARGV[1]");
-
-warn "Generating fieldmapper-c code...\n";
-
-print HEADER <<C;
-#ifndef _TOXML_H_
-#define _TOXML_H_
-
-char* json_string_to_xml(char*);
-
-#endif
-C
-
-print SOURCE <<C;
-
-#include <string.h>
-
-/* and the JSON parser, so we can read the response we're XMLizing */
-#include <string.h>
-#include <stdio.h>
-#include "objson/object.h"
-#include "objson/json_parser.h"
-#include "opensrf/utils.h"
-
-char* json_string_to_xml(char*);
-void _rest_xml_output(growing_buffer*, object*, char*, int, int);
-char * _lookup_fm_field(char*,int);
-char* _escape_xml (char*);
-
-char* json_string_to_xml(char* content) {
-	object * obj;
-	growing_buffer * res_xml;
-	char * output;
-	int i;
-
-	obj = json_parse_string( content );
-	res_xml = buffer_init(1024);
-
-	if (!obj)
-		return NULL;
-	
-	buffer_add(res_xml, "<response>");
-
-	if(obj->is_array) {
-		for( i = 0; i!= obj->size; i++ ) {
-			_rest_xml_output(res_xml, obj->get_index(obj,i), NULL, 0,0);
-		}
-	} else {
-		_rest_xml_output(res_xml, obj, NULL, 0,0);
-	}
-
-	buffer_add(res_xml, "</response>");
-
-	output = buffer_data(res_xml);
-	buffer_free(res_xml);
-	free_object(obj);
-
-	return output;
-}
-
-char* _escape_xml (char* text) {
-	char* out;
-	growing_buffer* b = buffer_init(256);
-	int len = strlen(text);
-	int i;
-	for (i = 0; i < len; i++) {
-		if (text[i] == '&')
-			buffer_add(b,"&amp;");
-		else if (text[i] == '<')
-			buffer_add(b,"&lt;");
-		else if (text[i] == '>')
-			buffer_add(b,"&gt;");
-		else
-			buffer_add_char(b,text[i]);
-	}
-	out = buffer_data(b);
-	buffer_free(b);
-	return out;
-}
-
-void _rest_xml_output(growing_buffer* buf, object* obj, char * fm_class, int fm_index, int notag) {
-	char * tag;
-	int i;
-	
-	if(!obj) return;
-
-	if (obj->classname)
-		notag = 1;
-
-	if(fm_class) {
-		tag = _lookup_fm_field(fm_class,fm_index);
-	} else {
-		tag = strdup("datum");
-	}
-
-        
-   /* add class hints if we have a class name */
-   if(obj->classname) {
-     	if(obj->is_null) {
-			buffer_fadd(buf,"<%s><Object class_hint=\\\"%s\\\"/></%s>", tag, obj->classname, tag);
-			return;
-		} else {
-			buffer_fadd(buf,"<%s><Object class_hint=\\\"%s\\\">", tag, obj->classname);
-		}
-	}
-
-
-	/* now add the data */
-	if(obj->is_null) {
-		if (!notag)
-			buffer_fadd(buf, "<%s/>",tag);
-	} else if(obj->is_bool && obj->bool_value) {
-		if (notag)
-			buffer_add(buf, "true");
-		else
-			buffer_fadd(buf, "<%s>true</%s>",tag,tag);
-                
-	} else if(obj->is_bool && ! obj->bool_value) {
-		if (notag)
-			buffer_add(buf, "false");
-		else
-			buffer_fadd(buf, "<%s>false</%s>",tag,tag);
-
-	} else if (obj->is_string) {
-		if (notag) {
-			char * t = _escape_xml(obj->string_data);
-			buffer_add(buf,t);
-			free(t);
-		} else {
-			char * t = _escape_xml(obj->string_data);
-			buffer_fadd(buf,"<%s>%s</%s>",tag,t,tag);
-			free(t);
-		}
-
-	} else if(obj->is_number) {
-
-		if (notag)
-			buffer_fadd(buf,"%ld",obj->num_value);
-		else
-			buffer_fadd(buf,"<%s>%ld</%s>",tag,obj->num_value,tag);
-
-
-	} else if(obj->is_double) {
-		if (notag)
-			buffer_fadd(buf,"%f",tag,obj->double_value,tag);
-		else
-			buffer_fadd(buf,"<%s>%f</%s>",tag,obj->double_value,tag);
-
-
-	} else if (obj->is_array) {
-		if (!notag) {
-			if(!fm_class)
-        	       		buffer_add(buf,"<array>");
-			else
-               			buffer_fadd(buf,"<%s>",tag);
-		}
-
-	       	for( i = 0; i!= obj->size; i++ ) {
-			_rest_xml_output(buf, obj->get_index(obj,i), obj->classname, i,0);
-		}
-
-		if (!notag) {
-			if(!fm_class)
-        	       		buffer_add(buf,"</array>");
-			else
-               			buffer_fadd(buf,"</%s>",tag);
-		}
-
-        } else if (obj->is_hash) {
-
-		if (!notag) {
-			if(!fm_class)
-        	       		buffer_add(buf,"<hash>");
-			else
-               			buffer_fadd(buf,"<%s>",tag);
-		}
-
-                object_iterator* itr = new_iterator(obj);
-                object_node* tmp;
-                while( (tmp = itr->next(itr)) ) {
-			if (notag) {
-				buffer_fadd(buf,"<%s>",tmp->key);
-			} else {
-				buffer_add(buf,"<pair>");
-				buffer_fadd(buf,"<key>%s</key><value>",tmp->key);
-			}
-
-                        _rest_xml_output(buf, tmp->item, NULL,0,notag);
-
-			if (notag) {
-				buffer_fadd(buf,"</%s>",tmp->key);
-			} else {
-				buffer_add(buf,"</value></pair>");
-			}
-                }
-                free_iterator(itr);
-
-		if (!notag) {
-			if(!fm_class)
-        	       		buffer_add(buf,"</hash>");
-			else
-               			buffer_fadd(buf,"</%s>",tag);
-		}
-
-	}
-
-	if (obj->classname)
-                buffer_fadd(buf,"</Object></%s>",tag);
-
-	free(tag);
-}
-
-char * _lookup_fm_field(char * class, int pos) {
-
-C
-
-print SOURCE "	if (class == NULL) return NULL;";
-
-for my $object (keys %$map) {
-
-	my $short_name				= $map->{$object}->{hint};
-
-	print SOURCE <<"	C";
-
-	else if (!strcmp(class, "$short_name")) {
-		switch (pos) {
-	C
-
-	for my $field (keys %{$map->{$object}->{fields}}) {
-		my $position = $map->{$object}->{fields}->{$field}->{position};
-
-		print SOURCE <<"		C";
-			case $position:
-				return strdup("$field");
-				break;
-		C
-	}
-	print SOURCE "		}\n";
-	print SOURCE "	}\n";
-}
-print SOURCE '	return strdup("datum");'."\n";
-print SOURCE "}\n";
-
-close HEADER;
-close SOURCE;
-
-warn  "done\n";
-



More information about the opensrf-commits mailing list