This package provides support for SDML (the Simple Domain Modeling Language) in Org-Babel blocks.
Install is easiest from MELPA, here's how with use-package. Note the hook clause
to ensure this minor mode is always enabled for SDML source files.
(use-package ob-sdml
:after (ob sdml-mode)
:init (ob-sdml-setup))Or, interactively; M-x package-install RET sdml-ispell RET and then
run M-x ob-sdml-setup RET to add SDML to the Babel list of languages.
You will also need to install the SDML command-line tool to execute commands against source blocks.
〉cargo install sdml-cliFor example, the following source block calls the CLI to draw a concept diagram for the enclosed module.
#+NAME: lst:rentals-example
#+CAPTION: Rentals Concepts
#+BEGIN_SRC sdml :cmdline draw --diagram concepts :file ./rentals-concepts.svg :exports both
module rentals is
entity Vehicle
entity Location
entity Customer
entity Booking
end
#+END_SRC
The results block then references the resulting image.
#+NAME: fig:rentals-example-concepts
#+CAPTION: Rentals Concepts
#+RESULTS: lst:rentals-example
[[file:./rentals-concepts.svg]]
To simply show the source in a document the following does not require the command-line tool at all.
#+BEGIN_SRC sdml :exports code :eval never
module rentals is
;; ...
end
#+END_SRC
But, what if we want to produce more than one diagram from the same source? By using the built-in /noweb/ syntax we can create a new source block, but reference the original content. This source block has different command-line parameters and has it's own results block as well.
#+NAME: fig:rentals-example-erd
#+BEGIN_SRC sdml :cmdline draw --diagram concepts :file ./rentals-erd.svg :exports results :noweb yes
<<lst:rentals-example>>
#+END_SRC
This package includes an Eldev file and the following MUST be run before creating any PR.
eldev linteldev doctoreldev package --load-before-compiling --stop-on-failure --warnings-as-errorseldev testeldev test --undercover auto,coveralls,merge,dontsent -U simplecov.jsoneldev release -nU 9.9.9
The script eldev-check.sh may be useful to you if you do not have your own Eldev workflow.
The contents of this repository are made available under the following licenses:
Copyright 2023-2025 Simon Johnston <johnstonskj@gmail.com> Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
See the enclosed file LICENSE-Apache.
Copyright 2023-2025 Simon Johnston <johnstonskj@gmail.com> Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
See the enclosed file LICENSE-MIT.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
The 0.1.x series are all pre-release and do not appear in ELPA/MELPA.