[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,"&");
- else if (text[i] == '<')
- buffer_add(b,"<");
- else if (text[i] == '>')
- buffer_add(b,">");
- 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