[open-ils-commits] r10127 - in branches/acq-experiment: .
Open-ILS/examples Open-ILS/include/openils
Open-ILS/src/c-apps Open-ILS/src/extras Open-ILS/web/js/dojo/openils
Open-ILS/web/js/dojo/openils/widget
svn at svn.open-ils.org
svn at svn.open-ils.org
Fri Jul 25 10:55:22 EDT 2008
Author: erickson
Date: 2008-07-25 10:55:15 -0400 (Fri, 25 Jul 2008)
New Revision: 10127
Modified:
branches/acq-experiment/
branches/acq-experiment/Open-ILS/examples/fm_IDL.xml
branches/acq-experiment/Open-ILS/include/openils/oils_event.h
branches/acq-experiment/Open-ILS/include/openils/oils_utils.h
branches/acq-experiment/Open-ILS/src/c-apps/oils_cstore.c
branches/acq-experiment/Open-ILS/src/extras/Makefile
branches/acq-experiment/Open-ILS/web/js/dojo/openils/I18N.js
branches/acq-experiment/Open-ILS/web/js/dojo/openils/widget/TranslatorPopup.js
Log:
Merged revisions 10112,10115,10119,10121,10123-10124 via svnmerge from
svn://svn.open-ils.org/ILS/trunk
........
r10112 | miker | 2008-07-24 11:04:05 -0400 (Thu, 24 Jul 2008) | 1 line
backporting virtual field support from acq branch
........
r10115 | miker | 2008-07-24 13:35:44 -0400 (Thu, 24 Jul 2008) | 1 line
adding locale table to IDL
........
r10119 | miker | 2008-07-24 13:58:20 -0400 (Thu, 24 Jul 2008) | 1 line
pull valid locales from the configured set in the database
........
r10121 | miker | 2008-07-24 17:00:39 -0400 (Thu, 24 Jul 2008) | 1 line
use filtering select to present the friendly name of the locale ... the default set needs to be normalized against CLDR
........
r10123 | erickson | 2008-07-24 17:31:08 -0400 (Thu, 24 Jul 2008) | 5 lines
Ported jsonObjectIterator to new jsonIterator API and removed all references to the legacy objson headers
........
r10124 | miker | 2008-07-24 21:03:47 -0400 (Thu, 24 Jul 2008) | 1 line
correcting column name in the IDL
........
Property changes on: branches/acq-experiment
___________________________________________________________________
Name: svnmerge-integrated
- /trunk:1-10092
+ /trunk:1-10124
Modified: branches/acq-experiment/Open-ILS/examples/fm_IDL.xml
===================================================================
--- branches/acq-experiment/Open-ILS/examples/fm_IDL.xml 2008-07-25 04:03:20 UTC (rev 10126)
+++ branches/acq-experiment/Open-ILS/examples/fm_IDL.xml 2008-07-25 14:55:15 UTC (rev 10127)
@@ -3253,7 +3253,9 @@
<field name="translation" oils_obj:array_position="6" oils_persist:virtual="false" reporter:datatype="text"/>
<field name="string" oils_obj:array_position="7" oils_persist:virtual="false" reporter:datatype="text"/>
</fields>
- <links/>
+ <links>
+ <link field="translation" reltype="has_a" key="code" map="" class="i18n_l"/>
+ </links>
<permacrud xmlns="http://open-ils.org/spec/opensrf/IDL/permacrud/v1">
<actions>
<create permission="CREATE_TRANSLATION" global_required="true"/>
@@ -3263,7 +3265,6 @@
</actions>
</permacrud>
</class>
-
<class id="acqct" controller="open-ils.cstore open-ils.reporter-store" oils_obj:fieldmapper="acq::currency_type" oils_persist:tablename="acq.currency_type">
<fields oils_persist:primary="code">
<field name="isnew" oils_obj:array_position="0" oils_persist:virtual="true" />
@@ -3773,7 +3774,26 @@
</fields>
<links/>
</class>
-
+ <class id="i18n_l" controller="open-ils.cstore" oils_obj:fieldmapper="config::i18n_locale" oils_persist:tablename="config.i18n_locale" oils_persist:field_safe="true">
+ <fields oils_persist:primary="id">
+ <field name="isnew" oils_obj:array_position="0" oils_persist:virtual="true" />
+ <field name="ischanged" oils_obj:array_position="1" oils_persist:virtual="true" />
+ <field name="isdeleted" oils_obj:array_position="2" oils_persist:virtual="true" />
+ <field name="code" oils_obj:array_position="3" oils_persist:virtual="false" reporter:datatype="id" />
+ <field name="marc_code" oils_obj:array_position="4" oils_persist:virtual="false" reporter:datatype="text"/>
+ <field name="name" oils_obj:array_position="5" oils_persist:virtual="false" reporter:datatype="text"/>
+ <field name="description" oils_obj:array_position="6" oils_persist:virtual="false" reporter:datatype="text"/>
+ </fields>
+ <links/>
+ <permacrud xmlns="http://open-ils.org/spec/opensrf/IDL/permacrud/v1">
+ <actions>
+ <create permission="CREATE_LOCALE" global_required="true"/>
+ <retrieve permission="CREATE_LOCALE|UPDATE_LOCALE|DELETE_LOCALE" global_required="true"/>
+ <update permission="UPDATE_LOCALE" global_required="true"/>
+ <delete permission="DELETE_LOCALE" global_required="true"/>
+ </actions>
+ </permacrud>
+ </class>
<class id="rof" controller="open-ils.reporter-store" oils_obj:fieldmapper="reporter::output_folder" oils_persist:tablename="reporter.output_folder">
<fields oils_persist:primary="id" oils_persist:sequence="reporter.output_folder_id_seq">
<field name="isnew" oils_obj:array_position="0" oils_persist:virtual="true" />
Modified: branches/acq-experiment/Open-ILS/include/openils/oils_event.h
===================================================================
--- branches/acq-experiment/Open-ILS/include/openils/oils_event.h 2008-07-25 04:03:20 UTC (rev 10126)
+++ branches/acq-experiment/Open-ILS/include/openils/oils_event.h 2008-07-25 14:55:15 UTC (rev 10127)
@@ -1,6 +1,6 @@
#ifndef OILS_EVENT_HEADER
#define OILS_EVENT_HEADER
-#include "objson/object.h"
+#include "opensrf/osrf_json.h"
#include "opensrf/utils.h"
#include "opensrf/log.h"
#include "opensrf/osrf_hash.h"
Modified: branches/acq-experiment/Open-ILS/include/openils/oils_utils.h
===================================================================
--- branches/acq-experiment/Open-ILS/include/openils/oils_utils.h 2008-07-25 04:03:20 UTC (rev 10126)
+++ branches/acq-experiment/Open-ILS/include/openils/oils_utils.h 2008-07-25 14:55:15 UTC (rev 10127)
@@ -1,4 +1,4 @@
-#include "objson/object.h"
+#include "opensrf/osrf_json.h"
#include "opensrf/log.h"
// XXX replacing this with liboils_idl implementation
Modified: branches/acq-experiment/Open-ILS/src/c-apps/oils_cstore.c
===================================================================
--- branches/acq-experiment/Open-ILS/src/c-apps/oils_cstore.c 2008-07-25 04:03:20 UTC (rev 10126)
+++ branches/acq-experiment/Open-ILS/src/c-apps/oils_cstore.c 2008-07-25 14:55:15 UTC (rev 10127)
@@ -6,7 +6,6 @@
#include "opensrf/log.h"
#include "openils/oils_idl.h"
#include <dbi/dbi.h>
-#include <objson/object.h>
#include <time.h>
#include <stdlib.h>
@@ -53,9 +52,9 @@
static char* searchWriteSimplePredicate ( const char*, osrfHash*,
const char*, const char*, const char* );
static char* searchSimplePredicate ( const char*, const char*, osrfHash*, const jsonObject* );
-static char* searchFunctionPredicate ( const char*, osrfHash*, const jsonObjectNode* );
+static char* searchFunctionPredicate ( const char*, osrfHash*, const jsonObject*, const char* );
static char* searchFieldTransform ( const char*, osrfHash*, const jsonObject*);
-static char* searchFieldTransformPredicate ( const char*, osrfHash*, jsonObjectNode* );
+static char* searchFieldTransformPredicate ( const char*, osrfHash*, jsonObject*, const char* );
static char* searchBETWEENPredicate ( const char*, osrfHash*, jsonObject* );
static char* searchINPredicate ( const char*, osrfHash*, const jsonObject*, const char* );
static char* searchPredicate ( const char*, osrfHash*, jsonObject* );
@@ -181,7 +180,7 @@
int i = 0;
char* method_type;
- char* st_tmp;
+ char* st_tmp = NULL;
char* _fm;
char* part;
osrfHash* method_meta;
@@ -649,12 +648,12 @@
obj = doFieldmapperSearch(ctx, class_obj, ctx->params, &err);
if(err) return err;
- jsonObjectNode* cur;
- jsonObjectIterator* itr = jsonNewObjectIterator( obj );
- while ((cur = jsonObjectIteratorNext( itr ))) {
- osrfAppRespond( ctx, cur->item );
+ jsonObject* cur;
+ jsonIterator* itr = jsonNewIterator( obj );
+ while ((cur = jsonIteratorNext( itr ))) {
+ osrfAppRespond( ctx, cur );
}
- jsonObjectIteratorFree(itr);
+ jsonIteratorFree(itr);
osrfAppRespondComplete( ctx, NULL );
} else if (!strcmp(methodtype, "id_list")) {
@@ -679,13 +678,13 @@
jsonObjectFree(_p);
if(err) return err;
- jsonObjectNode* cur;
- jsonObjectIterator* itr = jsonNewObjectIterator( obj );
- while ((cur = jsonObjectIteratorNext( itr ))) {
+ jsonObject* cur;
+ jsonIterator* itr = jsonNewIterator( obj );
+ while ((cur = jsonIteratorNext( itr ))) {
osrfAppRespond(
ctx,
jsonObjectGetIndex(
- cur->item,
+ cur,
atoi(
osrfHashGet(
osrfHashGet(
@@ -698,7 +697,7 @@
)
);
}
- jsonObjectIteratorFree(itr);
+ jsonIteratorFree(itr);
osrfAppRespondComplete( ctx, NULL );
} else {
@@ -1149,17 +1148,17 @@
}
static char* searchFunctionPredicate (const char* class, osrfHash* field,
- const jsonObjectNode* node) {
+ const jsonObject* node, const char* node_key) {
growing_buffer* sql_buf = buffer_init(32);
- char* val = searchValueTransform(node->item);
+ char* val = searchValueTransform(node);
buffer_fadd(
sql_buf,
"\"%s\".%s %s %s",
class,
osrfHashGet(field, "name"),
- node->key,
+ node_key,
val
);
@@ -1228,21 +1227,21 @@
return buffer_release(sql_buf);
}
-static char* searchFieldTransformPredicate (const char* class, osrfHash* field, jsonObjectNode* node) {
- char* field_transform = searchFieldTransform( class, field, node->item );
+static char* searchFieldTransformPredicate (const char* class, osrfHash* field, jsonObject* node, const char* node_key) {
+ char* field_transform = searchFieldTransform( class, field, node );
char* value = NULL;
- if (!jsonObjectGetKeyConst( node->item, "value" )) {
- value = searchWHERE( node->item, osrfHashGet( oilsIDL(), class ), AND_OP_JOIN );
- } else if (jsonObjectGetKeyConst( node->item, "value" )->type == JSON_ARRAY) {
- value = searchValueTransform(jsonObjectGetKeyConst( node->item, "value" ));
- } else if (jsonObjectGetKeyConst( node->item, "value" )->type == JSON_HASH) {
- value = searchWHERE( jsonObjectGetKeyConst( node->item, "value" ), osrfHashGet( oilsIDL(), class ), AND_OP_JOIN );
- } else if (jsonObjectGetKeyConst( node->item, "value" )->type != JSON_NULL) {
+ if (!jsonObjectGetKeyConst( node, "value" )) {
+ value = searchWHERE( node, osrfHashGet( oilsIDL(), class ), AND_OP_JOIN );
+ } else if (jsonObjectGetKeyConst( node, "value" )->type == JSON_ARRAY) {
+ value = searchValueTransform(jsonObjectGetKeyConst( node, "value" ));
+ } else if (jsonObjectGetKeyConst( node, "value" )->type == JSON_HASH) {
+ value = searchWHERE( jsonObjectGetKeyConst( node, "value" ), osrfHashGet( oilsIDL(), class ), AND_OP_JOIN );
+ } else if (jsonObjectGetKeyConst( node, "value" )->type != JSON_NULL) {
if ( !strcmp(osrfHashGet(field, "primitive"), "number") ) {
- value = jsonNumberToDBString( field, jsonObjectGetKeyConst( node->item, "value" ) );
+ value = jsonNumberToDBString( field, jsonObjectGetKeyConst( node, "value" ) );
} else {
- value = jsonObjectToSimpleString(jsonObjectGetKeyConst( node->item, "value" ));
+ value = jsonObjectToSimpleString(jsonObjectGetKeyConst( node, "value" ));
if ( !dbi_conn_quote_string(dbhandle, &value) ) {
osrfLogError(OSRF_LOG_MARK, "%s: Error quoting key string [%s]", MODULENAME, value);
free(value);
@@ -1258,7 +1257,7 @@
sql_buf,
"%s %s %s",
field_transform,
- node->key,
+ node_key,
value
);
@@ -1357,23 +1356,23 @@
if (node->type == JSON_ARRAY) { // equality IN search
pred = searchINPredicate( class, field, node, NULL );
} else if (node->type == JSON_HASH) { // non-equality search
- jsonObjectNode* pred_node;
- jsonObjectIterator* pred_itr = jsonNewObjectIterator( node );
- while ( (pred_node = jsonObjectIteratorNext( pred_itr )) ) {
- if ( !(strcasecmp( pred_node->key,"between" )) )
- pred = searchBETWEENPredicate( class, field, pred_node->item );
- else if ( !(strcasecmp( pred_node->key,"in" )) || !(strcasecmp( pred_node->key,"not in" )) )
- pred = searchINPredicate( class, field, pred_node->item, pred_node->key );
- else if ( pred_node->item->type == JSON_ARRAY )
- pred = searchFunctionPredicate( class, field, pred_node );
- else if ( pred_node->item->type == JSON_HASH )
- pred = searchFieldTransformPredicate( class, field, pred_node );
+ jsonObject* pred_node;
+ jsonIterator* pred_itr = jsonNewIterator( node );
+ while ( (pred_node = jsonIteratorNext( pred_itr )) ) {
+ if ( !(strcasecmp( pred_itr->key,"between" )) )
+ pred = searchBETWEENPredicate( class, field, pred_node );
+ else if ( !(strcasecmp( pred_itr->key,"in" )) || !(strcasecmp( pred_itr->key,"not in" )) )
+ pred = searchINPredicate( class, field, pred_node, pred_itr->key );
+ else if ( pred_node->type == JSON_ARRAY )
+ pred = searchFunctionPredicate( class, field, pred_node, pred_itr->key );
+ else if ( pred_node->type == JSON_HASH )
+ pred = searchFieldTransformPredicate( class, field, pred_node, pred_itr->key );
else
- pred = searchSimplePredicate( pred_node->key, class, field, pred_node->item );
+ pred = searchSimplePredicate( pred_itr->key, class, field, pred_node );
break;
}
- jsonObjectIteratorFree(pred_itr);
+ jsonIteratorFree(pred_itr);
} else if (node->type == JSON_NULL) { // IS NULL search
growing_buffer* _p = buffer_init(64);
buffer_fadd(
@@ -1438,18 +1437,18 @@
growing_buffer* join_buf = buffer_init(128);
char* leftclass = osrfHashGet(leftmeta, "classname");
- jsonObjectNode* snode = NULL;
- jsonObjectIterator* search_itr = jsonNewObjectIterator( working_hash );
+ jsonObject* snode = NULL;
+ jsonIterator* search_itr = jsonNewIterator( working_hash );
if(freeable_hash)
jsonObjectFree(freeable_hash);
- while ( (snode = jsonObjectIteratorNext( search_itr )) ) {
- osrfHash* idlClass = osrfHashGet( oilsIDL(), snode->key );
+ while ( (snode = jsonIteratorNext( search_itr )) ) {
+ osrfHash* idlClass = osrfHashGet( oilsIDL(), search_itr->key );
char* class = osrfHashGet(idlClass, "classname");
- char* fkey = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode->item, "fkey" ) );
- char* field = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode->item, "field" ) );
+ char* fkey = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode, "fkey" ) );
+ char* field = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode, "field" ) );
if (field && !fkey) {
fkey = (char*)oilsIDLFindPath("/%s/links/%s/key", class, field);
@@ -1464,7 +1463,7 @@
);
buffer_free(join_buf);
free(field);
- jsonObjectIteratorFree(search_itr);
+ jsonIteratorFree(search_itr);
return NULL;
}
fkey = strdup( fkey );
@@ -1482,7 +1481,7 @@
);
buffer_free(join_buf);
free(fkey);
- jsonObjectIteratorFree(search_itr);
+ jsonIteratorFree(search_itr);
return NULL;
}
field = strdup( field );
@@ -1529,13 +1528,13 @@
class
);
buffer_free(join_buf);
- jsonObjectIteratorFree(search_itr);
+ jsonIteratorFree(search_itr);
return NULL;
}
}
- char* type = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode->item, "type" ) );
+ char* type = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode, "type" ) );
if (type) {
if ( !strcasecmp(type,"left") ) {
buffer_add(join_buf, " LEFT JOIN");
@@ -1555,9 +1554,9 @@
buffer_fadd(join_buf, " %s AS \"%s\" ON ( \"%s\".%s = \"%s\".%s", table, class, class, field, leftclass, fkey);
free(table);
- const jsonObject* filter = jsonObjectGetKeyConst( snode->item, "filter" );
+ const jsonObject* filter = jsonObjectGetKeyConst( snode, "filter" );
if (filter) {
- char* filter_op = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode->item, "filter_op" ) );
+ char* filter_op = jsonObjectToSimpleString( jsonObjectGetKeyConst( snode, "filter_op" ) );
if (filter_op) {
if (!strcasecmp("or",filter_op)) {
buffer_add( join_buf, " OR " );
@@ -1576,7 +1575,7 @@
buffer_add(join_buf, " ) ");
- const jsonObject* join_filter = jsonObjectGetKeyConst( snode->item, "join" );
+ const jsonObject* join_filter = jsonObjectGetKeyConst( snode, "join" );
if (join_filter) {
char* jpred = searchJOIN( join_filter, idlClass );
buffer_fadd( join_buf, " %s", jpred );
@@ -1587,7 +1586,7 @@
free(field);
}
- jsonObjectIteratorFree(search_itr);
+ jsonIteratorFree(search_itr);
return buffer_release(join_buf);
}
@@ -1603,12 +1602,12 @@
growing_buffer* sql_buf = buffer_init(128);
- jsonObjectNode* node = NULL;
+ jsonObject* node = NULL;
int first = 1;
if ( search_hash->type == JSON_ARRAY ) {
- jsonObjectIterator* search_itr = jsonNewObjectIterator( search_hash );
- while ( (node = jsonObjectIteratorNext( search_itr )) ) {
+ jsonIterator* search_itr = jsonNewIterator( search_hash );
+ while ( (node = jsonIteratorNext( search_itr )) ) {
if (first) {
first = 0;
} else {
@@ -1616,15 +1615,15 @@
else buffer_add(sql_buf, " AND ");
}
- char* subpred = searchWHERE( node->item, meta, opjoin_type );
+ char* subpred = searchWHERE( node, meta, opjoin_type );
buffer_fadd(sql_buf, "( %s )", subpred);
free(subpred);
}
- jsonObjectIteratorFree(search_itr);
+ jsonIteratorFree(search_itr);
} else if ( search_hash->type == JSON_HASH ) {
- jsonObjectIterator* search_itr = jsonNewObjectIterator( search_hash );
- while ( (node = jsonObjectIteratorNext( search_itr )) ) {
+ jsonIterator* search_itr = jsonNewIterator( search_hash );
+ while ( (node = jsonIteratorNext( search_itr )) ) {
if (first) {
first = 0;
@@ -1633,29 +1632,29 @@
else buffer_add(sql_buf, " AND ");
}
- if ( !strncmp("+",node->key,1) ) {
- if ( node->item->type == JSON_STRING ) {
- char* subpred = jsonObjectToSimpleString( node->item );
- buffer_fadd(sql_buf, " \"%s\".%s ", node->key + 1, subpred);
+ if ( !strncmp("+",search_itr->key,1) ) {
+ if ( node->type == JSON_STRING ) {
+ char* subpred = jsonObjectToSimpleString( node );
+ buffer_fadd(sql_buf, " \"%s\".%s ", search_itr->key + 1, subpred);
free(subpred);
} else {
- char* subpred = searchWHERE( node->item, osrfHashGet( oilsIDL(), node->key + 1 ), AND_OP_JOIN );
+ char* subpred = searchWHERE( node, osrfHashGet( oilsIDL(), search_itr->key + 1 ), AND_OP_JOIN );
buffer_fadd(sql_buf, "( %s )", subpred);
free(subpred);
}
- } else if ( !strcasecmp("-or",node->key) ) {
- char* subpred = searchWHERE( node->item, meta, OR_OP_JOIN );
+ } else if ( !strcasecmp("-or",search_itr->key) ) {
+ char* subpred = searchWHERE( node, meta, OR_OP_JOIN );
buffer_fadd(sql_buf, "( %s )", subpred);
free(subpred);
- } else if ( !strcasecmp("-and",node->key) ) {
- char* subpred = searchWHERE( node->item, meta, AND_OP_JOIN );
+ } else if ( !strcasecmp("-and",search_itr->key) ) {
+ char* subpred = searchWHERE( node, meta, AND_OP_JOIN );
buffer_fadd(sql_buf, "( %s )", subpred);
free(subpred);
} else {
char* class = osrfHashGet(meta, "classname");
osrfHash* fields = osrfHashGet(meta, "fields");
- osrfHash* field = osrfHashGet( fields, node->key );
+ osrfHash* field = osrfHashGet( fields, search_itr->key );
if (!field) {
@@ -1664,22 +1663,22 @@
OSRF_LOG_MARK,
"%s: Attempt to reference non-existant column %s on %s (%s)",
MODULENAME,
- node->key,
+ search_itr->key,
table,
class
);
buffer_free(sql_buf);
free(table);
- jsonObjectIteratorFree(search_itr);
+ jsonIteratorFree(search_itr);
return NULL;
}
- char* subpred = searchPredicate( class, field, node->item );
+ char* subpred = searchPredicate( class, field, node );
buffer_add( sql_buf, subpred );
free(subpred);
}
}
- jsonObjectIteratorFree(search_itr);
+ jsonIteratorFree(search_itr);
} else {
// ERROR ... only hash and array allowed at this level
@@ -1719,10 +1718,10 @@
// general tmp objects
const jsonObject* tmp_const;
jsonObject* _tmp = NULL;
- jsonObjectNode* selclass = NULL;
- jsonObjectNode* selfield = NULL;
- jsonObjectNode* snode = NULL;
- jsonObjectNode* onode = NULL;
+ jsonObject* selclass = NULL;
+ jsonObject* selfield = NULL;
+ jsonObject* snode = NULL;
+ jsonObject* onode = NULL;
jsonObject* found = NULL;
char* string = NULL;
@@ -1744,13 +1743,13 @@
// get the core class -- the only key of the top level FROM clause, or a string
if (join_hash->type == JSON_HASH) {
- jsonObjectIterator* tmp_itr = jsonNewObjectIterator( join_hash );
- snode = jsonObjectIteratorNext( tmp_itr );
+ jsonIterator* tmp_itr = jsonNewIterator( join_hash );
+ snode = jsonIteratorNext( tmp_itr );
- core_class = strdup( snode->key );
- join_hash = snode->item;
+ core_class = strdup( tmp_itr->key );
+ join_hash = snode;
- jsonObjectIteratorFree( tmp_itr );
+ jsonIteratorFree( tmp_itr );
snode = NULL;
} else if (join_hash->type == JSON_STRING) {
@@ -1808,11 +1807,11 @@
jsonObject* is_agg = jsonObjectFindPath(selhash, "//aggregate");
first = 1;
gfirst = 1;
- jsonObjectIterator* selclass_itr = jsonNewObjectIterator( selhash );
- while ( (selclass = jsonObjectIteratorNext( selclass_itr )) ) {
+ jsonIterator* selclass_itr = jsonNewIterator( selhash );
+ while ( (selclass = jsonIteratorNext( selclass_itr )) ) {
// round trip through the idl, just to be safe
- idlClass = osrfHashGet( oilsIDL(), selclass->key );
+ idlClass = osrfHashGet( oilsIDL(), selclass_itr->key );
if (!idlClass) continue;
char* cname = osrfHashGet(idlClass, "classname");
@@ -1837,17 +1836,17 @@
}
// stitch together the column list ...
- jsonObjectIterator* select_itr = jsonNewObjectIterator( selclass->item );
- while ( (selfield = jsonObjectIteratorNext( select_itr )) ) {
+ jsonIterator* select_itr = jsonNewIterator( selclass );
+ while ( (selfield = jsonIteratorNext( select_itr )) ) {
char* __column = NULL;
char* __alias = NULL;
// ... if it's a sstring, just toss it on the pile
- if (selfield->item->type == JSON_STRING) {
+ if (selfield->type == JSON_STRING) {
// again, just to be safe
- char* _requested_col = jsonObjectToSimpleString(selfield->item);
+ char* _requested_col = jsonObjectToSimpleString(selfield);
osrfHash* field = osrfHashGet( osrfHashGet( idlClass, "fields" ), _requested_col );
free(_requested_col);
@@ -1880,7 +1879,7 @@
// ... but it could be an object, in which case we check for a Field Transform
} else {
- __column = jsonObjectToSimpleString( jsonObjectGetKeyConst( selfield->item, "column" ) );
+ __column = jsonObjectToSimpleString( jsonObjectGetKeyConst( selfield, "column" ) );
// again, just to be safe
osrfHash* field = osrfHashGet( osrfHashGet( idlClass, "fields" ), __column );
@@ -1893,15 +1892,15 @@
buffer_add(select_buf, ",");
}
- if ((tmp_const = jsonObjectGetKeyConst( selfield->item, "alias" ))) {
+ if ((tmp_const = jsonObjectGetKeyConst( selfield, "alias" ))) {
__alias = jsonObjectToSimpleString( tmp_const );
} else {
__alias = strdup(__column);
}
- if (jsonObjectGetKeyConst( selfield->item, "transform" )) {
+ if (jsonObjectGetKeyConst( selfield, "transform" )) {
free(__column);
- __column = searchFieldTransform(cname, field, selfield->item);
+ __column = searchFieldTransform(cname, field, selfield);
buffer_fadd(select_buf, " %s AS \"%s\"", __column, __alias);
} else {
if (locale) {
@@ -1925,7 +1924,7 @@
if (is_agg->size || (flags & SELECT_DISTINCT)) {
- if (!jsonBoolIsTrue( jsonObjectGetKey( selfield->item, "aggregate" ) )) {
+ if (!jsonBoolIsTrue( jsonObjectGetKey( selfield, "aggregate" ) )) {
if (gfirst) {
gfirst = 0;
} else {
@@ -1934,16 +1933,16 @@
buffer_fadd(group_buf, " %d", sel_pos);
/*
- } else if (is_agg = jsonObjectGetKey( selfield->item, "having" )) {
+ } else if (is_agg = jsonObjectGetKey( selfield, "having" )) {
if (gfirst) {
gfirst = 0;
} else {
buffer_add(group_buf, ",");
}
- __column = searchFieldTransform(cname, field, selfield->item);
+ __column = searchFieldTransform(cname, field, selfield);
buffer_fadd(group_buf, " %s", __column);
- __column = searchFieldTransform(cname, field, selfield->item);
+ __column = searchFieldTransform(cname, field, selfield);
*/
}
}
@@ -1954,10 +1953,10 @@
sel_pos++;
}
- // jsonObjectIteratorFree(select_itr);
+ // jsonIteratorFree(select_itr);
}
- // jsonObjectIteratorFree(selclass_itr);
+ // jsonIteratorFree(selclass_itr);
if (is_agg) jsonObjectFree(is_agg);
@@ -2031,35 +2030,35 @@
}
first = 1;
- jsonObjectIterator* class_itr = jsonNewObjectIterator( order_hash );
- while ( (snode = jsonObjectIteratorNext( class_itr )) ) {
+ jsonIterator* class_itr = jsonNewIterator( order_hash );
+ while ( (snode = jsonIteratorNext( class_itr )) ) {
- if (!jsonObjectGetKeyConst(selhash,snode->key))
+ if (!jsonObjectGetKeyConst(selhash,class_itr->key))
continue;
- if ( snode->item->type == JSON_HASH ) {
+ if ( snode->type == JSON_HASH ) {
- jsonObjectIterator* order_itr = jsonNewObjectIterator( snode->item );
- while ( (onode = jsonObjectIteratorNext( order_itr )) ) {
+ jsonIterator* order_itr = jsonNewIterator( snode );
+ while ( (onode = jsonIteratorNext( order_itr )) ) {
- if (!oilsIDLFindPath( "/%s/fields/%s", snode->key, onode->key ))
+ if (!oilsIDLFindPath( "/%s/fields/%s", class_itr->key, order_itr->key ))
continue;
char* direction = NULL;
- if ( onode->item->type == JSON_HASH ) {
- if ( jsonObjectGetKeyConst( onode->item, "transform" ) ) {
+ if ( onode->type == JSON_HASH ) {
+ if ( jsonObjectGetKeyConst( onode, "transform" ) ) {
string = searchFieldTransform(
- snode->key,
- oilsIDLFindPath( "/%s/fields/%s", snode->key, onode->key ),
- onode->item
+ class_itr->key,
+ oilsIDLFindPath( "/%s/fields/%s", class_itr->key, order_itr->key ),
+ onode
);
} else {
growing_buffer* field_buf = buffer_init(16);
- buffer_fadd(field_buf, "\"%s\".%s", snode->key, onode->key);
+ buffer_fadd(field_buf, "\"%s\".%s", class_itr->key, order_itr->key);
string = buffer_release(field_buf);
}
- if ( (tmp_const = jsonObjectGetKeyConst( onode->item, "direction" )) ) {
+ if ( (tmp_const = jsonObjectGetKeyConst( onode, "direction" )) ) {
direction = jsonObjectToSimpleString(tmp_const);
if (!strncasecmp(direction, "d", 1)) {
free(direction);
@@ -2071,8 +2070,8 @@
}
} else {
- string = strdup(onode->key);
- direction = jsonObjectToSimpleString(onode->item);
+ string = strdup(order_itr->key);
+ direction = jsonObjectToSimpleString(onode);
if (!strncasecmp(direction, "d", 1)) {
free(direction);
direction = " DESC";
@@ -2096,16 +2095,16 @@
}
}
- // jsonObjectIteratorFree(order_itr);
+ // jsonIteratorFree(order_itr);
- } else if ( snode->item->type == JSON_ARRAY ) {
+ } else if ( snode->type == JSON_ARRAY ) {
- jsonObjectIterator* order_itr = jsonNewObjectIterator( snode->item );
- while ( (onode = jsonObjectIteratorNext( order_itr )) ) {
+ jsonIterator* order_itr = jsonNewIterator( snode );
+ while ( (onode = jsonIteratorNext( order_itr )) ) {
- char* _f = jsonObjectToSimpleString( onode->item );
+ char* _f = jsonObjectToSimpleString( onode );
- if (!oilsIDLFindPath( "/%s/fields/%s", snode->key, _f))
+ if (!oilsIDLFindPath( "/%s/fields/%s", class_itr->key, _f))
continue;
if (first) {
@@ -2118,7 +2117,7 @@
free(_f);
}
- // jsonObjectIteratorFree(order_itr);
+ // jsonIteratorFree(order_itr);
// IT'S THE OOOOOOOOOOOLD STYLE!
@@ -2138,13 +2137,13 @@
buffer_free(order_buf);
buffer_free(sql_buf);
if (defaultselhash) jsonObjectFree(defaultselhash);
- jsonObjectIteratorFree(class_itr);
+ jsonIteratorFree(class_itr);
return NULL;
}
}
- // jsonObjectIteratorFree(class_itr);
+ // jsonIteratorFree(class_itr);
string = buffer_release(group_buf);
@@ -2212,9 +2211,9 @@
const jsonObject* join_hash = jsonObjectGetKeyConst( order_hash, "join" );
- jsonObjectNode* node = NULL;
- jsonObjectNode* snode = NULL;
- jsonObjectNode* onode = NULL;
+ jsonObject* node = NULL;
+ jsonObject* snode = NULL;
+ jsonObject* onode = NULL;
const jsonObject* _tmp = NULL;
jsonObject* selhash = NULL;
jsonObject* defaultselhash = NULL;
@@ -2243,17 +2242,17 @@
}
int first = 1;
- jsonObjectIterator* class_itr = jsonNewObjectIterator( selhash );
- while ( (snode = jsonObjectIteratorNext( class_itr )) ) {
+ jsonIterator* class_itr = jsonNewIterator( selhash );
+ while ( (snode = jsonIteratorNext( class_itr )) ) {
- osrfHash* idlClass = osrfHashGet( oilsIDL(), snode->key );
+ osrfHash* idlClass = osrfHashGet( oilsIDL(), class_itr->key );
if (!idlClass) continue;
char* cname = osrfHashGet(idlClass, "classname");
- if (strcmp(core_class,snode->key)) {
+ if (strcmp(core_class,class_itr->key)) {
if (!join_hash) continue;
- jsonObject* found = jsonObjectFindPath(join_hash, "//%s", snode->key);
+ jsonObject* found = jsonObjectFindPath(join_hash, "//%s", class_itr->key);
if (!found->size) {
jsonObjectFree(found);
continue;
@@ -2262,9 +2261,9 @@
jsonObjectFree(found);
}
- jsonObjectIterator* select_itr = jsonNewObjectIterator( snode->item );
- while ( (node = jsonObjectIteratorNext( select_itr )) ) {
- char* item_str = jsonObjectToSimpleString(node->item);
+ jsonIterator* select_itr = jsonNewIterator( snode );
+ while ( (node = jsonIteratorNext( select_itr )) ) {
+ char* item_str = jsonObjectToSimpleString(node);
osrfHash* field = osrfHashGet( osrfHashGet( idlClass, "fields" ), item_str );
free(item_str);
char* fname = osrfHashGet(field, "name");
@@ -2295,10 +2294,10 @@
}
}
- jsonObjectIteratorFree(select_itr);
+ jsonIteratorFree(select_itr);
}
- jsonObjectIteratorFree(class_itr);
+ jsonIteratorFree(class_itr);
char* col_list = buffer_release(select_buf);
char* table = getSourceDefinition(meta);
@@ -2343,35 +2342,35 @@
growing_buffer* order_buf = buffer_init(128);
first = 1;
- jsonObjectIterator* class_itr = jsonNewObjectIterator( _tmp );
- while ( (snode = jsonObjectIteratorNext( class_itr )) ) {
+ jsonIterator* class_itr = jsonNewIterator( _tmp );
+ while ( (snode = jsonIteratorNext( class_itr )) ) {
- if (!jsonObjectGetKeyConst(selhash,snode->key))
+ if (!jsonObjectGetKeyConst(selhash,class_itr->key))
continue;
- if ( snode->item->type == JSON_HASH ) {
+ if ( snode->type == JSON_HASH ) {
- jsonObjectIterator* order_itr = jsonNewObjectIterator( snode->item );
- while ( (onode = jsonObjectIteratorNext( order_itr )) ) {
+ jsonIterator* order_itr = jsonNewIterator( snode );
+ while ( (onode = jsonIteratorNext( order_itr )) ) {
- if (!oilsIDLFindPath( "/%s/fields/%s", snode->key, onode->key ))
+ if (!oilsIDLFindPath( "/%s/fields/%s", class_itr->key, order_itr->key ))
continue;
char* direction = NULL;
- if ( onode->item->type == JSON_HASH ) {
- if ( jsonObjectGetKeyConst( onode->item, "transform" ) ) {
+ if ( onode->type == JSON_HASH ) {
+ if ( jsonObjectGetKeyConst( onode, "transform" ) ) {
string = searchFieldTransform(
- snode->key,
- oilsIDLFindPath( "/%s/fields/%s", snode->key, onode->key ),
- onode->item
+ class_itr->key,
+ oilsIDLFindPath( "/%s/fields/%s", class_itr->key, order_itr->key ),
+ onode
);
} else {
growing_buffer* field_buf = buffer_init(16);
- buffer_fadd(field_buf, "\"%s\".%s", snode->key, onode->key);
+ buffer_fadd(field_buf, "\"%s\".%s", class_itr->key, order_itr->key);
string = buffer_release(field_buf);
}
- if ( (_tmp = jsonObjectGetKeyConst( onode->item, "direction" )) ) {
+ if ( (_tmp = jsonObjectGetKeyConst( onode, "direction" )) ) {
direction = jsonObjectToSimpleString(_tmp);
if (!strncasecmp(direction, "d", 1)) {
free(direction);
@@ -2383,8 +2382,8 @@
}
} else {
- string = strdup(onode->key);
- direction = jsonObjectToSimpleString(onode->item);
+ string = strdup(order_itr->key);
+ direction = jsonObjectToSimpleString(onode);
if (!strncasecmp(direction, "d", 1)) {
free(direction);
direction = " DESC";
@@ -2409,10 +2408,10 @@
}
- jsonObjectIteratorFree(order_itr);
+ jsonIteratorFree(order_itr);
} else {
- string = jsonObjectToSimpleString(snode->item);
+ string = jsonObjectToSimpleString(snode);
buffer_add(order_buf, string);
free(string);
break;
@@ -2420,7 +2419,7 @@
}
- jsonObjectIteratorFree(class_itr);
+ jsonIteratorFree(class_itr);
string = buffer_release(order_buf);
@@ -2641,19 +2640,19 @@
}
if (!link_fields) {
- jsonObjectNode* _f;
+ jsonObject* _f;
link_fields = osrfNewStringArray(1);
- jsonObjectIterator* _i = jsonNewObjectIterator( flesh_fields );
- while ((_f = jsonObjectIteratorNext( _i ))) {
- osrfStringArrayAdd( link_fields, jsonObjectToSimpleString( _f->item ) );
+ jsonIterator* _i = jsonNewIterator( flesh_fields );
+ while ((_f = jsonIteratorNext( _i ))) {
+ osrfStringArrayAdd( link_fields, jsonObjectToSimpleString( _f ) );
}
- jsonObjectIteratorFree(_i);
+ jsonIteratorFree(_i);
}
}
- jsonObjectNode* cur;
- jsonObjectIterator* itr = jsonNewObjectIterator( res_list );
- while ((cur = jsonObjectIteratorNext( itr ))) {
+ jsonObject* cur;
+ jsonIterator* itr = jsonNewIterator( res_list );
+ while ((cur = jsonIteratorNext( itr ))) {
int i = 0;
char* link_field;
@@ -2715,7 +2714,7 @@
char* search_key =
jsonObjectToSimpleString(
jsonObjectGetIndex(
- cur->item,
+ cur,
atoi( osrfHashGet(value_field, "array_position") )
)
);
@@ -2764,7 +2763,7 @@
if(*err) {
jsonObjectFree( fake_params );
osrfStringArrayFree(link_fields);
- jsonObjectIteratorFree(itr);
+ jsonIteratorFree(itr);
jsonObjectFree(res_list);
jsonObjectFree(flesh_blob);
return jsonNULL;
@@ -2777,14 +2776,14 @@
X = kids;
kids = jsonNewObjectType(JSON_ARRAY);
- jsonObjectNode* _k_node;
- jsonObjectIterator* _k = jsonNewObjectIterator( X );
- while ((_k_node = jsonObjectIteratorNext( _k ))) {
+ jsonObject* _k_node;
+ jsonIterator* _k = jsonNewIterator( X );
+ while ((_k_node = jsonIteratorNext( _k ))) {
jsonObjectPush(
kids,
jsonObjectClone(
jsonObjectGetIndex(
- _k_node->item,
+ _k_node,
(unsigned long)atoi(
osrfHashGet(
osrfHashGet(
@@ -2804,13 +2803,13 @@
)
);
}
- jsonObjectIteratorFree(_k);
+ jsonIteratorFree(_k);
}
if (!(strcmp( osrfHashGet(kid_link, "reltype"), "has_a" )) || !(strcmp( osrfHashGet(kid_link, "reltype"), "might_have" ))) {
osrfLogDebug(OSRF_LOG_MARK, "Storing fleshed objects in %s", osrfHashGet(kid_link, "field"));
jsonObjectSetIndex(
- cur->item,
+ cur,
(unsigned long)atoi( osrfHashGet( field, "array_position" ) ),
jsonObjectClone( jsonObjectGetIndex(kids, 0) )
);
@@ -2819,7 +2818,7 @@
if (!(strcmp( osrfHashGet(kid_link, "reltype"), "has_many" ))) { // has_many
osrfLogDebug(OSRF_LOG_MARK, "Storing fleshed objects in %s", osrfHashGet(kid_link, "field"));
jsonObjectSetIndex(
- cur->item,
+ cur,
(unsigned long)atoi( osrfHashGet( field, "array_position" ) ),
jsonObjectClone( kids )
);
@@ -2834,13 +2833,13 @@
jsonObjectFree( fake_params );
osrfLogDebug(OSRF_LOG_MARK, "Fleshing of %s complete", osrfHashGet(kid_link, "field"));
- osrfLogDebug(OSRF_LOG_MARK, "%s", jsonObjectToJSON(cur->item));
+ osrfLogDebug(OSRF_LOG_MARK, "%s", jsonObjectToJSON(cur));
}
}
jsonObjectFree( flesh_blob );
osrfStringArrayFree(link_fields);
- jsonObjectIteratorFree(itr);
+ jsonIteratorFree(itr);
}
}
}
Modified: branches/acq-experiment/Open-ILS/src/extras/Makefile
===================================================================
--- branches/acq-experiment/Open-ILS/src/extras/Makefile 2008-07-25 04:03:20 UTC (rev 10126)
+++ branches/acq-experiment/Open-ILS/src/extras/Makefile 2008-07-25 14:55:15 UTC (rev 10127)
@@ -1,4 +1,4 @@
-LDLIBS += -lreadline -loils_utils -lopensrf -lobjson -lxml2 -loils_idl -L../c-apps
+LDLIBS += -lreadline -loils_utils -lopensrf -lxml2 -loils_idl -L../c-apps
CFLAGS += -I../../include
all: oils_requestor
Modified: branches/acq-experiment/Open-ILS/web/js/dojo/openils/I18N.js
===================================================================
--- branches/acq-experiment/Open-ILS/web/js/dojo/openils/I18N.js 2008-07-25 04:03:20 UTC (rev 10126)
+++ branches/acq-experiment/Open-ILS/web/js/dojo/openils/I18N.js 2008-07-25 14:55:15 UTC (rev 10127)
@@ -25,20 +25,11 @@
dojo.declare('openils.I18N', null, {});
- openils.I18N.BaseLocales = {
- "en" : "English",
- "en_us" : "US English",
- "en_ca" : "Canadian English",
- "es" : "Spanish",
- "es_us" : "US Spanish",
- "fr" : "French",
- "fr_ca" : "Canadian French"
- };
-
+ openils.I18N.BaseLocales = fieldmapper.standardRequest( [ 'open-ils.fielder', 'open-ils.fielder.i18n_l.atomic'], [ { query : { code : { '!=' : null } } } ] );
openils.I18N.localeStore = new dojo.data.ItemFileWriteStore( { data : {identifier : 'locale', label : 'label', items : [] } } );
for (var i in openils.I18N.BaseLocales) {
- openils.I18N.localeStore.newItem({ locale : i, label : openils.I18N.BaseLocales[i] });
+ openils.I18N.localeStore.newItem({ locale : openils.I18N.BaseLocales[i].code, label : openils.I18N.BaseLocales[i].name });
}
openils.I18N.getTranslations = function ( obj /* Fieldmapper object */, field /* Field to translate */, locale /* optional locale */) {
Modified: branches/acq-experiment/Open-ILS/web/js/dojo/openils/widget/TranslatorPopup.js
===================================================================
--- branches/acq-experiment/Open-ILS/web/js/dojo/openils/widget/TranslatorPopup.js 2008-07-25 04:03:20 UTC (rev 10126)
+++ branches/acq-experiment/Open-ILS/web/js/dojo/openils/widget/TranslatorPopup.js 2008-07-25 14:55:15 UTC (rev 10127)
@@ -29,7 +29,7 @@
dojo.require("dijit.Dialog");
dojo.require("dijit.form.Button");
dojo.require("dijit.form.TextBox");
- dojo.require("dijit.form.ComboBox");
+ dojo.require("dijit.form.FilteringSelect");
dojo.require("dojox.jsonPath");
dojo.requireLocalization("openils.widget", "TranslatorPopup");
@@ -100,9 +100,10 @@
if (old_dijit) old_dijit.destroy();
dojo.query('.locale_combobox',trans_row).instantiate(
- dijit.form.ComboBox,
+ dijit.form.FilteringSelect,
{ store:openils.I18N.localeStore,
searchAttr:'locale',
+ labelAttr:'label',
lowercase:true,
required:true,
id:'locale_' + trans_id,
@@ -143,9 +144,10 @@
trans_row = dojo.query('tr',trans_template)[0].cloneNode(true);
dojo.query('.locale_combobox',trans_row).instantiate(
- dijit.form.ComboBox,
+ dijit.form.FilteringSelect,
{ store:openils.I18N.localeStore,
searchAttr:'locale',
+ labelAttr:'label',
id:'i18n_new_locale_' + this._targetObject.classname + '.' + this.field + this.unique,
lowercase:true,
required:true,
More information about the open-ils-commits
mailing list