about summary refs log tree commit diff
path: root/src/libexpr/value-to-json.cc
diff options
context:
space:
mode:
authorEelco Dolstra <eelco.dolstra@logicblox.com>2014-12-02T16·52+0100
committerEelco Dolstra <eelco.dolstra@logicblox.com>2014-12-02T16·52+0100
commitf43a8ede931a4173fc0dd24463bfad873e56a7da (patch)
tree25fb469c4c82fb6ce8670f01a088a63513e9e1b7 /src/libexpr/value-to-json.cc
parent5f04da905fcd01ea2d68cdbf7af41c836df5bb4e (diff)
parent608110804cc753eee31418fda1b33cb77a83d0fc (diff)
Merge pull request #401 from shlevy/external-value
Allow external code using libnixexpr to add types
Diffstat (limited to 'src/libexpr/value-to-json.cc')
-rw-r--r--src/libexpr/value-to-json.cc11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/libexpr/value-to-json.cc b/src/libexpr/value-to-json.cc
index d1ec9b566d66..cdb71341875a 100644
--- a/src/libexpr/value-to-json.cc
+++ b/src/libexpr/value-to-json.cc
@@ -80,10 +80,21 @@ void printValueAsJSON(EvalState & state, bool strict,
             break;
         }
 
+	case tExternal:
+            v.external->printValueAsJSON(state, strict, str, context);
+            break;
+
         default:
             throw TypeError(format("cannot convert %1% to JSON") % showType(v));
     }
 }
 
 
+void ExternalValueBase::printValueAsJSON(EvalState & state, bool strict,
+      std::ostream & str, PathSet & context) const
+{
+    throw TypeError(format("cannot convert %1% to JSON") % showType());
+}
+
+
 }