1 import "JavaBuiltin" as Java
2 include "http://www.simantics.org/Layer0-1.1" as L0
9 "org.simantics.db.ReadGraph"
13 "org.simantics.db.WriteGraph"
15 importJava "org.simantics.db.Resource" where
16 "A resource is a node in a semantic graph."
19 "Returns the 64-bit unique identifier of the resource."
20 @JavaName getResourceId
21 resourceId :: Resource -> Long
23 isPersistent :: Resource -> Boolean
25 importJava "org.simantics.db.ReadGraph" where
28 instance Ord Resource where
29 compare a b = compare (resourceId a) (resourceId b)
31 instance Show Resource where
32 show r = "#" + show (resourceId r)
34 instance Show Statement where
35 show s = "#" + show (resourceId ( subjectOf s)) + "#" + show (resourceId ( predicateOf s)) + "#" + show (resourceId ( objectOf s))
37 importJava "org.simantics.db.Statement" where
38 "A statement is an edge in a semantic graph."
42 subjectOf :: Statement -> Resource
43 @JavaName getPredicate
44 predicateOf :: Statement -> Resource
46 objectOf :: Statement -> Resource
48 isAsserted :: Statement -> Resource -> <ReadGraph> Boolean
50 importJava "org.simantics.db.ReadGraph" where
51 "Converts an absolute URI to a resource or returns `Nothing` if there is no such resource."
52 @JavaName getPossibleResource
53 possibleResource :: String -> <ReadGraph> (Maybe Resource)
55 getDataType :: Resource -> <ReadGraph> Datatype
57 @JavaName getSupertypes
58 superTypesOf :: Resource -> <ReadGraph> Set.T Resource
62 uriOfResource :: Resource -> <ReadGraph> String
65 @JavaName getPossibleURI
66 possibleUriOfResource :: Resource -> <ReadGraph> Maybe String
69 objects_ :: Resource -> Resource -> <ReadGraph> Collection Resource
71 @JavaName getStatements
72 statements_ :: Resource -> Resource -> <ReadGraph> Collection Statement
74 @JavaName hasStatement
75 existsStatement :: Resource -> Resource -> <ReadGraph> Boolean
77 @JavaName hasStatement
78 existsStatement3 :: Resource -> Resource -> Resource -> <ReadGraph> Boolean
80 "Assumes that there is exactly one object with the given subject and predicate and returns it."
81 @JavaName getSingleObject
82 singleObject :: Resource -> Resource -> <ReadGraph> Resource
85 If there is exactly one object with the given `subject` and `predicate`,
86 `possibleObject subject predicate` returns it. Otherwise, it returns
89 @JavaName getPossibleObject
90 possibleObject :: Resource -> Resource -> <ReadGraph> Maybe Resource
92 "Assumes that there is exactly one statement with the given subject and predicate and returns it."
93 @JavaName getSingleStatement
94 singleStatement :: Resource -> Resource -> <ReadGraph> Statement
96 @JavaName getPossibleStatement
97 possibleStatement :: Resource -> Resource -> <ReadGraph> Maybe Statement
99 @JavaName getRelatedVariantValue
100 relatedVariantValue :: Resource -> Resource -> <ReadGraph> Variant
102 @JavaName getRelatedValue
103 relatedValue_ :: Resource -> Resource -> Binding a -> <ReadGraph> a
105 @JavaName getRelatedValue
106 untypedRelatedValue :: Resource -> Resource -> <ReadGraph> a
108 @JavaName getRelatedValue2
109 relatedValue2 :: Resource -> Resource -> <ReadGraph> a
111 @JavaName getPossibleRelatedValue2
112 possibleRelatedValue2 :: Resource -> Resource -> <ReadGraph> Maybe a
114 @JavaName getRelatedVariantValue2
115 relatedVariantValue2 :: Resource -> Resource -> <ReadGraph> Variant
117 @JavaName getPossibleRelatedValue
118 possibleRelatedValue_ :: Resource -> Resource -> Binding a -> <ReadGraph> Maybe a
120 @JavaName getPossibleRelatedValue
121 untypedPossibleRelatedValue :: Resource -> Resource -> <ReadGraph> Maybe a
125 valueOf_ :: Resource -> Binding a -> <ReadGraph> a
128 @JavaName getVariantValue
129 variantValueOf_ :: Resource -> <ReadGraph> Variant
132 untypedValueOf :: Resource -> <ReadGraph> Dynamic
134 @JavaName getPossibleValue
135 untypedPossibleValueOf :: Resource -> <ReadGraph> Maybe Dynamic
138 inverseOf :: Resource -> <ReadGraph> Resource
139 @JavaName getPossibleInverse
140 possibleInverseOf :: Resource -> <ReadGraph> Maybe Resource
142 @JavaName getSingleType
143 singleTypeOf :: Resource -> Resource -> <ReadGraph> Resource
145 @JavaName getPossibleType
146 possibleTypeOf :: Resource -> Resource -> <ReadGraph> Maybe Resource
148 "`isInstanceOf r t` returns true, if `r` is an instance of `t`"
149 isInstanceOf :: Resource -> Resource -> <ReadGraph> Boolean
150 isSubrelationOf :: Resource -> Resource -> <ReadGraph> Boolean
151 isInheritedFrom :: Resource -> Resource -> <ReadGraph> Boolean
153 getRootLibrary :: () -> <ReadGraph> Resource
155 @JavaName getPredicates
156 predicatesOf :: Resource -> <ReadGraph> [Resource]
158 isImmutable :: Resource -> <ReadGraph> Boolean
160 importJava "org.simantics.db.layer0.util.ExtendedUris" where
161 "Converts an absolute URI to a resource"
162 @JavaName resolveAbsoluteUri
163 resource :: String -> <ReadGraph> Resource
165 "Converts a relative URI to a resource starting from the given resource"
166 @JavaName resolveRelativeUri
167 relativeResource :: Resource -> String -> <ReadGraph> Resource
169 "Reads the value of a literal that is an object with the given subject and predicate"
171 relatedValue :: Serializable a => Resource -> Resource -> <ReadGraph> a
172 relatedValue s p = relatedValue_ s p binding
175 possibleRelatedValue :: Serializable a => Resource -> Resource -> <ReadGraph> Maybe a
176 possibleRelatedValue s p = possibleRelatedValue_ s p binding
178 class Browsable a where
179 fromUri :: String -> <ReadGraph> a
181 "Returns the URI of the given value."
182 uriOf :: a -> <ReadGraph> String
184 "Returns the URI of the given value if it exists or Nothing."
185 possibleUriOf :: a -> <ReadGraph> Maybe String
187 "Reads the name of the value."
188 nameOf :: a -> <ReadGraph> String
189 possibleNameOf :: a -> <ReadGraph> Maybe String
191 valueOf :: Serializable v => a -> <ReadGraph> v
193 genericRelatedValue :: a -> Resource -> <ReadGraph> t
194 genericPossibleRelatedValue :: a -> Resource -> <ReadGraph> Maybe t
196 variantValueOf :: a -> <ReadGraph> Variant
198 children :: a -> <ReadGraph> [a]
199 parent :: a -> <ReadGraph> a
200 possibleParent :: a -> <ReadGraph> Maybe a
202 child :: a -> String -> <ReadGraph> a
203 possibleChild :: a -> String -> <ReadGraph> Maybe a
205 instance Browsable Resource where
207 uriOf = uriOfResource
208 possibleUriOf = possibleUriOfResource
209 nameOf r = relatedValue r L0.HasName
210 possibleNameOf r = possibleRelatedValue r L0.HasName
212 valueOf r = valueOf_ r binding
213 variantValueOf = variantValueOf_
215 genericRelatedValue = relatedValue2
216 genericPossibleRelatedValue = possibleRelatedValue2
218 children r = r # L0.ConsistsOf
219 parent r = singleObject r L0.PartOf
220 possibleParent r = possibleObject r L0.PartOf
222 possibleChild = possibleResourceChild
223 child r n = fromJust (possibleResourceChild r n)
225 importJava "org.simantics.db.WriteOnlyGraph" where
226 markUndoPoint :: () -> <WriteGraph> ()
228 importJava "org.simantics.db.WriteGraph" where
229 "Creates a new resource."
230 newResource :: () -> <WriteGraph> Resource
231 "Adds a statement to the semantic graph."
232 claim :: Resource -> Resource -> Resource -> <WriteGraph> ()
234 claimWithInverse :: Resource -> Resource -> Maybe Resource -> Resource -> <WriteGraph> ()
235 @JavaName claimLiteral
236 claimRelatedValue_ :: Resource -> Resource -> a -> Binding a -> <WriteGraph> ()
237 @JavaName claimLiteral
238 untypedClaimRelatedValue :: Resource -> Resource -> a -> <WriteGraph> ()
240 untypedClaimValue :: Resource -> a -> <WriteGraph> ()
241 @JavaName claimLiteral
242 claimRelatedValueWithType_ :: Resource -> Resource -> Resource -> a -> Binding a -> <WriteGraph> ()
243 "Removes a statement with the given subject, predicate and object"
244 deny :: Resource -> Resource -> Resource -> <WriteGraph> ()
246 denyByPredicate :: Resource -> Resource -> <WriteGraph> ()
248 denyAllStatements :: Resource -> <WriteGraph> ()
249 newClusterSet :: Resource -> <WriteGraph> ()
251 denyValue :: Resource -> <WriteGraph> ()
253 claimAssertion :: Resource -> Resource -> Resource -> <WriteGraph> ()
254 claimAssertion type_ predicate object = do
256 claim ass L0.HasPredicate predicate
257 claim ass L0.HasObject object
258 claim type_ L0.Asserts ass
260 "Sets the value of the literal that is an object with the given subject and predicate."
262 claimRelatedValue :: Serializable a => Resource -> Resource -> a -> <WriteGraph> ()
263 claimRelatedValue s p v = claimRelatedValue_ s p v binding
266 claimRelatedValueWithType :: Serializable a => Resource -> Resource -> Resource -> a -> <WriteGraph> ()
267 claimRelatedValueWithType s p t v = claimRelatedValueWithType_ s p t v binding
269 importJava "org.simantics.layer0.utils.direct.GraphUtils" where
270 @JavaName getPossibleChild
271 possibleResourceChild :: Resource -> String -> <ReadGraph> (Maybe Resource)
273 @deprecated "Use function children instead."
274 resourceChildrenOf :: Resource -> <ReadGraph> [Resource]
275 resourceChildrenOf r = r # L0.ConsistsOf
277 importJava "org.simantics.db.common.utils.OrderedSetUtils" where
278 "`addToOrderedSet s e` adds element `e` to ordered set `s`"
280 addToOrderedSet :: Resource -> Resource -> <WriteGraph> Boolean
282 "`addFirstToOrderedSet s e` adds element `e` to ordered set `s` as the first element"
284 addFirstToOrderedSet :: Resource -> Resource -> <WriteGraph> Boolean
286 "`addAfterToOrderedSet s p e` adds element `e` to ordered set `s` after element `p`"
288 addAfterToOrderedSet :: Resource -> Resource -> Resource -> <WriteGraph> Boolean
290 "`addBeforeToOrderedSet s p e` adds element `e` to ordered set `s` before element `p`"
292 addBeforeToOrderedSet :: Resource -> Resource -> Resource -> <WriteGraph> Boolean
294 "`removeFromOrderedSet s e` removes element `e` from ordered set `s`"
296 removeFromOrderedSet :: Resource -> Resource -> <WriteGraph> Boolean
299 setOrderedSet :: Resource -> [Resource] -> <WriteGraph> Boolean
301 @JavaName getSingleOwnerList
302 parentOrderedSet :: Resource -> <ReadGraph> Resource
305 elementsOfOrderedSet :: Resource -> <ReadGraph> [Resource]
307 importJava "org.simantics.db.common.utils.ListUtils" where
309 elementsOfList :: Resource -> <ReadGraph> [Resource]
312 createList :: [Resource] -> <WriteGraph> Resource
315 createListWithType :: Resource -> [Resource] -> <WriteGraph> Resource
318 insertBack :: Resource -> [Resource] -> <WriteGraph> ()
320 @javaName removeElement
321 removeElement :: Resource -> Resource -> <WriteGraph> Boolean
323 @javaName swapWithPrevious
324 swapWithPrevious :: Resource -> Resource -> <WriteGraph> Boolean
326 @javaName swapWithNext
327 swapWithNext :: Resource -> Resource -> <WriteGraph> Boolean
330 importJava "org.simantics.db.common.utils.CommonDBUtils" where
331 isParent :: Resource -> Resource -> <ReadGraph> Boolean
332 possibleRelatedString :: Resource -> Resource -> <ReadGraph> Maybe String
333 possibleRelatedInteger :: Resource -> Resource -> <ReadGraph> Maybe Integer
334 objectsWithType :: Resource -> Resource -> Resource -> <ReadGraph> [Resource]
335 possibleObjectWithType :: Resource -> Resource -> Resource -> <ReadGraph> Maybe Resource
337 importJava "org.simantics.db.common.utils.NameUtils" where
338 findFreshName :: String -> Resource -> <ReadGraph> String
339 findFreshEscapedName :: String -> Resource -> <ReadGraph> String
341 "`subject # predicate` returns all objects with the given `subject` and `predicate`."
342 (#) :: Resource -> Resource -> <ReadGraph> [Resource]
343 subject # predicate = collectionToList $ objects_ subject predicate
345 "statements subject predicate` returns all statements with the given subject and predicate."
346 statements :: Resource -> Resource -> <ReadGraph> [Statement]
347 statements subject predicate = collectionToList $ statements_ subject predicate
349 importJava "org.simantics.scl.db.SCLFunctions" where
350 "Executes a read transaction and waits that it completes."
351 syncRead :: (() -> <Proc,ReadGraph> a) -> <Proc> a
352 "Executes a write transaction and waits that it completes."
353 syncWrite :: (() -> <Proc,ReadGraph,WriteGraph> a) -> <Proc> a
354 "Executes a delayed write transaction and waits that it completes."
355 delayedSyncWrite :: (() -> <Proc,WriteGraph> a) -> <Proc> a
357 "Begins a read transaction and immediately returns."
358 asyncRead :: (() -> <Proc,ReadGraph> a) -> <Proc> ()
359 "Begins a write transaction and immediately returns."
360 asyncWrite :: (() -> <Proc,ReadGraph,WriteGraph> a) -> <Proc> ()
362 virtualSyncWriteMem :: String -> (() -> <e,WriteGraph> a) -> <e,WriteGraph> a
363 virtualSyncWriteWS :: String -> (() -> <e,WriteGraph> a) -> <e,WriteGraph> a
365 safeExec :: (() -> <Proc> a) -> <Proc> a
366 activateOnce :: Resource -> <Proc> ()
367 syncActivateOnce :: Resource -> <WriteGraph, Proc> ()
368 resourceFromId :: Long -> <ReadGraph> Resource
369 enableDependencies :: () -> <WriteGraph> ()
370 disableDependencies :: () -> <WriteGraph> ()
372 unaryQuery :: (a -> <ReadGraph,e> b) -> a -> <ReadGraph> b
373 unaryQueryCached :: (a -> <ReadGraph,e> b) -> a -> <ReadGraph> b
375 "Makes a new read request with given procedure for calculating the result. The request is cached only if the current request is listened."
376 subquery :: (<ReadGraph,Proc> a) -> <ReadGraph,Proc> a
377 "Makes a new read request with given procedure for calculating the result. The request is always cached."
378 subqueryC :: (<ReadGraph,Proc> a) -> <ReadGraph,Proc> a
379 "Makes a new read asynchronous request with function to handle the request result. The last `isDisposed` function parameter is used to determine if the listener is still alive or not."
380 subqueryL :: (<ReadGraph,Proc> a) -> (a -> <ReadGraph, e> ()) -> (Throwable -> <ReadGraph, e> ()) -> (<e> Boolean) -> <ReadGraph, Proc, e> ()
381 "Tries to convert the given Dynamic value to a value with the inferred type"
382 possibleFromDynamic :: Typeable a => String -> Dynamic -> Maybe a
384 importJava "org.simantics.db.layer0.util.Layer0Utils" where
385 undo :: () -> <Proc> String
386 undoOperations :: Integer -> <Proc> String
387 redo :: () -> <Proc> String
388 queryDebugSupport :: String -> <Proc> String
389 queryListSupport :: String -> <Proc> String
390 addCommentMetadata :: String -> <WriteGraph> ()
391 sortByCluster :: [a] -> (a->Resource) -> <ReadGraph> [a]
392 makeSynchronous :: Boolean -> <ReadGraph> ()
393 listOntologies :: () -> <ReadGraph> [Resource]
394 emptyTrashBin :: () -> <Proc> ()
395 purgeDatabase :: () -> <Proc> ()
396 prettyPrintResource :: Resource -> Boolean -> <ReadGraph> String
400 copyTo_ :: Resource -> Resource -> <WriteGraph> Collection Resource
401 @JavaName getPossiblePredicateByName
402 possiblePredicateByName :: Resource -> String -> <ReadGraph> Maybe Resource
403 @JavaName getPossiblePredicateByNameFromType
404 possiblePredicateByNameFromType :: Resource -> String -> <ReadGraph> Maybe Resource
406 addMetadataListener :: ChangeListener -> <Proc> ()
407 removeMetadataListener :: ChangeListener -> <Proc> ()
409 copyTo :: Resource -> Resource -> <WriteGraph> Resource
410 copyTo targetContainer source = do
411 (collectionToList $ copyTo_ targetContainer source)!0
413 importJava "org.simantics.db.common.utils.CommonDBUtils" where
414 selectClusterSet :: Resource -> <WriteGraph> ()
416 importJava "org.simantics.Simantics" where
417 @JavaName getProjectResource
418 currentProject :: () -> /*<Proc>*/ Resource
420 // Move to somewhere more generic module
421 importJava "java.util.Collection" where
424 importJava "java.util.ArrayList" where
426 collectionToList :: Collection a -> [a]
428 collectionToList :: Collection a -> [a]
429 collectionToList x = Java.unsafeCoerce x
432 resourceToCollection :: a -> Collection a
433 resourceToCollection x = Java.unsafeCoerce x
435 newEntity :: [Resource -> <ReadGraph,WriteGraph> ()] -> <ReadGraph,WriteGraph> Resource
436 newEntity entitySpecs = do
437 entity = newResource ()
438 for entitySpecs (\spec -> spec entity)
441 updateEntity :: Resource -> [Resource -> <ReadGraph,WriteGraph> ()] -> <ReadGraph,WriteGraph> Resource
442 updateEntity entity entitySpecs = do
443 for entitySpecs (\spec -> spec entity)
446 hasStatement predicate object entity =
447 claim entity predicate object
448 hasProperty relation value entity =
449 claimRelatedValue entity relation value
450 hasPossibleProperty relation value entity =
452 Just v -> claimRelatedValue entity relation v
454 hasTypedProperty relation value t entity =
455 claimRelatedValueWithType entity relation t value
456 hasName (n :: String) = hasProperty L0.HasName n
457 hasLabel (l :: String) = hasProperty L0.HasLabel l
458 hasType t = hasStatement L0.InstanceOf t
459 hasParent p = hasStatement L0.PartOf p
461 importJava "org.simantics.databoard.util.URIStringUtils" where
462 @JavaName splitURISCL
463 splitURI :: String -> [String]
465 escapeURI :: String -> String
467 unescapeURI :: String -> String
470 importJava "org.simantics.db.layer0.request.ActiveModels" where
471 @JavaName getPossibleActiveModel
472 activeModel :: Resource -> <ReadGraph> Maybe Resource
474 "Gives the current active model."
475 currentModel :: <ReadGraph> Resource
476 currentModel = match activeModel (currentProject ()) with
478 Nothing -> fail "No active model."
480 "Gives the current active model if it exists or Nothing otherwise."
481 possibleCurrentModel :: <ReadGraph> Maybe Resource
482 possibleCurrentModel = activeModel (currentProject ())
484 startUndoPoint :: String -> <WriteGraph> ()
485 startUndoPoint string = do
487 addCommentMetadata (string)
491 lift1Read :: (a -> <ReadGraph,Proc> b) -> (a -> <Proc> b)
492 lift1Read f x = syncRead (\_ -> f x)
495 lift2Read :: (a -> b -> <ReadGraph,Proc> c) -> (a -> b -> <Proc> c)
496 lift2Read f x y = syncRead (\_ -> f x y)
499 lift3Read :: (a -> b -> c -> <ReadGraph,Proc> d) -> (a -> b -> c -> <Proc> d)
500 lift3Read f x y z = syncRead (\_ -> f x y z)
503 lift1Write :: (a -> <WriteGraph,Proc> b) -> (a -> <Proc> b)
504 lift1Write f x = syncWrite (\_ -> f x)
507 lift2Write :: (a -> b -> <WriteGraph,Proc> c) -> (a -> b -> <Proc> c)
508 lift2Write f x y = syncWrite (\_ -> f x y)
511 lift3Write :: (a -> b -> c -> <WriteGraph,Proc> d) -> (a -> b -> c -> <Proc> d)
512 lift3Write f x y z = syncWrite (\_ -> f x y z)
515 Returns a child Browsable of the specified parent that has that is the child
516 of the specified parent with the specified name path.
518 childWithPath :: Browsable a => a -> [String] -> <ReadGraph> a
519 childWithPath parent path =
520 foldl (\r name -> match possibleChild r name with
522 Nothing -> fail ("Didn't find " + name + ".")
527 Like `childWithPath` but returns Maybe a which will be `Nothing` if no child
530 possibleChildWithPath :: Browsable a => a -> [String] -> <ReadGraph> Maybe a
531 possibleChildWithPath parent path =
532 foldl (\r name -> match r with
533 Just c -> possibleChild c name
538 importJava "org.simantics.db.MetadataI" where
541 importJava "org.simantics.db.event.ChangeListener" where
544 importJava "org.simantics.db.layer0.genericrelation.DependencyChanges" where
545 data DependencyChanges