{"diffoscope-json-version": 1, "source1": "/srv/reproducible-results/rbuild-debian/r-b-build.Yo1CrBXE/b1/maloc_1.5-1_armhf.changes", "source2": "/srv/reproducible-results/rbuild-debian/r-b-build.Yo1CrBXE/b2/maloc_1.5-1_armhf.changes", "unified_diff": null, "details": [{"source1": "Files", "source2": "Files", "unified_diff": "@@ -1,4 +1,4 @@\n \n- 015f63397811d56309e2b35a3e32d51f 121952 libdevel optional libmaloc-dev_1.5-1_armhf.deb\n+ 4ce7f36f0f3592ce233418ccccc6414c 122276 libdevel optional libmaloc-dev_1.5-1_armhf.deb\n e73921360fbec3a1e87d20921667bcec 251896 debug optional libmaloc1-dbgsym_1.5-1_armhf.deb\n 0bc3aedbab004429cdff739b415a1fc9 72508 libs optional libmaloc1_1.5-1_armhf.deb\n"}, {"source1": "libmaloc-dev_1.5-1_armhf.deb", "source2": "libmaloc-dev_1.5-1_armhf.deb", "unified_diff": null, "details": [{"source1": "file list", "source2": "file list", "unified_diff": "@@ -1,3 +1,3 @@\n -rw-r--r-- 0 0 0 4 2020-03-28 08:32:11.000000 debian-binary\n--rw-r--r-- 0 0 0 5460 2020-03-28 08:32:11.000000 control.tar.xz\n--rw-r--r-- 0 0 0 116300 2020-03-28 08:32:11.000000 data.tar.xz\n+-rw-r--r-- 0 0 0 5452 2020-03-28 08:32:11.000000 control.tar.xz\n+-rw-r--r-- 0 0 0 116632 2020-03-28 08:32:11.000000 data.tar.xz\n"}, {"source1": "control.tar.xz", "source2": "control.tar.xz", "unified_diff": null, "details": [{"source1": "control.tar", "source2": "control.tar", "unified_diff": null, "details": [{"source1": "./md5sums", "source2": "./md5sums", "unified_diff": null, "details": [{"source1": "./md5sums", "source2": "./md5sums", "comments": ["Files differ"], "unified_diff": null}]}]}]}, {"source1": "data.tar.xz", "source2": "data.tar.xz", "unified_diff": null, "details": [{"source1": "data.tar", "source2": "data.tar", "unified_diff": null, "details": [{"source1": "file list", "source2": "file list", "unified_diff": "@@ -22,62 +22,62 @@\n drwxr-xr-x 0 root (0) root (0) 0 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/\n -rw-r--r-- 0 root (0) root (0) 941 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/changelog.Debian.gz\n -rw-r--r-- 0 root (0) root (0) 2759 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/copyright\n drwxr-xr-x 0 root (0) root (0) 0 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/\n -rw-r--r-- 0 root (0) root (0) 102678 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00002.html\n -rw-r--r-- 0 root (0) root (0) 34019 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00002_source.html\n -rw-r--r-- 0 root (0) root (0) 3831 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00003.dot\n--rw-r--r-- 0 root (0) root (0) 1128 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00004.dot.gz\n--rw-r--r-- 0 root (0) root (0) 17978 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00005.html\n--rw-r--r-- 0 root (0) root (0) 24222 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00005_source.html\n--rw-r--r-- 0 root (0) root (0) 1158 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00006.dot.gz\n--rw-r--r-- 0 root (0) root (0) 1319 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00007.dot\n--rw-r--r-- 0 root (0) root (0) 5867 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00008.html\n--rw-r--r-- 0 root (0) root (0) 6411 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00008_source.html\n--rw-r--r-- 0 root (0) root (0) 1407 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00009.dot.gz\n--rw-r--r-- 0 root (0) root (0) 701 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00010.dot\n--rw-r--r-- 0 root (0) root (0) 12339 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00011.html\n--rw-r--r-- 0 root (0) root (0) 16675 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00011_source.html\n--rw-r--r-- 0 root (0) root (0) 1274 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00012.dot.gz\n--rw-r--r-- 0 root (0) root (0) 1004 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00013.dot\n+-rw-r--r-- 0 root (0) root (0) 1127 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00004.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 12339 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00005.html\n+-rw-r--r-- 0 root (0) root (0) 16675 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00005_source.html\n+-rw-r--r-- 0 root (0) root (0) 1275 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00006.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 1004 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00007.dot\n+-rw-r--r-- 0 root (0) root (0) 17978 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00008.html\n+-rw-r--r-- 0 root (0) root (0) 24222 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00008_source.html\n+-rw-r--r-- 0 root (0) root (0) 1159 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00009.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 1319 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00010.dot\n+-rw-r--r-- 0 root (0) root (0) 5867 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00011.html\n+-rw-r--r-- 0 root (0) root (0) 6411 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00011_source.html\n+-rw-r--r-- 0 root (0) root (0) 1410 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00012.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 701 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00013.dot\n -rw-r--r-- 0 root (0) root (0) 14174 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00014.html\n -rw-r--r-- 0 root (0) root (0) 18584 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00014_source.html\n--rw-r--r-- 0 root (0) root (0) 1151 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00015.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 1152 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00015.dot.gz\n -rw-r--r-- 0 root (0) root (0) 1310 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00016.dot\n -rw-r--r-- 0 root (0) root (0) 17659 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00017.html\n -rw-r--r-- 0 root (0) root (0) 36490 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00017_source.html\n--rw-r--r-- 0 root (0) root (0) 1148 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00018.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 1149 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00018.dot.gz\n -rw-r--r-- 0 root (0) root (0) 1108 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00019.dot\n--rw-r--r-- 0 root (0) root (0) 5032 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00020.html\n--rw-r--r-- 0 root (0) root (0) 5722 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00020_source.html\n--rw-r--r-- 0 root (0) root (0) 1091 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00021.dot.gz\n--rw-r--r-- 0 root (0) root (0) 2895 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00022.dot\n--rw-r--r-- 0 root (0) root (0) 28830 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00023.html\n--rw-r--r-- 0 root (0) root (0) 53368 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00023_source.html\n--rw-r--r-- 0 root (0) root (0) 805 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00024.dot.gz\n--rw-r--r-- 0 root (0) root (0) 3202 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00025.dot\n+-rw-r--r-- 0 root (0) root (0) 54413 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00020.html\n+-rw-r--r-- 0 root (0) root (0) 23410 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00020_source.html\n+-rw-r--r-- 0 root (0) root (0) 704 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00021.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 3191 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00022.dot\n+-rw-r--r-- 0 root (0) root (0) 5032 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00023.html\n+-rw-r--r-- 0 root (0) root (0) 5722 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00023_source.html\n+-rw-r--r-- 0 root (0) root (0) 1090 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00024.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 2895 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00025.dot\n -rw-r--r-- 0 root (0) root (0) 18643 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00026.html\n -rw-r--r-- 0 root (0) root (0) 40474 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00026_source.html\n -rw-r--r-- 0 root (0) root (0) 854 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00027.dot.gz\n -rw-r--r-- 0 root (0) root (0) 3181 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00028.dot\n -rw-r--r-- 0 root (0) root (0) 17560 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00029.html\n -rw-r--r-- 0 root (0) root (0) 25468 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00029_source.html\n -rw-r--r-- 0 root (0) root (0) 717 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00030.dot.gz\n -rw-r--r-- 0 root (0) root (0) 3601 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00031.dot\n--rw-r--r-- 0 root (0) root (0) 54413 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00032.html\n--rw-r--r-- 0 root (0) root (0) 23410 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00032_source.html\n--rw-r--r-- 0 root (0) root (0) 704 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00033.dot.gz\n--rw-r--r-- 0 root (0) root (0) 3191 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00034.dot\n--rw-r--r-- 0 root (0) root (0) 86130 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00035.html\n--rw-r--r-- 0 root (0) root (0) 36241 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00035_source.html\n--rw-r--r-- 0 root (0) root (0) 717 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00036.dot.gz\n--rw-r--r-- 0 root (0) root (0) 4020 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00037.dot\n+-rw-r--r-- 0 root (0) root (0) 86130 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00032.html\n+-rw-r--r-- 0 root (0) root (0) 36241 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00032_source.html\n+-rw-r--r-- 0 root (0) root (0) 717 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00033.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 4020 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00034.dot\n+-rw-r--r-- 0 root (0) root (0) 28830 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00035.html\n+-rw-r--r-- 0 root (0) root (0) 53368 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00035_source.html\n+-rw-r--r-- 0 root (0) root (0) 805 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00036.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 3202 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00037.dot\n -rw-r--r-- 0 root (0) root (0) 4710 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00038.html\n -rw-r--r-- 0 root (0) root (0) 5011 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00038_source.html\n--rw-r--r-- 0 root (0) root (0) 1458 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00039.dot.gz\n+-rw-r--r-- 0 root (0) root (0) 1460 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00039.dot.gz\n -rw-r--r-- 0 root (0) root (0) 1997 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00041.html\n -rw-r--r-- 0 root (0) root (0) 6016 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00041_source.html\n -rw-r--r-- 0 root (0) root (0) 1991 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00044.html\n -rw-r--r-- 0 root (0) root (0) 2307 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00044_source.html\n -rw-r--r-- 0 root (0) root (0) 3596 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00047.html\n -rw-r--r-- 0 root (0) root (0) 38748 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00048.html\n -rw-r--r-- 0 root (0) root (0) 22555 2020-03-28 08:32:11.000000 ./usr/share/doc/libmaloc-dev/html/a00049.html\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00004.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00004.dot.gz", "unified_diff": null, "details": [{"source1": "a00004.dot", "source2": "a00004.dot", "unified_diff": "@@ -4,25 +4,25 @@\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n Node1 [id=\"Node000001\",label=\"maloc_base.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n Node1 -> Node3 [id=\"edge2_Node000001_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node3 -> Node2 [id=\"edge3_Node000003_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node4 [id=\"edge4_Node000001_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node4 [id=\"Node000004\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node4 [id=\"Node000004\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n Node4 -> Node5 [id=\"edge5_Node000004_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node5 [id=\"Node000005\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node5 [id=\"Node000005\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node5 -> Node3 [id=\"edge6_Node000005_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node6 [id=\"edge7_Node000001_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node6 [id=\"Node000006\",label=\"vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node6 [id=\"Node000006\",label=\"vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node6 -> Node7 [id=\"edge8_Node000006_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node7 [id=\"Node000007\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node7 [id=\"Node000007\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node7 -> Node2 [id=\"edge9_Node000007_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node7 -> Node3 [id=\"edge10_Node000007_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node7 -> Node4 [id=\"edge11_Node000007_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node7 -> Node5 [id=\"edge12_Node000007_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node7 -> Node8 [id=\"edge13_Node000007_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node8 [id=\"Node000008\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n Node8 -> Node5 [id=\"edge14_Node000008_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n@@ -35,18 +35,18 @@\n Node10 -> Node11 [id=\"edge19_Node000010_Node000011\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node11 [id=\"Node000011\",label=\"vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node11 -> Node7 [id=\"edge20_Node000011_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node10 -> Node7 [id=\"edge21_Node000010_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node5 [id=\"edge22_Node000001_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node8 [id=\"edge23_Node000001_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node12 [id=\"edge24_Node000001_Node000012\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node12 [id=\"Node000012\",label=\"vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node12 [id=\"Node000012\",label=\"vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node12 -> Node6 [id=\"edge25_Node000012_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node12 -> Node11 [id=\"edge26_Node000012_Node000011\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node12 -> Node7 [id=\"edge27_Node000012_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node13 [id=\"edge28_Node000001_Node000013\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node13 [id=\"Node000013\",label=\"vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node13 [id=\"Node000013\",label=\"vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node13 -> Node7 [id=\"edge29_Node000013_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node11 [id=\"edge30_Node000001_Node000011\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node9 [id=\"edge31_Node000001_Node000009\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node7 [id=\"edge32_Node000001_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00005.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00005.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vcom.h File Reference\n+MALOC: vmp.h File Reference\n \n \n \n \n \n \n
\n@@ -41,113 +41,91 @@\n \n
\n \n
\n \n-
vcom.h File Reference
\n+
vmp.h File Reference
\n
\n
\n \n-

Class Vcom: virtual (currently just MPI) communications layer. \n+

Class Vmp: a Virtual MPI communication layer object. \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vsys.h>
\n+#include <maloc/vsys.h>
\n+#include <maloc/vmpi.h>
\n+#include <maloc/vcom.h>
\n
\n-Include dependency graph for vcom.h:
\n+Include dependency graph for vmp.h:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n This graph shows which files directly or indirectly include this file:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n

Go to the source code of this file.

\n \n \n-\n-\n+\n+\n \n

\n Classes

struct  sVcom
 Contains public data members for Vcom class. More...
struct  sVmp
 Contains public data members for Vmp class. More...
 
\n-\n-\n-\n-\n-

\n-Macros

#define VCOM_MPI_TAG   111
 A base value for MPI tags.
 
\n \n-\n-\n-\n+\n+\n+\n

\n Typedefs

typedef struct sVcom Vcom
 Declaration of the Vcom class as the Vcom structure
\n-
 
typedef struct sVmp Vmp
 Declaration of the Vmp class as teh Vmp structure.
 
\n \n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n-\n-\n-\n-\n+\n

\n Functions

int Vcom_init (int *argc, char ***argv)
 The Vmp initializer.
 
int Vcom_finalize (void)
 The Vmp finalizer.
 
VcomVcom_ctor (int commtype)
 Construct the communications object. This routine sets up data members of class and initializes MPI.
 
int Vcom_ctor2 (Vcom *thee, int commtype)
 Construct the communications object. This routine sets up data members of class and initializes MPI. This is broken into two parts to be callable from FORTRAN.
 
void Vcom_dtor (Vcom **thee)
 Destroy the communications object.
 
void Vcom_dtor2 (Vcom *thee)
 Destroy the communications object. This is broken into two parts to be callable from FORTRAN.
 
int Vcom_send (Vcom *thee, int des, void *buf, int len, int type, int block)
 Send a buffer. Returns 1 on success.
 
int Vcom_recv (Vcom *thee, int src, void *buf, int len, int type, int block)
 Receive a (character) buffer.
\n- The blocking flag is present, but not used. All receives are assumed to be blocking. A non-blocking receive would be very ugly to implement (signals or something?).
 
int Vcom_getCount (Vcom *thee, int src, int *length, int type)
 Perform a blocking probe to get the length (in number of items of specified type) of an incoming message and place it in the
\n- argument ``length\".
 
int Vcom_reduce (Vcom *thee, void *sendbuf, void *recvbuf, int length, int type, int op)
 Perform a reduction of the data across all processors. This is equivalent (and in the case of MPI is identical to) MPI_Allreduce. Basically, the specified operations are appleed to each member of
\n- the sendbuf across all processors and the results are written to recvbuf.
 
int Vcom_size (Vcom *thee)
 Get the number of PEs in communicator.
 
int Vcom_resize (Vcom *thee, int newsize)
 Resize (shrink) the communications group to include only newsize number of processors.
\n- Obsolete processes are given rank of -1 and size of 0.
 
int Vcom_rank (Vcom *thee)
 Get the ID of the local PE
\n+
int Vmp_init (int *argc, char ***argv)
 The Vmp initializer.
 
int Vmp_finalize (void)
 The Vmp finalizer.
 
VmpVmp_ctor (void)
 The Vmp constructor.
 
void Vmp_dtor (Vmp **thee)
 The Vmp destructor.
 
int Vmp_rank (Vmp *thee)
 Return my processor ID.
 
int Vmp_size (Vmp *thee)
 Return the number of processors involved.
\n+
 
int Vmp_barr (Vmp *thee)
 An MPI barrier.
\n+
 
int Vmp_send (Vmp *thee, int des, char *buf, int bufsize)
 An MPI blocking send.
\n+
 
int Vmp_recv (Vmp *thee, int src, char *buf, int bufsize)
 An MPI blocking receive.
\n
 
int Vcom_barr (Vcom *thee)
 Synchronization barrier.
 
 
\n

Detailed Description

\n-

Class Vcom: virtual (currently just MPI) communications layer.

\n-
Authors
Nathan Baker and Michael Holst
\n+

Class Vmp: a Virtual MPI communication layer object.

\n+
Author
Michael Holst
\n
Note
None
\n
Version
\n-
Id
vcom.h,v 1.38 2010/08/12 05:40:23 fetk Exp
\n+
Id
vmp.h,v 1.22 2010/08/12 05:40:23 fetk Exp
\n
Attention
*\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n@@ -159,31 +137,14 @@\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n * \n *  
\n-

Macro Definition Documentation

\n-\n-

◆ VCOM_MPI_TAG

\n-\n-
\n-
\n- \n- \n- \n- \n-
#define VCOM_MPI_TAG   111
\n-
\n-\n-

A base value for MPI tags.

\n-\n-
\n-
\n-
\n+\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,107 +3,74 @@\n \n \n MALOC\u00a00.1\n \n * src\n * psh\n * maloc\n-Classes | Macros | Typedefs | Functions\n-vcom.h File Reference\n-Vcom_class\n-Class Vcom: virtual (currently just MPI) communications layer. More...\n+Classes | Typedefs | Functions\n+vmp.h File Reference\n+Vmp_class\n+Class Vmp: a Virtual MPI communication layer object. More...\n #include \n #include \n-Include dependency graph for vcom.h:\n+#include \n+#include \n+Include dependency graph for vmp.h:\n This graph shows which files directly or indirectly include this file:\n Go_to_the_source_code_of_this_file.\n Classes\n-struct \u00a0sVcom\n-\u00a0 Contains public data members for Vcom class. More...\n-\u00a0\n- Macros\n-#define\u00a0VCOM_MPI_TAG\u00a0\u00a0\u00a0111\n-\u00a0 A base value for MPI tags.\n+struct \u00a0sVmp\n+\u00a0 Contains public data members for Vmp class. More...\n \u00a0\n Typedefs\n-typedef struct sVcom\u00a0Vcom\n-\u00a0 Declaration of the Vcom class as the Vcom structure\n-\n+typedef struct sVmp\u00a0Vmp\n+\u00a0 Declaration of the Vmp class as teh Vmp structure.\n \u00a0\n Functions\n- int\u00a0Vcom_init (int *argc, char ***argv)\n-\u00a0 The Vmp initializer.\n+ int\u00a0Vmp_init (int *argc, char ***argv)\n+\u00a0 The Vmp initializer.\n+\u00a0\n+ int\u00a0Vmp_finalize (void)\n+\u00a0 The Vmp finalizer.\n \u00a0\n- int\u00a0Vcom_finalize (void)\n-\u00a0 The Vmp finalizer.\n+Vmp *\u00a0Vmp_ctor (void)\n+\u00a0 The Vmp constructor.\n \u00a0\n-Vcom *\u00a0Vcom_ctor (int commtype)\n-\u00a0 Construct the communications object. This routine sets up data members\n- of class and initializes MPI.\n-\u00a0\n- int\u00a0Vcom_ctor2 (Vcom *thee, int commtype)\n- Construct the communications object. This routine sets up data members\n-\u00a0 of class and initializes MPI. This is broken into two parts to be\n- callable from FORTRAN.\n-\u00a0\n- void\u00a0Vcom_dtor (Vcom **thee)\n-\u00a0 Destroy the communications object.\n-\u00a0\n- void\u00a0Vcom_dtor2 (Vcom *thee)\n-\u00a0 Destroy the communications object. This is broken into two parts to be\n- callable from FORTRAN.\n-\u00a0\n- int\u00a0Vcom_send (Vcom *thee, int des, void *buf, int len, int type, int\n- block)\n-\u00a0 Send a buffer. Returns 1 on success.\n-\u00a0\n- int\u00a0Vcom_recv (Vcom *thee, int src, void *buf, int len, int type, int\n- block)\n- Receive a (character) buffer.\n-\u00a0 The blocking flag is present, but not used. All receives are assumed to\n- be blocking. A non-blocking receive would be very ugly to implement\n- (signals or something?).\n-\u00a0\n- int\u00a0Vcom_getCount (Vcom *thee, int src, int *length, int type)\n- Perform a blocking probe to get the length (in number of items of\n-\u00a0 specified type) of an incoming message and place it in the\n- argument ``length\".\n-\u00a0\n- int\u00a0Vcom_reduce (Vcom *thee, void *sendbuf, void *recvbuf, int length, int\n- type, int op)\n- Perform a reduction of the data across all processors. This is\n- equivalent (and in the case of MPI is identical to) MPI_Allreduce.\n-\u00a0 Basically, the specified operations are appleed to each member of\n- the sendbuf across all processors and the results are written to\n- recvbuf.\n-\u00a0\n- int\u00a0Vcom_size (Vcom *thee)\n-\u00a0 Get the number of PEs in communicator.\n-\u00a0\n- int\u00a0Vcom_resize (Vcom *thee, int newsize)\n- Resize (shrink) the communications group to include only newsize number\n-\u00a0 of processors.\n- Obsolete processes are given rank of -1 and size of 0.\n+ void\u00a0Vmp_dtor (Vmp **thee)\n+\u00a0 The Vmp destructor.\n \u00a0\n- int\u00a0Vcom_rank (Vcom *thee)\n-\u00a0 Get the ID of the local PE\n+ int\u00a0Vmp_rank (Vmp *thee)\n+\u00a0 Return my processor ID.\n+\u00a0\n+ int\u00a0Vmp_size (Vmp *thee)\n+\u00a0 Return the number of processors involved.\n \n \u00a0\n- int\u00a0Vcom_barr (Vcom *thee)\n-\u00a0 Synchronization barrier.\n+ int\u00a0Vmp_barr (Vmp *thee)\n+\u00a0 An MPI barrier.\n+\n+\u00a0\n+ int\u00a0Vmp_send (Vmp *thee, int des, char *buf, int bufsize)\n+\u00a0 An MPI blocking send.\n+\n+\u00a0\n+ int\u00a0Vmp_recv (Vmp *thee, int src, char *buf, int bufsize)\n+\u00a0 An MPI blocking receive.\n+\n \u00a0\n ***** Detailed Description *****\n-Class Vcom: virtual (currently just MPI) communications layer.\n- Authors\n- Nathan Baker and Michael Holst\n+Class Vmp: a Virtual MPI communication layer object.\n+ Author\n+ Michael Holst\n Note\n None\n Version\n Id\n- vcom.h,v 1.38 2010/08/12 05:40:23 fetk Exp\n+ vmp.h,v 1.22 2010/08/12 05:40:23 fetk Exp\n Attention\n *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n@@ -116,14 +83,10 @@\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n *\n *\n-***** Macro Definition Documentation *****\n-***** \u25c6\u00a0VCOM_MPI_TAG *****\n-#define VCOM_MPI_TAG\u00a0\u00a0\u00a0111\n-A base value for MPI tags.\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00005_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00005_source.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vcom.h Source File\n+MALOC: vmp.h Source File\n \n \n \n \n \n \n
\n@@ -44,114 +44,89 @@\n \n
\n \n
\n
\n
\n-
vcom.h
\n+
vmp.h
\n
\n
\n Go to the documentation of this file.
1
\n-
38#ifndef _VCOM_H_
\n-
39#define _VCOM_H_
\n-
40
\n-
41#include <maloc/maloc_base.h>
\n-
42
\n-
43#include <maloc/vsys.h>
\n-
44
\n-
46#define VCOM_MPI_TAG 111
\n-
47
\n-
48/*
\n+
37#ifndef _VMP_H_
\n+
38#define _VMP_H_
\n+
39
\n+
40#include <maloc/maloc_base.h>
\n+
41
\n+
42#include <maloc/vsys.h>
\n+
43#include <maloc/vmpi.h>
\n+
44#include <maloc/vcom.h>
\n+
45
\n+
46/*
\n+
47 * ***************************************************************************
\n+
48 * Class Vmp: Parameters and datatypes
\n
49 * ***************************************************************************
\n-
50 * Class Vcom: Parameters and datatypes
\n-
51 * ***************************************************************************
\n-
52 */
\n-
53
\n-
\n-
60struct sVcom {
\n-
61
\n-\n-\n-
66
\n-
71 int type;
\n-
73 int error;
\n-
75 void *core;
\n-
76
\n-
77};
\n+
50 */
\n+
51
\n+
\n+
58struct sVmp {
\n+\n+\n+
61};
\n
\n-
78
\n-
85typedef struct sVcom Vcom;
\n-
86
\n-
87/*
\n-
88 * ***************************************************************************
\n-
89 * Class Vcom: Inlineable methods (vcom.c)
\n-
90 * ***************************************************************************
\n-
91 */
\n-
92
\n-
93#if !defined(VINLINE_MALOC)
\n-
94#else /* if defined(VINLINE_MALOC) */
\n-
95#endif /* if !defined(VINLINE_MALOC) */
\n-
96
\n-
97
\n-
107int Vcom_init(int *argc, char ***argv);
\n-
108
\n-\n-
117
\n-
127Vcom* Vcom_ctor(int commtype);
\n-
128
\n-
140int Vcom_ctor2(Vcom* thee, int commtype);
\n-
141
\n-
150void Vcom_dtor(Vcom **thee);
\n-
151
\n-
161void Vcom_dtor2(Vcom *thee);
\n+
62
\n+
68typedef struct sVmp Vmp;
\n+
69
\n+
70/*
\n+
71 * ***************************************************************************
\n+
72 * Class Vmp: Inlineable methods (vmp.c)
\n+
73 * ***************************************************************************
\n+
74 */
\n+
75
\n+
76#if !defined(VINLINE_MALOC)
\n+
77#else /* if defined(VINLINE_MALOC) */
\n+
78#endif /* if !defined(VINLINE_MALOC) */
\n+
79
\n+
80
\n+
90int Vmp_init(int *argc, char ***argv);
\n+
91
\n+
99int Vmp_finalize(void);
\n+
100
\n+\n+
109
\n+
118void Vmp_dtor(Vmp **thee);
\n+
119
\n+
128int Vmp_rank(Vmp *thee);
\n+
129
\n+
138int Vmp_size(Vmp *thee);
\n+
139
\n+
148int Vmp_barr(Vmp *thee);
\n+
149
\n+
161int Vmp_send(Vmp *thee, int des, char *buf, int bufsize);
\n
162
\n-
177int Vcom_send(Vcom *thee, int des, void *buf, int len, int type,
\n-
178 int block);
\n-
179
\n-
197int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type,
\n-
198 int block);
\n-
199
\n-
214int Vcom_getCount(Vcom *thee, int src, int *length, int type);
\n-
215
\n-
237int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length,
\n-
238 int type, int op);
\n-
239
\n-
248int Vcom_size(Vcom *thee);
\n-
249
\n-
261int Vcom_resize(Vcom *thee, int newsize);
\n-
262
\n-
271int Vcom_rank(Vcom *thee);
\n-
272
\n-
281int Vcom_barr(Vcom *thee);
\n-
282
\n-
283#endif /* _VCOM_H_ */
\n-
284
\n+
174int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize);
\n+
175
\n+
176#endif /* _VMP_H_ */
\n+
177
\n
The base (or foundation) header for MALOC.
\n-
The primary header for VSYS. (Virtual SYStem utilities library.)
\n-
int Vcom_rank(Vcom *thee)
Get the ID of the local PE
\n-
int Vcom_resize(Vcom *thee, int newsize)
Resize (shrink) the communications group to include only newsize number of processors....
\n-
int Vcom_ctor2(Vcom *thee, int commtype)
Construct the communications object. This routine sets up data members of class and initializes MPI....
\n-
int Vcom_size(Vcom *thee)
Get the number of PEs in communicator.
\n-
int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length, int type, int op)
Perform a reduction of the data across all processors. This is equivalent (and in the case of MPI is ...
\n-
Vcom * Vcom_ctor(int commtype)
Construct the communications object. This routine sets up data members of class and initializes MPI.
\n-
int Vcom_init(int *argc, char ***argv)
The Vmp initializer.
\n-
int Vcom_finalize(void)
The Vmp finalizer.
\n-
int Vcom_barr(Vcom *thee)
Synchronization barrier.
\n-
void Vcom_dtor(Vcom **thee)
Destroy the communications object.
\n-
int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type, int block)
Receive a (character) buffer. The blocking flag is present, but not used. All receives are assumed ...
\n-
int Vcom_getCount(Vcom *thee, int src, int *length, int type)
Perform a blocking probe to get the length (in number of items of specified type) of an incoming mess...
\n-
int Vcom_send(Vcom *thee, int des, void *buf, int len, int type, int block)
Send a buffer. Returns 1 on success.
\n-
void Vcom_dtor2(Vcom *thee)
Destroy the communications object. This is broken into two parts to be callable from FORTRAN.
\n-
Contains public data members for Vcom class.
Definition vcom.h:60
\n-
int type
Communication type. 0 = not initialized 1 = Message Passing Interface 1.1.
Definition vcom.h:71
\n-
int error
note if any error has occurred on this vcom device
Definition vcom.h:73
\n-
int mpi_size
Total number of PEs in this communicator from MPI.
Definition vcom.h:65
\n-
void * core
Private MPI core.
Definition vcom.h:75
\n-
int mpi_rank
Local PE rank from MPI.
Definition vcom.h:63
\n+
Class Vcom: virtual (currently just MPI) communications layer.
\n+
Class Vmpi: a Virtual MPI communication layer object.
\n+
The primary header for VSYS. (Virtual SYStem utilities library.)
\n+
int Vmp_finalize(void)
The Vmp finalizer.
\n+
int Vmp_send(Vmp *thee, int des, char *buf, int bufsize)
An MPI blocking send.
\n+
int Vmp_init(int *argc, char ***argv)
The Vmp initializer.
\n+
int Vmp_rank(Vmp *thee)
Return my processor ID.
\n+
int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize)
An MPI blocking receive.
\n+
Vmp * Vmp_ctor(void)
The Vmp constructor.
\n+
void Vmp_dtor(Vmp **thee)
The Vmp destructor.
\n+
int Vmp_barr(Vmp *thee)
An MPI barrier.
\n+
int Vmp_size(Vmp *thee)
Return the number of processors involved.
\n+
Contains public data members for Vmp class.
Definition vmp.h:58
\n+
int mpi_rank
Definition vmp.h:59
\n+
int mpi_size
Definition vmp.h:60
\n
\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,166 +3,114 @@\n \n \n MALOC\u00a00.1\n \n * src\n * psh\n * maloc\n-vcom.h\n+vmp.h\n Go_to_the_documentation_of_this_file.\n 1\n- 38#ifndef _VCOM_H_\n- 39#define _VCOM_H_\n- 40\n- 41#include \n- 42\n- 43#include \n- 44\n-46#define VCOM_MPI_TAG 111\n- 47\n- 48/*\n- 49 *\n+ 37#ifndef _VMP_H_\n+ 38#define _VMP_H_\n+ 39\n+ 40#include \n+ 41\n+ 42#include \n+ 43#include \n+ 44#include \n+ 45\n+ 46/*\n+ 47 *\n ***************************************************************************\n- 50 * Class Vcom: Parameters and datatypes\n- 51 *\n+ 48 * Class Vmp: Parameters and datatypes\n+ 49 *\n ***************************************************************************\n- 52 */\n- 53\n-60struct sVcom {\n- 61\n-63 int mpi_rank;\n-65 int mpi_size;\n- 66\n-71 int type;\n-73 int error;\n-75 void *core;\n- 76\n- 77};\n- 78\n-85typedef struct sVcom Vcom;\n- 86\n- 87/*\n- 88 *\n+ 50 */\n+ 51\n+58struct sVmp {\n+59 int mpi_rank;\n+60 int mpi_size;\n+ 61};\n+ 62\n+68typedef struct sVmp Vmp;\n+ 69\n+ 70/*\n+ 71 *\n ***************************************************************************\n- 89 * Class Vcom: Inlineable methods (vcom.c)\n- 90 *\n+ 72 * Class Vmp: Inlineable methods (vmp.c)\n+ 73 *\n ***************************************************************************\n- 91 */\n- 92\n- 93#if !defined(VINLINE_MALOC)\n- 94#else /* if defined(VINLINE_MALOC) */\n- 95#endif /* if !defined(VINLINE_MALOC) */\n- 96\n- 97\n-107int Vcom_init(int *argc, char ***argv);\n- 108\n-116int Vcom_finalize(void);\n- 117\n-127Vcom* Vcom_ctor(int commtype);\n- 128\n-140int Vcom_ctor2(Vcom* thee, int commtype);\n- 141\n-150void Vcom_dtor(Vcom **thee);\n- 151\n-161void Vcom_dtor2(Vcom *thee);\n+ 74 */\n+ 75\n+ 76#if !defined(VINLINE_MALOC)\n+ 77#else /* if defined(VINLINE_MALOC) */\n+ 78#endif /* if !defined(VINLINE_MALOC) */\n+ 79\n+ 80\n+90int Vmp_init(int *argc, char ***argv);\n+ 91\n+99int Vmp_finalize(void);\n+ 100\n+108Vmp* Vmp_ctor(void);\n+ 109\n+118void Vmp_dtor(Vmp **thee);\n+ 119\n+128int Vmp_rank(Vmp *thee);\n+ 129\n+138int Vmp_size(Vmp *thee);\n+ 139\n+148int Vmp_barr(Vmp *thee);\n+ 149\n+161int Vmp_send(Vmp *thee, int des, char *buf, int bufsize);\n 162\n-177int Vcom_send(Vcom *thee, int des, void *buf, int len, int type,\n- 178 int block);\n- 179\n-197int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type,\n- 198 int block);\n- 199\n-214int Vcom_getCount(Vcom *thee, int src, int *length, int type);\n- 215\n-237int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length,\n- 238 int type, int op);\n- 239\n-248int Vcom_size(Vcom *thee);\n- 249\n-261int Vcom_resize(Vcom *thee, int newsize);\n- 262\n-271int Vcom_rank(Vcom *thee);\n- 272\n-281int Vcom_barr(Vcom *thee);\n- 282\n- 283#endif /* _VCOM_H_ */\n- 284\n+174int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize);\n+ 175\n+ 176#endif /* _VMP_H_ */\n+ 177\n maloc_base.h\n The base (or foundation) header for MALOC.\n+vcom.h\n+Class Vcom: virtual (currently just MPI) communications layer.\n+vmpi.h\n+Class Vmpi: a Virtual MPI communication layer object.\n vsys.h\n The primary header for VSYS. (Virtual SYStem utilities library.)\n-Vcom_rank\n-int Vcom_rank(Vcom *thee)\n-Get the ID of the local PE\n-Vcom_resize\n-int Vcom_resize(Vcom *thee, int newsize)\n-Resize (shrink) the communications group to include only newsize number of\n-processors....\n-Vcom_ctor2\n-int Vcom_ctor2(Vcom *thee, int commtype)\n-Construct the communications object. This routine sets up data members of class\n-and initializes MPI....\n-Vcom_size\n-int Vcom_size(Vcom *thee)\n-Get the number of PEs in communicator.\n-Vcom_reduce\n-int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length, int type,\n-int op)\n-Perform a reduction of the data across all processors. This is equivalent (and\n-in the case of MPI is ...\n-Vcom_ctor\n-Vcom * Vcom_ctor(int commtype)\n-Construct the communications object. This routine sets up data members of class\n-and initializes MPI.\n-Vcom_init\n-int Vcom_init(int *argc, char ***argv)\n-The Vmp initializer.\n-Vcom_finalize\n-int Vcom_finalize(void)\n+Vmp_finalize\n+int Vmp_finalize(void)\n The Vmp finalizer.\n-Vcom_barr\n-int Vcom_barr(Vcom *thee)\n-Synchronization barrier.\n-Vcom_dtor\n-void Vcom_dtor(Vcom **thee)\n-Destroy the communications object.\n-Vcom_recv\n-int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type, int block)\n-Receive a (character) buffer. The blocking flag is present, but not used. All\n-receives are assumed ...\n-Vcom_getCount\n-int Vcom_getCount(Vcom *thee, int src, int *length, int type)\n-Perform a blocking probe to get the length (in number of items of specified\n-type) of an incoming mess...\n-Vcom_send\n-int Vcom_send(Vcom *thee, int des, void *buf, int len, int type, int block)\n-Send a buffer. Returns 1 on success.\n-Vcom_dtor2\n-void Vcom_dtor2(Vcom *thee)\n-Destroy the communications object. This is broken into two parts to be callable\n-from FORTRAN.\n-sVcom\n-Contains public data members for Vcom class.\n-Definition vcom.h:60\n-sVcom::type\n-int type\n-Communication type. 0 = not initialized 1 = Message Passing Interface 1.1.\n-Definition vcom.h:71\n-sVcom::error\n-int error\n-note if any error has occurred on this vcom device\n-Definition vcom.h:73\n-sVcom::mpi_size\n-int mpi_size\n-Total number of PEs in this communicator from MPI.\n-Definition vcom.h:65\n-sVcom::core\n-void * core\n-Private MPI core.\n-Definition vcom.h:75\n-sVcom::mpi_rank\n+Vmp_send\n+int Vmp_send(Vmp *thee, int des, char *buf, int bufsize)\n+An MPI blocking send.\n+Vmp_init\n+int Vmp_init(int *argc, char ***argv)\n+The Vmp initializer.\n+Vmp_rank\n+int Vmp_rank(Vmp *thee)\n+Return my processor ID.\n+Vmp_recv\n+int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize)\n+An MPI blocking receive.\n+Vmp_ctor\n+Vmp * Vmp_ctor(void)\n+The Vmp constructor.\n+Vmp_dtor\n+void Vmp_dtor(Vmp **thee)\n+The Vmp destructor.\n+Vmp_barr\n+int Vmp_barr(Vmp *thee)\n+An MPI barrier.\n+Vmp_size\n+int Vmp_size(Vmp *thee)\n+Return the number of processors involved.\n+sVmp\n+Contains public data members for Vmp class.\n+Definition vmp.h:58\n+sVmp::mpi_rank\n int mpi_rank\n-Local PE rank from MPI.\n-Definition vcom.h:63\n+Definition vmp.h:59\n+sVmp::mpi_size\n+int mpi_size\n+Definition vmp.h:60\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00006.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00006.dot.gz", "unified_diff": null, "details": [{"source1": "a00006.dot", "source2": "a00006.dot", "unified_diff": "@@ -1,14 +1,14 @@\n-digraph \"vcom.h\"\n+digraph \"vmp.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vcom.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node1 [id=\"Node000001\",label=\"vmp.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc/maloc_base.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00002.html\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"assert.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"ctype.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge4_Node000002_Node000005\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n@@ -34,28 +34,36 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node19 [id=\"edge19_Node000018_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node20 [id=\"edge21_Node000018_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node20 [id=\"Node000020\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node21 [id=\"edge23_Node000018_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node21 -> Node2 [id=\"edge24_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node21 -> Node19 [id=\"edge25_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node22 [id=\"edge26_Node000018_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 [id=\"Node000022\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node22 -> Node2 [id=\"edge27_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node19 [id=\"edge28_Node000022_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node20 [id=\"edge29_Node000022_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node23 [id=\"edge30_Node000018_Node000023\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node23 -> Node2 [id=\"edge31_Node000023_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node24 [id=\"edge32_Node000001_Node000024\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node24 [id=\"Node000024\",label=\"maloc/vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n+ Node24 -> Node2 [id=\"edge33_Node000024_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node24 -> Node18 [id=\"edge34_Node000024_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node25 [id=\"edge35_Node000001_Node000025\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node25 [id=\"Node000025\",label=\"maloc/vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node25 -> Node2 [id=\"edge36_Node000025_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node25 -> Node18 [id=\"edge37_Node000025_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00007.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00007.dot", "unified_diff": "@@ -1,14 +1,12 @@\n-digraph \"vcom.h\"\n+digraph \"vmp.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vcom.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node1 [id=\"Node000001\",label=\"vmp.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node2 [id=\"Node000002\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n- Node3 -> Node4 [id=\"edge3_Node000003_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node4 [id=\"Node000004\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n+ Node3 [id=\"Node000003\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00008.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00008.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: psh.h File Reference\n+MALOC: vcom.h File Reference\n \n \n \n \n \n \n
\n@@ -40,50 +40,114 @@\n
\n \n
\n
\n
\n \n-
psh.h File Reference
\n+
vcom.h File Reference
\n
\n
\n \n-

Header file for a simple parallel extension of ALOC's VSH. \n+

Class Vcom: virtual (currently just MPI) communications layer. \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vsys.h>
\n-#include <maloc/vsh.h>
\n-#include <maloc/vmp.h>
\n+#include <maloc/vsys.h>
\n
\n-Include dependency graph for psh.h:
\n+Include dependency graph for vcom.h:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n This graph shows which files directly or indirectly include this file:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n

Go to the source code of this file.

\n \n+\n+\n+\n+\n+

\n+Classes

struct  sVcom
 Contains public data members for Vcom class. More...
 
\n+\n+\n+\n+\n+

\n+Macros

#define VCOM_MPI_TAG   111
 A base value for MPI tags.
 
\n+\n+\n+\n+\n+

\n+Typedefs

typedef struct sVcom Vcom
 Declaration of the Vcom class as the Vcom structure
\n+
 
\n \n-\n-\n-\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n

\n Functions

int Vsh_pshell (Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee, int argc, char **argv))
 Drop-in replacement for Vsh_shell giving parallel extensions.
 
int Vcom_init (int *argc, char ***argv)
 The Vmp initializer.
 
int Vcom_finalize (void)
 The Vmp finalizer.
 
VcomVcom_ctor (int commtype)
 Construct the communications object. This routine sets up data members of class and initializes MPI.
 
int Vcom_ctor2 (Vcom *thee, int commtype)
 Construct the communications object. This routine sets up data members of class and initializes MPI. This is broken into two parts to be callable from FORTRAN.
 
void Vcom_dtor (Vcom **thee)
 Destroy the communications object.
 
void Vcom_dtor2 (Vcom *thee)
 Destroy the communications object. This is broken into two parts to be callable from FORTRAN.
 
int Vcom_send (Vcom *thee, int des, void *buf, int len, int type, int block)
 Send a buffer. Returns 1 on success.
 
int Vcom_recv (Vcom *thee, int src, void *buf, int len, int type, int block)
 Receive a (character) buffer.
\n+ The blocking flag is present, but not used. All receives are assumed to be blocking. A non-blocking receive would be very ugly to implement (signals or something?).
 
int Vcom_getCount (Vcom *thee, int src, int *length, int type)
 Perform a blocking probe to get the length (in number of items of specified type) of an incoming message and place it in the
\n+ argument ``length\".
 
int Vcom_reduce (Vcom *thee, void *sendbuf, void *recvbuf, int length, int type, int op)
 Perform a reduction of the data across all processors. This is equivalent (and in the case of MPI is identical to) MPI_Allreduce. Basically, the specified operations are appleed to each member of
\n+ the sendbuf across all processors and the results are written to recvbuf.
 
int Vcom_size (Vcom *thee)
 Get the number of PEs in communicator.
 
int Vcom_resize (Vcom *thee, int newsize)
 Resize (shrink) the communications group to include only newsize number of processors.
\n+ Obsolete processes are given rank of -1 and size of 0.
 
int Vcom_rank (Vcom *thee)
 Get the ID of the local PE
\n+
 
int Vcom_barr (Vcom *thee)
 Synchronization barrier.
 
\n

Detailed Description

\n-

Header file for a simple parallel extension of ALOC's VSH.

\n-
Author
Michael Holst
\n+

Class Vcom: virtual (currently just MPI) communications layer.

\n+
Authors
Nathan Baker and Michael Holst
\n
Note
None
\n
Version
\n-
Id
psh.h,v 1.28 2010/08/12 05:40:23 fetk Exp
\n+
Id
vcom.h,v 1.38 2010/08/12 05:40:23 fetk Exp
\n
Attention
*\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n@@ -95,14 +159,31 @@\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n * \n *  
\n-
\n+

Macro Definition Documentation

\n+\n+

◆ VCOM_MPI_TAG

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+
#define VCOM_MPI_TAG   111
\n+
\n+\n+

A base value for MPI tags.

\n+\n+
\n+
\n+\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,39 +3,107 @@\n \n \n MALOC\u00a00.1\n \n * src\n * psh\n * maloc\n-Functions\n-psh.h File Reference\n-Vsh_class\n-Header file for a simple parallel extension of ALOC's VSH. More...\n+Classes | Macros | Typedefs | Functions\n+vcom.h File Reference\n+Vcom_class\n+Class Vcom: virtual (currently just MPI) communications layer. More...\n #include \n #include \n-#include \n-#include \n-Include dependency graph for psh.h:\n+Include dependency graph for vcom.h:\n This graph shows which files directly or indirectly include this file:\n Go_to_the_source_code_of_this_file.\n+ Classes\n+struct \u00a0sVcom\n+\u00a0 Contains public data members for Vcom class. More...\n+\u00a0\n+ Macros\n+#define\u00a0VCOM_MPI_TAG\u00a0\u00a0\u00a0111\n+\u00a0 A base value for MPI tags.\n+\u00a0\n+ Typedefs\n+typedef struct sVcom\u00a0Vcom\n+\u00a0 Declaration of the Vcom class as the Vcom structure\n+\n+\u00a0\n Functions\n-int\u00a0Vsh_pshell (Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee,\n- int argc, char **argv))\n-\u00a0 Drop-in replacement for Vsh_shell giving parallel extensions.\n+ int\u00a0Vcom_init (int *argc, char ***argv)\n+\u00a0 The Vmp initializer.\n+\u00a0\n+ int\u00a0Vcom_finalize (void)\n+\u00a0 The Vmp finalizer.\n+\u00a0\n+Vcom *\u00a0Vcom_ctor (int commtype)\n+\u00a0 Construct the communications object. This routine sets up data members\n+ of class and initializes MPI.\n+\u00a0\n+ int\u00a0Vcom_ctor2 (Vcom *thee, int commtype)\n+ Construct the communications object. This routine sets up data members\n+\u00a0 of class and initializes MPI. This is broken into two parts to be\n+ callable from FORTRAN.\n+\u00a0\n+ void\u00a0Vcom_dtor (Vcom **thee)\n+\u00a0 Destroy the communications object.\n+\u00a0\n+ void\u00a0Vcom_dtor2 (Vcom *thee)\n+\u00a0 Destroy the communications object. This is broken into two parts to be\n+ callable from FORTRAN.\n+\u00a0\n+ int\u00a0Vcom_send (Vcom *thee, int des, void *buf, int len, int type, int\n+ block)\n+\u00a0 Send a buffer. Returns 1 on success.\n+\u00a0\n+ int\u00a0Vcom_recv (Vcom *thee, int src, void *buf, int len, int type, int\n+ block)\n+ Receive a (character) buffer.\n+\u00a0 The blocking flag is present, but not used. All receives are assumed to\n+ be blocking. A non-blocking receive would be very ugly to implement\n+ (signals or something?).\n+\u00a0\n+ int\u00a0Vcom_getCount (Vcom *thee, int src, int *length, int type)\n+ Perform a blocking probe to get the length (in number of items of\n+\u00a0 specified type) of an incoming message and place it in the\n+ argument ``length\".\n+\u00a0\n+ int\u00a0Vcom_reduce (Vcom *thee, void *sendbuf, void *recvbuf, int length, int\n+ type, int op)\n+ Perform a reduction of the data across all processors. This is\n+ equivalent (and in the case of MPI is identical to) MPI_Allreduce.\n+\u00a0 Basically, the specified operations are appleed to each member of\n+ the sendbuf across all processors and the results are written to\n+ recvbuf.\n+\u00a0\n+ int\u00a0Vcom_size (Vcom *thee)\n+\u00a0 Get the number of PEs in communicator.\n+\u00a0\n+ int\u00a0Vcom_resize (Vcom *thee, int newsize)\n+ Resize (shrink) the communications group to include only newsize number\n+\u00a0 of processors.\n+ Obsolete processes are given rank of -1 and size of 0.\n+\u00a0\n+ int\u00a0Vcom_rank (Vcom *thee)\n+\u00a0 Get the ID of the local PE\n+\n+\u00a0\n+ int\u00a0Vcom_barr (Vcom *thee)\n+\u00a0 Synchronization barrier.\n \u00a0\n ***** Detailed Description *****\n-Header file for a simple parallel extension of ALOC's VSH.\n- Author\n- Michael Holst\n+Class Vcom: virtual (currently just MPI) communications layer.\n+ Authors\n+ Nathan Baker and Michael Holst\n Note\n None\n Version\n Id\n- psh.h,v 1.28 2010/08/12 05:40:23 fetk Exp\n+ vcom.h,v 1.38 2010/08/12 05:40:23 fetk Exp\n Attention\n *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n@@ -48,10 +116,14 @@\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n *\n *\n+***** Macro Definition Documentation *****\n+***** \u25c6\u00a0VCOM_MPI_TAG *****\n+#define VCOM_MPI_TAG\u00a0\u00a0\u00a0111\n+A base value for MPI tags.\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00008_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00008_source.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: psh.h Source File\n+MALOC: vcom.h Source File\n \n \n \n \n \n \n
\n@@ -44,38 +44,114 @@\n \n
\n \n
\n
\n
\n-
psh.h
\n+
vcom.h
\n
\n
\n Go to the documentation of this file.
1
\n-
32#ifndef _PSH_H_
\n-
33#define _PSH_H_
\n-
34
\n-
35#include <maloc/maloc_base.h>
\n-
36
\n-
37#include <maloc/vsys.h>
\n-
38#include <maloc/vsh.h>
\n-
39#include <maloc/vmp.h>
\n+
38#ifndef _VCOM_H_
\n+
39#define _VCOM_H_
\n
40
\n-
52int Vsh_pshell(Vsh *thee, char *pPR, void *pthee,
\n-
53 int (*builtin)(void *thee, int argc, char **argv));
\n-
54
\n-
55#endif /* _PSH_H_ */
\n-
56
\n+
41#include <maloc/maloc_base.h>
\n+
42
\n+
43#include <maloc/vsys.h>
\n+
44
\n+
46#define VCOM_MPI_TAG 111
\n+
47
\n+
48/*
\n+
49 * ***************************************************************************
\n+
50 * Class Vcom: Parameters and datatypes
\n+
51 * ***************************************************************************
\n+
52 */
\n+
53
\n+
\n+
60struct sVcom {
\n+
61
\n+\n+\n+
66
\n+
71 int type;
\n+
73 int error;
\n+
75 void *core;
\n+
76
\n+
77};
\n+
\n+
78
\n+
85typedef struct sVcom Vcom;
\n+
86
\n+
87/*
\n+
88 * ***************************************************************************
\n+
89 * Class Vcom: Inlineable methods (vcom.c)
\n+
90 * ***************************************************************************
\n+
91 */
\n+
92
\n+
93#if !defined(VINLINE_MALOC)
\n+
94#else /* if defined(VINLINE_MALOC) */
\n+
95#endif /* if !defined(VINLINE_MALOC) */
\n+
96
\n+
97
\n+
107int Vcom_init(int *argc, char ***argv);
\n+
108
\n+\n+
117
\n+
127Vcom* Vcom_ctor(int commtype);
\n+
128
\n+
140int Vcom_ctor2(Vcom* thee, int commtype);
\n+
141
\n+
150void Vcom_dtor(Vcom **thee);
\n+
151
\n+
161void Vcom_dtor2(Vcom *thee);
\n+
162
\n+
177int Vcom_send(Vcom *thee, int des, void *buf, int len, int type,
\n+
178 int block);
\n+
179
\n+
197int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type,
\n+
198 int block);
\n+
199
\n+
214int Vcom_getCount(Vcom *thee, int src, int *length, int type);
\n+
215
\n+
237int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length,
\n+
238 int type, int op);
\n+
239
\n+
248int Vcom_size(Vcom *thee);
\n+
249
\n+
261int Vcom_resize(Vcom *thee, int newsize);
\n+
262
\n+
271int Vcom_rank(Vcom *thee);
\n+
272
\n+
281int Vcom_barr(Vcom *thee);
\n+
282
\n+
283#endif /* _VCOM_H_ */
\n+
284
\n
The base (or foundation) header for MALOC.
\n-
Class Vmp: a Virtual MPI communication layer object.
\n-
Header file for vsh, a bourne-compatible shell.
\n-
The primary header for VSYS. (Virtual SYStem utilities library.)
\n-
int Vsh_pshell(Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee, int argc, char **argv))
Drop-in replacement for Vsh_shell giving parallel extensions.
\n-
Contains public data members for Vsh class.
Definition vsh.h:56
\n+
The primary header for VSYS. (Virtual SYStem utilities library.)
\n+
int Vcom_rank(Vcom *thee)
Get the ID of the local PE
\n+
int Vcom_resize(Vcom *thee, int newsize)
Resize (shrink) the communications group to include only newsize number of processors....
\n+
int Vcom_ctor2(Vcom *thee, int commtype)
Construct the communications object. This routine sets up data members of class and initializes MPI....
\n+
int Vcom_size(Vcom *thee)
Get the number of PEs in communicator.
\n+
int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length, int type, int op)
Perform a reduction of the data across all processors. This is equivalent (and in the case of MPI is ...
\n+
Vcom * Vcom_ctor(int commtype)
Construct the communications object. This routine sets up data members of class and initializes MPI.
\n+
int Vcom_init(int *argc, char ***argv)
The Vmp initializer.
\n+
int Vcom_finalize(void)
The Vmp finalizer.
\n+
int Vcom_barr(Vcom *thee)
Synchronization barrier.
\n+
void Vcom_dtor(Vcom **thee)
Destroy the communications object.
\n+
int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type, int block)
Receive a (character) buffer. The blocking flag is present, but not used. All receives are assumed ...
\n+
int Vcom_getCount(Vcom *thee, int src, int *length, int type)
Perform a blocking probe to get the length (in number of items of specified type) of an incoming mess...
\n+
int Vcom_send(Vcom *thee, int des, void *buf, int len, int type, int block)
Send a buffer. Returns 1 on success.
\n+
void Vcom_dtor2(Vcom *thee)
Destroy the communications object. This is broken into two parts to be callable from FORTRAN.
\n+
Contains public data members for Vcom class.
Definition vcom.h:60
\n+
int type
Communication type. 0 = not initialized 1 = Message Passing Interface 1.1.
Definition vcom.h:71
\n+
int error
note if any error has occurred on this vcom device
Definition vcom.h:73
\n+
int mpi_size
Total number of PEs in this communicator from MPI.
Definition vcom.h:65
\n+
void * core
Private MPI core.
Definition vcom.h:75
\n+
int mpi_rank
Local PE rank from MPI.
Definition vcom.h:63
\n
\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,42 +3,166 @@\n \n \n MALOC\u00a00.1\n \n * src\n * psh\n * maloc\n-psh.h\n+vcom.h\n Go_to_the_documentation_of_this_file.\n 1\n- 32#ifndef _PSH_H_\n- 33#define _PSH_H_\n- 34\n- 35#include \n- 36\n- 37#include \n- 38#include \n- 39#include \n+ 38#ifndef _VCOM_H_\n+ 39#define _VCOM_H_\n 40\n-52int Vsh_pshell(Vsh *thee, char *pPR, void *pthee,\n- 53 int (*builtin)(void *thee, int argc, char **argv));\n- 54\n- 55#endif /* _PSH_H_ */\n- 56\n+ 41#include \n+ 42\n+ 43#include \n+ 44\n+46#define VCOM_MPI_TAG 111\n+ 47\n+ 48/*\n+ 49 *\n+***************************************************************************\n+ 50 * Class Vcom: Parameters and datatypes\n+ 51 *\n+***************************************************************************\n+ 52 */\n+ 53\n+60struct sVcom {\n+ 61\n+63 int mpi_rank;\n+65 int mpi_size;\n+ 66\n+71 int type;\n+73 int error;\n+75 void *core;\n+ 76\n+ 77};\n+ 78\n+85typedef struct sVcom Vcom;\n+ 86\n+ 87/*\n+ 88 *\n+***************************************************************************\n+ 89 * Class Vcom: Inlineable methods (vcom.c)\n+ 90 *\n+***************************************************************************\n+ 91 */\n+ 92\n+ 93#if !defined(VINLINE_MALOC)\n+ 94#else /* if defined(VINLINE_MALOC) */\n+ 95#endif /* if !defined(VINLINE_MALOC) */\n+ 96\n+ 97\n+107int Vcom_init(int *argc, char ***argv);\n+ 108\n+116int Vcom_finalize(void);\n+ 117\n+127Vcom* Vcom_ctor(int commtype);\n+ 128\n+140int Vcom_ctor2(Vcom* thee, int commtype);\n+ 141\n+150void Vcom_dtor(Vcom **thee);\n+ 151\n+161void Vcom_dtor2(Vcom *thee);\n+ 162\n+177int Vcom_send(Vcom *thee, int des, void *buf, int len, int type,\n+ 178 int block);\n+ 179\n+197int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type,\n+ 198 int block);\n+ 199\n+214int Vcom_getCount(Vcom *thee, int src, int *length, int type);\n+ 215\n+237int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length,\n+ 238 int type, int op);\n+ 239\n+248int Vcom_size(Vcom *thee);\n+ 249\n+261int Vcom_resize(Vcom *thee, int newsize);\n+ 262\n+271int Vcom_rank(Vcom *thee);\n+ 272\n+281int Vcom_barr(Vcom *thee);\n+ 282\n+ 283#endif /* _VCOM_H_ */\n+ 284\n maloc_base.h\n The base (or foundation) header for MALOC.\n-vmp.h\n-Class Vmp: a Virtual MPI communication layer object.\n-vsh.h\n-Header file for vsh, a bourne-compatible shell.\n vsys.h\n The primary header for VSYS. (Virtual SYStem utilities library.)\n-Vsh_pshell\n-int Vsh_pshell(Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee, int\n-argc, char **argv))\n-Drop-in replacement for Vsh_shell giving parallel extensions.\n-sVsh\n-Contains public data members for Vsh class.\n-Definition vsh.h:56\n+Vcom_rank\n+int Vcom_rank(Vcom *thee)\n+Get the ID of the local PE\n+Vcom_resize\n+int Vcom_resize(Vcom *thee, int newsize)\n+Resize (shrink) the communications group to include only newsize number of\n+processors....\n+Vcom_ctor2\n+int Vcom_ctor2(Vcom *thee, int commtype)\n+Construct the communications object. This routine sets up data members of class\n+and initializes MPI....\n+Vcom_size\n+int Vcom_size(Vcom *thee)\n+Get the number of PEs in communicator.\n+Vcom_reduce\n+int Vcom_reduce(Vcom *thee, void *sendbuf, void *recvbuf, int length, int type,\n+int op)\n+Perform a reduction of the data across all processors. This is equivalent (and\n+in the case of MPI is ...\n+Vcom_ctor\n+Vcom * Vcom_ctor(int commtype)\n+Construct the communications object. This routine sets up data members of class\n+and initializes MPI.\n+Vcom_init\n+int Vcom_init(int *argc, char ***argv)\n+The Vmp initializer.\n+Vcom_finalize\n+int Vcom_finalize(void)\n+The Vmp finalizer.\n+Vcom_barr\n+int Vcom_barr(Vcom *thee)\n+Synchronization barrier.\n+Vcom_dtor\n+void Vcom_dtor(Vcom **thee)\n+Destroy the communications object.\n+Vcom_recv\n+int Vcom_recv(Vcom *thee, int src, void *buf, int len, int type, int block)\n+Receive a (character) buffer. The blocking flag is present, but not used. All\n+receives are assumed ...\n+Vcom_getCount\n+int Vcom_getCount(Vcom *thee, int src, int *length, int type)\n+Perform a blocking probe to get the length (in number of items of specified\n+type) of an incoming mess...\n+Vcom_send\n+int Vcom_send(Vcom *thee, int des, void *buf, int len, int type, int block)\n+Send a buffer. Returns 1 on success.\n+Vcom_dtor2\n+void Vcom_dtor2(Vcom *thee)\n+Destroy the communications object. This is broken into two parts to be callable\n+from FORTRAN.\n+sVcom\n+Contains public data members for Vcom class.\n+Definition vcom.h:60\n+sVcom::type\n+int type\n+Communication type. 0 = not initialized 1 = Message Passing Interface 1.1.\n+Definition vcom.h:71\n+sVcom::error\n+int error\n+note if any error has occurred on this vcom device\n+Definition vcom.h:73\n+sVcom::mpi_size\n+int mpi_size\n+Total number of PEs in this communicator from MPI.\n+Definition vcom.h:65\n+sVcom::core\n+void * core\n+Private MPI core.\n+Definition vcom.h:75\n+sVcom::mpi_rank\n+int mpi_rank\n+Local PE rank from MPI.\n+Definition vcom.h:63\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00009.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00009.dot.gz", "unified_diff": null, "details": [{"source1": "a00009.dot", "source2": "a00009.dot", "unified_diff": "@@ -1,14 +1,14 @@\n-digraph \"psh.h\"\n+digraph \"vcom.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"psh.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node1 [id=\"Node000001\",label=\"vcom.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc/maloc_base.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00002.html\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"assert.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"ctype.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge4_Node000002_Node000005\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n@@ -34,44 +34,28 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node19 [id=\"edge19_Node000018_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node20 [id=\"edge21_Node000018_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node20 [id=\"Node000020\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node21 [id=\"edge23_Node000018_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node21 -> Node2 [id=\"edge24_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node21 -> Node19 [id=\"edge25_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node22 [id=\"edge26_Node000018_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 [id=\"Node000022\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node22 -> Node2 [id=\"edge27_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node19 [id=\"edge28_Node000022_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node20 [id=\"edge29_Node000022_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node23 [id=\"edge30_Node000018_Node000023\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node23 -> Node2 [id=\"edge31_Node000023_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node24 [id=\"edge32_Node000001_Node000024\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node24 [id=\"Node000024\",label=\"maloc/vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n- Node24 -> Node2 [id=\"edge33_Node000024_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node24 -> Node18 [id=\"edge34_Node000024_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node25 [id=\"edge35_Node000001_Node000025\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node25 [id=\"Node000025\",label=\"maloc/vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n- Node25 -> Node2 [id=\"edge36_Node000025_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node25 -> Node18 [id=\"edge37_Node000025_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node25 -> Node26 [id=\"edge38_Node000025_Node000026\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node26 [id=\"Node000026\",label=\"maloc/vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n- Node26 -> Node2 [id=\"edge39_Node000026_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node26 -> Node18 [id=\"edge40_Node000026_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node25 -> Node27 [id=\"edge41_Node000025_Node000027\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node27 [id=\"Node000027\",label=\"maloc/vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n- Node27 -> Node2 [id=\"edge42_Node000027_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node27 -> Node18 [id=\"edge43_Node000027_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00010.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00010.dot", "unified_diff": "@@ -1,10 +1,14 @@\n-digraph \"psh.h\"\n+digraph \"vcom.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"psh.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node1 [id=\"Node000001\",label=\"vcom.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n+ Node2 [id=\"Node000002\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node3 -> Node4 [id=\"edge3_Node000003_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node4 [id=\"Node000004\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00011.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00011.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vmp.h File Reference\n+MALOC: psh.h File Reference\n \n \n \n \n \n \n
\n@@ -40,92 +40,50 @@\n
\n \n
\n
\n
\n \n-
vmp.h File Reference
\n+
psh.h File Reference
\n
\n
\n \n-

Class Vmp: a Virtual MPI communication layer object. \n+

Header file for a simple parallel extension of ALOC's VSH. \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vsys.h>
\n-#include <maloc/vmpi.h>
\n-#include <maloc/vcom.h>
\n+#include <maloc/vsys.h>
\n+#include <maloc/vsh.h>
\n+#include <maloc/vmp.h>
\n
\n-Include dependency graph for vmp.h:
\n+Include dependency graph for psh.h:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n This graph shows which files directly or indirectly include this file:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n

Go to the source code of this file.

\n \n-\n-\n-\n-\n-

\n-Classes

struct  sVmp
 Contains public data members for Vmp class. More...
 
\n-\n-\n-\n-\n-

\n-Typedefs

typedef struct sVmp Vmp
 Declaration of the Vmp class as teh Vmp structure.
 
\n \n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n+\n+\n+\n

\n Functions

int Vmp_init (int *argc, char ***argv)
 The Vmp initializer.
 
int Vmp_finalize (void)
 The Vmp finalizer.
 
VmpVmp_ctor (void)
 The Vmp constructor.
 
void Vmp_dtor (Vmp **thee)
 The Vmp destructor.
 
int Vmp_rank (Vmp *thee)
 Return my processor ID.
 
int Vmp_size (Vmp *thee)
 Return the number of processors involved.
\n-
 
int Vmp_barr (Vmp *thee)
 An MPI barrier.
\n-
 
int Vmp_send (Vmp *thee, int des, char *buf, int bufsize)
 An MPI blocking send.
\n-
 
int Vmp_recv (Vmp *thee, int src, char *buf, int bufsize)
 An MPI blocking receive.
\n-
 
int Vsh_pshell (Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee, int argc, char **argv))
 Drop-in replacement for Vsh_shell giving parallel extensions.
 
\n

Detailed Description

\n-

Class Vmp: a Virtual MPI communication layer object.

\n+

Header file for a simple parallel extension of ALOC's VSH.

\n
Author
Michael Holst
\n
Note
None
\n
Version
\n-
Id
vmp.h,v 1.22 2010/08/12 05:40:23 fetk Exp
\n+
Id
psh.h,v 1.28 2010/08/12 05:40:23 fetk Exp
\n
Attention
*\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,74 +3,39 @@\n \n \n MALOC\u00a00.1\n \n     * src\n     * psh\n     * maloc\n-Classes | Typedefs | Functions\n-vmp.h File Reference\n-Vmp_class\n-Class Vmp: a Virtual MPI communication layer object. More...\n+Functions\n+psh.h File Reference\n+Vsh_class\n+Header file for a simple parallel extension of ALOC's VSH. More...\n #include \n #include \n-#include \n-#include \n-Include dependency graph for vmp.h:\n+#include \n+#include \n+Include dependency graph for psh.h:\n This graph shows which files directly or indirectly include this file:\n Go_to_the_source_code_of_this_file.\n- Classes\n-struct \u00a0sVmp\n-\u00a0       Contains public data members for Vmp class. More...\n-\u00a0\n- Typedefs\n-typedef struct sVmp\u00a0Vmp\n-\u00a0                   Declaration of the Vmp class as teh Vmp structure.\n-\u00a0\n  Functions\n-  int\u00a0Vmp_init (int *argc, char ***argv)\n-\u00a0     The Vmp initializer.\n-\u00a0\n-  int\u00a0Vmp_finalize (void)\n-\u00a0     The Vmp finalizer.\n-\u00a0\n-Vmp *\u00a0Vmp_ctor (void)\n-\u00a0     The Vmp constructor.\n-\u00a0\n- void\u00a0Vmp_dtor (Vmp **thee)\n-\u00a0     The Vmp destructor.\n-\u00a0\n-  int\u00a0Vmp_rank (Vmp *thee)\n-\u00a0     Return my processor ID.\n-\u00a0\n-  int\u00a0Vmp_size (Vmp *thee)\n-\u00a0     Return the number of processors involved.\n-\n-\u00a0\n-  int\u00a0Vmp_barr (Vmp *thee)\n-\u00a0     An MPI barrier.\n-\n-\u00a0\n-  int\u00a0Vmp_send (Vmp *thee, int des, char *buf, int bufsize)\n-\u00a0     An MPI blocking send.\n-\n-\u00a0\n-  int\u00a0Vmp_recv (Vmp *thee, int src, char *buf, int bufsize)\n-\u00a0     An MPI blocking receive.\n-\n+int\u00a0Vsh_pshell (Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee,\n+     int argc, char **argv))\n+\u00a0   Drop-in replacement for Vsh_shell giving parallel extensions.\n \u00a0\n ***** Detailed Description *****\n-Class Vmp: a Virtual MPI communication layer object.\n+Header file for a simple parallel extension of ALOC's VSH.\n   Author\n       Michael Holst\n   Note\n       None\n   Version\n   Id\n-      vmp.h,v 1.22 2010/08/12 05:40:23 fetk Exp\n+      psh.h,v 1.28 2010/08/12 05:40:23 fetk Exp\n   Attention\n       *\n       * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n       * Copyright (C) 1994-- Michael Holst\n       *\n       * This library is free software; you can redistribute it and/or\n       * modify it under the terms of the GNU Lesser General Public\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00011_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00011_source.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vmp.h Source File\n+MALOC: psh.h Source File\n \n \n \n \n \n \n 
\n@@ -44,89 +44,38 @@\n \n
\n \n
\n
\n
\n-
vmp.h
\n+
psh.h
\n
\n
\n Go to the documentation of this file.
1
\n-
37#ifndef _VMP_H_
\n-
38#define _VMP_H_
\n-
39
\n-
40#include <maloc/maloc_base.h>
\n-
41
\n-
42#include <maloc/vsys.h>
\n-
43#include <maloc/vmpi.h>
\n-
44#include <maloc/vcom.h>
\n-
45
\n-
46/*
\n-
47 * ***************************************************************************
\n-
48 * Class Vmp: Parameters and datatypes
\n-
49 * ***************************************************************************
\n-
50 */
\n-
51
\n-
\n-
58struct sVmp {
\n-\n-\n-
61};
\n-
\n-
62
\n-
68typedef struct sVmp Vmp;
\n-
69
\n-
70/*
\n-
71 * ***************************************************************************
\n-
72 * Class Vmp: Inlineable methods (vmp.c)
\n-
73 * ***************************************************************************
\n-
74 */
\n-
75
\n-
76#if !defined(VINLINE_MALOC)
\n-
77#else /* if defined(VINLINE_MALOC) */
\n-
78#endif /* if !defined(VINLINE_MALOC) */
\n-
79
\n-
80
\n-
90int Vmp_init(int *argc, char ***argv);
\n-
91
\n-
99int Vmp_finalize(void);
\n-
100
\n-\n-
109
\n-
118void Vmp_dtor(Vmp **thee);
\n-
119
\n-
128int Vmp_rank(Vmp *thee);
\n-
129
\n-
138int Vmp_size(Vmp *thee);
\n-
139
\n-
148int Vmp_barr(Vmp *thee);
\n-
149
\n-
161int Vmp_send(Vmp *thee, int des, char *buf, int bufsize);
\n-
162
\n-
174int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize);
\n-
175
\n-
176#endif /* _VMP_H_ */
\n-
177
\n+
32#ifndef _PSH_H_
\n+
33#define _PSH_H_
\n+
34
\n+
35#include <maloc/maloc_base.h>
\n+
36
\n+
37#include <maloc/vsys.h>
\n+
38#include <maloc/vsh.h>
\n+
39#include <maloc/vmp.h>
\n+
40
\n+
52int Vsh_pshell(Vsh *thee, char *pPR, void *pthee,
\n+
53 int (*builtin)(void *thee, int argc, char **argv));
\n+
54
\n+
55#endif /* _PSH_H_ */
\n+
56
\n
The base (or foundation) header for MALOC.
\n-
Class Vcom: virtual (currently just MPI) communications layer.
\n-
Class Vmpi: a Virtual MPI communication layer object.
\n-
The primary header for VSYS. (Virtual SYStem utilities library.)
\n-
int Vmp_finalize(void)
The Vmp finalizer.
\n-
int Vmp_send(Vmp *thee, int des, char *buf, int bufsize)
An MPI blocking send.
\n-
int Vmp_init(int *argc, char ***argv)
The Vmp initializer.
\n-
int Vmp_rank(Vmp *thee)
Return my processor ID.
\n-
int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize)
An MPI blocking receive.
\n-
Vmp * Vmp_ctor(void)
The Vmp constructor.
\n-
void Vmp_dtor(Vmp **thee)
The Vmp destructor.
\n-
int Vmp_barr(Vmp *thee)
An MPI barrier.
\n-
int Vmp_size(Vmp *thee)
Return the number of processors involved.
\n-
Contains public data members for Vmp class.
Definition vmp.h:58
\n-
int mpi_rank
Definition vmp.h:59
\n-
int mpi_size
Definition vmp.h:60
\n+
Class Vmp: a Virtual MPI communication layer object.
\n+
Header file for vsh, a bourne-compatible shell.
\n+
The primary header for VSYS. (Virtual SYStem utilities library.)
\n+
int Vsh_pshell(Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee, int argc, char **argv))
Drop-in replacement for Vsh_shell giving parallel extensions.
\n+
Contains public data members for Vsh class.
Definition vsh.h:56
\n
\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,114 +3,42 @@\n \n \n MALOC\u00a00.1\n \n * src\n * psh\n * maloc\n-vmp.h\n+psh.h\n Go_to_the_documentation_of_this_file.\n 1\n- 37#ifndef _VMP_H_\n- 38#define _VMP_H_\n- 39\n- 40#include \n- 41\n- 42#include \n- 43#include \n- 44#include \n- 45\n- 46/*\n- 47 *\n-***************************************************************************\n- 48 * Class Vmp: Parameters and datatypes\n- 49 *\n-***************************************************************************\n- 50 */\n- 51\n-58struct sVmp {\n-59 int mpi_rank;\n-60 int mpi_size;\n- 61};\n- 62\n-68typedef struct sVmp Vmp;\n- 69\n- 70/*\n- 71 *\n-***************************************************************************\n- 72 * Class Vmp: Inlineable methods (vmp.c)\n- 73 *\n-***************************************************************************\n- 74 */\n- 75\n- 76#if !defined(VINLINE_MALOC)\n- 77#else /* if defined(VINLINE_MALOC) */\n- 78#endif /* if !defined(VINLINE_MALOC) */\n- 79\n- 80\n-90int Vmp_init(int *argc, char ***argv);\n- 91\n-99int Vmp_finalize(void);\n- 100\n-108Vmp* Vmp_ctor(void);\n- 109\n-118void Vmp_dtor(Vmp **thee);\n- 119\n-128int Vmp_rank(Vmp *thee);\n- 129\n-138int Vmp_size(Vmp *thee);\n- 139\n-148int Vmp_barr(Vmp *thee);\n- 149\n-161int Vmp_send(Vmp *thee, int des, char *buf, int bufsize);\n- 162\n-174int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize);\n- 175\n- 176#endif /* _VMP_H_ */\n- 177\n+ 32#ifndef _PSH_H_\n+ 33#define _PSH_H_\n+ 34\n+ 35#include \n+ 36\n+ 37#include \n+ 38#include \n+ 39#include \n+ 40\n+52int Vsh_pshell(Vsh *thee, char *pPR, void *pthee,\n+ 53 int (*builtin)(void *thee, int argc, char **argv));\n+ 54\n+ 55#endif /* _PSH_H_ */\n+ 56\n maloc_base.h\n The base (or foundation) header for MALOC.\n-vcom.h\n-Class Vcom: virtual (currently just MPI) communications layer.\n-vmpi.h\n-Class Vmpi: a Virtual MPI communication layer object.\n+vmp.h\n+Class Vmp: a Virtual MPI communication layer object.\n+vsh.h\n+Header file for vsh, a bourne-compatible shell.\n vsys.h\n The primary header for VSYS. (Virtual SYStem utilities library.)\n-Vmp_finalize\n-int Vmp_finalize(void)\n-The Vmp finalizer.\n-Vmp_send\n-int Vmp_send(Vmp *thee, int des, char *buf, int bufsize)\n-An MPI blocking send.\n-Vmp_init\n-int Vmp_init(int *argc, char ***argv)\n-The Vmp initializer.\n-Vmp_rank\n-int Vmp_rank(Vmp *thee)\n-Return my processor ID.\n-Vmp_recv\n-int Vmp_recv(Vmp *thee, int src, char *buf, int bufsize)\n-An MPI blocking receive.\n-Vmp_ctor\n-Vmp * Vmp_ctor(void)\n-The Vmp constructor.\n-Vmp_dtor\n-void Vmp_dtor(Vmp **thee)\n-The Vmp destructor.\n-Vmp_barr\n-int Vmp_barr(Vmp *thee)\n-An MPI barrier.\n-Vmp_size\n-int Vmp_size(Vmp *thee)\n-Return the number of processors involved.\n-sVmp\n-Contains public data members for Vmp class.\n-Definition vmp.h:58\n-sVmp::mpi_rank\n-int mpi_rank\n-Definition vmp.h:59\n-sVmp::mpi_size\n-int mpi_size\n-Definition vmp.h:60\n+Vsh_pshell\n+int Vsh_pshell(Vsh *thee, char *pPR, void *pthee, int(*builtin)(void *thee, int\n+argc, char **argv))\n+Drop-in replacement for Vsh_shell giving parallel extensions.\n+sVsh\n+Contains public data members for Vsh class.\n+Definition vsh.h:56\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00012.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00012.dot.gz", "unified_diff": null, "details": [{"source1": "a00012.dot", "source2": "a00012.dot", "unified_diff": "@@ -1,14 +1,14 @@\n-digraph \"vmp.h\"\n+digraph \"psh.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vmp.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node1 [id=\"Node000001\",label=\"psh.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc/maloc_base.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00002.html\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"assert.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"ctype.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge4_Node000002_Node000005\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n@@ -34,36 +34,44 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node19 [id=\"edge19_Node000018_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node20 [id=\"edge21_Node000018_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node20 [id=\"Node000020\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node21 [id=\"edge23_Node000018_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node21 -> Node2 [id=\"edge24_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node21 -> Node19 [id=\"edge25_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node22 [id=\"edge26_Node000018_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 [id=\"Node000022\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node22 -> Node2 [id=\"edge27_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node19 [id=\"edge28_Node000022_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node20 [id=\"edge29_Node000022_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node23 [id=\"edge30_Node000018_Node000023\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node23 -> Node2 [id=\"edge31_Node000023_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node24 [id=\"edge32_Node000001_Node000024\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node24 [id=\"Node000024\",label=\"maloc/vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n+ Node24 [id=\"Node000024\",label=\"maloc/vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n Node24 -> Node2 [id=\"edge33_Node000024_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node24 -> Node18 [id=\"edge34_Node000024_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node25 [id=\"edge35_Node000001_Node000025\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node25 [id=\"Node000025\",label=\"maloc/vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node25 [id=\"Node000025\",label=\"maloc/vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node25 -> Node2 [id=\"edge36_Node000025_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node25 -> Node18 [id=\"edge37_Node000025_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node25 -> Node26 [id=\"edge38_Node000025_Node000026\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node26 [id=\"Node000026\",label=\"maloc/vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n+ Node26 -> Node2 [id=\"edge39_Node000026_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node26 -> Node18 [id=\"edge40_Node000026_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node25 -> Node27 [id=\"edge41_Node000025_Node000027\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node27 [id=\"Node000027\",label=\"maloc/vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node27 -> Node2 [id=\"edge42_Node000027_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node27 -> Node18 [id=\"edge43_Node000027_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00013.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00013.dot", "unified_diff": "@@ -1,12 +1,10 @@\n-digraph \"vmp.h\"\n+digraph \"psh.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vmp.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node1 [id=\"Node000001\",label=\"psh.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n- Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n+ Node2 [id=\"Node000002\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00014.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00014.html", "unified_diff": "@@ -50,15 +50,15 @@\n
vmpi.h File Reference
\n
\n
\n \n

Class Vmpi: a Virtual MPI communication layer object. \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vsys.h>
\n+#include <maloc/vsys.h>
\n
\n Include dependency graph for vmpi.h:
\n
\n
\"\"/
\n
\n
\n This graph shows which files directly or indirectly include this file:
\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00014_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00014_source.html", "unified_diff": "@@ -53,15 +53,15 @@\n
\n Go to the documentation of this file.
1
\n
38#ifndef _VMPI_H_
\n
39#define _VMPI_H_
\n
40
\n
41#include <maloc/maloc_base.h>
\n
42
\n-
43#include <maloc/vsys.h>
\n+
43#include <maloc/vsys.h>
\n
44
\n
45/*
\n
46 * ***************************************************************************
\n
47 * Class Vmpi: Parameters and datatypes
\n
48 * ***************************************************************************
\n
49 */
\n
50
\n@@ -108,15 +108,15 @@\n
197int Vmpi_reduce(Vmpi *thee, char *sbuf, char *rbuf, int bufsize);
\n
198
\n
210int Vmpi_isend(Vmpi *thee, int des, char *buf, int bufsize);
\n
211
\n
212#endif /* _VMPI_H_ */
\n
213
\n
The base (or foundation) header for MALOC.
\n-
The primary header for VSYS. (Virtual SYStem utilities library.)
\n+
The primary header for VSYS. (Virtual SYStem utilities library.)
\n
int Vmpi_init(int *argc, char ***argv)
The Vmp initializer.
\n
int Vmpi_finalize(void)
The Vmp finalizer.
\n
int Vmpi_size(Vmpi *thee)
Return the number of processors involved.
\n
int Vmpi_reduce(Vmpi *thee, char *sbuf, char *rbuf, int bufsize)
An MPI reduce.
\n
int Vmpi_recv(Vmpi *thee, int src, char *buf, int bufsize)
An MPI blocking receive.
\n
int Vmpi_isend(Vmpi *thee, int des, char *buf, int bufsize)
An MPI non-blocking send.
\n
void Vmpi_dtor(Vmpi **thee)
The Vmpi destructor.
\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00015.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00015.dot.gz", "unified_diff": null, "details": [{"source1": "a00015.dot", "source2": "a00015.dot", "unified_diff": "@@ -34,28 +34,28 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node19 [id=\"edge19_Node000018_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node20 [id=\"edge21_Node000018_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node20 [id=\"Node000020\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node21 [id=\"edge23_Node000018_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node21 -> Node2 [id=\"edge24_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node21 -> Node19 [id=\"edge25_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node22 [id=\"edge26_Node000018_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 [id=\"Node000022\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node22 -> Node2 [id=\"edge27_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node19 [id=\"edge28_Node000022_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node20 [id=\"edge29_Node000022_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node23 [id=\"edge30_Node000018_Node000023\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node23 -> Node2 [id=\"edge31_Node000023_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00016.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00016.dot", "unified_diff": "@@ -2,13 +2,13 @@\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n Node1 [id=\"Node000001\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node2 [id=\"Node000002\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node3 -> Node4 [id=\"edge3_Node000003_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00017.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00017.html", "unified_diff": "@@ -50,15 +50,15 @@\n
vsh.h File Reference
\n
\n
\n \n

Header file for vsh, a bourne-compatible shell. \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vsys.h>
\n+#include <maloc/vsys.h>
\n
\n Include dependency graph for vsh.h:
\n
\n
\"\"/
\n
\n
\n This graph shows which files directly or indirectly include this file:
\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00017_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00017_source.html", "unified_diff": "@@ -53,15 +53,15 @@\n
\n Go to the documentation of this file.
1
\n
38#ifndef _VSH_H_
\n
39#define _VSH_H_
\n
40
\n
41#include <maloc/maloc_base.h>
\n
42
\n-
43#include <maloc/vsys.h>
\n+
43#include <maloc/vsys.h>
\n
44
\n
45/*
\n
46 * ***************************************************************************
\n
47 * Class Vsh: Parameters and datatypes
\n
48 * ***************************************************************************
\n
49 */
\n
50
\n@@ -146,15 +146,15 @@\n
296
\n
306void Vsh_ioCleanup(Vsh *thee, Vio **sock);
\n
307
\n
308#endif /* _VSH_H_ */
\n
309
\n
The base (or foundation) header for MALOC.
\n
#define VMAX_ARGLEN
Global constant.
Definition maloc_base.h:227
\n-
The primary header for VSYS. (Virtual SYStem utilities library.)
\n+
The primary header for VSYS. (Virtual SYStem utilities library.)
\n
double Vsh_getenvReal(Vsh *thee, const char *envi)
Get a value of variable in the environment as a real.
\n
int Vsh_putenvInfo(Vsh *thee, const char *envi, const char *valu)
Place a variable with an info string in the environment.
\n
char * Vsh_getenv(Vsh *thee, const char *envi)
Get a value of variable in the environment.
\n
char * Vsh_getenvInfo(Vsh *thee, const char *envi)
Get info associated with a variable in the environment.
\n
int Vsh_putenv(Vsh *thee, const char *envi, const char *valu)
Place a variable with a value in the environment.
\n
void Vsh_ioCleanup(Vsh *thee, Vio **sock)
Cleanup an I/O command.
\n
int Vsh_getenvInt(Vsh *thee, const char *envi)
Get a value of variable in the environment as an integer.
\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00018.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00018.dot.gz", "unified_diff": null, "details": [{"source1": "a00018.dot", "source2": "a00018.dot", "unified_diff": "@@ -34,28 +34,28 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node19 [id=\"edge19_Node000018_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node20 [id=\"edge21_Node000018_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node20 [id=\"Node000020\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node21 [id=\"edge23_Node000018_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node21 -> Node2 [id=\"edge24_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node21 -> Node19 [id=\"edge25_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node22 [id=\"edge26_Node000018_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 [id=\"Node000022\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node22 -> Node2 [id=\"edge27_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node19 [id=\"edge28_Node000022_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node20 [id=\"edge29_Node000022_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node23 [id=\"edge30_Node000018_Node000023\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node23 -> Node2 [id=\"edge31_Node000023_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00019.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00019.dot", "unified_diff": "@@ -4,10 +4,10 @@\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n Node1 [id=\"Node000001\",label=\"vsh.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n Node1 -> Node3 [id=\"edge2_Node000001_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node3 -> Node2 [id=\"edge3_Node000003_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00020.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00020.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vsys.h File Reference\n+MALOC: vpred.h File Reference\n \n \n \n \n \n \n
\n@@ -39,43 +39,105 @@\n
\n
\n \n
\n
\n
\n-
vsys.h File Reference
\n+ \n+
vpred.h File Reference
\n
\n
\n \n-

The primary header for VSYS. (Virtual SYStem utilities library.) \n+

Header file for the Geometric Predicates. \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vnm.h>
\n-#include <maloc/vmem.h>
\n-#include <maloc/vio.h>
\n-#include <maloc/vset.h>
\n-#include <maloc/vpred.h>
\n
\n-Include dependency graph for vsys.h:
\n+Include dependency graph for vpred.h:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n This graph shows which files directly or indirectly include this file:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n

Go to the source code of this file.

\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+

\n+Macros

#define INEXACT   /* Nothing */
 Parameters and constants \"INEXACT\".
 
#define REAL   double
 float or double
 
#define REALPRINT   doubleprint
 Print the bit representation of a double.
 
#define REALRAND   doublerand
 Generate a double with random 53-bit significand and a random exponent in [0, 511].
 
#define NARROWRAND   narrowdoublerand
 Generate a double with random 53-bit significand and a random exponent in [0, 7].
 
#define UNIFORMRAND   uniformdoublerand
 Generate a double with random 53-bit significand.
 
\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+

\n+Functions

void Vpred_exactinit (void)
 Initialize the variables used for exact arithmetic.
 
REAL Vpred_orient2d (REAL *pa, REAL *pb, REAL *pc)
 Adaptive exact 2D orientation test. Robust.
 
REAL Vpred_orient2dfast (REAL *pa, REAL *pb, REAL *pc)
 Approximate 2D orientation test. Nonrobust.
 
REAL Vpred_orient2dexact (REAL *pa, REAL *pb, REAL *pc)
 Exact 2D orientation test. Robust.
 
REAL Vpred_orient3d (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
 Adaptive exact 3D orientation test. Robust.
 
REAL Vpred_orient3dfast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
 Approximate 3D orientation test. Nonrobust.
 
REAL Vpred_orient3dexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
 Exact 3D orientation test. Robust.
 
REAL Vpred_incircle (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
 Adaptive exact 2D incircle test. Robust.
 
REAL Vpred_incirclefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
 Approximate 2D incircle test. Nonrobust.
 
REAL Vpred_incircleexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
 Exact 2D incircle test. Robust.
 
REAL Vpred_insphere (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
 Adaptive exact 3D insphere test. Robust.
 
REAL Vpred_inspherefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
 Approximate 3D insphere test. Nonrobust.
 
REAL Vpred_insphereexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
 Exact 3D insphere test. Robust.
 
\n

Detailed Description

\n-

The primary header for VSYS. (Virtual SYStem utilities library.)

\n-
Author
Michael Holst
\n+

Header file for the Geometric Predicates.

\n
Version
\n-
Id
vsys.h,v 1.12 2010/08/12 05:40:37 fetk Exp
\n+
Id
vpred.h,v 1.4 2010/08/12 05:40:37 fetk Exp
\n+
Author
Michael Holst
\n
Attention
*\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n@@ -87,14 +149,757 @@\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n * \n *  
\n-
\n+

Macro Definition Documentation

\n+\n+

◆ INEXACT

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+
#define INEXACT   /* Nothing */
\n+
\n+\n+

Parameters and constants \"INEXACT\".

\n+\n+
\n+
\n+\n+

◆ NARROWRAND

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+
#define NARROWRAND   narrowdoublerand
\n+
\n+\n+

Generate a double with random 53-bit significand and a random exponent in [0, 7].

\n+\n+
\n+
\n+\n+

◆ REAL

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+
#define REAL   double
\n+
\n+\n+

float or double

\n+\n+
\n+
\n+\n+

◆ REALPRINT

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+
#define REALPRINT   doubleprint
\n+
\n+\n+

Print the bit representation of a double.

\n+\n+
\n+
\n+\n+

◆ REALRAND

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+
#define REALRAND   doublerand
\n+
\n+\n+

Generate a double with random 53-bit significand and a random exponent in [0, 511].

\n+\n+
\n+
\n+\n+

◆ UNIFORMRAND

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+
#define UNIFORMRAND   uniformdoublerand
\n+
\n+\n+

Generate a double with random 53-bit significand.

\n+\n+
\n+
\n+

Function Documentation

\n+\n+

◆ Vpred_exactinit()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
void Vpred_exactinit (void )
\n+
\n+\n+

Initialize the variables used for exact arithmetic.

\n+
Note
‘epsilon’ is the largest power of two such that 1.0 + epsilon = 1.0 in floating-point arithmetic. ‘epsilon’ bounds the relative roundoff error. It is used for floating-point error analysis. ‘splitter’ is used to split floating-point numbers into two half- length significands for exact multiplication. I imagine that a highly optimizing compiler might be too smart for its own good, and somehow cause this routine to fail, if it pretends that floating-point arithmetic is too much like real arithmetic. Don't change this routine unless you fully understand it.
\n+\n+
\n+
\n+\n+

◆ Vpred_incircle()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_incircle (REALpa,
REALpb,
REALpc,
REALpd 
)
\n+
\n+\n+

Adaptive exact 2D incircle test. Robust.

\n+
Returns
a positive value if the point pd lies inside the circle passing through pa, pb, and pc; a negative value if it lies outside; and zero if the four points are cocircular. The points pa, pb, and pc must be in counterclockwise order, or the sign of the result will be reversed.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_incircleexact()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_incircleexact (REALpa,
REALpb,
REALpc,
REALpd 
)
\n+
\n+\n+

Exact 2D incircle test. Robust.

\n+
Returns
a positive value if the point pd lies inside the circle passing through pa, pb, and pc; a negative value if it lies outside; and zero if the four points are cocircular. The points pa, pb, and pc must be in counterclockwise order, or the sign of the result will be reversed.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_incirclefast()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_incirclefast (REALpa,
REALpb,
REALpc,
REALpd 
)
\n+
\n+\n+

Approximate 2D incircle test. Nonrobust.

\n+
Returns
a positive value if the point pd lies inside the circle passing through pa, pb, and pc; a negative value if it lies outside; and zero if the four points are cocircular. The points pa, pb, and pc must be in counterclockwise order, or the sign of the result will be reversed.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_insphere()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_insphere (REALpa,
REALpb,
REALpc,
REALpd,
REALpe 
)
\n+
\n+\n+

Adaptive exact 3D insphere test. Robust.

\n+
Returns
a positive value if the point pe lies inside the sphere passing through pa, pb, pc, and pd; a negative value if it lies outside; and zero if the five points are cospherical. The points pa, pb, pc, and pd must be ordered so that they have a positive orientation (as defined by orient3d()), or the sign of the result will be reversed.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
pePointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_insphereexact()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_insphereexact (REALpa,
REALpb,
REALpc,
REALpd,
REALpe 
)
\n+
\n+\n+

Exact 3D insphere test. Robust.

\n+
Returns
a positive value if the point pe lies inside the sphere passing through pa, pb, pc, and pd; a negative value if it lies outside; and zero if the five points are cospherical. The points pa, pb, pc, and pd must be ordered so that they have a positive orientation (as defined by orient3d()), or the sign of the result will be reversed.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
pePointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_inspherefast()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_inspherefast (REALpa,
REALpb,
REALpc,
REALpd,
REALpe 
)
\n+
\n+\n+

Approximate 3D insphere test. Nonrobust.

\n+
Returns
a positive value if the point pe lies inside the sphere passing through pa, pb, pc, and pd; a negative value if it lies outside; and zero if the five points are cospherical. The points pa, pb, pc, and pd must be ordered so that they have a positive orientation (as defined by orient3d()), or the sign of the result will be reversed.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
pePointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_orient2d()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_orient2d (REALpa,
REALpb,
REALpc 
)
\n+
\n+\n+

Adaptive exact 2D orientation test. Robust.

\n+
Returns
a positive value if the points pa, pb, and pc occur in counterclockwise order; a negative value if they occur in clockwise order; and zero if they are collinear. The result is also a rough approximation of twice the signed area of the triangle defined by the three points.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_orient2dexact()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_orient2dexact (REALpa,
REALpb,
REALpc 
)
\n+
\n+\n+

Exact 2D orientation test. Robust.

\n+
Returns
a positive value if the points pa, pb, and pc occur in counterclockwise order; a negative value if they occur in clockwise order; and zero if they are collinear. The result is also a rough approximation of twice the signed area of the triangle defined by the three points.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_orient2dfast()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_orient2dfast (REALpa,
REALpb,
REALpc 
)
\n+
\n+\n+

Approximate 2D orientation test. Nonrobust.

\n+
Returns
a positive value if the points pa, pb, and pc occur in counterclockwise order; a negative value if they occur in clockwise order; and zero if they are collinear. The result is also a rough approximation of twice the signed area of the triangle defined by the three points.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_orient3d()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_orient3d (REALpa,
REALpb,
REALpc,
REALpd 
)
\n+
\n+\n+

Adaptive exact 3D orientation test. Robust.

\n+
Returns
a positive value if the point pd lies below the plane passing through pa, pb, and pc; \"below\" is defined so that pa, pb, and pc appear in counterclockwise order when viewed from above the plane. Returns a negative value if pd lies above the plane. Returns zero if the points are coplanar. The result is also a rough approximation of six times the signed volume of the tetrahedron defined by the four points.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_orient3dexact()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_orient3dexact (REALpa,
REALpb,
REALpc,
REALpd 
)
\n+
\n+\n+

Exact 3D orientation test. Robust.

\n+
Returns
a positive value if the point pd lies below the plane passing through pa, pb, and pc; \"below\" is defined so that pa, pb, and pc appear in counterclockwise order when viewed from above the plane. Returns a negative value if pd lies above the plane. Returns zero if the points are coplanar. The result is also a rough approximation of six times the signed volume of the tetrahedron defined by the four points.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+\n+

◆ Vpred_orient3dfast()

\n+\n+
\n+
\n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
REAL Vpred_orient3dfast (REALpa,
REALpb,
REALpc,
REALpd 
)
\n+
\n+\n+

Approximate 3D orientation test. Nonrobust.

\n+
Returns
a positive value if the point pd lies below the plane passing through pa, pb, and pc; \"below\" is defined so that pa, pb, and pc appear in counterclockwise order when viewed from above the plane. Returns a negative value if pd lies above the plane. Returns zero if the points are coplanar. The result is also a rough approximation of six times the signed volume of the tetrahedron defined by the four points.
\n+
Parameters
\n+ \n+ \n+ \n+ \n+ \n+
paPointer to a real parameter
pbPointer to a real parameter
pcPointer to a real parameter
pdPointer to a real parameter
\n+
\n+
\n+\n+
\n+
\n+
\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,33 +3,89 @@\n \n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n-vsys.h File Reference\n-global_maloc_class\n-The primary header for VSYS. (Virtual SYStem utilities library.) More...\n+Macros | Functions\n+vpred.h File Reference\n+Header file for the Geometric Predicates. More...\n #include \n-#include \n-#include \n-#include \n-#include \n-#include \n-Include dependency graph for vsys.h:\n+Include dependency graph for vpred.h:\n This graph shows which files directly or indirectly include this file:\n Go_to_the_source_code_of_this_file.\n+ Macros\n+#define\u00a0INEXACT\u00a0\u00a0\u00a0/* Nothing */\n+\u00a0 Parameters and constants \"INEXACT\".\n+\u00a0\n+#define\u00a0REAL\u00a0\u00a0\u00a0double\n+\u00a0 float or double\n+\u00a0\n+#define\u00a0REALPRINT\u00a0\u00a0\u00a0doubleprint\n+\u00a0 Print the bit representation of a double.\n+\u00a0\n+#define\u00a0REALRAND\u00a0\u00a0\u00a0doublerand\n+\u00a0 Generate a double with random 53-bit significand and a random exponent\n+ in [0, 511].\n+\u00a0\n+#define\u00a0NARROWRAND\u00a0\u00a0\u00a0narrowdoublerand\n+\u00a0 Generate a double with random 53-bit significand and a random exponent\n+ in [0, 7].\n+\u00a0\n+#define\u00a0UNIFORMRAND\u00a0\u00a0\u00a0uniformdoublerand\n+\u00a0 Generate a double with random 53-bit significand.\n+\u00a0\n+ Functions\n+void\u00a0Vpred_exactinit (void)\n+\u00a0 Initialize the variables used for exact arithmetic.\n+\u00a0\n+REAL\u00a0Vpred_orient2d (REAL *pa, REAL *pb, REAL *pc)\n+\u00a0 Adaptive exact 2D orientation test. Robust.\n+\u00a0\n+REAL\u00a0Vpred_orient2dfast (REAL *pa, REAL *pb, REAL *pc)\n+\u00a0 Approximate 2D orientation test. Nonrobust.\n+\u00a0\n+REAL\u00a0Vpred_orient2dexact (REAL *pa, REAL *pb, REAL *pc)\n+\u00a0 Exact 2D orientation test. Robust.\n+\u00a0\n+REAL\u00a0Vpred_orient3d (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+\u00a0 Adaptive exact 3D orientation test. Robust.\n+\u00a0\n+REAL\u00a0Vpred_orient3dfast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+\u00a0 Approximate 3D orientation test. Nonrobust.\n+\u00a0\n+REAL\u00a0Vpred_orient3dexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+\u00a0 Exact 3D orientation test. Robust.\n+\u00a0\n+REAL\u00a0Vpred_incircle (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+\u00a0 Adaptive exact 2D incircle test. Robust.\n+\u00a0\n+REAL\u00a0Vpred_incirclefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+\u00a0 Approximate 2D incircle test. Nonrobust.\n+\u00a0\n+REAL\u00a0Vpred_incircleexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+\u00a0 Exact 2D incircle test. Robust.\n+\u00a0\n+REAL\u00a0Vpred_insphere (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n+\u00a0 Adaptive exact 3D insphere test. Robust.\n+\u00a0\n+REAL\u00a0Vpred_inspherefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n+\u00a0 Approximate 3D insphere test. Nonrobust.\n+\u00a0\n+REAL\u00a0Vpred_insphereexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n+\u00a0 Exact 3D insphere test. Robust.\n+\u00a0\n ***** Detailed Description *****\n-The primary header for VSYS. (Virtual SYStem utilities library.)\n- Author\n- Michael Holst\n+Header file for the Geometric Predicates.\n Version\n Id\n- vsys.h,v 1.12 2010/08/12 05:40:37 fetk Exp\n+ vpred.h,v 1.4 2010/08/12 05:40:37 fetk Exp\n+ Author\n+ Michael Holst\n Attention\n *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n@@ -42,10 +98,257 @@\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n *\n *\n+***** Macro Definition Documentation *****\n+***** \u25c6\u00a0INEXACT *****\n+#define INEXACT\u00a0\u00a0\u00a0/* Nothing */\n+Parameters and constants \"INEXACT\".\n+***** \u25c6\u00a0NARROWRAND *****\n+#define NARROWRAND\u00a0\u00a0\u00a0narrowdoublerand\n+Generate a double with random 53-bit significand and a random exponent in [0,\n+7].\n+***** \u25c6\u00a0REAL *****\n+#define REAL\u00a0\u00a0\u00a0double\n+float or double\n+***** \u25c6\u00a0REALPRINT *****\n+#define REALPRINT\u00a0\u00a0\u00a0doubleprint\n+Print the bit representation of a double.\n+***** \u25c6\u00a0REALRAND *****\n+#define REALRAND\u00a0\u00a0\u00a0doublerand\n+Generate a double with random 53-bit significand and a random exponent in [0,\n+511].\n+***** \u25c6\u00a0UNIFORMRAND *****\n+#define UNIFORMRAND\u00a0\u00a0\u00a0uniformdoublerand\n+Generate a double with random 53-bit significand.\n+***** Function Documentation *****\n+***** \u25c6\u00a0Vpred_exactinit() *****\n+void Vpred_exactinit ( void\u00a0 )\n+Initialize the variables used for exact arithmetic.\n+ Note\n+ \u2018epsilon\u2019 is the largest power of two such that 1.0 + epsilon = 1.0 in\n+ floating-point arithmetic. \u2018epsilon\u2019 bounds the relative roundoff error.\n+ It is used for floating-point error analysis. \u2018splitter\u2019 is used to split\n+ floating-point numbers into two half- length significands for exact\n+ multiplication. I imagine that a highly optimizing compiler might be too\n+ smart for its own good, and somehow cause this routine to fail, if it\n+ pretends that floating-point arithmetic is too much like real arithmetic.\n+ Don't change this routine unless you fully understand it.\n+***** \u25c6\u00a0Vpred_incircle() *****\n+REAL Vpred_incircle ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd\u00a0\n+ )\n+Adaptive exact 2D incircle test. Robust.\n+ Returns\n+ a positive value if the point pd lies inside the circle passing through\n+ pa, pb, and pc; a negative value if it lies outside; and zero if the four\n+ points are cocircular. The points pa, pb, and pc must be in\n+ counterclockwise order, or the sign of the result will be reversed.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_incircleexact() *****\n+REAL Vpred_incircleexact ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd\u00a0\n+ )\n+Exact 2D incircle test. Robust.\n+ Returns\n+ a positive value if the point pd lies inside the circle passing through\n+ pa, pb, and pc; a negative value if it lies outside; and zero if the four\n+ points are cocircular. The points pa, pb, and pc must be in\n+ counterclockwise order, or the sign of the result will be reversed.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_incirclefast() *****\n+REAL Vpred_incirclefast ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd\u00a0\n+ )\n+Approximate 2D incircle test. Nonrobust.\n+ Returns\n+ a positive value if the point pd lies inside the circle passing through\n+ pa, pb, and pc; a negative value if it lies outside; and zero if the four\n+ points are cocircular. The points pa, pb, and pc must be in\n+ counterclockwise order, or the sign of the result will be reversed.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_insphere() *****\n+REAL Vpred_insphere ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd,\n+ REAL *\u00a0pe\u00a0\n+ )\n+Adaptive exact 3D insphere test. Robust.\n+ Returns\n+ a positive value if the point pe lies inside the sphere passing through\n+ pa, pb, pc, and pd; a negative value if it lies outside; and zero if the\n+ five points are cospherical. The points pa, pb, pc, and pd must be\n+ ordered so that they have a positive orientation (as defined by orient3d\n+ ()), or the sign of the result will be reversed.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+ pe Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_insphereexact() *****\n+REAL Vpred_insphereexact ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd,\n+ REAL *\u00a0pe\u00a0\n+ )\n+Exact 3D insphere test. Robust.\n+ Returns\n+ a positive value if the point pe lies inside the sphere passing through\n+ pa, pb, pc, and pd; a negative value if it lies outside; and zero if the\n+ five points are cospherical. The points pa, pb, pc, and pd must be\n+ ordered so that they have a positive orientation (as defined by orient3d\n+ ()), or the sign of the result will be reversed.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+ pe Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_inspherefast() *****\n+REAL Vpred_inspherefast ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd,\n+ REAL *\u00a0pe\u00a0\n+ )\n+Approximate 3D insphere test. Nonrobust.\n+ Returns\n+ a positive value if the point pe lies inside the sphere passing through\n+ pa, pb, pc, and pd; a negative value if it lies outside; and zero if the\n+ five points are cospherical. The points pa, pb, pc, and pd must be\n+ ordered so that they have a positive orientation (as defined by orient3d\n+ ()), or the sign of the result will be reversed.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+ pe Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_orient2d() *****\n+REAL Vpred_orient2d ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc\u00a0\n+ )\n+Adaptive exact 2D orientation test. Robust.\n+ Returns\n+ a positive value if the points pa, pb, and pc occur in counterclockwise\n+ order; a negative value if they occur in clockwise order; and zero if\n+ they are collinear. The result is also a rough approximation of twice the\n+ signed area of the triangle defined by the three points.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_orient2dexact() *****\n+REAL Vpred_orient2dexact ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc\u00a0\n+ )\n+Exact 2D orientation test. Robust.\n+ Returns\n+ a positive value if the points pa, pb, and pc occur in counterclockwise\n+ order; a negative value if they occur in clockwise order; and zero if\n+ they are collinear. The result is also a rough approximation of twice the\n+ signed area of the triangle defined by the three points.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_orient2dfast() *****\n+REAL Vpred_orient2dfast ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc\u00a0\n+ )\n+Approximate 2D orientation test. Nonrobust.\n+ Returns\n+ a positive value if the points pa, pb, and pc occur in counterclockwise\n+ order; a negative value if they occur in clockwise order; and zero if\n+ they are collinear. The result is also a rough approximation of twice the\n+ signed area of the triangle defined by the three points.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_orient3d() *****\n+REAL Vpred_orient3d ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd\u00a0\n+ )\n+Adaptive exact 3D orientation test. Robust.\n+ Returns\n+ a positive value if the point pd lies below the plane passing through pa,\n+ pb, and pc; \"below\" is defined so that pa, pb, and pc appear in\n+ counterclockwise order when viewed from above the plane. Returns a\n+ negative value if pd lies above the plane. Returns zero if the points are\n+ coplanar. The result is also a rough approximation of six times the\n+ signed volume of the tetrahedron defined by the four points.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_orient3dexact() *****\n+REAL Vpred_orient3dexact ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd\u00a0\n+ )\n+Exact 3D orientation test. Robust.\n+ Returns\n+ a positive value if the point pd lies below the plane passing through pa,\n+ pb, and pc; \"below\" is defined so that pa, pb, and pc appear in\n+ counterclockwise order when viewed from above the plane. Returns a\n+ negative value if pd lies above the plane. Returns zero if the points are\n+ coplanar. The result is also a rough approximation of six times the\n+ signed volume of the tetrahedron defined by the four points.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n+***** \u25c6\u00a0Vpred_orient3dfast() *****\n+REAL Vpred_orient3dfast ( REAL *\u00a0pa,\n+ REAL *\u00a0pb,\n+ REAL *\u00a0pc,\n+ REAL *\u00a0pd\u00a0\n+ )\n+Approximate 3D orientation test. Nonrobust.\n+ Returns\n+ a positive value if the point pd lies below the plane passing through pa,\n+ pb, and pc; \"below\" is defined so that pa, pb, and pc appear in\n+ counterclockwise order when viewed from above the plane. Returns a\n+ negative value if pd lies above the plane. Returns zero if the points are\n+ coplanar. The result is also a rough approximation of six times the\n+ signed volume of the tetrahedron defined by the four points.\n+ Parameters\n+ pa Pointer to a real parameter\n+ pb Pointer to a real parameter\n+ pc Pointer to a real parameter\n+ pd Pointer to a real parameter\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00020_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00020_source.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vsys.h Source File\n+MALOC: vpred.h Source File\n \n \n \n \n \n \n
\n@@ -44,37 +44,95 @@\n \n
\n \n
\n
\n
\n-
vsys.h
\n+
vpred.h
\n
\n
\n Go to the documentation of this file.
1
\n-
31#ifndef _VSYS_H_
\n-
32#define _VSYS_H_
\n-
33
\n-
34#include <maloc/maloc_base.h>
\n-
35
\n-
36#include <maloc/vnm.h>
\n-
37#include <maloc/vmem.h>
\n-
38#include <maloc/vio.h>
\n-
39#include <maloc/vset.h>
\n-
40#include <maloc/vpred.h>
\n+
30#ifndef _VPRED_H_
\n+
31#define _VPRED_H_
\n+
32
\n+
33#include <maloc/maloc_base.h>
\n+
34
\n+
35/* random() prototype seems to be missing in <stdlib.h> */
\n+
36/*
\n+
37 * if !defined(VOSF1)
\n+
38 * extern long int random(void);
\n+
39 * endif
\n+
40 */
\n
41
\n-
42#endif /* _VSYS_H_ */
\n-
43
\n+
42/* On some machines, the exact arithmetic routines might be defeated by the */
\n+
43/* use of internal extended precision floating-point registers. Sometimes */
\n+
44/* this problem can be fixed by defining certain values to be volatile, */
\n+
45/* thus forcing them to be stored to memory and rounded off. This isn't */
\n+
46/* a great solution, though, as it slows the arithmetic down. */
\n+
47/* */
\n+
48/* To try this out, write "#define INEXACT volatile" below. Normally, */
\n+
49/* however, INEXACT should be defined to be nothing. ("#define INEXACT".) */
\n+
50
\n+
52#define INEXACT /* Nothing */
\n+
53/* #define INEXACT volatile */
\n+
54
\n+
56#define REAL double
\n+
57
\n+
59#define REALPRINT doubleprint
\n+
60
\n+
63#define REALRAND doublerand
\n+
64
\n+
67#define NARROWRAND narrowdoublerand
\n+
68
\n+
70#define UNIFORMRAND uniformdoublerand
\n+
71
\n+
84void Vpred_exactinit(void);
\n+
85
\n+\n+
98
\n+\n+
111
\n+\n+
124
\n+
139REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd);
\n+
140
\n+\n+
156
\n+\n+
172
\n+
185REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd);
\n+
186
\n+\n+
200
\n+\n+
214
\n+
228REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);
\n+
229
\n+
243REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);
\n+
244
\n+
258REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);
\n+
259
\n+
260#endif /* _VPRED_H_ */
\n+
261
\n
The base (or foundation) header for MALOC.
\n-
Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.
\n-
Class Vset: a dynamic set object.
\n-
Class Vmem: A safer, object-oriented, malloc/free object.
\n-
Header file for the Geometric Predicates.
\n-
Header file for an ISO C [V]irtual [N]umerical [M]achine.
\n+
REAL Vpred_orient2d(REAL *pa, REAL *pb, REAL *pc)
Adaptive exact 2D orientation test. Robust.
\n+
REAL Vpred_orient3dfast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
Approximate 3D orientation test. Nonrobust.
\n+
#define REAL
float or double
Definition vpred.h:56
\n+
REAL Vpred_orient3dexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
Exact 3D orientation test. Robust.
\n+
REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
Approximate 3D insphere test. Nonrobust.
\n+
REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
Adaptive exact 3D orientation test. Robust.
\n+
REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
Exact 3D insphere test. Robust.
\n+
void Vpred_exactinit(void)
Initialize the variables used for exact arithmetic.
\n+
REAL Vpred_incircleexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
Exact 2D incircle test. Robust.
\n+
REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
Adaptive exact 3D insphere test. Robust.
\n+
REAL Vpred_orient2dfast(REAL *pa, REAL *pb, REAL *pc)
Approximate 2D orientation test. Nonrobust.
\n+
REAL Vpred_orient2dexact(REAL *pa, REAL *pb, REAL *pc)
Exact 2D orientation test. Robust.
\n+
REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
Adaptive exact 2D incircle test. Robust.
\n+
REAL Vpred_incirclefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
Approximate 2D incircle test. Nonrobust.
\n
\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,38 +3,121 @@\n \n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n-vsys.h\n+vpred.h\n Go_to_the_documentation_of_this_file.\n 1\n- 31#ifndef _VSYS_H_\n- 32#define _VSYS_H_\n- 33\n- 34#include \n- 35\n- 36#include \n- 37#include \n- 38#include \n- 39#include \n- 40#include \n+ 30#ifndef _VPRED_H_\n+ 31#define _VPRED_H_\n+ 32\n+ 33#include \n+ 34\n+ 35/* random() prototype seems to be missing in */\n+ 36/*\n+ 37 * if !defined(VOSF1)\n+ 38 * extern long int random(void);\n+ 39 * endif\n+ 40 */\n 41\n- 42#endif /* _VSYS_H_ */\n- 43\n+ 42/* On some machines, the exact arithmetic routines might be defeated by the\n+*/\n+ 43/* use of internal extended precision floating-point registers. Sometimes */\n+ 44/* this problem can be fixed by defining certain values to be volatile, */\n+ 45/* thus forcing them to be stored to memory and rounded off. This isn't */\n+ 46/* a great solution, though, as it slows the arithmetic down. */\n+ 47/* */\n+ 48/* To try this out, write \"#define INEXACT volatile\" below. Normally, */\n+ 49/* however, INEXACT should be defined to be nothing. (\"#define INEXACT\".) */\n+ 50\n+52#define INEXACT /* Nothing */\n+ 53/* #define INEXACT volatile */\n+ 54\n+56#define REAL double\n+ 57\n+59#define REALPRINT doubleprint\n+ 60\n+63#define REALRAND doublerand\n+ 64\n+67#define NARROWRAND narrowdoublerand\n+ 68\n+70#define UNIFORMRAND uniformdoublerand\n+ 71\n+84void Vpred_exactinit(void);\n+ 85\n+97REAL Vpred_orient2d(REAL *pa, REAL *pb, REAL *pc);\n+ 98\n+110REAL Vpred_orient2dfast(REAL *pa, REAL *pb, REAL *pc);\n+ 111\n+123REAL Vpred_orient2dexact(REAL *pa, REAL *pb, REAL *pc);\n+ 124\n+139REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n+ 140\n+155REAL Vpred_orient3dfast(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n+ 156\n+171REAL Vpred_orient3dexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n+ 172\n+185REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n+ 186\n+199REAL Vpred_incirclefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n+ 200\n+213REAL Vpred_incircleexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n+ 214\n+228REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);\n+ 229\n+243REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);\n+ 244\n+258REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);\n+ 259\n+ 260#endif /* _VPRED_H_ */\n+ 261\n maloc_base.h\n The base (or foundation) header for MALOC.\n-vio.h\n-Class Vio: virtual I/O layer.\n-vset.h\n-Class Vset: a dynamic set object.\n-vmem.h\n-Class Vmem: A safer, object-oriented, malloc/free object.\n-vpred.h\n-Header file for the Geometric Predicates.\n-vnm.h\n-Header file for an ISO C [V]irtual [N]umerical [M]achine.\n+Vpred_orient2d\n+REAL Vpred_orient2d(REAL *pa, REAL *pb, REAL *pc)\n+Adaptive exact 2D orientation test. Robust.\n+Vpred_orient3dfast\n+REAL Vpred_orient3dfast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+Approximate 3D orientation test. Nonrobust.\n+REAL\n+#define REAL\n+float or double\n+Definition vpred.h:56\n+Vpred_orient3dexact\n+REAL Vpred_orient3dexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+Exact 3D orientation test. Robust.\n+Vpred_inspherefast\n+REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n+Approximate 3D insphere test. Nonrobust.\n+Vpred_orient3d\n+REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+Adaptive exact 3D orientation test. Robust.\n+Vpred_insphereexact\n+REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n+Exact 3D insphere test. Robust.\n+Vpred_exactinit\n+void Vpred_exactinit(void)\n+Initialize the variables used for exact arithmetic.\n+Vpred_incircleexact\n+REAL Vpred_incircleexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+Exact 2D incircle test. Robust.\n+Vpred_insphere\n+REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n+Adaptive exact 3D insphere test. Robust.\n+Vpred_orient2dfast\n+REAL Vpred_orient2dfast(REAL *pa, REAL *pb, REAL *pc)\n+Approximate 2D orientation test. Nonrobust.\n+Vpred_orient2dexact\n+REAL Vpred_orient2dexact(REAL *pa, REAL *pb, REAL *pc)\n+Exact 2D orientation test. Robust.\n+Vpred_incircle\n+REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+Adaptive exact 2D incircle test. Robust.\n+Vpred_incirclefast\n+REAL Vpred_incirclefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n+Approximate 2D incircle test. Nonrobust.\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00021.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00021.dot.gz", "unified_diff": null, "details": [{"source1": "a00021.dot", "source2": "a00021.dot", "unified_diff": "@@ -1,14 +1,14 @@\n-digraph \"vsys.h\"\n+digraph \"vpred.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vsys.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node1 [id=\"Node000001\",label=\"vpred.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc/maloc_base.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00002.html\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"assert.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"ctype.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge4_Node000002_Node000005\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n@@ -33,26 +33,8 @@\n Node14 [id=\"Node000014\",label=\"stdlib.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n- Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n- Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node19 [id=\"edge19_Node000001_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node19 [id=\"Node000019\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n- Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node20 [id=\"edge21_Node000001_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node20 [id=\"Node000020\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n- Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node20 -> Node18 [id=\"edge23_Node000020_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node21 [id=\"edge24_Node000001_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 [id=\"Node000021\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n- Node21 -> Node2 [id=\"edge25_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 -> Node18 [id=\"edge26_Node000021_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 -> Node19 [id=\"edge27_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node22 [id=\"edge28_Node000001_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node22 [id=\"Node000022\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n- Node22 -> Node2 [id=\"edge29_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00022.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00022.dot", "unified_diff": "@@ -1,26 +1,28 @@\n-digraph \"vsys.h\"\n+digraph \"vpred.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vsys.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node1 [id=\"Node000001\",label=\"vpred.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n- Node1 -> Node3 [id=\"edge2_Node000001_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n- Node3 -> Node2 [id=\"edge3_Node000003_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node4 [id=\"edge4_Node000001_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node4 [id=\"Node000004\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n- Node4 -> Node5 [id=\"edge5_Node000004_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node5 [id=\"Node000005\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n- Node5 -> Node3 [id=\"edge6_Node000005_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node5 [id=\"edge7_Node000001_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node6 [id=\"edge8_Node000001_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node6 [id=\"Node000006\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n- Node6 -> Node5 [id=\"edge9_Node000006_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node7 [id=\"edge10_Node000001_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node7 [id=\"Node000007\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n- Node7 -> Node2 [id=\"edge11_Node000007_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node7 -> Node3 [id=\"edge12_Node000007_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 [id=\"Node000002\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 [id=\"Node000003\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n+ Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node4 [id=\"Node000004\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node4 -> Node3 [id=\"edge4_Node000004_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node5 [id=\"edge5_Node000002_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node5 [id=\"Node000005\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node5 -> Node6 [id=\"edge6_Node000005_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node6 [id=\"Node000006\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node6 -> Node4 [id=\"edge7_Node000006_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node6 [id=\"edge8_Node000002_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node7 [id=\"edge9_Node000002_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node7 [id=\"Node000007\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n+ Node7 -> Node6 [id=\"edge10_Node000007_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node8 [id=\"edge11_Node000002_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node8 [id=\"Node000008\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n+ Node8 -> Node3 [id=\"edge12_Node000008_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node8 -> Node4 [id=\"edge13_Node000008_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00023.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00023.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vio.h File Reference\n+MALOC: vsys.h File Reference\n \n \n \n \n \n \n
\n@@ -39,169 +39,43 @@\n
\n
\n \n
\n
\n
\n- \n-
vio.h File Reference
\n+
vsys.h File Reference
\n
\n
\n \n-

Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer. \n+

The primary header for VSYS. (Virtual SYStem utilities library.) \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vnm.h>
\n+#include <maloc/vnm.h>
\n+#include <maloc/vmem.h>
\n+#include <maloc/vio.h>
\n+#include <maloc/vset.h>
\n+#include <maloc/vpred.h>
\n
\n-Include dependency graph for vio.h:
\n+Include dependency graph for vsys.h:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n This graph shows which files directly or indirectly include this file:
\n
\n-
\"\"/
\n+
\"\"/
\n
\n
\n

Go to the source code of this file.

\n-\n-\n-\n-\n-\n-

\n-Classes

struct  sVio
 Contains public data members for Vio class. More...
 
\n-\n-\n-\n-\n-\n-\n-\n-

\n-Macros

#define VPORTNUMBER   14916
 our portbase; 5000 < VPORTNUMBER < 49152
 
#define VIO_MAXBUF   10
 number of internal buffers (BUFF datatype)
 
\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-

\n-Typedefs

typedef enum VIOtype VIOtype
 Parameter for I/O type (sdio,buff,file,unix,inet)
 
typedef enum VIOfrmt VIOfrmt
 Parameter for compression type (XDR,ASC)
 
typedef enum VIOrwkey VIOrwkey
 Parameter for rw type (R,RW)
 
typedef struct sVio Vio
 Declaration of the Vio class as the Vio structure.
 
\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-

\n-Enumerations

enum  VIOtype {
\n-  VIO_NO_TYPE\n-, VIO_SDIO\n-, VIO_BUFF\n-, VIO_FILE\n-,
\n-  VIO_UNIX\n-, VIO_INET\n-
\n- }
 Parameter for I/O type (sdio,buff,file,unix,inet) More...
 
enum  VIOfrmt { VIO_NO_FRMT\n-, VIO_XDR\n-, VIO_ASC\n- }
 Parameter for compression type (XDR,ASC) More...
 
enum  VIOrwkey { VIO_NO_RW\n-, VIO_R\n-, VIO_W\n- }
 Parameter for rw type (R,RW) More...
 
\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-

\n-Functions

void Vio_start (void)
 Start Vio communication layer (init internal variables/buffers)
 
void Vio_stop (void)
 Shutdown Vio communication layer.
 
VioVio_ctor (const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
 Construct the Vio object.
 
int Vio_ctor2 (Vio *thee, const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
 Work routine that Vio_ctor calls to do most of the construction.
 
void Vio_dtor (Vio **thee)
 Destruct the Vio object.
 
void Vio_dtor2 (Vio *thee)
 Work routine that Vio_dtor calls to do most of the destruction.
 
void Vio_setWhiteChars (Vio *thee, char *whiteChars)
 Set the white character set for I/O stream.
 
void Vio_setCommChars (Vio *thee, char *commChars)
 Set the comment character set for I/O stream.
 
int Vio_accept (Vio *thee, int nonblock)
 Accept any waiting connect attempt to our socket on our machine.
 
void Vio_acceptFree (Vio *thee)
 Free the socket child that was used for the last accept.
 
int Vio_connect (Vio *thee, int nonblock)
 Connect to some socket on a remote machine (or on our machine)
 
void Vio_connectFree (Vio *thee)
 Purge any output buffers (for <UNIX/INET>, else a no-op)
 
int Vio_scanf (Vio *thee, char *parms,...)
 Mimic \"scanf\" from an arbitrary Vio device.
 
int Vio_printf (Vio *thee, char *parms,...)
 Mimic \"printf\" from an arbitrary Vio device.
 
int Vio_read (Vio *thee, char *buf, int bufsize)
 Read (up to) bufsize characters into buf from input device.
 
int Vio_write (Vio *thee, char *buf, int bufsize)
 Write bufsize characters from buf to output device.
 
void Vio_bufTake (Vio *thee, char *buf, int bufsize)
 Set the pointer to the internal buffer.
 
char * Vio_bufGive (Vio *thee)
 Return the pointer to the internal buffer.
 
int Vio_bufSize (Vio *thee)
 Return the length to the internal buffer.
 
VioVio_socketOpen (char *key, const char *iodev, const char *iofmt, const char *iohost, const char *iofile)
 Socket open for read or write.
 
void Vio_socketClose (Vio **sock)
 Socket close from read or write.
 
\n

Detailed Description

\n-

Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.

\n+

The primary header for VSYS. (Virtual SYStem utilities library.)

\n+
Author
Michael Holst
\n
Version
\n-
Id
vio.h,v 1.28 2010/08/12 05:40:35 fetk Exp
\n-
Author
Michael Holst
\n+
Id
vsys.h,v 1.12 2010/08/12 05:40:37 fetk Exp
\n
Attention
*\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n@@ -212,48 +86,15 @@\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n * \n-* 
\n-

Macro Definition Documentation

\n-\n-

◆ VIO_MAXBUF

\n-\n-
\n-
\n- \n- \n- \n- \n-
#define VIO_MAXBUF   10
\n-
\n-\n-

number of internal buffers (BUFF datatype)

\n-\n-
\n-
\n-\n-

◆ VPORTNUMBER

\n-\n-
\n-
\n- \n- \n- \n- \n-
#define VPORTNUMBER   14916
\n-
\n-\n-

our portbase; 5000 < VPORTNUMBER < 49152

\n-\n-
\n-
\n-
\n+* \n+
\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,134 +3,33 @@\n \n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n-Classes | Macros | Typedefs | Enumerations | Functions\n-vio.h File Reference\n-Vio_class\n-Class Vio: virtual I/O layer. More...\n+vsys.h File Reference\n+global_maloc_class\n+The primary header for VSYS. (Virtual SYStem utilities library.) More...\n #include \n #include \n-Include dependency graph for vio.h:\n+#include \n+#include \n+#include \n+#include \n+Include dependency graph for vsys.h:\n This graph shows which files directly or indirectly include this file:\n Go_to_the_source_code_of_this_file.\n- Classes\n-struct \u00a0sVio\n-\u00a0 Contains public data members for Vio class. More...\n-\u00a0\n- Macros\n-#define\u00a0VPORTNUMBER\u00a0\u00a0\u00a014916\n-\u00a0 our portbase; 5000 < VPORTNUMBER < 49152\n-\u00a0\n-#define\u00a0VIO_MAXBUF\u00a0\u00a0\u00a010\n-\u00a0 number of internal buffers (BUFF datatype)\n-\u00a0\n- Typedefs\n- typedef enum VIOtype\u00a0VIOtype\n-\u00a0 Parameter for I/O type (sdio,buff,file,unix,inet)\n-\u00a0\n- typedef enum VIOfrmt\u00a0VIOfrmt\n-\u00a0 Parameter for compression type (XDR,ASC)\n-\u00a0\n-typedef enum VIOrwkey\u00a0VIOrwkey\n-\u00a0 Parameter for rw type (R,RW)\n-\u00a0\n- typedef struct sVio\u00a0Vio\n-\u00a0 Declaration of the Vio class as the Vio structure.\n-\u00a0\n- Enumerations\n-enum \u00a0VIOtype {\n- \u00a0\u00a0VIO_NO_TYPE , VIO_SDIO , VIO_BUFF , VIO_FILE ,\n- \u00a0\u00a0VIO_UNIX , VIO_INET\n- }\n-\u00a0 Parameter for I/O type (sdio,buff,file,unix,inet) More...\n-\u00a0\n-enum \u00a0VIOfrmt { VIO_NO_FRMT , VIO_XDR , VIO_ASC }\n-\u00a0 Parameter for compression type (XDR,ASC) More...\n-\u00a0\n-enum \u00a0VIOrwkey { VIO_NO_RW , VIO_R , VIO_W }\n-\u00a0 Parameter for rw type (R,RW) More...\n-\u00a0\n- Functions\n- void\u00a0Vio_start (void)\n-\u00a0 Start Vio communication layer (init internal variables/buffers)\n-\u00a0\n- void\u00a0Vio_stop (void)\n-\u00a0 Shutdown Vio communication layer.\n-\u00a0\n- Vio *\u00a0Vio_ctor (const char *socktype, const char *datafrmt, const char\n- *hostname, const char *filename, const char *rwkey)\n-\u00a0 Construct the Vio object.\n-\u00a0\n- int\u00a0Vio_ctor2 (Vio *thee, const char *socktype, const char *datafrmt, const\n- char *hostname, const char *filename, const char *rwkey)\n-\u00a0 Work routine that Vio_ctor calls to do most of the construction.\n-\u00a0\n- void\u00a0Vio_dtor (Vio **thee)\n-\u00a0 Destruct the Vio object.\n-\u00a0\n- void\u00a0Vio_dtor2 (Vio *thee)\n-\u00a0 Work routine that Vio_dtor calls to do most of the destruction.\n-\u00a0\n- void\u00a0Vio_setWhiteChars (Vio *thee, char *whiteChars)\n-\u00a0 Set the white character set for I/O stream.\n-\u00a0\n- void\u00a0Vio_setCommChars (Vio *thee, char *commChars)\n-\u00a0 Set the comment character set for I/O stream.\n-\u00a0\n- int\u00a0Vio_accept (Vio *thee, int nonblock)\n-\u00a0 Accept any waiting connect attempt to our socket on our machine.\n-\u00a0\n- void\u00a0Vio_acceptFree (Vio *thee)\n-\u00a0 Free the socket child that was used for the last accept.\n-\u00a0\n- int\u00a0Vio_connect (Vio *thee, int nonblock)\n-\u00a0 Connect to some socket on a remote machine (or on our machine)\n-\u00a0\n- void\u00a0Vio_connectFree (Vio *thee)\n-\u00a0 Purge any output buffers (for , else a no-op)\n-\u00a0\n- int\u00a0Vio_scanf (Vio *thee, char *parms,...)\n-\u00a0 Mimic \"scanf\" from an arbitrary Vio device.\n-\u00a0\n- int\u00a0Vio_printf (Vio *thee, char *parms,...)\n-\u00a0 Mimic \"printf\" from an arbitrary Vio device.\n-\u00a0\n- int\u00a0Vio_read (Vio *thee, char *buf, int bufsize)\n-\u00a0 Read (up to) bufsize characters into buf from input device.\n-\u00a0\n- int\u00a0Vio_write (Vio *thee, char *buf, int bufsize)\n-\u00a0 Write bufsize characters from buf to output device.\n-\u00a0\n- void\u00a0Vio_bufTake (Vio *thee, char *buf, int bufsize)\n-\u00a0 Set the pointer to the internal buffer.\n-\u00a0\n-char *\u00a0Vio_bufGive (Vio *thee)\n-\u00a0 Return the pointer to the internal buffer.\n-\u00a0\n- int\u00a0Vio_bufSize (Vio *thee)\n-\u00a0 Return the length to the internal buffer.\n-\u00a0\n- Vio *\u00a0Vio_socketOpen (char *key, const char *iodev, const char *iofmt, const\n- char *iohost, const char *iofile)\n-\u00a0 Socket open for read or write.\n-\u00a0\n- void\u00a0Vio_socketClose (Vio **sock)\n-\u00a0 Socket close from read or write.\n-\u00a0\n ***** Detailed Description *****\n-Class Vio: virtual I/O layer.\n- Version\n- Id\n- vio.h,v 1.28 2010/08/12 05:40:35 fetk Exp\n+The primary header for VSYS. (Virtual SYStem utilities library.)\n Author\n Michael Holst\n+ Version\n+ Id\n+ vsys.h,v 1.12 2010/08/12 05:40:37 fetk Exp\n Attention\n *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n@@ -143,17 +42,10 @@\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n *\n *\n-***** Macro Definition Documentation *****\n-***** \u25c6\u00a0VIO_MAXBUF *****\n-#define VIO_MAXBUF\u00a0\u00a0\u00a010\n-number of internal buffers (BUFF datatype)\n-***** \u25c6\u00a0VPORTNUMBER *****\n-#define VPORTNUMBER\u00a0\u00a0\u00a014916\n-our portbase; 5000 < VPORTNUMBER < 49152\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00023_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00023_source.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vio.h Source File\n+MALOC: vsys.h Source File\n \n \n \n \n \n \n
\n@@ -44,219 +44,37 @@\n \n
\n \n
\n
\n
\n-
vio.h
\n+
vsys.h
\n
\n
\n Go to the documentation of this file.
1
\n-
39#ifndef _VIO_H_
\n-
40#define _VIO_H_
\n+
31#ifndef _VSYS_H_
\n+
32#define _VSYS_H_
\n+
33
\n+
34#include <maloc/maloc_base.h>
\n+
35
\n+
36#include <maloc/vnm.h>
\n+
37#include <maloc/vmem.h>
\n+
38#include <maloc/vio.h>
\n+
39#include <maloc/vset.h>
\n+
40#include <maloc/vpred.h>
\n
41
\n-
42#include <maloc/maloc_base.h>
\n+
42#endif /* _VSYS_H_ */
\n
43
\n-
44#include <maloc/vnm.h>
\n-
45
\n-
46/*
\n-
47 * ***************************************************************************
\n-
48 * Class Vio: Parameters and datatypes
\n-
49 * ***************************************************************************
\n-
50 */
\n-
51
\n-
53#define VPORTNUMBER 14916
\n-
55#define VIO_MAXBUF 10
\n-
56
\n-
\n-
62typedef enum VIOtype {
\n-\n-\n-\n-\n-\n-\n-\n-
\n-
70
\n-
\n-
76typedef enum VIOfrmt {
\n-\n-\n-\n-\n-
\n-
81
\n-
\n-
87typedef enum VIOrwkey {
\n-\n-\n-
90 VIO_W
\n-\n-
\n-
92
\n-
\n-
98struct sVio {
\n-
99
\n-\n-\n-\n-\n-\n-\n-
122 int error;
\n-
123 int dirty;
\n-
125 FILE *fp;
\n-
126 int so;
\n-
127 int soc;
\n-
128 void *name;
\n-
129 void *axdr;
\n-\n-\n-\n-\n-\n-\n-
140 char *VIObuffer;
\n-\n-\n-
144};
\n-
\n-
145
\n-
151typedef struct sVio Vio;
\n-
152
\n-
153/*
\n-
154 * ***************************************************************************
\n-
155 * Class Vio: Inlineable methods (vio.c)
\n-
156 * ***************************************************************************
\n-
157 */
\n-
158
\n-
159#if !defined(VINLINE_MALOC)
\n-
160#else /* if defined(VINLINE_MALOC) */
\n-
161#endif /* if !defined(VINLINE_MALOC) */
\n-
162
\n-
163/*
\n-
164 * ***************************************************************************
\n-
165 * Class Vio: Non-Inlineable methods (vio.c)
\n-
166 * ***************************************************************************
\n-
167 */
\n-
168
\n-
176void Vio_start(void);
\n-
177
\n-
185void Vio_stop(void);
\n-
186
\n-
199Vio* Vio_ctor(const char *socktype, const char *datafrmt,
\n-
200 const char *hostname, const char *filename, const char *rwkey);
\n-
201
\n-
215int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt,
\n-
216 const char *hostname, const char *filename, const char *rwkey);
\n-
217
\n-
226void Vio_dtor(Vio **thee);
\n-
227
\n-
236void Vio_dtor2(Vio *thee);
\n-
237
\n-\n-
248
\n-
258void Vio_setCommChars(Vio *thee, char *commChars);
\n-
259
\n-
272int Vio_accept(Vio *thee, int nonblock);
\n-
273
\n-
282void Vio_acceptFree(Vio *thee);
\n-
283
\n-
296int Vio_connect(Vio *thee, int nonblock);
\n-
297
\n-\n-
307
\n-
317int Vio_scanf(Vio *thee, char *parms, ...);
\n-
318
\n-
328int Vio_printf(Vio *thee, char *parms, ...);
\n-
329
\n-
340int Vio_read(Vio *thee, char *buf, int bufsize);
\n-
341
\n-
352int Vio_write(Vio *thee, char *buf, int bufsize);
\n-
353
\n-
364void Vio_bufTake(Vio *thee, char *buf, int bufsize);
\n-
365
\n-
374char* Vio_bufGive(Vio *thee);
\n-
375
\n-
384int Vio_bufSize(Vio *thee);
\n-
385
\n-\n-
399 const char *iodev, const char *iofmt,
\n-
400 const char *iohost, const char *iofile);
\n-
401
\n-
410void Vio_socketClose(Vio **sock);
\n-
411
\n-
412#endif /* _VIO_H_ */
\n-
413
\n
The base (or foundation) header for MALOC.
\n-
#define VMAX_ARGNUM
Global constant.
Definition maloc_base.h:225
\n-
#define VMAX_BUFSIZE
Global constant.
Definition maloc_base.h:229
\n-
#define VMAX_ARGLEN
Global constant.
Definition maloc_base.h:227
\n-
Header file for an ISO C [V]irtual [N]umerical [M]achine.
\n-
int Vio_bufSize(Vio *thee)
Return the length to the internal buffer.
\n-
void Vio_stop(void)
Shutdown Vio communication layer.
\n-
int Vio_write(Vio *thee, char *buf, int bufsize)
Write bufsize characters from buf to output device.
\n-
int Vio_scanf(Vio *thee, char *parms,...)
Mimic "scanf" from an arbitrary Vio device.
\n-
void Vio_acceptFree(Vio *thee)
Free the socket child that was used for the last accept.
\n-
void Vio_start(void)
Start Vio communication layer (init internal variables/buffers)
\n-
int Vio_printf(Vio *thee, char *parms,...)
Mimic "printf" from an arbitrary Vio device.
\n-
Vio * Vio_socketOpen(char *key, const char *iodev, const char *iofmt, const char *iohost, const char *iofile)
Socket open for read or write.
\n-
void Vio_setWhiteChars(Vio *thee, char *whiteChars)
Set the white character set for I/O stream.
\n-
void Vio_socketClose(Vio **sock)
Socket close from read or write.
\n-
int Vio_connect(Vio *thee, int nonblock)
Connect to some socket on a remote machine (or on our machine)
\n-
VIOfrmt
Parameter for compression type (XDR,ASC)
Definition vio.h:76
\n-
int Vio_accept(Vio *thee, int nonblock)
Accept any waiting connect attempt to our socket on our machine.
\n-
Vio * Vio_ctor(const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
Construct the Vio object.
\n-
VIOtype
Parameter for I/O type (sdio,buff,file,unix,inet)
Definition vio.h:62
\n-
void Vio_dtor(Vio **thee)
Destruct the Vio object.
\n-
int Vio_read(Vio *thee, char *buf, int bufsize)
Read (up to) bufsize characters into buf from input device.
\n-
void Vio_bufTake(Vio *thee, char *buf, int bufsize)
Set the pointer to the internal buffer.
\n-
void Vio_connectFree(Vio *thee)
Purge any output buffers (for <UNIX/INET>, else a no-op)
\n-
void Vio_setCommChars(Vio *thee, char *commChars)
Set the comment character set for I/O stream.
\n-
char * Vio_bufGive(Vio *thee)
Return the pointer to the internal buffer.
\n-
VIOrwkey
Parameter for rw type (R,RW)
Definition vio.h:87
\n-
void Vio_dtor2(Vio *thee)
Work routine that Vio_dtor calls to do most of the destruction.
\n-
int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
Work routine that Vio_ctor calls to do most of the construction.
\n-
@ VIO_XDR
Definition vio.h:78
\n-
@ VIO_NO_FRMT
Definition vio.h:77
\n-
@ VIO_ASC
Definition vio.h:79
\n-
@ VIO_NO_TYPE
Definition vio.h:63
\n-
@ VIO_FILE
Definition vio.h:66
\n-
@ VIO_UNIX
Definition vio.h:67
\n-
@ VIO_BUFF
Definition vio.h:65
\n-
@ VIO_SDIO
Definition vio.h:64
\n-
@ VIO_INET
Definition vio.h:68
\n-
@ VIO_NO_RW
Definition vio.h:88
\n-
@ VIO_W
Definition vio.h:90
\n-
@ VIO_R
Definition vio.h:89
\n-
Contains public data members for Vio class.
Definition vio.h:98
\n-
char putBuffer[VMAX_BUFSIZE]
Definition vio.h:137
\n-
VIOtype type
Definition vio.h:100
\n-
int ioBufferLen
Definition vio.h:135
\n-
VIOrwkey rwkey
Definition vio.h:113
\n-
char commChars[VMAX_ARGNUM]
Definition vio.h:132
\n-
int VIObufferPtr
Definition vio.h:142
\n-
FILE * fp
Definition vio.h:125
\n-
VIOfrmt frmt
Definition vio.h:108
\n-
int dirty
Definition vio.h:123
\n-
int soc
Definition vio.h:127
\n-
char lhost[VMAX_ARGLEN]
Definition vio.h:119
\n-
char whiteChars[VMAX_ARGNUM]
Definition vio.h:131
\n-
char ioBuffer[VMAX_BUFSIZE]
Definition vio.h:134
\n-
int VIObufferLen
Definition vio.h:141
\n-
char file[VMAX_ARGLEN]
Definition vio.h:118
\n-
void * name
Definition vio.h:128
\n-
void * axdr
Definition vio.h:129
\n-
char * VIObuffer
Definition vio.h:140
\n-
int putBufferLen
Definition vio.h:138
\n-
int so
Definition vio.h:126
\n-
char rhost[VMAX_ARGLEN]
Definition vio.h:120
\n-
int error
Definition vio.h:122
\n+
Header file for the Geometric Predicates.
\n+
Class Vset: a dynamic set object.
\n+
Class Vmem: A safer, object-oriented, malloc/free object.
\n+
Header file for an ISO C [V]irtual [N]umerical [M]achine.
\n+
Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.
\n
\n \n
\n Generated by \"doxygen\"/ 1.9.8\n
\n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,347 +3,38 @@\n \n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n-vio.h\n+vsys.h\n Go_to_the_documentation_of_this_file.\n 1\n- 39#ifndef _VIO_H_\n- 40#define _VIO_H_\n+ 31#ifndef _VSYS_H_\n+ 32#define _VSYS_H_\n+ 33\n+ 34#include \n+ 35\n+ 36#include \n+ 37#include \n+ 38#include \n+ 39#include \n+ 40#include \n 41\n- 42#include \n+ 42#endif /* _VSYS_H_ */\n 43\n- 44#include \n- 45\n- 46/*\n- 47 *\n-***************************************************************************\n- 48 * Class Vio: Parameters and datatypes\n- 49 *\n-***************************************************************************\n- 50 */\n- 51\n-53#define VPORTNUMBER 14916\n-55#define VIO_MAXBUF 10\n- 56\n-62typedef enum VIOtype {\n-63 VIO_NO_TYPE,\n-64 VIO_SDIO,\n-65 VIO_BUFF,\n-66 VIO_FILE,\n-67 VIO_UNIX,\n- 68 VIO_INET\n-69} VIOtype;\n- 70\n-76typedef enum VIOfrmt {\n-77 VIO_NO_FRMT,\n-78 VIO_XDR,\n- 79 VIO_ASC\n-80} VIOfrmt;\n- 81\n-87typedef enum VIOrwkey {\n-88 VIO_NO_RW,\n-89 VIO_R,\n- 90 VIO_W\n-91} VIOrwkey;\n- 92\n-98struct sVio {\n- 99\n-100 VIOtype type;\n-108 VIOfrmt frmt;\n-113 VIOrwkey rwkey;\n-118 char file[VMAX_ARGLEN];\n-119 char lhost[VMAX_ARGLEN];\n-120 char rhost[VMAX_ARGLEN];\n-122 int error;\n-123 int dirty;\n-125 FILE *fp;\n-126 int so;\n-127 int soc;\n-128 void *name;\n-129 void *axdr;\n-131 char whiteChars[VMAX_ARGNUM];\n-132 char commChars[VMAX_ARGNUM];\n-134 char ioBuffer[VMAX_BUFSIZE];\n-135 int ioBufferLen;\n-137 char putBuffer[VMAX_BUFSIZE];\n-138 int putBufferLen;\n-140 char *VIObuffer;\n-141 int VIObufferLen;\n-142 int VIObufferPtr;\n- 144};\n- 145\n-151typedef struct sVio Vio;\n- 152\n- 153/*\n- 154 *\n-***************************************************************************\n- 155 * Class Vio: Inlineable methods (vio.c)\n- 156 *\n-***************************************************************************\n- 157 */\n- 158\n- 159#if !defined(VINLINE_MALOC)\n- 160#else /* if defined(VINLINE_MALOC) */\n- 161#endif /* if !defined(VINLINE_MALOC) */\n- 162\n- 163/*\n- 164 *\n-***************************************************************************\n- 165 * Class Vio: Non-Inlineable methods (vio.c)\n- 166 *\n-***************************************************************************\n- 167 */\n- 168\n-176void Vio_start(void);\n- 177\n-185void Vio_stop(void);\n- 186\n-199Vio* Vio_ctor(const char *socktype, const char *datafrmt,\n- 200 const char *hostname, const char *filename, const char *rwkey);\n- 201\n-215int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt,\n- 216 const char *hostname, const char *filename, const char *rwkey);\n- 217\n-226void Vio_dtor(Vio **thee);\n- 227\n-236void Vio_dtor2(Vio *thee);\n- 237\n-247void Vio_setWhiteChars(Vio *thee, char *whiteChars);\n- 248\n-258void Vio_setCommChars(Vio *thee, char *commChars);\n- 259\n-272int Vio_accept(Vio *thee, int nonblock);\n- 273\n-282void Vio_acceptFree(Vio *thee);\n- 283\n-296int Vio_connect(Vio *thee, int nonblock);\n- 297\n-306void Vio_connectFree(Vio *thee);\n- 307\n-317int Vio_scanf(Vio *thee, char *parms, ...);\n- 318\n-328int Vio_printf(Vio *thee, char *parms, ...);\n- 329\n-340int Vio_read(Vio *thee, char *buf, int bufsize);\n- 341\n-352int Vio_write(Vio *thee, char *buf, int bufsize);\n- 353\n-364void Vio_bufTake(Vio *thee, char *buf, int bufsize);\n- 365\n-374char* Vio_bufGive(Vio *thee);\n- 375\n-384int Vio_bufSize(Vio *thee);\n- 385\n-398Vio *Vio_socketOpen(char *key,\n- 399 const char *iodev, const char *iofmt,\n- 400 const char *iohost, const char *iofile);\n- 401\n-410void Vio_socketClose(Vio **sock);\n- 411\n- 412#endif /* _VIO_H_ */\n- 413\n maloc_base.h\n The base (or foundation) header for MALOC.\n-VMAX_ARGNUM\n-#define VMAX_ARGNUM\n-Global constant.\n-Definition maloc_base.h:225\n-VMAX_BUFSIZE\n-#define VMAX_BUFSIZE\n-Global constant.\n-Definition maloc_base.h:229\n-VMAX_ARGLEN\n-#define VMAX_ARGLEN\n-Global constant.\n-Definition maloc_base.h:227\n+vpred.h\n+Header file for the Geometric Predicates.\n+vset.h\n+Class Vset: a dynamic set object.\n+vmem.h\n+Class Vmem: A safer, object-oriented, malloc/free object.\n vnm.h\n Header file for an ISO C [V]irtual [N]umerical [M]achine.\n-Vio_bufSize\n-int Vio_bufSize(Vio *thee)\n-Return the length to the internal buffer.\n-Vio_stop\n-void Vio_stop(void)\n-Shutdown Vio communication layer.\n-Vio_write\n-int Vio_write(Vio *thee, char *buf, int bufsize)\n-Write bufsize characters from buf to output device.\n-Vio_scanf\n-int Vio_scanf(Vio *thee, char *parms,...)\n-Mimic \"scanf\" from an arbitrary Vio device.\n-Vio_acceptFree\n-void Vio_acceptFree(Vio *thee)\n-Free the socket child that was used for the last accept.\n-Vio_start\n-void Vio_start(void)\n-Start Vio communication layer (init internal variables/buffers)\n-Vio_printf\n-int Vio_printf(Vio *thee, char *parms,...)\n-Mimic \"printf\" from an arbitrary Vio device.\n-Vio_socketOpen\n-Vio * Vio_socketOpen(char *key, const char *iodev, const char *iofmt, const\n-char *iohost, const char *iofile)\n-Socket open for read or write.\n-Vio_setWhiteChars\n-void Vio_setWhiteChars(Vio *thee, char *whiteChars)\n-Set the white character set for I/O stream.\n-Vio_socketClose\n-void Vio_socketClose(Vio **sock)\n-Socket close from read or write.\n-Vio_connect\n-int Vio_connect(Vio *thee, int nonblock)\n-Connect to some socket on a remote machine (or on our machine)\n-VIOfrmt\n-VIOfrmt\n-Parameter for compression type (XDR,ASC)\n-Definition vio.h:76\n-Vio_accept\n-int Vio_accept(Vio *thee, int nonblock)\n-Accept any waiting connect attempt to our socket on our machine.\n-Vio_ctor\n-Vio * Vio_ctor(const char *socktype, const char *datafrmt, const char\n-*hostname, const char *filename, const char *rwkey)\n-Construct the Vio object.\n-VIOtype\n-VIOtype\n-Parameter for I/O type (sdio,buff,file,unix,inet)\n-Definition vio.h:62\n-Vio_dtor\n-void Vio_dtor(Vio **thee)\n-Destruct the Vio object.\n-Vio_read\n-int Vio_read(Vio *thee, char *buf, int bufsize)\n-Read (up to) bufsize characters into buf from input device.\n-Vio_bufTake\n-void Vio_bufTake(Vio *thee, char *buf, int bufsize)\n-Set the pointer to the internal buffer.\n-Vio_connectFree\n-void Vio_connectFree(Vio *thee)\n-Purge any output buffers (for , else a no-op)\n-Vio_setCommChars\n-void Vio_setCommChars(Vio *thee, char *commChars)\n-Set the comment character set for I/O stream.\n-Vio_bufGive\n-char * Vio_bufGive(Vio *thee)\n-Return the pointer to the internal buffer.\n-VIOrwkey\n-VIOrwkey\n-Parameter for rw type (R,RW)\n-Definition vio.h:87\n-Vio_dtor2\n-void Vio_dtor2(Vio *thee)\n-Work routine that Vio_dtor calls to do most of the destruction.\n-Vio_ctor2\n-int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt, const char\n-*hostname, const char *filename, const char *rwkey)\n-Work routine that Vio_ctor calls to do most of the construction.\n-VIO_XDR\n-@ VIO_XDR\n-Definition vio.h:78\n-VIO_NO_FRMT\n-@ VIO_NO_FRMT\n-Definition vio.h:77\n-VIO_ASC\n-@ VIO_ASC\n-Definition vio.h:79\n-VIO_NO_TYPE\n-@ VIO_NO_TYPE\n-Definition vio.h:63\n-VIO_FILE\n-@ VIO_FILE\n-Definition vio.h:66\n-VIO_UNIX\n-@ VIO_UNIX\n-Definition vio.h:67\n-VIO_BUFF\n-@ VIO_BUFF\n-Definition vio.h:65\n-VIO_SDIO\n-@ VIO_SDIO\n-Definition vio.h:64\n-VIO_INET\n-@ VIO_INET\n-Definition vio.h:68\n-VIO_NO_RW\n-@ VIO_NO_RW\n-Definition vio.h:88\n-VIO_W\n-@ VIO_W\n-Definition vio.h:90\n-VIO_R\n-@ VIO_R\n-Definition vio.h:89\n-sVio\n-Contains public data members for Vio class.\n-Definition vio.h:98\n-sVio::putBuffer\n-char putBuffer[VMAX_BUFSIZE]\n-Definition vio.h:137\n-sVio::type\n-VIOtype type\n-Definition vio.h:100\n-sVio::ioBufferLen\n-int ioBufferLen\n-Definition vio.h:135\n-sVio::rwkey\n-VIOrwkey rwkey\n-Definition vio.h:113\n-sVio::commChars\n-char commChars[VMAX_ARGNUM]\n-Definition vio.h:132\n-sVio::VIObufferPtr\n-int VIObufferPtr\n-Definition vio.h:142\n-sVio::fp\n-FILE * fp\n-Definition vio.h:125\n-sVio::frmt\n-VIOfrmt frmt\n-Definition vio.h:108\n-sVio::dirty\n-int dirty\n-Definition vio.h:123\n-sVio::soc\n-int soc\n-Definition vio.h:127\n-sVio::lhost\n-char lhost[VMAX_ARGLEN]\n-Definition vio.h:119\n-sVio::whiteChars\n-char whiteChars[VMAX_ARGNUM]\n-Definition vio.h:131\n-sVio::ioBuffer\n-char ioBuffer[VMAX_BUFSIZE]\n-Definition vio.h:134\n-sVio::VIObufferLen\n-int VIObufferLen\n-Definition vio.h:141\n-sVio::file\n-char file[VMAX_ARGLEN]\n-Definition vio.h:118\n-sVio::name\n-void * name\n-Definition vio.h:128\n-sVio::axdr\n-void * axdr\n-Definition vio.h:129\n-sVio::VIObuffer\n-char * VIObuffer\n-Definition vio.h:140\n-sVio::putBufferLen\n-int putBufferLen\n-Definition vio.h:138\n-sVio::so\n-int so\n-Definition vio.h:126\n-sVio::rhost\n-char rhost[VMAX_ARGLEN]\n-Definition vio.h:120\n-sVio::error\n-int error\n-Definition vio.h:122\n+vio.h\n+Class Vio: virtual I/O layer.\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00024.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00024.dot.gz", "unified_diff": null, "details": [{"source1": "a00024.dot", "source2": "a00024.dot", "unified_diff": "@@ -1,14 +1,14 @@\n-digraph \"vio.h\"\n+digraph \"vsys.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vio.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node1 [id=\"Node000001\",label=\"vsys.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc/maloc_base.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00002.html\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"assert.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"ctype.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge4_Node000002_Node000005\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n@@ -34,10 +34,25 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node19 [id=\"edge19_Node000001_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node19 [id=\"Node000019\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n+ Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node20 [id=\"edge21_Node000001_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node20 [id=\"Node000020\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node20 -> Node18 [id=\"edge23_Node000020_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node21 [id=\"edge24_Node000001_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node21 [id=\"Node000021\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n+ Node21 -> Node2 [id=\"edge25_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node21 -> Node18 [id=\"edge26_Node000021_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node21 -> Node19 [id=\"edge27_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node22 [id=\"edge28_Node000001_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node22 [id=\"Node000022\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node22 -> Node2 [id=\"edge29_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00025.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00025.dot", "unified_diff": "@@ -1,28 +1,26 @@\n-digraph \"vio.h\"\n+digraph \"vsys.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vio.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node1 [id=\"Node000001\",label=\"vsys.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n- Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n- Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node4 [id=\"Node000004\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n- Node4 -> Node3 [id=\"edge4_Node000004_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node5 [id=\"edge5_Node000002_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node5 [id=\"Node000005\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n- Node5 -> Node6 [id=\"edge6_Node000005_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node6 [id=\"Node000006\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n- Node6 -> Node4 [id=\"edge7_Node000006_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node6 [id=\"edge8_Node000002_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node7 [id=\"edge9_Node000002_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node7 [id=\"Node000007\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n- Node7 -> Node6 [id=\"edge10_Node000007_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node8 [id=\"edge11_Node000002_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node8 [id=\"Node000008\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n- Node8 -> Node3 [id=\"edge12_Node000008_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node8 -> Node4 [id=\"edge13_Node000008_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 [id=\"Node000002\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n+ Node1 -> Node3 [id=\"edge2_Node000001_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 [id=\"Node000003\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node3 -> Node2 [id=\"edge3_Node000003_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node4 [id=\"edge4_Node000001_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node4 [id=\"Node000004\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node4 -> Node5 [id=\"edge5_Node000004_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node5 [id=\"Node000005\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node5 -> Node3 [id=\"edge6_Node000005_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node5 [id=\"edge7_Node000001_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node6 [id=\"edge8_Node000001_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node6 [id=\"Node000006\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n+ Node6 -> Node5 [id=\"edge9_Node000006_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node7 [id=\"edge10_Node000001_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node7 [id=\"Node000007\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n+ Node7 -> Node2 [id=\"edge11_Node000007_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node7 -> Node3 [id=\"edge12_Node000007_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00026.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00026.html", "unified_diff": "@@ -50,15 +50,15 @@\n
vset.h File Reference
\n
\n
\n \n

Class Vset: a dynamic set object. \n More...

\n
#include <maloc/maloc_base.h>
\n-#include <maloc/vnm.h>
\n+#include <maloc/vnm.h>
\n #include <maloc/vmem.h>
\n
\n Include dependency graph for vset.h:
\n
\n
\"\"/
\n
\n
\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00026_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00026_source.html", "unified_diff": "@@ -53,15 +53,15 @@\n
\n Go to the documentation of this file.
1
\n
38#ifndef _VSET_H_
\n
39#define _VSET_H_
\n
40
\n
41#include <maloc/maloc_base.h>
\n
42
\n-
43#include <maloc/vnm.h>
\n+
43#include <maloc/vnm.h>
\n
44#include <maloc/vmem.h>
\n
45
\n
46/*
\n
47 * ***************************************************************************
\n
48 * Class Vset: Parameters and datatypes
\n
49 * ***************************************************************************
\n
50 */
\n@@ -193,15 +193,15 @@\n
433void Vset_memChk(Vset *thee);
\n
434
\n
435#endif /* _VSET_H_ */
\n
436
\n
The base (or foundation) header for MALOC.
\n
#define VMAX_ARGLEN
Global constant.
Definition maloc_base.h:227
\n
Class Vmem: A safer, object-oriented, malloc/free object.
\n-
Header file for an ISO C [V]irtual [N]umerical [M]achine.
\n+
Header file for an ISO C [V]irtual [N]umerical [M]achine.
\n
char * Vset_peekFirst(Vset *thee)
Return the first object in the set.
\n
char * Vset_prev(Vset *thee)
Return the prev object in the set.
\n
void Vset_dtor(Vset **thee)
Destroy the set object.
\n
char * Vset_first(Vset *thee)
Return the first object in the set.
\n
Vset * Vset_ctor(Vmem *vmem, const char *tname, int tsize, int tmaxNum, int ioKey)
Construct the set object.
\n
void Vset_reset(Vset *thee)
Release all Ram controlled by this (thee) and re-initialize.
\n
char * Vset_next(Vset *thee)
Return the next object in the set.
\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00027.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00027.dot.gz", "unified_diff": null, "details": [{"source1": "a00027.dot", "source2": "a00027.dot", "unified_diff": "@@ -34,13 +34,13 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node19 [id=\"edge19_Node000001_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node19 [id=\"Node000019\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00028.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00028.dot", "unified_diff": "@@ -2,24 +2,24 @@\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n Node1 [id=\"Node000001\",label=\"vset.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node2 [id=\"Node000002\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node4 [id=\"Node000004\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node4 [id=\"Node000004\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node4 -> Node3 [id=\"edge4_Node000004_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge5_Node000002_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node5 [id=\"Node000005\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node5 [id=\"Node000005\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n Node5 -> Node6 [id=\"edge6_Node000005_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node6 [id=\"Node000006\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node6 [id=\"Node000006\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node6 -> Node4 [id=\"edge7_Node000006_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 -> Node6 [id=\"edge8_Node000002_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 -> Node7 [id=\"edge9_Node000002_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node7 [id=\"Node000007\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n Node7 -> Node6 [id=\"edge10_Node000007_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 -> Node8 [id=\"edge11_Node000002_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node8 [id=\"Node000008\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00031.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00031.dot", "unified_diff": "@@ -4,24 +4,24 @@\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n Node1 [id=\"Node000001\",label=\"vmem.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node3 [id=\"Node000003\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node3 -> Node4 [id=\"edge3_Node000003_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n Node3 -> Node5 [id=\"edge4_Node000003_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node5 [id=\"Node000005\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node5 [id=\"Node000005\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node5 -> Node4 [id=\"edge5_Node000005_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 -> Node6 [id=\"edge6_Node000003_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node6 [id=\"Node000006\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node6 [id=\"Node000006\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n Node6 -> Node7 [id=\"edge7_Node000006_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node7 [id=\"Node000007\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node7 [id=\"Node000007\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node7 -> Node5 [id=\"edge8_Node000007_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 -> Node7 [id=\"edge9_Node000003_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 -> Node8 [id=\"edge10_Node000003_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node8 [id=\"Node000008\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n Node8 -> Node7 [id=\"edge11_Node000008_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 -> Node9 [id=\"edge12_Node000003_Node000009\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node9 [id=\"Node000009\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00032.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00032.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vpred.h File Reference\n+MALOC: vnm.h File Reference\n \n \n \n \n \n \n
\n@@ -42,102 +42,188 @@\n
  • src
  • vsys
  • maloc
  • \n
    \n
    \n
    \n \n-
    vpred.h File Reference
    \n+
    vnm.h File Reference
    \n
    \n
    \n \n-

    Header file for the Geometric Predicates. \n+

    Header file for an ISO C [V]irtual [N]umerical [M]achine. \n More...

    \n
    #include <maloc/maloc_base.h>
    \n
    \n-Include dependency graph for vpred.h:
    \n+Include dependency graph for vnm.h:
    \n
    \n-
    \"\"/
    \n+
    \"\"/
    \n
    \n
    \n This graph shows which files directly or indirectly include this file:
    \n
    \n-
    \"\"/
    \n+
    \"\"/
    \n
    \n
    \n

    Go to the source code of this file.

    \n \n \n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n+\n+\n+\n+\n+\n+\n

    \n Macros

    #define INEXACT   /* Nothing */
     Parameters and constants \"INEXACT\".
     
    #define REAL   double
     float or double
     
    #define REALPRINT   doubleprint
     Print the bit representation of a double.
     
    #define REALRAND   doublerand
     Generate a double with random 53-bit significand and a random exponent in [0, 511].
     
    #define NARROWRAND   narrowdoublerand
     Generate a double with random 53-bit significand and a random exponent in [0, 7].
     
    #define UNIFORMRAND   uniformdoublerand
     Generate a double with random 53-bit significand.
     
    #define VPOW_SAFE(x, y)   (Vnm_powsafe(x,y))
     A safe VPOW function (avoids division by zero)
     
    #define VTIMERS   100
     the maiximal timer constant
     
    \n \n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n

    \n Functions

    void Vpred_exactinit (void)
     Initialize the variables used for exact arithmetic.
     
    REAL Vpred_orient2d (REAL *pa, REAL *pb, REAL *pc)
     Adaptive exact 2D orientation test. Robust.
     
    REAL Vpred_orient2dfast (REAL *pa, REAL *pb, REAL *pc)
     Approximate 2D orientation test. Nonrobust.
     
    REAL Vpred_orient2dexact (REAL *pa, REAL *pb, REAL *pc)
     Exact 2D orientation test. Robust.
     
    REAL Vpred_orient3d (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
     Adaptive exact 3D orientation test. Robust.
     
    REAL Vpred_orient3dfast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
     Approximate 3D orientation test. Nonrobust.
     
    REAL Vpred_orient3dexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
     Exact 3D orientation test. Robust.
     
    REAL Vpred_incircle (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
     Adaptive exact 2D incircle test. Robust.
     
    REAL Vpred_incirclefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
     Approximate 2D incircle test. Nonrobust.
     
    REAL Vpred_incircleexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)
     Exact 2D incircle test. Robust.
     
    REAL Vpred_insphere (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
     Adaptive exact 3D insphere test. Robust.
     
    REAL Vpred_inspherefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
     Approximate 3D insphere test. Nonrobust.
     
    REAL Vpred_insphereexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
     Exact 3D insphere test. Robust.
     
    int Vnm_sigInt (void)
     Signal and setjmp handling routine. Return the signal interrupt flag.
     
    void Vnm_sigIntSet (void)
     Signal and setjmp handling routine. Set the signal interrupt flag.
     
    void Vnm_sigIntClear (void)
     Signal and setjmp handling routine. Clear the signal interrupt flag.
    \n+
     
    int Vnm_jmpOk (void)
     Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.
     
    void Vnm_jmpOkSet (void)
     Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.
     
    void Vnm_jmpOkClear (void)
     Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.
    \n+
     
    jmp_buf * Vnm_signalInit (void)
     Initialize the signal handling data structures.
     
    void Vnm_regHand (void)
     Register the signal handler with the operating system.
     
    void Vnm_sigHand (int num)
     Handle events such as SIGINT. We must have first been registered with \"Vnm_signalInit\".
     
    double Vnm_powsafe (double x, double y)
     A safe VPOW function (avoids division by zero).
    \n+
     
    void Vnm_typeChk (void)
     Check out the sizes of various datatypes.
    \n+
     
    double Vnm_epsmac (void)
     Computes the unit roundoff of the machine in single
    \n+ precision. This is defined as the smallest positive machine number u such that 1.0d0 + u .ne. 1.0d0 (in single precision).
    \n+
    \n+ A safe hardcoded machine epsilon as alternative:
    \n+ double value;
    \n+ value = 1.0e-9;
    \n+ return value;.
     
    int Vnm_gentokens (char *buf, char **argv, const int argvmax, const char *white, const char *comment)
     Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-terminated) in which tokens are separated by whitespace \"white\" with possible comments \"comment\" occuring. THE INPUT STRING IS MODIFIED HERE!
     
    void Vnm_tstart (int timer, const char *name)
     Starts the timer on the particular machine.
    \n+
     
    void Vnm_tstop (int timer, const char *name)
     Stops the timer on the particular machine.
     
    char * Vnm_getuser (char *user, int usermax)
     Ask the system for the username.
     
    char * Vnm_getos (char *os, int osmax)
     Ask the system for the operating system name.
     
    char * Vnm_gethost (char *host, int hostmax)
     Ask the system for the hostname.
     
    char * Vnm_gethome (char *path, int pathmax)
     Ask the system for the home directory.
     
    char * Vnm_getcwd (char *path, int pathmax)
     Ask the system for the current working directory.
     
    int Vnm_chdir (const char *path)
     Interact with the system to change the working directory.
     
    int Vnm_mkdir (const char *path)
     Interact with the system to make a new directory.
    \n+
     
    int Vnm_system (const char *cmd)
     An improved ANSI-C \"system\" call.
     
    int Vnm_systemBack (const char *cmd)
     A background variant of the ANSI-C \"system\" call.
    \n+
     
    int Vnm_systemKill (const char *cmd)
     Something like a UNIX \"killall\" call.
     
    int Vnm_exec (int argc, char **argv)
     An improved UNIX \"exec\" call. This routine does not return except on error.
     
    void Vnm_sleep (int nusecs)
     Implement a sleep function with microsecond resolution.
     
    int Vnm_ioTag (void)
     Return my I/O tag.
     
    int Vnm_nTags (void)
     Return the total number of tags.
     
    void Vnm_setIoTag (int myTag, int numTags)
     Set my id.
     
    FILE * Vnm_open (const int unit)
     Open an I/O console.
     
    int Vnm_close (const int unit)
     Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_flush (const int unit)
     Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_redirect (const int flag)
     Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_print (const int unit, const char *format,...)
     External interface to the console i/o routine.
    \n+ We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_tprint (const int unit, const char *format,...)
     Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_qsort (int *u, int size)
     Front-end to quick sort integer array from [-large] to [+large].
    \n+
     
    void Vnm_qsortOrd (int *u, int *ord, int size)
     Front-end to quick sort integer array from [-large] to [+large].
     
    void Vnm_dqsort (double *u, int size)
     Front-end to quick sort integer array from [-large] to [+large].
    \n+
     
    void Vnm_dqsortOrd (double *u, int *ord, int size)
     Front-end to quick sort integer array from [-large] to [+large].
     
    \n

    Detailed Description

    \n-

    Header file for the Geometric Predicates.

    \n+

    Header file for an ISO C [V]irtual [N]umerical [M]achine.

    \n+
    Author
    Michael Holst
    \n+
    Note
    None
    \n
    Version
    \n-
    Id
    vpred.h,v 1.4 2010/08/12 05:40:37 fetk Exp
    \n-
    Author
    Michael Holst
    \n+
    Id
    vnm.h,v 1.22 2010/08/12 05:40:36 fetk Exp
    \n
    Attention
    *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n@@ -150,756 +236,1448 @@\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n * \n *  
    \n

    Macro Definition Documentation

    \n-\n-

    ◆ INEXACT

    \n+\n+

    ◆ VPOW_SAFE

    \n \n
    \n
    \n \n \n- \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n \n
    #define INEXACT   /* Nothing */#define VPOW_SAFE( x,
     
    )   (Vnm_powsafe(x,y))
    \n
    \n \n-

    Parameters and constants \"INEXACT\".

    \n+

    A safe VPOW function (avoids division by zero)

    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n \n
    \n
    \n-\n-

    ◆ NARROWRAND

    \n+\n+

    ◆ VTIMERS

    \n \n
    \n
    \n \n \n- \n+ \n \n
    #define NARROWRAND   narrowdoublerand#define VTIMERS   100
    \n
    \n \n-

    Generate a double with random 53-bit significand and a random exponent in [0, 7].

    \n+

    the maiximal timer constant

    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n \n
    \n
    \n-\n-

    ◆ REAL

    \n+

    Function Documentation

    \n+\n+

    ◆ Vnm_chdir()

    \n \n
    \n
    \n \n \n- \n+ \n+ \n+ \n+ \n+ \n \n
    #define REAL   doubleint Vnm_chdir (const char * path)
    \n
    \n \n-

    float or double

    \n+

    Interact with the system to change the working directory.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    Success enumeration
    \n+
    Parameters
    \n+ \n+ \n+
    pathPointer to the path
    \n+
    \n+
    \n \n
    \n
    \n-\n-

    ◆ REALPRINT

    \n+\n+

    ◆ Vnm_close()

    \n \n
    \n
    \n \n \n- \n+ \n+ \n+ \n+ \n+ \n \n
    #define REALPRINT   doubleprintint Vnm_close (const int unit)
    \n
    \n \n-

    Print the bit representation of a double.

    \n+

    Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    Success enumeration
    \n+
    Parameters
    \n+ \n+ \n+
    unitindex for the file unit
    \n+
    \n+
    \n \n
    \n
    \n-\n-

    ◆ REALRAND

    \n+\n+

    ◆ Vnm_dqsort()

    \n \n
    \n
    \n \n \n- \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n \n
    #define REALRAND   doublerandvoid Vnm_dqsort (double * u,
    int size 
    )
    \n
    \n \n-

    Generate a double with random 53-bit significand and a random exponent in [0, 511].

    \n+

    Front-end to quick sort integer array from [-large] to [+large].
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+
    Parameters
    \n+ \n+ \n+ \n+
    uPointer to quick sort integer array
    sizesize of the integer array
    \n+
    \n+
    \n \n
    \n
    \n-\n-

    ◆ UNIFORMRAND

    \n+\n+

    ◆ Vnm_dqsortOrd()

    \n \n
    \n
    \n \n \n- \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n \n
    #define UNIFORMRAND   uniformdoublerandvoid Vnm_dqsortOrd (double * u,
    int * ord,
    int size 
    )
    \n
    \n \n-

    Generate a double with random 53-bit significand.

    \n+

    Front-end to quick sort integer array from [-large] to [+large].

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+
    Parameters
    \n+ \n+ \n+ \n+ \n+
    uPointer to quick sort integer array
    ordPointer to reordered array
    sizesize of the integer array
    \n+
    \n+
    \n \n
    \n
    \n-

    Function Documentation

    \n-\n-

    ◆ Vpred_exactinit()

    \n+\n+

    ◆ Vnm_epsmac()

    \n \n
    \n
    \n \n \n- \n+ \n \n \n \n \n \n
    void Vpred_exactinit double Vnm_epsmac (void )
    \n
    \n \n-

    Initialize the variables used for exact arithmetic.

    \n-
    Note
    ‘epsilon’ is the largest power of two such that 1.0 + epsilon = 1.0 in floating-point arithmetic. ‘epsilon’ bounds the relative roundoff error. It is used for floating-point error analysis. ‘splitter’ is used to split floating-point numbers into two half- length significands for exact multiplication. I imagine that a highly optimizing compiler might be too smart for its own good, and somehow cause this routine to fail, if it pretends that floating-point arithmetic is too much like real arithmetic. Don't change this routine unless you fully understand it.
    \n+

    Computes the unit roundoff of the machine in single
    \n+ precision. This is defined as the smallest positive machine number u such that 1.0d0 + u .ne. 1.0d0 (in single precision).
    \n+
    \n+ A safe hardcoded machine epsilon as alternative:
    \n+ double value;
    \n+ value = 1.0e-9;
    \n+ return value;.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    the unit roundoff of the machine in single precision.
    \n \n
    \n
    \n-\n-

    ◆ Vpred_incircle()

    \n+\n+

    ◆ Vnm_exec()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n- \n- \n- \n- \n- \n- \n- \n \n- \n- \n+ \n+ \n \n+
    REAL Vpred_incircle int Vnm_exec (REALpa, int argc,
    REALpb, char ** argv 
    REALpc,
    REALpd )
    \n+
    \n+\n+

    An improved UNIX \"exec\" call. This routine does not return except on error.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    no return except on error
    \n+
    Parameters
    \n+ \n+ \n+ \n+
    argcnumber of the command line arguments
    argvthe command line arguments
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_flush()

    \n+\n+
    \n+
    \n+ \n \n+ \n+ \n+ \n+ \n \n- \n- \n \n
    void Vnm_flush (const int unit))
    \n
    \n \n-

    Adaptive exact 2D incircle test. Robust.

    \n-
    Returns
    a positive value if the point pd lies inside the circle passing through pa, pb, and pc; a negative value if it lies outside; and zero if the four points are cocircular. The points pa, pb, and pc must be in counterclockwise order, or the sign of the result will be reversed.
    \n+

    Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n- \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    unitindex for the file unit
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_incircleexact()

    \n+\n+

    ◆ Vnm_gentokens()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n \n \n
    REAL Vpred_incircleexact int Vnm_gentokens (REALpa, char * buf,
    REALpb, char ** argv,
    REALpc, const int argvmax,
    REALpd const char * white,
    const char * comment 
    )
    \n
    \n \n-

    Exact 2D incircle test. Robust.

    \n-
    Returns
    a positive value if the point pd lies inside the circle passing through pa, pb, and pc; a negative value if it lies outside; and zero if the four points are cocircular. The points pa, pb, and pc must be in counterclockwise order, or the sign of the result will be reversed.
    \n+

    Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-terminated) in which tokens are separated by whitespace \"white\" with possible comments \"comment\" occuring. THE INPUT STRING IS MODIFIED HERE!

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    \n+ Again, the input string \"buf\" IS MODIFIED; white space characters (defined in the input string \"white\") are replaced by the NULL character '\\0'. The output \"argv\" is simply a list of pointers
    \n+ to the start of the tokens in \"buf\", which are NULL-terminated
    \n+ after we replace the white space with NULLs.
    \n+
    \n+ We follow convention and \"NULL\"-terminate \"argv\" by setting the pointer following the last token to \"VNULL\". The return value is \"argc\", the number of tokens found (not including the terminating NULL pointer). For safety you must pass in the maximal length of argv in the parameter \"argvmax\".
    \n+
    \n+ If we encounter a token which begins with a comment character (defined in the input string \"comment\"), then we ignore the rest of the tokens in the input buffer \"buf\". This is suitable
    \n+ for parsing shell languages such as sh/ksh/bash which have comments that start with e.g. \"#\" and continue until a newline.
    \n+
    \n+ We DO NOT use the C library function strtok in this routine. (There are some bad implementations of strtok around apparently; the internal state variables maintained by strtok can get very
    \n+ messed up if you use strtok in multiple places in a code.)
    \n+
    Returns
    number of tokens
    \n
    Parameters
    \n \n- \n- \n- \n- \n+ \n+ \n+ \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    bufbuffer containing message
    argvthe command line arguments
    argvmaxmaximal number of the command line arguments
    whitePointer to the input string
    commenttoken which begins with a comment character
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_incirclefast()

    \n+\n+

    ◆ Vnm_getcwd()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n- \n \n- \n- \n+ \n+ \n+ \n+
    REAL Vpred_incirclefast char * Vnm_getcwd (REALpa, char * path,
    REALpb, int pathmax 
    REALpc, )
    \n+
    \n+\n+

    Ask the system for the current working directory.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    \n+ Consider it an error if we can't return something useful; therefore we will VASSERT(path!=VNULL) before returning.
    \n+
    \n+ Note that unlike Vnm_gethome, a call to Vnm_getcwd returns the current directory, possibly modified from call to call.
    \n+
    \n+ I.e., calls to Vnm_chdir can change the current working
    \n+ directory; Vnm_getcwd returns the current directory, whatever that might be.
    \n+
    Returns
    the current working directory
    \n+
    Parameters
    \n+ \n+ \n+ \n+
    pathPointer to the path
    pathmaxindex for the size of path
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_gethome()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    char * Vnm_gethome (char * path,
    REALpd int pathmax 
    )
    \n
    \n \n-

    Approximate 2D incircle test. Nonrobust.

    \n-
    Returns
    a positive value if the point pd lies inside the circle passing through pa, pb, and pc; a negative value if it lies outside; and zero if the four points are cocircular. The points pa, pb, and pc must be in counterclockwise order, or the sign of the result will be reversed.
    \n+

    Ask the system for the home directory.

    \n+

    =

    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    \n+ The following preference order is used to set the home directory:
    \n+
    \n+ MCSH_HOME (the user must define this in his environment)
    \n+ CWD (always defined as the current working directory)
    \n+
    \n+ We consider it an error if we can't return something useful;
    \n+ therefore we will VASSERT(path!=VNULL) before returning.
    \n+
    \n+ We settle on a home directory the first time we are called, and then we simply return this fixed home directory forever.
    \n+ In other words, the first call to Vnm_gethome, regardless of
    \n+ who makes the call, establishes the home directory for everyone else (as long as everyone goes through Vnm_gethome!).
    \n+
    Returns
    the home directory
    \n
    Parameters
    \n \n- \n- \n- \n- \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    pathPointer to the path
    pathmaxindex for the size of path
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_insphere()

    \n+\n+

    ◆ Vnm_gethost()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n- \n \n- \n- \n+ \n+ \n+ \n+
    REAL Vpred_insphere char * Vnm_gethost (REALpa, char * host,
    REALpb, int hostmax 
    REALpc, )
    \n+
    \n+\n+

    Ask the system for the hostname.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    the hostname
    \n+
    Parameters
    \n+ \n+ \n+ \n+
    hostPointer to the hostname.
    hostmaxindex for maximal size of host name
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_getos()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
    char * Vnm_getos (char * os,
    REALpd, int osmax 
    )
    \n+
    \n+\n+

    Ask the system for the operating system name.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    the operating system name
    \n+
    Parameters
    \n+ \n+ \n+ \n+
    osPointer to the OS type
    osmaxindex for maximal size of OS name
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_getuser()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    char * Vnm_getuser (char * user,
    REALpe int usermax 
    )
    \n
    \n \n-

    Adaptive exact 3D insphere test. Robust.

    \n-
    Returns
    a positive value if the point pe lies inside the sphere passing through pa, pb, pc, and pd; a negative value if it lies outside; and zero if the five points are cospherical. The points pa, pb, pc, and pd must be ordered so that they have a positive orientation (as defined by orient3d()), or the sign of the result will be reversed.
    \n+

    Ask the system for the username.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    the username of the system
    \n
    Parameters
    \n \n- \n- \n- \n- \n- \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    pePointer to a real parameter
    userPointer to the username of the system
    usermaxindex for maximal size of user name
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_insphereexact()

    \n+\n+

    ◆ Vnm_ioTag()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n+ \n \n+
    REAL Vpred_insphereexact int Vnm_ioTag (REALpa, void )
    \n+
    \n+\n+

    Return my I/O tag.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    my I/O tag.
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_jmpOk()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n \n+
    int Vnm_jmpOk (void )REALpb,
    \n+
    \n+\n+

    Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    \"ok-to-jump\" flag.
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_jmpOkClear()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n \n+
    void Vnm_jmpOkClear (void )REALpc,
    \n+
    \n+\n+

    Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_jmpOkSet()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n \n+
    void Vnm_jmpOkSet (void )REALpd,
    \n+
    \n+\n+

    Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.

    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Author
    Michael Holst
    \n+
    Returns
    None
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_mkdir()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n \n+
    int Vnm_mkdir (const char * path)REALpe 
    \n+
    \n+\n+

    Interact with the system to make a new directory.
    \n+

    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Author
    Michael Holst
    \n+
    Returns
    Success enumeration
    \n+
    Parameters
    \n+ \n+ \n+
    pathPointer to the path
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_nTags()

    \n+\n+
    \n+
    \n+ \n \n+ \n+ \n+ \n+ \n \n- \n- \n \n
    int Vnm_nTags (void ))
    \n
    \n \n-

    Exact 3D insphere test. Robust.

    \n-
    Returns
    a positive value if the point pe lies inside the sphere passing through pa, pb, pc, and pd; a negative value if it lies outside; and zero if the five points are cospherical. The points pa, pb, pc, and pd must be ordered so that they have a positive orientation (as defined by orient3d()), or the sign of the result will be reversed.
    \n+

    Return the total number of tags.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    total number of tags.
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_open()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
    FILE * Vnm_open (const int unit)
    \n+
    \n+\n+

    Open an I/O console.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    We MUST NOT use VASSERT (or Vnm_print!) in this routine.   \n+\n+The following codes are used:                                               \n+\n+unit#      C output unit      \n+-------    -------------                                                \n+\n+unit==0    garbage   -- Non-interactive i/o; lots of stuff                        \n+                        (can be redirected to ${MCSH_HOME/io.mc)\n+\n+unit==1    stdout    -- standard output (Interactive I/O)            \n+\n+unit==2    stderr    -- standard error (IMPORTANT interactive I/O)          \n+\n+unit==3    history   -- History file ${MCSH_HOME}/hist.mcsh                       \n+\n+unit==else /dev/null -- Error...                                \n+
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n- \n- \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    pePointer to a real parameter
    unitindex for the file unit
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_inspherefast()

    \n+\n+

    ◆ Vnm_powsafe()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n- \n \n- \n- \n+ \n+ \n+ \n+
    REAL Vpred_inspherefast double Vnm_powsafe (REALpa, double x,
    REALpb, double y 
    REALpc, )
    \n+
    \n+\n+

    A safe VPOW function (avoids division by zero).
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    output value of a VPOW function
    \n+
    Parameters
    \n+ \n+ \n+ \n+
    xinput parameter
    yinput parameter
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_print()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    void Vnm_print (const int unit,
    REALpd, const char * format,
    REALpe  ... 
    )
    \n
    \n \n-

    Approximate 3D insphere test. Nonrobust.

    \n-
    Returns
    a positive value if the point pe lies inside the sphere passing through pa, pb, pc, and pd; a negative value if it lies outside; and zero if the five points are cospherical. The points pa, pb, pc, and pd must be ordered so that they have a positive orientation (as defined by orient3d()), or the sign of the result will be reversed.
    \n+

    External interface to the console i/o routine.
    \n+ We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n- \n- \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    pePointer to a real parameter
    unitindex for the file unit
    formatPointer to the print format
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_orient2d()

    \n+\n+

    ◆ Vnm_qsort()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n- \n- \n- \n- \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    REAL Vpred_orient2d void Vnm_qsort (REALpa, int * u,
    REALpb,
    REALpc int size 
    )
    \n
    \n \n-

    Adaptive exact 2D orientation test. Robust.

    \n-
    Returns
    a positive value if the points pa, pb, and pc occur in counterclockwise order; a negative value if they occur in clockwise order; and zero if they are collinear. The result is also a rough approximation of twice the signed area of the triangle defined by the three points.
    \n+

    Front-end to quick sort integer array from [-large] to [+large].
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    uPointer to quick sort integer array
    sizesize of the integer array
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_orient2dexact()

    \n+\n+

    ◆ Vnm_qsortOrd()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    REAL Vpred_orient2dexact void Vnm_qsortOrd (REALpa, int * u,
    REALpb, int * ord,
    REALpc int size 
    )
    \n
    \n \n-

    Exact 2D orientation test. Robust.

    \n-
    Returns
    a positive value if the points pa, pb, and pc occur in counterclockwise order; a negative value if they occur in clockwise order; and zero if they are collinear. The result is also a rough approximation of twice the signed area of the triangle defined by the three points.
    \n+

    Front-end to quick sort integer array from [-large] to [+large].

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None *
    \n+
    Author
    Michael Holst
    \n
    Parameters
    \n \n- \n- \n- \n+ \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    uPointer to quick sort integer array
    ordPointer to reordered array
    sizesize of the integer array
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_orient2dfast()

    \n+\n+

    ◆ Vnm_redirect()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n+ \n \n+
    REAL Vpred_orient2dfast void Vnm_redirect (REALpa, const int flag)
    \n+
    \n+\n+

    Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+
    Parameters
    \n+ \n+ \n+
    flagindex for the redirect flag
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_regHand()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n+ \n+
    void Vnm_regHand (void )REALpb,
    \n+
    \n+\n+

    Register the signal handler with the operating system.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_setIoTag()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    void Vnm_setIoTag (int myTag,
    REALpc int numTags 
    )
    \n
    \n \n-

    Approximate 2D orientation test. Nonrobust.

    \n-
    Returns
    a positive value if the points pa, pb, and pc occur in counterclockwise order; a negative value if they occur in clockwise order; and zero if they are collinear. The result is also a rough approximation of twice the signed area of the triangle defined by the three points.
    \n+

    Set my id.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    myTagindex for the tag
    numTagsnumber of tags
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_orient3d()

    \n+\n+

    ◆ Vnm_sigHand()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n+ \n \n+
    REAL Vpred_orient3d void Vnm_sigHand (REALpa, int num)
    \n+
    \n+\n+

    Handle events such as SIGINT. We must have first been registered with \"Vnm_signalInit\".

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_sigInt()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n \n+
    int Vnm_sigInt (void )REALpb,
    \n+
    \n+\n+

    Signal and setjmp handling routine. Return the signal interrupt flag.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    Signal interrupt flag.
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_sigIntClear()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n \n+
    void Vnm_sigIntClear (void )REALpc,
    \n+
    \n+\n+

    Signal and setjmp handling routine. Clear the signal interrupt flag.
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_sigIntSet()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n \n- \n- \n \n+
    void Vnm_sigIntSet (void )REALpd 
    \n+
    \n+\n+

    Signal and setjmp handling routine. Set the signal interrupt flag.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_signalInit()

    \n+\n+
    \n+
    \n+ \n \n+ \n+ \n+ \n+ \n+ \n+ \n+
    jmp_buf * Vnm_signalInit (void )
    \n+
    \n+\n+

    Initialize the signal handling data structures.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    the signal handling data structures
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_sleep()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n- \n- \n \n
    void Vnm_sleep (int nusecs))
    \n
    \n \n-

    Adaptive exact 3D orientation test. Robust.

    \n-
    Returns
    a positive value if the point pd lies below the plane passing through pa, pb, and pc; \"below\" is defined so that pa, pb, and pc appear in counterclockwise order when viewed from above the plane. Returns a negative value if pd lies above the plane. Returns zero if the points are coplanar. The result is also a rough approximation of six times the signed volume of the tetrahedron defined by the four points.
    \n+

    Implement a sleep function with microsecond resolution.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+ This is hacked out of the \"sleep_us\" example in Rick Steven's Advance Unix Programming book.
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n- \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    nusecsnumber of microseconds
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_orient3dexact()

    \n+\n+

    ◆ Vnm_system()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n+ \n \n+
    REAL Vpred_orient3dexact int Vnm_system (REALpa, const char * cmd)
    \n+
    \n+\n+

    An improved ANSI-C \"system\" call.

    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Author
    Michael Holst
    \n+
    Returns
    Success enumeration
    \n+
    Parameters
    \n+ \n+ \n+
    cmdPointer to the command
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_systemBack()

    \n+\n+
    \n+
    \n+ \n \n- \n+ \n+ \n+ \n+ \n+ \n+ \n+
    int Vnm_systemBack (const char * cmd)
    \n+
    \n+\n+

    A background variant of the ANSI-C \"system\" call.
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    Success enumeration
    \n+
    Parameters
    \n+ \n+ \n+
    cmdPointer to the command
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_systemKill()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n- \n- \n+ \n+
    int Vnm_systemKill (const char * cmd)REALpb,
    \n+
    \n+\n+

    Something like a UNIX \"killall\" call.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    Success enumeration
    \n+
    Parameters
    \n+ \n+ \n+
    cmdPointer to the command
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_tprint()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    void Vnm_tprint (const int unit,
    REALpc, const char * format,
    REALpd  ... 
    )
    \n
    \n \n-

    Exact 3D orientation test. Robust.

    \n-
    Returns
    a positive value if the point pd lies below the plane passing through pa, pb, and pc; \"below\" is defined so that pa, pb, and pc appear in counterclockwise order when viewed from above the plane. Returns a negative value if pd lies above the plane. Returns zero if the points are coplanar. The result is also a rough approximation of six times the signed volume of the tetrahedron defined by the four points.
    \n+

    Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o) For a tag to be added, both of the following conditions must hold:
    \n+ Vnm_ioTag() >= 0 (I.e., I must have been given a tag)
    \n+ Vnm_nTags() > 1 (I must not be the only one given a tag)
    \n+
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n- \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    unitindex for the file unit
    formatPointer to the print format
    \n
    \n
    \n \n
    \n
    \n-\n-

    ◆ Vpred_orient3dfast()

    \n+\n+

    ◆ Vnm_tstart()

    \n \n
    \n
    \n \n \n- \n+ \n \n- \n- \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n- \n \n- \n- \n+ \n+ \n+ \n+
    REAL Vpred_orient3dfast void Vnm_tstart (REALpa, int timer,
    REALpb, const char * name 
    REALpc, )
    \n+
    \n+\n+

    Starts the timer on the particular machine.
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+
    Parameters
    \n+ \n+ \n+ \n+
    timerindex for the starting timer
    namePointer to the object
    \n+
    \n+
    \n+\n+
    \n+
    \n+\n+

    ◆ Vnm_tstop()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n \n \n \n \n- \n- \n+ \n+ \n \n \n \n \n \n \n
    void Vnm_tstop (int timer,
    REALpd const char * name 
    )
    \n
    \n \n-

    Approximate 3D orientation test. Nonrobust.

    \n-
    Returns
    a positive value if the point pd lies below the plane passing through pa, pb, and pc; \"below\" is defined so that pa, pb, and pc appear in counterclockwise order when viewed from above the plane. Returns a negative value if pd lies above the plane. Returns zero if the points are coplanar. The result is also a rough approximation of six times the signed volume of the tetrahedron defined by the four points.
    \n+

    Stops the timer on the particular machine.

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n
    Parameters
    \n \n- \n- \n- \n- \n+ \n+ \n
    paPointer to a real parameter
    pbPointer to a real parameter
    pcPointer to a real parameter
    pdPointer to a real parameter
    timerindex for the starting timer
    namePointer to the object
    \n
    \n
    \n \n
    \n
    \n+\n+

    ◆ Vnm_typeChk()

    \n+\n+
    \n+
    \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+ \n+
    void Vnm_typeChk (void )
    \n+
    \n+\n+

    Check out the sizes of various datatypes.
    \n+

    \n+
    Author
    Michael Holst
    \n+
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n+
    Returns
    None
    \n+\n+
    \n+
    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -4,88 +4,187 @@\n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n Macros | Functions\n-vpred.h File Reference\n-Header file for the Geometric Predicates. More...\n+vnm.h File Reference\n+Header file for an ISO C [V]irtual [N]umerical [M]achine. More...\n #include \n-Include dependency graph for vpred.h:\n+Include dependency graph for vnm.h:\n This graph shows which files directly or indirectly include this file:\n Go_to_the_source_code_of_this_file.\n Macros\n-#define\u00a0INEXACT\u00a0\u00a0\u00a0/* Nothing */\n-\u00a0 Parameters and constants \"INEXACT\".\n+#define\u00a0VPOW_SAFE(x, y)\u00a0\u00a0\u00a0(Vnm_powsafe(x,y))\n+\u00a0 A safe VPOW function (avoids division by zero)\n \u00a0\n-#define\u00a0REAL\u00a0\u00a0\u00a0double\n-\u00a0 float or double\n+#define\u00a0VTIMERS\u00a0\u00a0\u00a0100\n+\u00a0 the maiximal timer constant\n \u00a0\n-#define\u00a0REALPRINT\u00a0\u00a0\u00a0doubleprint\n-\u00a0 Print the bit representation of a double.\n+ Functions\n+ int\u00a0Vnm_sigInt (void)\n+\u00a0 Signal and setjmp handling routine. Return the signal interrupt\n+ flag.\n+\u00a0\n+ void\u00a0Vnm_sigIntSet (void)\n+\u00a0 Signal and setjmp handling routine. Set the signal interrupt flag.\n \u00a0\n-#define\u00a0REALRAND\u00a0\u00a0\u00a0doublerand\n-\u00a0 Generate a double with random 53-bit significand and a random exponent\n- in [0, 511].\n+ void\u00a0Vnm_sigIntClear (void)\n+ Signal and setjmp handling routine. Clear the signal interrupt flag.\n \u00a0\n-#define\u00a0NARROWRAND\u00a0\u00a0\u00a0narrowdoublerand\n-\u00a0 Generate a double with random 53-bit significand and a random exponent\n- in [0, 7].\n+\n \u00a0\n-#define\u00a0UNIFORMRAND\u00a0\u00a0\u00a0uniformdoublerand\n-\u00a0 Generate a double with random 53-bit significand.\n+ int\u00a0Vnm_jmpOk (void)\n+\u00a0 Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.\n \u00a0\n- Functions\n-void\u00a0Vpred_exactinit (void)\n-\u00a0 Initialize the variables used for exact arithmetic.\n+ void\u00a0Vnm_jmpOkSet (void)\n+\u00a0 Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.\n+\u00a0\n+ void\u00a0Vnm_jmpOkClear (void)\n+\u00a0 Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.\n+\n+\u00a0\n+jmp_buf *\u00a0Vnm_signalInit (void)\n+\u00a0 Initialize the signal handling data structures.\n+\u00a0\n+ void\u00a0Vnm_regHand (void)\n+\u00a0 Register the signal handler with the operating system.\n \u00a0\n-REAL\u00a0Vpred_orient2d (REAL *pa, REAL *pb, REAL *pc)\n-\u00a0 Adaptive exact 2D orientation test. Robust.\n+ void\u00a0Vnm_sigHand (int num)\n+\u00a0 Handle events such as SIGINT. We must have first been registered\n+ with \"Vnm_signalInit\".\n \u00a0\n-REAL\u00a0Vpred_orient2dfast (REAL *pa, REAL *pb, REAL *pc)\n-\u00a0 Approximate 2D orientation test. Nonrobust.\n+ double\u00a0Vnm_powsafe (double x, double y)\n+\u00a0 A safe VPOW function (avoids division by zero).\n+\n+\u00a0\n+ void\u00a0Vnm_typeChk (void)\n+\u00a0 Check out the sizes of various datatypes.\n+\n+\u00a0\n+ double\u00a0Vnm_epsmac (void)\n+ Computes the unit roundoff of the machine in single\n+ precision. This is defined as the smallest positive machine number u\n+ such that 1.0d0 + u .ne. 1.0d0 (in single precision).\n+\u00a0\n+ A safe hardcoded machine epsilon as alternative:\n+ double value;\n+ value = 1.0e-9;\n+ return value;.\n+\u00a0\n+ int\u00a0Vnm_gentokens (char *buf, char **argv, const int argvmax, const char\n+ *white, const char *comment)\n+ Generate an [argv,argc] pair from a character string \"buf\" (assumed\n+\u00a0 NULL-terminated) in which tokens are separated by whitespace \"white\"\n+ with possible comments \"comment\" occuring. THE INPUT STRING IS\n+ MODIFIED HERE!\n \u00a0\n-REAL\u00a0Vpred_orient2dexact (REAL *pa, REAL *pb, REAL *pc)\n-\u00a0 Exact 2D orientation test. Robust.\n+ void\u00a0Vnm_tstart (int timer, const char *name)\n+\u00a0 Starts the timer on the particular machine.\n+\n+\u00a0\n+ void\u00a0Vnm_tstop (int timer, const char *name)\n+\u00a0 Stops the timer on the particular machine.\n \u00a0\n-REAL\u00a0Vpred_orient3d (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-\u00a0 Adaptive exact 3D orientation test. Robust.\n+ char *\u00a0Vnm_getuser (char *user, int usermax)\n+\u00a0 Ask the system for the username.\n \u00a0\n-REAL\u00a0Vpred_orient3dfast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-\u00a0 Approximate 3D orientation test. Nonrobust.\n+ char *\u00a0Vnm_getos (char *os, int osmax)\n+\u00a0 Ask the system for the operating system name.\n \u00a0\n-REAL\u00a0Vpred_orient3dexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-\u00a0 Exact 3D orientation test. Robust.\n+ char *\u00a0Vnm_gethost (char *host, int hostmax)\n+\u00a0 Ask the system for the hostname.\n \u00a0\n-REAL\u00a0Vpred_incircle (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-\u00a0 Adaptive exact 2D incircle test. Robust.\n+ char *\u00a0Vnm_gethome (char *path, int pathmax)\n+\u00a0 Ask the system for the home directory.\n \u00a0\n-REAL\u00a0Vpred_incirclefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-\u00a0 Approximate 2D incircle test. Nonrobust.\n+ char *\u00a0Vnm_getcwd (char *path, int pathmax)\n+\u00a0 Ask the system for the current working directory.\n \u00a0\n-REAL\u00a0Vpred_incircleexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-\u00a0 Exact 2D incircle test. Robust.\n+ int\u00a0Vnm_chdir (const char *path)\n+\u00a0 Interact with the system to change the working directory.\n+\u00a0\n+ int\u00a0Vnm_mkdir (const char *path)\n+\u00a0 Interact with the system to make a new directory.\n+\n \u00a0\n-REAL\u00a0Vpred_insphere (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n-\u00a0 Adaptive exact 3D insphere test. Robust.\n+ int\u00a0Vnm_system (const char *cmd)\n+\u00a0 An improved ANSI-C \"system\" call.\n \u00a0\n-REAL\u00a0Vpred_inspherefast (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n-\u00a0 Approximate 3D insphere test. Nonrobust.\n+ int\u00a0Vnm_systemBack (const char *cmd)\n+\u00a0 A background variant of the ANSI-C \"system\" call.\n+\n+\u00a0\n+ int\u00a0Vnm_systemKill (const char *cmd)\n+\u00a0 Something like a UNIX \"killall\" call.\n+\u00a0\n+ int\u00a0Vnm_exec (int argc, char **argv)\n+\u00a0 An improved UNIX \"exec\" call. This routine does not return except on\n+ error.\n+\u00a0\n+ void\u00a0Vnm_sleep (int nusecs)\n+\u00a0 Implement a sleep function with microsecond resolution.\n+\u00a0\n+ int\u00a0Vnm_ioTag (void)\n+\u00a0 Return my I/O tag.\n+\u00a0\n+ int\u00a0Vnm_nTags (void)\n+\u00a0 Return the total number of tags.\n+\u00a0\n+ void\u00a0Vnm_setIoTag (int myTag, int numTags)\n+\u00a0 Set my id.\n+\u00a0\n+ FILE *\u00a0Vnm_open (const int unit)\n+\u00a0 Open an I/O console.\n+\u00a0\n+ int\u00a0Vnm_close (const int unit)\n+\u00a0 Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in\n+ this routine.\n+\u00a0\n+ void\u00a0Vnm_flush (const int unit)\n+\u00a0 Attempt to flush the specified i/o stream. We MUST NOT use VASSERT\n+ (or Vnm_print!) in this routine.\n+\u00a0\n+ void\u00a0Vnm_redirect (const int flag)\n+ Set/unset the redirect flag for UNIT zero. When redirected, I/O goes\n+\u00a0 to the file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or\n+ Vnm_print!) in this routine.\n+\u00a0\n+ void\u00a0Vnm_print (const int unit, const char *format,...)\n+\u00a0 External interface to the console i/o routine.\n+ We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n+\u00a0\n+ void\u00a0Vnm_tprint (const int unit, const char *format,...)\n+\u00a0 Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or\n+ Vnm_print!) in this routine.\n+\u00a0\n+ void\u00a0Vnm_qsort (int *u, int size)\n+\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n+\n \u00a0\n-REAL\u00a0Vpred_insphereexact (REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n-\u00a0 Exact 3D insphere test. Robust.\n+ void\u00a0Vnm_qsortOrd (int *u, int *ord, int size)\n+\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n+\u00a0\n+ void\u00a0Vnm_dqsort (double *u, int size)\n+\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n+\n+\u00a0\n+ void\u00a0Vnm_dqsortOrd (double *u, int *ord, int size)\n+\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n \u00a0\n ***** Detailed Description *****\n-Header file for the Geometric Predicates.\n- Version\n- Id\n- vpred.h,v 1.4 2010/08/12 05:40:37 fetk Exp\n+Header file for an ISO C [V]irtual [N]umerical [M]achine.\n Author\n Michael Holst\n+ Note\n+ None\n+ Version\n+ Id\n+ vnm.h,v 1.22 2010/08/12 05:40:36 fetk Exp\n Attention\n *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n@@ -99,256 +198,591 @@\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n *\n *\n ***** Macro Definition Documentation *****\n-***** \u25c6\u00a0INEXACT *****\n-#define INEXACT\u00a0\u00a0\u00a0/* Nothing */\n-Parameters and constants \"INEXACT\".\n-***** \u25c6\u00a0NARROWRAND *****\n-#define NARROWRAND\u00a0\u00a0\u00a0narrowdoublerand\n-Generate a double with random 53-bit significand and a random exponent in [0,\n-7].\n-***** \u25c6\u00a0REAL *****\n-#define REAL\u00a0\u00a0\u00a0double\n-float or double\n-***** \u25c6\u00a0REALPRINT *****\n-#define REALPRINT\u00a0\u00a0\u00a0doubleprint\n-Print the bit representation of a double.\n-***** \u25c6\u00a0REALRAND *****\n-#define REALRAND\u00a0\u00a0\u00a0doublerand\n-Generate a double with random 53-bit significand and a random exponent in [0,\n-511].\n-***** \u25c6\u00a0UNIFORMRAND *****\n-#define UNIFORMRAND\u00a0\u00a0\u00a0uniformdoublerand\n-Generate a double with random 53-bit significand.\n+***** \u25c6\u00a0VPOW_SAFE *****\n+#define VPOW_SAFE ( \u00a0x,\n+ \u00a0y\u00a0\n+ ) \u00a0\u00a0\u00a0(Vnm_powsafe(x,y))\n+A safe VPOW function (avoids division by zero)\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+***** \u25c6\u00a0VTIMERS *****\n+#define VTIMERS\u00a0\u00a0\u00a0100\n+the maiximal timer constant\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n ***** Function Documentation *****\n-***** \u25c6\u00a0Vpred_exactinit() *****\n-void Vpred_exactinit ( void\u00a0 )\n-Initialize the variables used for exact arithmetic.\n- Note\n- \u2018epsilon\u2019 is the largest power of two such that 1.0 + epsilon = 1.0 in\n- floating-point arithmetic. \u2018epsilon\u2019 bounds the relative roundoff error.\n- It is used for floating-point error analysis. \u2018splitter\u2019 is used to split\n- floating-point numbers into two half- length significands for exact\n- multiplication. I imagine that a highly optimizing compiler might be too\n- smart for its own good, and somehow cause this routine to fail, if it\n- pretends that floating-point arithmetic is too much like real arithmetic.\n- Don't change this routine unless you fully understand it.\n-***** \u25c6\u00a0Vpred_incircle() *****\n-REAL Vpred_incircle ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd\u00a0\n- )\n-Adaptive exact 2D incircle test. Robust.\n- Returns\n- a positive value if the point pd lies inside the circle passing through\n- pa, pb, and pc; a negative value if it lies outside; and zero if the four\n- points are cocircular. The points pa, pb, and pc must be in\n- counterclockwise order, or the sign of the result will be reversed.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_incircleexact() *****\n-REAL Vpred_incircleexact ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd\u00a0\n- )\n-Exact 2D incircle test. Robust.\n- Returns\n- a positive value if the point pd lies inside the circle passing through\n- pa, pb, and pc; a negative value if it lies outside; and zero if the four\n- points are cocircular. The points pa, pb, and pc must be in\n- counterclockwise order, or the sign of the result will be reversed.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_incirclefast() *****\n-REAL Vpred_incirclefast ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd\u00a0\n- )\n-Approximate 2D incircle test. Nonrobust.\n- Returns\n- a positive value if the point pd lies inside the circle passing through\n- pa, pb, and pc; a negative value if it lies outside; and zero if the four\n- points are cocircular. The points pa, pb, and pc must be in\n- counterclockwise order, or the sign of the result will be reversed.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_insphere() *****\n-REAL Vpred_insphere ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd,\n- REAL *\u00a0pe\u00a0\n- )\n-Adaptive exact 3D insphere test. Robust.\n- Returns\n- a positive value if the point pe lies inside the sphere passing through\n- pa, pb, pc, and pd; a negative value if it lies outside; and zero if the\n- five points are cospherical. The points pa, pb, pc, and pd must be\n- ordered so that they have a positive orientation (as defined by orient3d\n- ()), or the sign of the result will be reversed.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n- pe Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_insphereexact() *****\n-REAL Vpred_insphereexact ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd,\n- REAL *\u00a0pe\u00a0\n- )\n-Exact 3D insphere test. Robust.\n- Returns\n- a positive value if the point pe lies inside the sphere passing through\n- pa, pb, pc, and pd; a negative value if it lies outside; and zero if the\n- five points are cospherical. The points pa, pb, pc, and pd must be\n- ordered so that they have a positive orientation (as defined by orient3d\n- ()), or the sign of the result will be reversed.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n- pe Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_inspherefast() *****\n-REAL Vpred_inspherefast ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd,\n- REAL *\u00a0pe\u00a0\n- )\n-Approximate 3D insphere test. Nonrobust.\n- Returns\n- a positive value if the point pe lies inside the sphere passing through\n- pa, pb, pc, and pd; a negative value if it lies outside; and zero if the\n- five points are cospherical. The points pa, pb, pc, and pd must be\n- ordered so that they have a positive orientation (as defined by orient3d\n- ()), or the sign of the result will be reversed.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n- pe Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_orient2d() *****\n-REAL Vpred_orient2d ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc\u00a0\n- )\n-Adaptive exact 2D orientation test. Robust.\n- Returns\n- a positive value if the points pa, pb, and pc occur in counterclockwise\n- order; a negative value if they occur in clockwise order; and zero if\n- they are collinear. The result is also a rough approximation of twice the\n- signed area of the triangle defined by the three points.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_orient2dexact() *****\n-REAL Vpred_orient2dexact ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc\u00a0\n- )\n-Exact 2D orientation test. Robust.\n- Returns\n- a positive value if the points pa, pb, and pc occur in counterclockwise\n- order; a negative value if they occur in clockwise order; and zero if\n- they are collinear. The result is also a rough approximation of twice the\n- signed area of the triangle defined by the three points.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_orient2dfast() *****\n-REAL Vpred_orient2dfast ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc\u00a0\n- )\n-Approximate 2D orientation test. Nonrobust.\n- Returns\n- a positive value if the points pa, pb, and pc occur in counterclockwise\n- order; a negative value if they occur in clockwise order; and zero if\n- they are collinear. The result is also a rough approximation of twice the\n- signed area of the triangle defined by the three points.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_orient3d() *****\n-REAL Vpred_orient3d ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd\u00a0\n- )\n-Adaptive exact 3D orientation test. Robust.\n- Returns\n- a positive value if the point pd lies below the plane passing through pa,\n- pb, and pc; \"below\" is defined so that pa, pb, and pc appear in\n- counterclockwise order when viewed from above the plane. Returns a\n- negative value if pd lies above the plane. Returns zero if the points are\n- coplanar. The result is also a rough approximation of six times the\n- signed volume of the tetrahedron defined by the four points.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_orient3dexact() *****\n-REAL Vpred_orient3dexact ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd\u00a0\n- )\n-Exact 3D orientation test. Robust.\n- Returns\n- a positive value if the point pd lies below the plane passing through pa,\n- pb, and pc; \"below\" is defined so that pa, pb, and pc appear in\n- counterclockwise order when viewed from above the plane. Returns a\n- negative value if pd lies above the plane. Returns zero if the points are\n- coplanar. The result is also a rough approximation of six times the\n- signed volume of the tetrahedron defined by the four points.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n-***** \u25c6\u00a0Vpred_orient3dfast() *****\n-REAL Vpred_orient3dfast ( REAL *\u00a0pa,\n- REAL *\u00a0pb,\n- REAL *\u00a0pc,\n- REAL *\u00a0pd\u00a0\n- )\n-Approximate 3D orientation test. Nonrobust.\n- Returns\n- a positive value if the point pd lies below the plane passing through pa,\n- pb, and pc; \"below\" is defined so that pa, pb, and pc appear in\n- counterclockwise order when viewed from above the plane. Returns a\n- negative value if pd lies above the plane. Returns zero if the points are\n- coplanar. The result is also a rough approximation of six times the\n- signed volume of the tetrahedron defined by the four points.\n- Parameters\n- pa Pointer to a real parameter\n- pb Pointer to a real parameter\n- pc Pointer to a real parameter\n- pd Pointer to a real parameter\n+***** \u25c6\u00a0Vnm_chdir() *****\n+int Vnm_chdir ( const char *\u00a0path )\n+Interact with the system to change the working directory.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ Success enumeration\n+ Parameters\n+ path Pointer to the path\n+***** \u25c6\u00a0Vnm_close() *****\n+int Vnm_close ( const int\u00a0unit )\n+Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ Success enumeration\n+ Parameters\n+ unit index for the file unit\n+***** \u25c6\u00a0Vnm_dqsort() *****\n+void Vnm_dqsort ( double *\u00a0u,\n+ int\u00a0 size\u00a0\n+ )\n+Front-end to quick sort integer array from [-large] to [+large].\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ u Pointer to quick sort integer array\n+ size size of the integer array\n+***** \u25c6\u00a0Vnm_dqsortOrd() *****\n+void Vnm_dqsortOrd ( double *\u00a0u,\n+ int *\u00a0 ord,\n+ int\u00a0 size\u00a0\n+ )\n+Front-end to quick sort integer array from [-large] to [+large].\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ u Pointer to quick sort integer array\n+ ord Pointer to reordered array\n+ size size of the integer array\n+***** \u25c6\u00a0Vnm_epsmac() *****\n+double Vnm_epsmac ( void\u00a0 )\n+Computes the unit roundoff of the machine in single\n+precision. This is defined as the smallest positive machine number u such that\n+1.0d0 + u .ne. 1.0d0 (in single precision).\n+\n+A safe hardcoded machine epsilon as alternative:\n+double value;\n+value = 1.0e-9;\n+return value;.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ the unit roundoff of the machine in single precision.\n+***** \u25c6\u00a0Vnm_exec() *****\n+int Vnm_exec ( int\u00a0 argc,\n+ char **\u00a0argv\u00a0\n+ )\n+An improved UNIX \"exec\" call. This routine does not return except on error.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ no return except on error\n+ Parameters\n+ argc number of the command line arguments\n+ argv the command line arguments\n+***** \u25c6\u00a0Vnm_flush() *****\n+void Vnm_flush ( const int\u00a0unit )\n+Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or\n+Vnm_print!) in this routine.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ unit index for the file unit\n+***** \u25c6\u00a0Vnm_gentokens() *****\n+int Vnm_gentokens ( char *\u00a0 buf,\n+ char **\u00a0 argv,\n+ const int\u00a0 argvmax,\n+ const char *\u00a0white,\n+ const char *\u00a0comment\u00a0\n+ )\n+Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-\n+terminated) in which tokens are separated by whitespace \"white\" with possible\n+comments \"comment\" occuring. THE INPUT STRING IS MODIFIED HERE!\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+\n+ Again, the input string \"buf\" IS MODIFIED; white space characters\n+ (defined in the input string \"white\") are replaced by the NULL character\n+ '\\0'. The output \"argv\" is simply a list of pointers\n+ to the start of the tokens in \"buf\", which are NULL-terminated\n+ after we replace the white space with NULLs.\n+\n+ We follow convention and \"NULL\"-terminate \"argv\" by setting the pointer\n+ following the last token to \"VNULL\". The return value is \"argc\", the\n+ number of tokens found (not including the terminating NULL pointer). For\n+ safety you must pass in the maximal length of argv in the parameter\n+ \"argvmax\".\n+\n+ If we encounter a token which begins with a comment character (defined in\n+ the input string \"comment\"), then we ignore the rest of the tokens in the\n+ input buffer \"buf\". This is suitable\n+ for parsing shell languages such as sh/ksh/bash which have comments that\n+ start with e.g. \"#\" and continue until a newline.\n+\n+ We DO NOT use the C library function strtok in this routine. (There are\n+ some bad implementations of strtok around apparently; the internal state\n+ variables maintained by strtok can get very\n+ messed up if you use strtok in multiple places in a code.)\n+ Returns\n+ number of tokens\n+ Parameters\n+ buf buffer containing message\n+ argv the command line arguments\n+ argvmax maximal number of the command line arguments\n+ white Pointer to the input string\n+ comment token which begins with a comment character\n+***** \u25c6\u00a0Vnm_getcwd() *****\n+char * Vnm_getcwd ( char *\u00a0path,\n+ int\u00a0 pathmax\u00a0\n+ )\n+Ask the system for the current working directory.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+\n+ Consider it an error if we can't return something useful; therefore we\n+ will VASSERT(path!=VNULL) before returning.\n+\n+ Note that unlike Vnm_gethome, a call to Vnm_getcwd returns the current\n+ directory, possibly modified from call to call.\n+\n+ I.e., calls to Vnm_chdir can change the current working\n+ directory; Vnm_getcwd returns the current directory, whatever that might\n+ be.\n+ Returns\n+ the current working directory\n+ Parameters\n+ path Pointer to the path\n+ pathmax index for the size of path\n+***** \u25c6\u00a0Vnm_gethome() *****\n+char * Vnm_gethome ( char *\u00a0path,\n+ int\u00a0 pathmax\u00a0\n+ )\n+Ask the system for the home directory.\n+=\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+\n+ The following preference order is used to set the home directory:\n+\n+ MCSH_HOME (the user must define this in his environment)\n+ CWD (always defined as the current working directory)\n+\n+ We consider it an error if we can't return something useful;\n+ therefore we will VASSERT(path!=VNULL) before returning.\n+\n+ We settle on a home directory the first time we are called, and then we\n+ simply return this fixed home directory forever.\n+ In other words, the first call to Vnm_gethome, regardless of\n+ who makes the call, establishes the home directory for everyone else (as\n+ long as everyone goes through Vnm_gethome!).\n+ Returns\n+ the home directory\n+ Parameters\n+ path Pointer to the path\n+ pathmax index for the size of path\n+***** \u25c6\u00a0Vnm_gethost() *****\n+char * Vnm_gethost ( char *\u00a0host,\n+ int\u00a0 hostmax\u00a0\n+ )\n+Ask the system for the hostname.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ the hostname\n+ Parameters\n+ host Pointer to the hostname.\n+ hostmax index for maximal size of host name\n+***** \u25c6\u00a0Vnm_getos() *****\n+char * Vnm_getos ( char *\u00a0os,\n+ int\u00a0 osmax\u00a0\n+ )\n+Ask the system for the operating system name.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ the operating system name\n+ Parameters\n+ os Pointer to the OS type\n+ osmax index for maximal size of OS name\n+***** \u25c6\u00a0Vnm_getuser() *****\n+char * Vnm_getuser ( char *\u00a0user,\n+ int\u00a0 usermax\u00a0\n+ )\n+Ask the system for the username.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ the username of the system\n+ Parameters\n+ user Pointer to the username of the system\n+ usermax index for maximal size of user name\n+***** \u25c6\u00a0Vnm_ioTag() *****\n+int Vnm_ioTag ( void\u00a0 )\n+Return my I/O tag.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ my I/O tag.\n+***** \u25c6\u00a0Vnm_jmpOk() *****\n+int Vnm_jmpOk ( void\u00a0 )\n+Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ \"ok-to-jump\" flag.\n+***** \u25c6\u00a0Vnm_jmpOkClear() *****\n+void Vnm_jmpOkClear ( void\u00a0 )\n+Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+***** \u25c6\u00a0Vnm_jmpOkSet() *****\n+void Vnm_jmpOkSet ( void\u00a0 )\n+Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Author\n+ Michael Holst\n+ Returns\n+ None\n+***** \u25c6\u00a0Vnm_mkdir() *****\n+int Vnm_mkdir ( const char *\u00a0path )\n+Interact with the system to make a new directory.\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Author\n+ Michael Holst\n+ Returns\n+ Success enumeration\n+ Parameters\n+ path Pointer to the path\n+***** \u25c6\u00a0Vnm_nTags() *****\n+int Vnm_nTags ( void\u00a0 )\n+Return the total number of tags.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ total number of tags.\n+***** \u25c6\u00a0Vnm_open() *****\n+FILE * Vnm_open ( const int\u00a0unit )\n+Open an I/O console.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n+\n+ The following codes are used:\n+\n+\n+ unit# C output unit\n+ ------- -------------\n+\n+ unit==0 garbage -- Non-interactive i/o; lots of stuff\n+\n+ (can be redirected to ${MCSH_HOME/io.mc)\n+\n+ unit==1 stdout -- standard output (Interactive I/O)\n+\n+ unit==2 stderr -- standard error (IMPORTANT interactive I/O)\n+\n+\n+ unit==3 history -- History file ${MCSH_HOME}/hist.mcsh\n+\n+\n+ unit==else /dev/null -- Error...\n+ Returns\n+ None\n+ Parameters\n+ unit index for the file unit\n+***** \u25c6\u00a0Vnm_powsafe() *****\n+double Vnm_powsafe ( double\u00a0x,\n+ double\u00a0y\u00a0\n+ )\n+A safe VPOW function (avoids division by zero).\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ output value of a VPOW function\n+ Parameters\n+ x input parameter\n+ y input parameter\n+***** \u25c6\u00a0Vnm_print() *****\n+void Vnm_print ( const int\u00a0 unit,\n+ const char *\u00a0format,\n+ \u00a0 ...\u00a0\n+ )\n+External interface to the console i/o routine.\n+We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ unit index for the file unit\n+ format Pointer to the print format\n+***** \u25c6\u00a0Vnm_qsort() *****\n+void Vnm_qsort ( int *\u00a0u,\n+ int\u00a0 size\u00a0\n+ )\n+Front-end to quick sort integer array from [-large] to [+large].\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ u Pointer to quick sort integer array\n+ size size of the integer array\n+***** \u25c6\u00a0Vnm_qsortOrd() *****\n+void Vnm_qsortOrd ( int *\u00a0u,\n+ int *\u00a0ord,\n+ int\u00a0 size\u00a0\n+ )\n+Front-end to quick sort integer array from [-large] to [+large].\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None *\n+ Author\n+ Michael Holst\n+ Parameters\n+ u Pointer to quick sort integer array\n+ ord Pointer to reordered array\n+ size size of the integer array\n+***** \u25c6\u00a0Vnm_redirect() *****\n+void Vnm_redirect ( const int\u00a0flag )\n+Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the\n+file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or Vnm_print!) in this\n+routine.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ flag index for the redirect flag\n+***** \u25c6\u00a0Vnm_regHand() *****\n+void Vnm_regHand ( void\u00a0 )\n+Register the signal handler with the operating system.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+***** \u25c6\u00a0Vnm_setIoTag() *****\n+void Vnm_setIoTag ( int\u00a0myTag,\n+ int\u00a0numTags\u00a0\n+ )\n+Set my id.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ myTag index for the tag\n+ numTags number of tags\n+***** \u25c6\u00a0Vnm_sigHand() *****\n+void Vnm_sigHand ( int\u00a0num )\n+Handle events such as SIGINT. We must have first been registered with\n+\"Vnm_signalInit\".\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+***** \u25c6\u00a0Vnm_sigInt() *****\n+int Vnm_sigInt ( void\u00a0 )\n+Signal and setjmp handling routine. Return the signal interrupt flag.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ Signal interrupt flag.\n+***** \u25c6\u00a0Vnm_sigIntClear() *****\n+void Vnm_sigIntClear ( void\u00a0 )\n+Signal and setjmp handling routine. Clear the signal interrupt flag.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+***** \u25c6\u00a0Vnm_sigIntSet() *****\n+void Vnm_sigIntSet ( void\u00a0 )\n+Signal and setjmp handling routine. Set the signal interrupt flag.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+***** \u25c6\u00a0Vnm_signalInit() *****\n+jmp_buf * Vnm_signalInit ( void\u00a0 )\n+Initialize the signal handling data structures.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ the signal handling data structures\n+***** \u25c6\u00a0Vnm_sleep() *****\n+void Vnm_sleep ( int\u00a0nusecs )\n+Implement a sleep function with microsecond resolution.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ This is hacked out of the \"sleep_us\" example in Rick Steven's Advance\n+ Unix Programming book.\n+ Returns\n+ None\n+ Parameters\n+ nusecs number of microseconds\n+***** \u25c6\u00a0Vnm_system() *****\n+int Vnm_system ( const char *\u00a0cmd )\n+An improved ANSI-C \"system\" call.\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Author\n+ Michael Holst\n+ Returns\n+ Success enumeration\n+ Parameters\n+ cmd Pointer to the command\n+***** \u25c6\u00a0Vnm_systemBack() *****\n+int Vnm_systemBack ( const char *\u00a0cmd )\n+A background variant of the ANSI-C \"system\" call.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ Success enumeration\n+ Parameters\n+ cmd Pointer to the command\n+***** \u25c6\u00a0Vnm_systemKill() *****\n+int Vnm_systemKill ( const char *\u00a0cmd )\n+Something like a UNIX \"killall\" call.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ Success enumeration\n+ Parameters\n+ cmd Pointer to the command\n+***** \u25c6\u00a0Vnm_tprint() *****\n+void Vnm_tprint ( const int\u00a0 unit,\n+ const char *\u00a0format,\n+ \u00a0 ...\u00a0\n+ )\n+Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in\n+this routine.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ For a tag to be added, both of the following conditions must hold:\n+ Vnm_ioTag() >= 0 (I.e., I must have been given a tag)\n+ Vnm_nTags() > 1 (I must not be the only one given a tag)\n+ Returns\n+ None\n+ Parameters\n+ unit index for the file unit\n+ format Pointer to the print format\n+***** \u25c6\u00a0Vnm_tstart() *****\n+void Vnm_tstart ( int\u00a0 timer,\n+ const char *\u00a0name\u00a0\n+ )\n+Starts the timer on the particular machine.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ timer index for the starting timer\n+ name Pointer to the object\n+***** \u25c6\u00a0Vnm_tstop() *****\n+void Vnm_tstop ( int\u00a0 timer,\n+ const char *\u00a0name\u00a0\n+ )\n+Stops the timer on the particular machine.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n+ Parameters\n+ timer index for the starting timer\n+ name Pointer to the object\n+***** \u25c6\u00a0Vnm_typeChk() *****\n+void Vnm_typeChk ( void\u00a0 )\n+Check out the sizes of various datatypes.\n+ Author\n+ Michael Holst\n+ Note\n+ Useful constants and functions (timers, epsilon, token generators, i/o)\n+ Returns\n+ None\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00032_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00032_source.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vpred.h Source File\n+MALOC: vnm.h Source File\n \n \n \n \n \n \n
    \n@@ -44,95 +44,152 @@\n \n
    \n \n
    \n
    \n
    \n-
    vpred.h
    \n+
    vnm.h
    \n
    \n
    \n Go to the documentation of this file.
    1
    \n-
    30#ifndef _VPRED_H_
    \n-
    31#define _VPRED_H_
    \n-
    32
    \n-
    33#include <maloc/maloc_base.h>
    \n-
    34
    \n-
    35/* random() prototype seems to be missing in <stdlib.h> */
    \n-
    36/*
    \n-
    37 * if !defined(VOSF1)
    \n-
    38 * extern long int random(void);
    \n-
    39 * endif
    \n-
    40 */
    \n-
    41
    \n-
    42/* On some machines, the exact arithmetic routines might be defeated by the */
    \n-
    43/* use of internal extended precision floating-point registers. Sometimes */
    \n-
    44/* this problem can be fixed by defining certain values to be volatile, */
    \n-
    45/* thus forcing them to be stored to memory and rounded off. This isn't */
    \n-
    46/* a great solution, though, as it slows the arithmetic down. */
    \n-
    47/* */
    \n-
    48/* To try this out, write "#define INEXACT volatile" below. Normally, */
    \n-
    49/* however, INEXACT should be defined to be nothing. ("#define INEXACT".) */
    \n-
    50
    \n-
    52#define INEXACT /* Nothing */
    \n-
    53/* #define INEXACT volatile */
    \n-
    54
    \n-
    56#define REAL double
    \n-
    57
    \n-
    59#define REALPRINT doubleprint
    \n-
    60
    \n-
    63#define REALRAND doublerand
    \n-
    64
    \n-
    67#define NARROWRAND narrowdoublerand
    \n-
    68
    \n-
    70#define UNIFORMRAND uniformdoublerand
    \n-
    71
    \n-
    84void Vpred_exactinit(void);
    \n-
    85
    \n-\n-
    98
    \n-\n-
    111
    \n-\n-
    124
    \n-
    139REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd);
    \n-
    140
    \n-\n-
    156
    \n-\n-
    172
    \n-
    185REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd);
    \n-
    186
    \n-\n-
    200
    \n-\n-
    214
    \n-
    228REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);
    \n-
    229
    \n-
    243REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);
    \n-
    244
    \n-
    258REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);
    \n+
    33#ifndef _VNM_H_
    \n+
    34#define _VNM_H_
    \n+
    35
    \n+
    36#include <maloc/maloc_base.h>
    \n+
    37
    \n+
    38
    \n+
    46int Vnm_sigInt(void);
    \n+
    47
    \n+
    55void Vnm_sigIntSet(void);
    \n+
    56
    \n+
    64void Vnm_sigIntClear(void);
    \n+
    65
    \n+
    73int Vnm_jmpOk(void);
    \n+
    74
    \n+
    82void Vnm_jmpOkSet(void);
    \n+
    83
    \n+
    91void Vnm_jmpOkClear(void);
    \n+
    92
    \n+
    100jmp_buf *Vnm_signalInit(void);
    \n+
    101
    \n+
    109void Vnm_regHand(void);
    \n+
    110
    \n+
    119void Vnm_sigHand(int num);
    \n+
    120
    \n+
    125#define VPOW_SAFE(x,y) (Vnm_powsafe(x,y))
    \n+
    126
    \n+
    136double Vnm_powsafe(double x, double y);
    \n+
    137
    \n+
    145void Vnm_typeChk(void);
    \n+
    146
    \n+
    160double Vnm_epsmac(void);
    \n+
    161
    \n+
    196int Vnm_gentokens(char *buf, char **argv,
    \n+
    197 const int argvmax, const char *white, const char *comment);
    \n+
    198
    \n+
    203#define VTIMERS 100
    \n+
    204
    \n+
    214void Vnm_tstart(int timer, const char *name);
    \n+
    215
    \n+
    225void Vnm_tstop(int timer, const char *name);
    \n+
    226
    \n+
    236char *Vnm_getuser(char *user, int usermax);
    \n+
    237
    \n+
    247char *Vnm_getos(char *os, int osmax);
    \n+
    248
    \n+
    258char *Vnm_gethost(char *host, int hostmax);
    \n
    259
    \n-
    260#endif /* _VPRED_H_ */
    \n-
    261
    \n+
    279char *Vnm_gethome(char *path, int pathmax);
    \n+
    280
    \n+
    297char *Vnm_getcwd(char *path, int pathmax);
    \n+
    298
    \n+
    307int Vnm_chdir(const char *path);
    \n+
    308
    \n+
    317int Vnm_mkdir(const char *path);
    \n+
    318
    \n+
    327int Vnm_system(const char *cmd);
    \n+
    328
    \n+
    337int Vnm_systemBack(const char *cmd);
    \n+
    338
    \n+
    347int Vnm_systemKill(const char *cmd);
    \n+
    348
    \n+
    359int Vnm_exec(int argc, char **argv);
    \n+
    360
    \n+
    371void Vnm_sleep(int nusecs);
    \n+
    372
    \n+
    380int Vnm_ioTag(void);
    \n+
    381
    \n+
    389int Vnm_nTags(void);
    \n+
    390
    \n+
    400void Vnm_setIoTag(int myTag, int numTags);
    \n+
    401
    \n+
    429FILE *Vnm_open(const int unit);
    \n+
    430
    \n+
    440int Vnm_close(const int unit);
    \n+
    441
    \n+
    451void Vnm_flush(const int unit);
    \n+
    452
    \n+
    463void Vnm_redirect(const int flag);
    \n+
    464
    \n+
    475void Vnm_print(const int unit, const char *format, ...);
    \n+
    476
    \n+
    490void Vnm_tprint(const int unit, const char *format, ...);
    \n+
    491
    \n+
    501void Vnm_qsort(int *u, int size);
    \n+
    502
    \n+
    513void Vnm_qsortOrd(int *u, int *ord, int size);
    \n+
    514
    \n+
    524void Vnm_dqsort(double *u, int size);
    \n+
    525
    \n+
    536void Vnm_dqsortOrd(double *u, int *ord, int size);
    \n+
    537
    \n+
    538#endif /* _VNM_H_ */
    \n+
    539
    \n
    The base (or foundation) header for MALOC.
    \n-
    REAL Vpred_orient2d(REAL *pa, REAL *pb, REAL *pc)
    Adaptive exact 2D orientation test. Robust.
    \n-
    REAL Vpred_orient3dfast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
    Approximate 3D orientation test. Nonrobust.
    \n-
    #define REAL
    float or double
    Definition vpred.h:56
    \n-
    REAL Vpred_orient3dexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
    Exact 3D orientation test. Robust.
    \n-
    REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
    Approximate 3D insphere test. Nonrobust.
    \n-
    REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
    Adaptive exact 3D orientation test. Robust.
    \n-
    REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
    Exact 3D insphere test. Robust.
    \n-
    void Vpred_exactinit(void)
    Initialize the variables used for exact arithmetic.
    \n-
    REAL Vpred_incircleexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
    Exact 2D incircle test. Robust.
    \n-
    REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)
    Adaptive exact 3D insphere test. Robust.
    \n-
    REAL Vpred_orient2dfast(REAL *pa, REAL *pb, REAL *pc)
    Approximate 2D orientation test. Nonrobust.
    \n-
    REAL Vpred_orient2dexact(REAL *pa, REAL *pb, REAL *pc)
    Exact 2D orientation test. Robust.
    \n-
    REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
    Adaptive exact 2D incircle test. Robust.
    \n-
    REAL Vpred_incirclefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)
    Approximate 2D incircle test. Nonrobust.
    \n+
    int Vnm_mkdir(const char *path)
    Interact with the system to make a new directory.
    \n+
    void Vnm_sigHand(int num)
    Handle events such as SIGINT. We must have first been registered with "Vnm_signalInit".
    \n+
    int Vnm_close(const int unit)
    Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
    \n+
    char * Vnm_getos(char *os, int osmax)
    Ask the system for the operating system name.
    \n+
    int Vnm_ioTag(void)
    Return my I/O tag.
    \n+
    void Vnm_print(const int unit, const char *format,...)
    External interface to the console i/o routine. We MUST NOT use VASSERT (or Vnm_print!...
    \n+
    void Vnm_setIoTag(int myTag, int numTags)
    Set my id.
    \n+
    double Vnm_powsafe(double x, double y)
    A safe VPOW function (avoids division by zero).
    \n+
    void Vnm_qsortOrd(int *u, int *ord, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n+
    int Vnm_nTags(void)
    Return the total number of tags.
    \n+
    void Vnm_sigIntClear(void)
    Signal and setjmp handling routine. Clear the signal interrupt flag.
    \n+
    void Vnm_flush(const int unit)
    Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
    \n+
    FILE * Vnm_open(const int unit)
    Open an I/O console.
    \n+
    int Vnm_sigInt(void)
    Signal and setjmp handling routine. Return the signal interrupt flag.
    \n+
    int Vnm_system(const char *cmd)
    An improved ANSI-C "system" call.
    \n+
    int Vnm_exec(int argc, char **argv)
    An improved UNIX "exec" call. This routine does not return except on error.
    \n+
    void Vnm_dqsortOrd(double *u, int *ord, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n+
    void Vnm_jmpOkSet(void)
    Signal and setjmp handling routine. Set the "okay-to-jump" flag.
    \n+
    void Vnm_tstart(int timer, const char *name)
    Starts the timer on the particular machine.
    \n+
    char * Vnm_gethost(char *host, int hostmax)
    Ask the system for the hostname.
    \n+
    void Vnm_sleep(int nusecs)
    Implement a sleep function with microsecond resolution.
    \n+
    void Vnm_jmpOkClear(void)
    Signal and setjmp handling routine. Clear the "okay-to-jump" flag.
    \n+
    jmp_buf * Vnm_signalInit(void)
    Initialize the signal handling data structures.
    \n+
    int Vnm_chdir(const char *path)
    Interact with the system to change the working directory.
    \n+
    void Vnm_typeChk(void)
    Check out the sizes of various datatypes.
    \n+
    int Vnm_jmpOk(void)
    Signal and setjmp handling routine. Return the "ok-to-jump" flag.
    \n+
    void Vnm_tprint(const int unit, const char *format,...)
    Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
    \n+
    char * Vnm_gethome(char *path, int pathmax)
    Ask the system for the home directory.
    \n+
    double Vnm_epsmac(void)
    Computes the unit roundoff of the machine in single precision. This is defined as the smallest posi...
    \n+
    int Vnm_systemBack(const char *cmd)
    A background variant of the ANSI-C "system" call.
    \n+
    int Vnm_gentokens(char *buf, char **argv, const int argvmax, const char *white, const char *comment)
    Generate an [argv,argc] pair from a character string "buf" (assumed NULL-terminated) in which tokens ...
    \n+
    int Vnm_systemKill(const char *cmd)
    Something like a UNIX "killall" call.
    \n+
    void Vnm_qsort(int *u, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n+
    void Vnm_sigIntSet(void)
    Signal and setjmp handling routine. Set the signal interrupt flag.
    \n+
    void Vnm_redirect(const int flag)
    Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the file: ${MCSH_HOME}/io....
    \n+
    char * Vnm_getcwd(char *path, int pathmax)
    Ask the system for the current working directory.
    \n+
    char * Vnm_getuser(char *user, int usermax)
    Ask the system for the username.
    \n+
    void Vnm_regHand(void)
    Register the signal handler with the operating system.
    \n+
    void Vnm_dqsort(double *u, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n+
    void Vnm_tstop(int timer, const char *name)
    Stops the timer on the particular machine.
    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,121 +3,236 @@\n \n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n-vpred.h\n+vnm.h\n Go_to_the_documentation_of_this_file.\n 1\n- 30#ifndef _VPRED_H_\n- 31#define _VPRED_H_\n- 32\n- 33#include \n- 34\n- 35/* random() prototype seems to be missing in */\n- 36/*\n- 37 * if !defined(VOSF1)\n- 38 * extern long int random(void);\n- 39 * endif\n- 40 */\n- 41\n- 42/* On some machines, the exact arithmetic routines might be defeated by the\n-*/\n- 43/* use of internal extended precision floating-point registers. Sometimes */\n- 44/* this problem can be fixed by defining certain values to be volatile, */\n- 45/* thus forcing them to be stored to memory and rounded off. This isn't */\n- 46/* a great solution, though, as it slows the arithmetic down. */\n- 47/* */\n- 48/* To try this out, write \"#define INEXACT volatile\" below. Normally, */\n- 49/* however, INEXACT should be defined to be nothing. (\"#define INEXACT\".) */\n- 50\n-52#define INEXACT /* Nothing */\n- 53/* #define INEXACT volatile */\n- 54\n-56#define REAL double\n- 57\n-59#define REALPRINT doubleprint\n- 60\n-63#define REALRAND doublerand\n- 64\n-67#define NARROWRAND narrowdoublerand\n- 68\n-70#define UNIFORMRAND uniformdoublerand\n- 71\n-84void Vpred_exactinit(void);\n- 85\n-97REAL Vpred_orient2d(REAL *pa, REAL *pb, REAL *pc);\n- 98\n-110REAL Vpred_orient2dfast(REAL *pa, REAL *pb, REAL *pc);\n- 111\n-123REAL Vpred_orient2dexact(REAL *pa, REAL *pb, REAL *pc);\n- 124\n-139REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n- 140\n-155REAL Vpred_orient3dfast(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n- 156\n-171REAL Vpred_orient3dexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n- 172\n-185REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n- 186\n-199REAL Vpred_incirclefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n- 200\n-213REAL Vpred_incircleexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd);\n- 214\n-228REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);\n- 229\n-243REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);\n- 244\n-258REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe);\n+ 33#ifndef _VNM_H_\n+ 34#define _VNM_H_\n+ 35\n+ 36#include \n+ 37\n+ 38\n+46int Vnm_sigInt(void);\n+ 47\n+55void Vnm_sigIntSet(void);\n+ 56\n+64void Vnm_sigIntClear(void);\n+ 65\n+73int Vnm_jmpOk(void);\n+ 74\n+82void Vnm_jmpOkSet(void);\n+ 83\n+91void Vnm_jmpOkClear(void);\n+ 92\n+100jmp_buf *Vnm_signalInit(void);\n+ 101\n+109void Vnm_regHand(void);\n+ 110\n+119void Vnm_sigHand(int num);\n+ 120\n+125#define VPOW_SAFE(x,y) (Vnm_powsafe(x,y))\n+ 126\n+136double Vnm_powsafe(double x, double y);\n+ 137\n+145void Vnm_typeChk(void);\n+ 146\n+160double Vnm_epsmac(void);\n+ 161\n+196int Vnm_gentokens(char *buf, char **argv,\n+ 197 const int argvmax, const char *white, const char *comment);\n+ 198\n+203#define VTIMERS 100\n+ 204\n+214void Vnm_tstart(int timer, const char *name);\n+ 215\n+225void Vnm_tstop(int timer, const char *name);\n+ 226\n+236char *Vnm_getuser(char *user, int usermax);\n+ 237\n+247char *Vnm_getos(char *os, int osmax);\n+ 248\n+258char *Vnm_gethost(char *host, int hostmax);\n 259\n- 260#endif /* _VPRED_H_ */\n- 261\n+279char *Vnm_gethome(char *path, int pathmax);\n+ 280\n+297char *Vnm_getcwd(char *path, int pathmax);\n+ 298\n+307int Vnm_chdir(const char *path);\n+ 308\n+317int Vnm_mkdir(const char *path);\n+ 318\n+327int Vnm_system(const char *cmd);\n+ 328\n+337int Vnm_systemBack(const char *cmd);\n+ 338\n+347int Vnm_systemKill(const char *cmd);\n+ 348\n+359int Vnm_exec(int argc, char **argv);\n+ 360\n+371void Vnm_sleep(int nusecs);\n+ 372\n+380int Vnm_ioTag(void);\n+ 381\n+389int Vnm_nTags(void);\n+ 390\n+400void Vnm_setIoTag(int myTag, int numTags);\n+ 401\n+429FILE *Vnm_open(const int unit);\n+ 430\n+440int Vnm_close(const int unit);\n+ 441\n+451void Vnm_flush(const int unit);\n+ 452\n+463void Vnm_redirect(const int flag);\n+ 464\n+475void Vnm_print(const int unit, const char *format, ...);\n+ 476\n+490void Vnm_tprint(const int unit, const char *format, ...);\n+ 491\n+501void Vnm_qsort(int *u, int size);\n+ 502\n+513void Vnm_qsortOrd(int *u, int *ord, int size);\n+ 514\n+524void Vnm_dqsort(double *u, int size);\n+ 525\n+536void Vnm_dqsortOrd(double *u, int *ord, int size);\n+ 537\n+ 538#endif /* _VNM_H_ */\n+ 539\n maloc_base.h\n The base (or foundation) header for MALOC.\n-Vpred_orient2d\n-REAL Vpred_orient2d(REAL *pa, REAL *pb, REAL *pc)\n-Adaptive exact 2D orientation test. Robust.\n-Vpred_orient3dfast\n-REAL Vpred_orient3dfast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-Approximate 3D orientation test. Nonrobust.\n-REAL\n-#define REAL\n-float or double\n-Definition vpred.h:56\n-Vpred_orient3dexact\n-REAL Vpred_orient3dexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-Exact 3D orientation test. Robust.\n-Vpred_inspherefast\n-REAL Vpred_inspherefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n-Approximate 3D insphere test. Nonrobust.\n-Vpred_orient3d\n-REAL Vpred_orient3d(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-Adaptive exact 3D orientation test. Robust.\n-Vpred_insphereexact\n-REAL Vpred_insphereexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n-Exact 3D insphere test. Robust.\n-Vpred_exactinit\n-void Vpred_exactinit(void)\n-Initialize the variables used for exact arithmetic.\n-Vpred_incircleexact\n-REAL Vpred_incircleexact(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-Exact 2D incircle test. Robust.\n-Vpred_insphere\n-REAL Vpred_insphere(REAL *pa, REAL *pb, REAL *pc, REAL *pd, REAL *pe)\n-Adaptive exact 3D insphere test. Robust.\n-Vpred_orient2dfast\n-REAL Vpred_orient2dfast(REAL *pa, REAL *pb, REAL *pc)\n-Approximate 2D orientation test. Nonrobust.\n-Vpred_orient2dexact\n-REAL Vpred_orient2dexact(REAL *pa, REAL *pb, REAL *pc)\n-Exact 2D orientation test. Robust.\n-Vpred_incircle\n-REAL Vpred_incircle(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-Adaptive exact 2D incircle test. Robust.\n-Vpred_incirclefast\n-REAL Vpred_incirclefast(REAL *pa, REAL *pb, REAL *pc, REAL *pd)\n-Approximate 2D incircle test. Nonrobust.\n+Vnm_mkdir\n+int Vnm_mkdir(const char *path)\n+Interact with the system to make a new directory.\n+Vnm_sigHand\n+void Vnm_sigHand(int num)\n+Handle events such as SIGINT. We must have first been registered with\n+\"Vnm_signalInit\".\n+Vnm_close\n+int Vnm_close(const int unit)\n+Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n+Vnm_getos\n+char * Vnm_getos(char *os, int osmax)\n+Ask the system for the operating system name.\n+Vnm_ioTag\n+int Vnm_ioTag(void)\n+Return my I/O tag.\n+Vnm_print\n+void Vnm_print(const int unit, const char *format,...)\n+External interface to the console i/o routine. We MUST NOT use VASSERT (or\n+Vnm_print!...\n+Vnm_setIoTag\n+void Vnm_setIoTag(int myTag, int numTags)\n+Set my id.\n+Vnm_powsafe\n+double Vnm_powsafe(double x, double y)\n+A safe VPOW function (avoids division by zero).\n+Vnm_qsortOrd\n+void Vnm_qsortOrd(int *u, int *ord, int size)\n+Front-end to quick sort integer array from [-large] to [+large].\n+Vnm_nTags\n+int Vnm_nTags(void)\n+Return the total number of tags.\n+Vnm_sigIntClear\n+void Vnm_sigIntClear(void)\n+Signal and setjmp handling routine. Clear the signal interrupt flag.\n+Vnm_flush\n+void Vnm_flush(const int unit)\n+Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or\n+Vnm_print!) in this routine.\n+Vnm_open\n+FILE * Vnm_open(const int unit)\n+Open an I/O console.\n+Vnm_sigInt\n+int Vnm_sigInt(void)\n+Signal and setjmp handling routine. Return the signal interrupt flag.\n+Vnm_system\n+int Vnm_system(const char *cmd)\n+An improved ANSI-C \"system\" call.\n+Vnm_exec\n+int Vnm_exec(int argc, char **argv)\n+An improved UNIX \"exec\" call. This routine does not return except on error.\n+Vnm_dqsortOrd\n+void Vnm_dqsortOrd(double *u, int *ord, int size)\n+Front-end to quick sort integer array from [-large] to [+large].\n+Vnm_jmpOkSet\n+void Vnm_jmpOkSet(void)\n+Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.\n+Vnm_tstart\n+void Vnm_tstart(int timer, const char *name)\n+Starts the timer on the particular machine.\n+Vnm_gethost\n+char * Vnm_gethost(char *host, int hostmax)\n+Ask the system for the hostname.\n+Vnm_sleep\n+void Vnm_sleep(int nusecs)\n+Implement a sleep function with microsecond resolution.\n+Vnm_jmpOkClear\n+void Vnm_jmpOkClear(void)\n+Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.\n+Vnm_signalInit\n+jmp_buf * Vnm_signalInit(void)\n+Initialize the signal handling data structures.\n+Vnm_chdir\n+int Vnm_chdir(const char *path)\n+Interact with the system to change the working directory.\n+Vnm_typeChk\n+void Vnm_typeChk(void)\n+Check out the sizes of various datatypes.\n+Vnm_jmpOk\n+int Vnm_jmpOk(void)\n+Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.\n+Vnm_tprint\n+void Vnm_tprint(const int unit, const char *format,...)\n+Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in\n+this routine.\n+Vnm_gethome\n+char * Vnm_gethome(char *path, int pathmax)\n+Ask the system for the home directory.\n+Vnm_epsmac\n+double Vnm_epsmac(void)\n+Computes the unit roundoff of the machine in single precision. This is defined\n+as the smallest posi...\n+Vnm_systemBack\n+int Vnm_systemBack(const char *cmd)\n+A background variant of the ANSI-C \"system\" call.\n+Vnm_gentokens\n+int Vnm_gentokens(char *buf, char **argv, const int argvmax, const char *white,\n+const char *comment)\n+Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-\n+terminated) in which tokens ...\n+Vnm_systemKill\n+int Vnm_systemKill(const char *cmd)\n+Something like a UNIX \"killall\" call.\n+Vnm_qsort\n+void Vnm_qsort(int *u, int size)\n+Front-end to quick sort integer array from [-large] to [+large].\n+Vnm_sigIntSet\n+void Vnm_sigIntSet(void)\n+Signal and setjmp handling routine. Set the signal interrupt flag.\n+Vnm_redirect\n+void Vnm_redirect(const int flag)\n+Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the\n+file: ${MCSH_HOME}/io....\n+Vnm_getcwd\n+char * Vnm_getcwd(char *path, int pathmax)\n+Ask the system for the current working directory.\n+Vnm_getuser\n+char * Vnm_getuser(char *user, int usermax)\n+Ask the system for the username.\n+Vnm_regHand\n+void Vnm_regHand(void)\n+Register the signal handler with the operating system.\n+Vnm_dqsort\n+void Vnm_dqsort(double *u, int size)\n+Front-end to quick sort integer array from [-large] to [+large].\n+Vnm_tstop\n+void Vnm_tstop(int timer, const char *name)\n+Stops the timer on the particular machine.\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00033.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00033.dot.gz", "unified_diff": null, "details": [{"source1": "a00033.dot", "source2": "a00033.dot", "unified_diff": "@@ -1,14 +1,14 @@\n-digraph \"vpred.h\"\n+digraph \"vnm.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vpred.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node1 [id=\"Node000001\",label=\"vnm.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc/maloc_base.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00002.html\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"assert.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"ctype.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge4_Node000002_Node000005\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00034.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00034.dot", "unified_diff": "@@ -1,28 +1,34 @@\n-digraph \"vpred.h\"\n+digraph \"vnm.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vpred.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node1 [id=\"Node000001\",label=\"vnm.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node2 [id=\"Node000002\",label=\"vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n- Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node4 [id=\"Node000004\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n- Node4 -> Node3 [id=\"edge4_Node000004_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node5 [id=\"edge5_Node000002_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node5 [id=\"Node000005\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n- Node5 -> Node6 [id=\"edge6_Node000005_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node6 [id=\"Node000006\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n- Node6 -> Node4 [id=\"edge7_Node000006_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node6 [id=\"edge8_Node000002_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node7 [id=\"edge9_Node000002_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node7 [id=\"Node000007\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n- Node7 -> Node6 [id=\"edge10_Node000007_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 -> Node8 [id=\"edge11_Node000002_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node8 [id=\"Node000008\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n- Node8 -> Node3 [id=\"edge12_Node000008_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node8 -> Node4 [id=\"edge13_Node000008_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 [id=\"Node000003\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node3 -> Node4 [id=\"edge3_Node000003_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node4 [id=\"Node000004\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n+ Node3 -> Node5 [id=\"edge4_Node000003_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node5 [id=\"Node000005\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node5 -> Node4 [id=\"edge5_Node000005_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 -> Node6 [id=\"edge6_Node000003_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node6 [id=\"Node000006\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node6 -> Node7 [id=\"edge7_Node000006_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node7 [id=\"Node000007\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node7 -> Node5 [id=\"edge8_Node000007_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 -> Node7 [id=\"edge9_Node000003_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 -> Node8 [id=\"edge10_Node000003_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node8 [id=\"Node000008\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n+ Node8 -> Node7 [id=\"edge11_Node000008_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 -> Node9 [id=\"edge12_Node000003_Node000009\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node9 [id=\"Node000009\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n+ Node9 -> Node4 [id=\"edge13_Node000009_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node9 -> Node5 [id=\"edge14_Node000009_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node10 [id=\"edge15_Node000001_Node000010\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node10 [id=\"Node000010\",label=\"vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n+ Node10 -> Node3 [id=\"edge16_Node000010_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node1 -> Node3 [id=\"edge17_Node000001_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00035.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00035.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vnm.h File Reference\n+MALOC: vio.h File Reference\n \n \n \n \n \n \n
    \n@@ -40,190 +40,168 @@\n
    \n \n
    \n
    \n
    \n \n-
    vnm.h File Reference
    \n+
    vio.h File Reference
    \n
    \n
    \n \n-

    Header file for an ISO C [V]irtual [N]umerical [M]achine. \n+

    Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer. \n More...

    \n
    #include <maloc/maloc_base.h>
    \n+#include <maloc/vnm.h>
    \n
    \n-Include dependency graph for vnm.h:
    \n+Include dependency graph for vio.h:
    \n
    \n-
    \"\"/
    \n+
    \"\"/
    \n
    \n
    \n This graph shows which files directly or indirectly include this file:
    \n
    \n-
    \"\"/
    \n+
    \"\"/
    \n
    \n
    \n

    Go to the source code of this file.

    \n \n+\n+\n+\n+\n+

    \n+Classes

    struct  sVio
     Contains public data members for Vio class. More...
     
    \n \n-\n-\n-\n-\n-\n-\n+\n+\n+\n+\n+\n+\n+

    \n Macros

    #define VPOW_SAFE(x, y)   (Vnm_powsafe(x,y))
     A safe VPOW function (avoids division by zero)
     
    #define VTIMERS   100
     the maiximal timer constant
     
    #define VPORTNUMBER   14916
     our portbase; 5000 < VPORTNUMBER < 49152
     
    #define VIO_MAXBUF   10
     number of internal buffers (BUFF datatype)
     
    \n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+

    \n+Typedefs

    typedef enum VIOtype VIOtype
     Parameter for I/O type (sdio,buff,file,unix,inet)
     
    typedef enum VIOfrmt VIOfrmt
     Parameter for compression type (XDR,ASC)
     
    typedef enum VIOrwkey VIOrwkey
     Parameter for rw type (R,RW)
     
    typedef struct sVio Vio
     Declaration of the Vio class as the Vio structure.
     
    \n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n

    \n+Enumerations

    enum  VIOtype {
    \n+  VIO_NO_TYPE\n+, VIO_SDIO\n+, VIO_BUFF\n+, VIO_FILE\n+,
    \n+  VIO_UNIX\n+, VIO_INET\n+
    \n+ }
     Parameter for I/O type (sdio,buff,file,unix,inet) More...
     
    enum  VIOfrmt { VIO_NO_FRMT\n+, VIO_XDR\n+, VIO_ASC\n+ }
     Parameter for compression type (XDR,ASC) More...
     
    enum  VIOrwkey { VIO_NO_RW\n+, VIO_R\n+, VIO_W\n+ }
     Parameter for rw type (R,RW) More...
     
    \n \n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n-\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n+\n

    \n Functions

    int Vnm_sigInt (void)
     Signal and setjmp handling routine. Return the signal interrupt flag.
     
    void Vnm_sigIntSet (void)
     Signal and setjmp handling routine. Set the signal interrupt flag.
     
    void Vnm_sigIntClear (void)
     Signal and setjmp handling routine. Clear the signal interrupt flag.
    \n-
     
    int Vnm_jmpOk (void)
     Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.
     
    void Vnm_jmpOkSet (void)
     Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.
     
    void Vnm_jmpOkClear (void)
     Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.
    \n-
     
    jmp_buf * Vnm_signalInit (void)
     Initialize the signal handling data structures.
     
    void Vnm_regHand (void)
     Register the signal handler with the operating system.
     
    void Vnm_sigHand (int num)
     Handle events such as SIGINT. We must have first been registered with \"Vnm_signalInit\".
     
    double Vnm_powsafe (double x, double y)
     A safe VPOW function (avoids division by zero).
    \n-
     
    void Vnm_typeChk (void)
     Check out the sizes of various datatypes.
    \n-
     
    double Vnm_epsmac (void)
     Computes the unit roundoff of the machine in single
    \n- precision. This is defined as the smallest positive machine number u such that 1.0d0 + u .ne. 1.0d0 (in single precision).
    \n-
    \n- A safe hardcoded machine epsilon as alternative:
    \n- double value;
    \n- value = 1.0e-9;
    \n- return value;.
     
    int Vnm_gentokens (char *buf, char **argv, const int argvmax, const char *white, const char *comment)
     Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-terminated) in which tokens are separated by whitespace \"white\" with possible comments \"comment\" occuring. THE INPUT STRING IS MODIFIED HERE!
     
    void Vnm_tstart (int timer, const char *name)
     Starts the timer on the particular machine.
    \n-
     
    void Vnm_tstop (int timer, const char *name)
     Stops the timer on the particular machine.
     
    char * Vnm_getuser (char *user, int usermax)
     Ask the system for the username.
     
    char * Vnm_getos (char *os, int osmax)
     Ask the system for the operating system name.
     
    char * Vnm_gethost (char *host, int hostmax)
     Ask the system for the hostname.
     
    char * Vnm_gethome (char *path, int pathmax)
     Ask the system for the home directory.
     
    char * Vnm_getcwd (char *path, int pathmax)
     Ask the system for the current working directory.
     
    int Vnm_chdir (const char *path)
     Interact with the system to change the working directory.
     
    int Vnm_mkdir (const char *path)
     Interact with the system to make a new directory.
    \n-
     
    int Vnm_system (const char *cmd)
     An improved ANSI-C \"system\" call.
     
    int Vnm_systemBack (const char *cmd)
     A background variant of the ANSI-C \"system\" call.
    \n-
     
    int Vnm_systemKill (const char *cmd)
     Something like a UNIX \"killall\" call.
     
    int Vnm_exec (int argc, char **argv)
     An improved UNIX \"exec\" call. This routine does not return except on error.
     
    void Vnm_sleep (int nusecs)
     Implement a sleep function with microsecond resolution.
     
    int Vnm_ioTag (void)
     Return my I/O tag.
     
    int Vnm_nTags (void)
     Return the total number of tags.
     
    void Vnm_setIoTag (int myTag, int numTags)
     Set my id.
     
    FILE * Vnm_open (const int unit)
     Open an I/O console.
     
    int Vnm_close (const int unit)
     Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_flush (const int unit)
     Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_redirect (const int flag)
     Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_print (const int unit, const char *format,...)
     External interface to the console i/o routine.
    \n- We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_tprint (const int unit, const char *format,...)
     Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
     
    void Vnm_qsort (int *u, int size)
     Front-end to quick sort integer array from [-large] to [+large].
    \n-
     
    void Vnm_qsortOrd (int *u, int *ord, int size)
     Front-end to quick sort integer array from [-large] to [+large].
     
    void Vnm_dqsort (double *u, int size)
     Front-end to quick sort integer array from [-large] to [+large].
    \n-
     
    void Vnm_dqsortOrd (double *u, int *ord, int size)
     Front-end to quick sort integer array from [-large] to [+large].
     
    void Vio_start (void)
     Start Vio communication layer (init internal variables/buffers)
     
    void Vio_stop (void)
     Shutdown Vio communication layer.
     
    VioVio_ctor (const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
     Construct the Vio object.
     
    int Vio_ctor2 (Vio *thee, const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
     Work routine that Vio_ctor calls to do most of the construction.
     
    void Vio_dtor (Vio **thee)
     Destruct the Vio object.
     
    void Vio_dtor2 (Vio *thee)
     Work routine that Vio_dtor calls to do most of the destruction.
     
    void Vio_setWhiteChars (Vio *thee, char *whiteChars)
     Set the white character set for I/O stream.
     
    void Vio_setCommChars (Vio *thee, char *commChars)
     Set the comment character set for I/O stream.
     
    int Vio_accept (Vio *thee, int nonblock)
     Accept any waiting connect attempt to our socket on our machine.
     
    void Vio_acceptFree (Vio *thee)
     Free the socket child that was used for the last accept.
     
    int Vio_connect (Vio *thee, int nonblock)
     Connect to some socket on a remote machine (or on our machine)
     
    void Vio_connectFree (Vio *thee)
     Purge any output buffers (for <UNIX/INET>, else a no-op)
     
    int Vio_scanf (Vio *thee, char *parms,...)
     Mimic \"scanf\" from an arbitrary Vio device.
     
    int Vio_printf (Vio *thee, char *parms,...)
     Mimic \"printf\" from an arbitrary Vio device.
     
    int Vio_read (Vio *thee, char *buf, int bufsize)
     Read (up to) bufsize characters into buf from input device.
     
    int Vio_write (Vio *thee, char *buf, int bufsize)
     Write bufsize characters from buf to output device.
     
    void Vio_bufTake (Vio *thee, char *buf, int bufsize)
     Set the pointer to the internal buffer.
     
    char * Vio_bufGive (Vio *thee)
     Return the pointer to the internal buffer.
     
    int Vio_bufSize (Vio *thee)
     Return the length to the internal buffer.
     
    VioVio_socketOpen (char *key, const char *iodev, const char *iofmt, const char *iohost, const char *iofile)
     Socket open for read or write.
     
    void Vio_socketClose (Vio **sock)
     Socket close from read or write.
     
    \n

    Detailed Description

    \n-

    Header file for an ISO C [V]irtual [N]umerical [M]achine.

    \n-
    Author
    Michael Holst
    \n-
    Note
    None
    \n+

    Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.

    \n
    Version
    \n-
    Id
    vnm.h,v 1.22 2010/08/12 05:40:36 fetk Exp
    \n+
    Id
    vio.h,v 1.28 2010/08/12 05:40:35 fetk Exp
    \n+
    Author
    Michael Holst
    \n
    Attention
    *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n@@ -234,1447 +212,45 @@\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n * Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n * \n-*  
    \n+* \n

    Macro Definition Documentation

    \n-\n-

    ◆ VPOW_SAFE

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    #define VPOW_SAFE( x,
     
    )   (Vnm_powsafe(x,y))
    \n-
    \n-\n-

    A safe VPOW function (avoids division by zero)

    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-\n-
    \n-
    \n-\n-

    ◆ VTIMERS

    \n-\n-
    \n-
    \n- \n- \n- \n- \n-
    #define VTIMERS   100
    \n-
    \n-\n-

    the maiximal timer constant

    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-\n-
    \n-
    \n-

    Function Documentation

    \n-\n-

    ◆ Vnm_chdir()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_chdir (const char * path)
    \n-
    \n-\n-

    Interact with the system to change the working directory.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    Success enumeration
    \n-
    Parameters
    \n- \n- \n-
    pathPointer to the path
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_close()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_close (const int unit)
    \n-
    \n-\n-

    Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    Success enumeration
    \n-
    Parameters
    \n- \n- \n-
    unitindex for the file unit
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_dqsort()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_dqsort (double * u,
    int size 
    )
    \n-
    \n-\n-

    Front-end to quick sort integer array from [-large] to [+large].
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n-
    uPointer to quick sort integer array
    sizesize of the integer array
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_dqsortOrd()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_dqsortOrd (double * u,
    int * ord,
    int size 
    )
    \n-
    \n-\n-

    Front-end to quick sort integer array from [-large] to [+large].

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n- \n-
    uPointer to quick sort integer array
    ordPointer to reordered array
    sizesize of the integer array
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_epsmac()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    double Vnm_epsmac (void )
    \n-
    \n-\n-

    Computes the unit roundoff of the machine in single
    \n- precision. This is defined as the smallest positive machine number u such that 1.0d0 + u .ne. 1.0d0 (in single precision).
    \n-
    \n- A safe hardcoded machine epsilon as alternative:
    \n- double value;
    \n- value = 1.0e-9;
    \n- return value;.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    the unit roundoff of the machine in single precision.
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_exec()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_exec (int argc,
    char ** argv 
    )
    \n-
    \n-\n-

    An improved UNIX \"exec\" call. This routine does not return except on error.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    no return except on error
    \n-
    Parameters
    \n- \n- \n- \n-
    argcnumber of the command line arguments
    argvthe command line arguments
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_flush()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_flush (const int unit)
    \n-
    \n-\n-

    Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n-
    unitindex for the file unit
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_gentokens()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_gentokens (char * buf,
    char ** argv,
    const int argvmax,
    const char * white,
    const char * comment 
    )
    \n-
    \n-\n-

    Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-terminated) in which tokens are separated by whitespace \"white\" with possible comments \"comment\" occuring. THE INPUT STRING IS MODIFIED HERE!

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    \n- Again, the input string \"buf\" IS MODIFIED; white space characters (defined in the input string \"white\") are replaced by the NULL character '\\0'. The output \"argv\" is simply a list of pointers
    \n- to the start of the tokens in \"buf\", which are NULL-terminated
    \n- after we replace the white space with NULLs.
    \n-
    \n- We follow convention and \"NULL\"-terminate \"argv\" by setting the pointer following the last token to \"VNULL\". The return value is \"argc\", the number of tokens found (not including the terminating NULL pointer). For safety you must pass in the maximal length of argv in the parameter \"argvmax\".
    \n-
    \n- If we encounter a token which begins with a comment character (defined in the input string \"comment\"), then we ignore the rest of the tokens in the input buffer \"buf\". This is suitable
    \n- for parsing shell languages such as sh/ksh/bash which have comments that start with e.g. \"#\" and continue until a newline.
    \n-
    \n- We DO NOT use the C library function strtok in this routine. (There are some bad implementations of strtok around apparently; the internal state variables maintained by strtok can get very
    \n- messed up if you use strtok in multiple places in a code.)
    \n-
    Returns
    number of tokens
    \n-
    Parameters
    \n- \n- \n- \n- \n- \n- \n-
    bufbuffer containing message
    argvthe command line arguments
    argvmaxmaximal number of the command line arguments
    whitePointer to the input string
    commenttoken which begins with a comment character
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_getcwd()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    char * Vnm_getcwd (char * path,
    int pathmax 
    )
    \n-
    \n-\n-

    Ask the system for the current working directory.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    \n- Consider it an error if we can't return something useful; therefore we will VASSERT(path!=VNULL) before returning.
    \n-
    \n- Note that unlike Vnm_gethome, a call to Vnm_getcwd returns the current directory, possibly modified from call to call.
    \n-
    \n- I.e., calls to Vnm_chdir can change the current working
    \n- directory; Vnm_getcwd returns the current directory, whatever that might be.
    \n-
    Returns
    the current working directory
    \n-
    Parameters
    \n- \n- \n- \n-
    pathPointer to the path
    pathmaxindex for the size of path
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_gethome()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    char * Vnm_gethome (char * path,
    int pathmax 
    )
    \n-
    \n-\n-

    Ask the system for the home directory.

    \n-

    =

    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    \n- The following preference order is used to set the home directory:
    \n-
    \n- MCSH_HOME (the user must define this in his environment)
    \n- CWD (always defined as the current working directory)
    \n-
    \n- We consider it an error if we can't return something useful;
    \n- therefore we will VASSERT(path!=VNULL) before returning.
    \n-
    \n- We settle on a home directory the first time we are called, and then we simply return this fixed home directory forever.
    \n- In other words, the first call to Vnm_gethome, regardless of
    \n- who makes the call, establishes the home directory for everyone else (as long as everyone goes through Vnm_gethome!).
    \n-
    Returns
    the home directory
    \n-
    Parameters
    \n- \n- \n- \n-
    pathPointer to the path
    pathmaxindex for the size of path
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_gethost()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    char * Vnm_gethost (char * host,
    int hostmax 
    )
    \n-
    \n-\n-

    Ask the system for the hostname.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    the hostname
    \n-
    Parameters
    \n- \n- \n- \n-
    hostPointer to the hostname.
    hostmaxindex for maximal size of host name
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_getos()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    char * Vnm_getos (char * os,
    int osmax 
    )
    \n-
    \n-\n-

    Ask the system for the operating system name.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    the operating system name
    \n-
    Parameters
    \n- \n- \n- \n-
    osPointer to the OS type
    osmaxindex for maximal size of OS name
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_getuser()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    char * Vnm_getuser (char * user,
    int usermax 
    )
    \n-
    \n-\n-

    Ask the system for the username.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    the username of the system
    \n-
    Parameters
    \n- \n- \n- \n-
    userPointer to the username of the system
    usermaxindex for maximal size of user name
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_ioTag()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_ioTag (void )
    \n-
    \n-\n-

    Return my I/O tag.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    my I/O tag.
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_jmpOk()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_jmpOk (void )
    \n-
    \n-\n-

    Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    \"ok-to-jump\" flag.
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_jmpOkClear()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_jmpOkClear (void )
    \n-
    \n-\n-

    Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_jmpOkSet()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_jmpOkSet (void )
    \n-
    \n-\n-

    Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.

    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Author
    Michael Holst
    \n-
    Returns
    None
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_mkdir()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_mkdir (const char * path)
    \n-
    \n-\n-

    Interact with the system to make a new directory.
    \n-

    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Author
    Michael Holst
    \n-
    Returns
    Success enumeration
    \n-
    Parameters
    \n- \n- \n-
    pathPointer to the path
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_nTags()

    \n+\n+

    ◆ VIO_MAXBUF

    \n \n
    \n
    \n \n \n- \n- \n- \n- \n- \n- \n-
    int Vnm_nTags (void )
    \n-
    \n-\n-

    Return the total number of tags.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    total number of tags.
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_open()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    FILE * Vnm_open (const int unit)
    \n-
    \n-\n-

    Open an I/O console.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    We MUST NOT use VASSERT (or Vnm_print!) in this routine.   \n-\n-The following codes are used:                                               \n-\n-unit#      C output unit      \n--------    -------------                                                \n-\n-unit==0    garbage   -- Non-interactive i/o; lots of stuff                        \n-                        (can be redirected to ${MCSH_HOME/io.mc)\n-\n-unit==1    stdout    -- standard output (Interactive I/O)            \n-\n-unit==2    stderr    -- standard error (IMPORTANT interactive I/O)          \n-\n-unit==3    history   -- History file ${MCSH_HOME}/hist.mcsh                       \n-\n-unit==else /dev/null -- Error...                                \n-
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n-
    unitindex for the file unit
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_powsafe()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    double Vnm_powsafe (double x,
    double y 
    )
    \n-
    \n-\n-

    A safe VPOW function (avoids division by zero).
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    output value of a VPOW function
    \n-
    Parameters
    \n- \n- \n- \n-
    xinput parameter
    yinput parameter
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_print()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_print (const int unit,
    const char * format,
     ... 
    )
    \n-
    \n-\n-

    External interface to the console i/o routine.
    \n- We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n-
    unitindex for the file unit
    formatPointer to the print format
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_qsort()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_qsort (int * u,
    int size 
    )
    \n-
    \n-\n-

    Front-end to quick sort integer array from [-large] to [+large].
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n-
    uPointer to quick sort integer array
    sizesize of the integer array
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_qsortOrd()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_qsortOrd (int * u,
    int * ord,
    int size 
    )
    \n-
    \n-\n-

    Front-end to quick sort integer array from [-large] to [+large].

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None *
    \n-
    Author
    Michael Holst
    \n-
    Parameters
    \n- \n- \n- \n- \n-
    uPointer to quick sort integer array
    ordPointer to reordered array
    sizesize of the integer array
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_redirect()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_redirect (const int flag)
    \n-
    \n-\n-

    Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n-
    flagindex for the redirect flag
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_regHand()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_regHand (void )
    \n-
    \n-\n-

    Register the signal handler with the operating system.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_setIoTag()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_setIoTag (int myTag,
    int numTags 
    )
    \n-
    \n-\n-

    Set my id.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n-
    myTagindex for the tag
    numTagsnumber of tags
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_sigHand()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_sigHand (int num)
    \n-
    \n-\n-

    Handle events such as SIGINT. We must have first been registered with \"Vnm_signalInit\".

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_sigInt()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_sigInt (void )
    \n-
    \n-\n-

    Signal and setjmp handling routine. Return the signal interrupt flag.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    Signal interrupt flag.
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_sigIntClear()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_sigIntClear (void )
    \n-
    \n-\n-

    Signal and setjmp handling routine. Clear the signal interrupt flag.
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_sigIntSet()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_sigIntSet (void )
    \n-
    \n-\n-

    Signal and setjmp handling routine. Set the signal interrupt flag.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_signalInit()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    jmp_buf * Vnm_signalInit (void )
    \n-
    \n-\n-

    Initialize the signal handling data structures.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    the signal handling data structures
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_sleep()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_sleep (int nusecs)
    \n-
    \n-\n-

    Implement a sleep function with microsecond resolution.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n- This is hacked out of the \"sleep_us\" example in Rick Steven's Advance Unix Programming book.
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n-
    nusecsnumber of microseconds
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_system()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_system (const char * cmd)
    \n-
    \n-\n-

    An improved ANSI-C \"system\" call.

    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Author
    Michael Holst
    \n-
    Returns
    Success enumeration
    \n-
    Parameters
    \n- \n- \n-
    cmdPointer to the command
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_systemBack()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_systemBack (const char * cmd)
    \n-
    \n-\n-

    A background variant of the ANSI-C \"system\" call.
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    Success enumeration
    \n-
    Parameters
    \n- \n- \n-
    cmdPointer to the command
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_systemKill()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n-
    int Vnm_systemKill (const char * cmd)
    \n-
    \n-\n-

    Something like a UNIX \"killall\" call.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    Success enumeration
    \n-
    Parameters
    \n- \n- \n-
    cmdPointer to the command
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_tprint()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_tprint (const int unit,
    const char * format,
     ... 
    )
    \n-
    \n-\n-

    Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in this routine.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o) For a tag to be added, both of the following conditions must hold:
    \n- Vnm_ioTag() >= 0 (I.e., I must have been given a tag)
    \n- Vnm_nTags() > 1 (I must not be the only one given a tag)
    \n-
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n-
    unitindex for the file unit
    formatPointer to the print format
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_tstart()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n-
    void Vnm_tstart (int timer,
    const char * name 
    )
    \n-
    \n-\n-

    Starts the timer on the particular machine.
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n-
    timerindex for the starting timer
    namePointer to the object
    \n-
    \n-
    \n-\n-
    \n-
    \n-\n-

    ◆ Vnm_tstop()

    \n-\n-
    \n-
    \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n- \n+ \n \n
    void Vnm_tstop (int timer,
    const char * name 
    )#define VIO_MAXBUF   10
    \n
    \n \n-

    Stops the timer on the particular machine.

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n-
    Parameters
    \n- \n- \n- \n-
    timerindex for the starting timer
    namePointer to the object
    \n-
    \n-
    \n+

    number of internal buffers (BUFF datatype)

    \n \n
    \n
    \n-\n-

    ◆ Vnm_typeChk()

    \n+\n+

    ◆ VPORTNUMBER

    \n \n
    \n
    \n \n \n- \n- \n- \n- \n- \n+ \n \n
    void Vnm_typeChk (void )#define VPORTNUMBER   14916
    \n
    \n \n-

    Check out the sizes of various datatypes.
    \n-

    \n-
    Author
    Michael Holst
    \n-
    Note
    Useful constants and functions (timers, epsilon, token generators, i/o)
    \n-
    Returns
    None
    \n+

    our portbase; 5000 < VPORTNUMBER < 49152

    \n \n
    \n
    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,188 +3,134 @@\n \n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n-Macros | Functions\n-vnm.h File Reference\n-Header file for an ISO C [V]irtual [N]umerical [M]achine. More...\n+Classes | Macros | Typedefs | Enumerations | Functions\n+vio.h File Reference\n+Vio_class\n+Class Vio: virtual I/O layer. More...\n #include \n-Include dependency graph for vnm.h:\n+#include \n+Include dependency graph for vio.h:\n This graph shows which files directly or indirectly include this file:\n Go_to_the_source_code_of_this_file.\n- Macros\n-#define\u00a0VPOW_SAFE(x, y)\u00a0\u00a0\u00a0(Vnm_powsafe(x,y))\n-\u00a0 A safe VPOW function (avoids division by zero)\n-\u00a0\n-#define\u00a0VTIMERS\u00a0\u00a0\u00a0100\n-\u00a0 the maiximal timer constant\n-\u00a0\n- Functions\n- int\u00a0Vnm_sigInt (void)\n-\u00a0 Signal and setjmp handling routine. Return the signal interrupt\n- flag.\n-\u00a0\n- void\u00a0Vnm_sigIntSet (void)\n-\u00a0 Signal and setjmp handling routine. Set the signal interrupt flag.\n-\u00a0\n- void\u00a0Vnm_sigIntClear (void)\n- Signal and setjmp handling routine. Clear the signal interrupt flag.\n-\u00a0\n-\n-\u00a0\n- int\u00a0Vnm_jmpOk (void)\n-\u00a0 Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.\n+ Classes\n+struct \u00a0sVio\n+\u00a0 Contains public data members for Vio class. More...\n \u00a0\n- void\u00a0Vnm_jmpOkSet (void)\n-\u00a0 Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.\n-\u00a0\n- void\u00a0Vnm_jmpOkClear (void)\n-\u00a0 Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.\n-\n-\u00a0\n-jmp_buf *\u00a0Vnm_signalInit (void)\n-\u00a0 Initialize the signal handling data structures.\n-\u00a0\n- void\u00a0Vnm_regHand (void)\n-\u00a0 Register the signal handler with the operating system.\n-\u00a0\n- void\u00a0Vnm_sigHand (int num)\n-\u00a0 Handle events such as SIGINT. We must have first been registered\n- with \"Vnm_signalInit\".\n-\u00a0\n- double\u00a0Vnm_powsafe (double x, double y)\n-\u00a0 A safe VPOW function (avoids division by zero).\n-\n+ Macros\n+#define\u00a0VPORTNUMBER\u00a0\u00a0\u00a014916\n+\u00a0 our portbase; 5000 < VPORTNUMBER < 49152\n \u00a0\n- void\u00a0Vnm_typeChk (void)\n-\u00a0 Check out the sizes of various datatypes.\n-\n+#define\u00a0VIO_MAXBUF\u00a0\u00a0\u00a010\n+\u00a0 number of internal buffers (BUFF datatype)\n \u00a0\n- double\u00a0Vnm_epsmac (void)\n- Computes the unit roundoff of the machine in single\n- precision. This is defined as the smallest positive machine number u\n- such that 1.0d0 + u .ne. 1.0d0 (in single precision).\n-\u00a0\n- A safe hardcoded machine epsilon as alternative:\n- double value;\n- value = 1.0e-9;\n- return value;.\n-\u00a0\n- int\u00a0Vnm_gentokens (char *buf, char **argv, const int argvmax, const char\n- *white, const char *comment)\n- Generate an [argv,argc] pair from a character string \"buf\" (assumed\n-\u00a0 NULL-terminated) in which tokens are separated by whitespace \"white\"\n- with possible comments \"comment\" occuring. THE INPUT STRING IS\n- MODIFIED HERE!\n+ Typedefs\n+ typedef enum VIOtype\u00a0VIOtype\n+\u00a0 Parameter for I/O type (sdio,buff,file,unix,inet)\n \u00a0\n- void\u00a0Vnm_tstart (int timer, const char *name)\n-\u00a0 Starts the timer on the particular machine.\n-\n+ typedef enum VIOfrmt\u00a0VIOfrmt\n+\u00a0 Parameter for compression type (XDR,ASC)\n \u00a0\n- void\u00a0Vnm_tstop (int timer, const char *name)\n-\u00a0 Stops the timer on the particular machine.\n+typedef enum VIOrwkey\u00a0VIOrwkey\n+\u00a0 Parameter for rw type (R,RW)\n \u00a0\n- char *\u00a0Vnm_getuser (char *user, int usermax)\n-\u00a0 Ask the system for the username.\n+ typedef struct sVio\u00a0Vio\n+\u00a0 Declaration of the Vio class as the Vio structure.\n \u00a0\n- char *\u00a0Vnm_getos (char *os, int osmax)\n-\u00a0 Ask the system for the operating system name.\n+ Enumerations\n+enum \u00a0VIOtype {\n+ \u00a0\u00a0VIO_NO_TYPE , VIO_SDIO , VIO_BUFF , VIO_FILE ,\n+ \u00a0\u00a0VIO_UNIX , VIO_INET\n+ }\n+\u00a0 Parameter for I/O type (sdio,buff,file,unix,inet) More...\n \u00a0\n- char *\u00a0Vnm_gethost (char *host, int hostmax)\n-\u00a0 Ask the system for the hostname.\n+enum \u00a0VIOfrmt { VIO_NO_FRMT , VIO_XDR , VIO_ASC }\n+\u00a0 Parameter for compression type (XDR,ASC) More...\n \u00a0\n- char *\u00a0Vnm_gethome (char *path, int pathmax)\n-\u00a0 Ask the system for the home directory.\n+enum \u00a0VIOrwkey { VIO_NO_RW , VIO_R , VIO_W }\n+\u00a0 Parameter for rw type (R,RW) More...\n \u00a0\n- char *\u00a0Vnm_getcwd (char *path, int pathmax)\n-\u00a0 Ask the system for the current working directory.\n+ Functions\n+ void\u00a0Vio_start (void)\n+\u00a0 Start Vio communication layer (init internal variables/buffers)\n \u00a0\n- int\u00a0Vnm_chdir (const char *path)\n-\u00a0 Interact with the system to change the working directory.\n+ void\u00a0Vio_stop (void)\n+\u00a0 Shutdown Vio communication layer.\n \u00a0\n- int\u00a0Vnm_mkdir (const char *path)\n-\u00a0 Interact with the system to make a new directory.\n-\n+ Vio *\u00a0Vio_ctor (const char *socktype, const char *datafrmt, const char\n+ *hostname, const char *filename, const char *rwkey)\n+\u00a0 Construct the Vio object.\n \u00a0\n- int\u00a0Vnm_system (const char *cmd)\n-\u00a0 An improved ANSI-C \"system\" call.\n+ int\u00a0Vio_ctor2 (Vio *thee, const char *socktype, const char *datafrmt, const\n+ char *hostname, const char *filename, const char *rwkey)\n+\u00a0 Work routine that Vio_ctor calls to do most of the construction.\n \u00a0\n- int\u00a0Vnm_systemBack (const char *cmd)\n-\u00a0 A background variant of the ANSI-C \"system\" call.\n-\n+ void\u00a0Vio_dtor (Vio **thee)\n+\u00a0 Destruct the Vio object.\n \u00a0\n- int\u00a0Vnm_systemKill (const char *cmd)\n-\u00a0 Something like a UNIX \"killall\" call.\n+ void\u00a0Vio_dtor2 (Vio *thee)\n+\u00a0 Work routine that Vio_dtor calls to do most of the destruction.\n \u00a0\n- int\u00a0Vnm_exec (int argc, char **argv)\n-\u00a0 An improved UNIX \"exec\" call. This routine does not return except on\n- error.\n+ void\u00a0Vio_setWhiteChars (Vio *thee, char *whiteChars)\n+\u00a0 Set the white character set for I/O stream.\n \u00a0\n- void\u00a0Vnm_sleep (int nusecs)\n-\u00a0 Implement a sleep function with microsecond resolution.\n+ void\u00a0Vio_setCommChars (Vio *thee, char *commChars)\n+\u00a0 Set the comment character set for I/O stream.\n \u00a0\n- int\u00a0Vnm_ioTag (void)\n-\u00a0 Return my I/O tag.\n+ int\u00a0Vio_accept (Vio *thee, int nonblock)\n+\u00a0 Accept any waiting connect attempt to our socket on our machine.\n \u00a0\n- int\u00a0Vnm_nTags (void)\n-\u00a0 Return the total number of tags.\n+ void\u00a0Vio_acceptFree (Vio *thee)\n+\u00a0 Free the socket child that was used for the last accept.\n \u00a0\n- void\u00a0Vnm_setIoTag (int myTag, int numTags)\n-\u00a0 Set my id.\n+ int\u00a0Vio_connect (Vio *thee, int nonblock)\n+\u00a0 Connect to some socket on a remote machine (or on our machine)\n \u00a0\n- FILE *\u00a0Vnm_open (const int unit)\n-\u00a0 Open an I/O console.\n+ void\u00a0Vio_connectFree (Vio *thee)\n+\u00a0 Purge any output buffers (for , else a no-op)\n \u00a0\n- int\u00a0Vnm_close (const int unit)\n-\u00a0 Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in\n- this routine.\n+ int\u00a0Vio_scanf (Vio *thee, char *parms,...)\n+\u00a0 Mimic \"scanf\" from an arbitrary Vio device.\n \u00a0\n- void\u00a0Vnm_flush (const int unit)\n-\u00a0 Attempt to flush the specified i/o stream. We MUST NOT use VASSERT\n- (or Vnm_print!) in this routine.\n+ int\u00a0Vio_printf (Vio *thee, char *parms,...)\n+\u00a0 Mimic \"printf\" from an arbitrary Vio device.\n \u00a0\n- void\u00a0Vnm_redirect (const int flag)\n- Set/unset the redirect flag for UNIT zero. When redirected, I/O goes\n-\u00a0 to the file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or\n- Vnm_print!) in this routine.\n+ int\u00a0Vio_read (Vio *thee, char *buf, int bufsize)\n+\u00a0 Read (up to) bufsize characters into buf from input device.\n \u00a0\n- void\u00a0Vnm_print (const int unit, const char *format,...)\n-\u00a0 External interface to the console i/o routine.\n- We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n+ int\u00a0Vio_write (Vio *thee, char *buf, int bufsize)\n+\u00a0 Write bufsize characters from buf to output device.\n \u00a0\n- void\u00a0Vnm_tprint (const int unit, const char *format,...)\n-\u00a0 Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or\n- Vnm_print!) in this routine.\n+ void\u00a0Vio_bufTake (Vio *thee, char *buf, int bufsize)\n+\u00a0 Set the pointer to the internal buffer.\n \u00a0\n- void\u00a0Vnm_qsort (int *u, int size)\n-\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n-\n+char *\u00a0Vio_bufGive (Vio *thee)\n+\u00a0 Return the pointer to the internal buffer.\n \u00a0\n- void\u00a0Vnm_qsortOrd (int *u, int *ord, int size)\n-\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n+ int\u00a0Vio_bufSize (Vio *thee)\n+\u00a0 Return the length to the internal buffer.\n \u00a0\n- void\u00a0Vnm_dqsort (double *u, int size)\n-\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n-\n+ Vio *\u00a0Vio_socketOpen (char *key, const char *iodev, const char *iofmt, const\n+ char *iohost, const char *iofile)\n+\u00a0 Socket open for read or write.\n \u00a0\n- void\u00a0Vnm_dqsortOrd (double *u, int *ord, int size)\n-\u00a0 Front-end to quick sort integer array from [-large] to [+large].\n+ void\u00a0Vio_socketClose (Vio **sock)\n+\u00a0 Socket close from read or write.\n \u00a0\n ***** Detailed Description *****\n-Header file for an ISO C [V]irtual [N]umerical [M]achine.\n- Author\n- Michael Holst\n- Note\n- None\n+Class Vio: virtual I/O layer.\n Version\n Id\n- vnm.h,v 1.22 2010/08/12 05:40:36 fetk Exp\n+ vio.h,v 1.28 2010/08/12 05:40:35 fetk Exp\n+ Author\n+ Michael Holst\n Attention\n *\n * MALOC = < Minimal Abstraction Layer for Object-oriented C >\n * Copyright (C) 1994-- Michael Holst\n *\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n@@ -198,591 +144,16 @@\n *\n * You should have received a copy of the GNU Lesser General Public\n * License along with this library; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\n *\n *\n ***** Macro Definition Documentation *****\n-***** \u25c6\u00a0VPOW_SAFE *****\n-#define VPOW_SAFE ( \u00a0x,\n- \u00a0y\u00a0\n- ) \u00a0\u00a0\u00a0(Vnm_powsafe(x,y))\n-A safe VPOW function (avoids division by zero)\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n-***** \u25c6\u00a0VTIMERS *****\n-#define VTIMERS\u00a0\u00a0\u00a0100\n-the maiximal timer constant\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n-***** Function Documentation *****\n-***** \u25c6\u00a0Vnm_chdir() *****\n-int Vnm_chdir ( const char *\u00a0path )\n-Interact with the system to change the working directory.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- Success enumeration\n- Parameters\n- path Pointer to the path\n-***** \u25c6\u00a0Vnm_close() *****\n-int Vnm_close ( const int\u00a0unit )\n-Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- Success enumeration\n- Parameters\n- unit index for the file unit\n-***** \u25c6\u00a0Vnm_dqsort() *****\n-void Vnm_dqsort ( double *\u00a0u,\n- int\u00a0 size\u00a0\n- )\n-Front-end to quick sort integer array from [-large] to [+large].\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- u Pointer to quick sort integer array\n- size size of the integer array\n-***** \u25c6\u00a0Vnm_dqsortOrd() *****\n-void Vnm_dqsortOrd ( double *\u00a0u,\n- int *\u00a0 ord,\n- int\u00a0 size\u00a0\n- )\n-Front-end to quick sort integer array from [-large] to [+large].\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- u Pointer to quick sort integer array\n- ord Pointer to reordered array\n- size size of the integer array\n-***** \u25c6\u00a0Vnm_epsmac() *****\n-double Vnm_epsmac ( void\u00a0 )\n-Computes the unit roundoff of the machine in single\n-precision. This is defined as the smallest positive machine number u such that\n-1.0d0 + u .ne. 1.0d0 (in single precision).\n-\n-A safe hardcoded machine epsilon as alternative:\n-double value;\n-value = 1.0e-9;\n-return value;.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- the unit roundoff of the machine in single precision.\n-***** \u25c6\u00a0Vnm_exec() *****\n-int Vnm_exec ( int\u00a0 argc,\n- char **\u00a0argv\u00a0\n- )\n-An improved UNIX \"exec\" call. This routine does not return except on error.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- no return except on error\n- Parameters\n- argc number of the command line arguments\n- argv the command line arguments\n-***** \u25c6\u00a0Vnm_flush() *****\n-void Vnm_flush ( const int\u00a0unit )\n-Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or\n-Vnm_print!) in this routine.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- unit index for the file unit\n-***** \u25c6\u00a0Vnm_gentokens() *****\n-int Vnm_gentokens ( char *\u00a0 buf,\n- char **\u00a0 argv,\n- const int\u00a0 argvmax,\n- const char *\u00a0white,\n- const char *\u00a0comment\u00a0\n- )\n-Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-\n-terminated) in which tokens are separated by whitespace \"white\" with possible\n-comments \"comment\" occuring. THE INPUT STRING IS MODIFIED HERE!\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n-\n- Again, the input string \"buf\" IS MODIFIED; white space characters\n- (defined in the input string \"white\") are replaced by the NULL character\n- '\\0'. The output \"argv\" is simply a list of pointers\n- to the start of the tokens in \"buf\", which are NULL-terminated\n- after we replace the white space with NULLs.\n-\n- We follow convention and \"NULL\"-terminate \"argv\" by setting the pointer\n- following the last token to \"VNULL\". The return value is \"argc\", the\n- number of tokens found (not including the terminating NULL pointer). For\n- safety you must pass in the maximal length of argv in the parameter\n- \"argvmax\".\n-\n- If we encounter a token which begins with a comment character (defined in\n- the input string \"comment\"), then we ignore the rest of the tokens in the\n- input buffer \"buf\". This is suitable\n- for parsing shell languages such as sh/ksh/bash which have comments that\n- start with e.g. \"#\" and continue until a newline.\n-\n- We DO NOT use the C library function strtok in this routine. (There are\n- some bad implementations of strtok around apparently; the internal state\n- variables maintained by strtok can get very\n- messed up if you use strtok in multiple places in a code.)\n- Returns\n- number of tokens\n- Parameters\n- buf buffer containing message\n- argv the command line arguments\n- argvmax maximal number of the command line arguments\n- white Pointer to the input string\n- comment token which begins with a comment character\n-***** \u25c6\u00a0Vnm_getcwd() *****\n-char * Vnm_getcwd ( char *\u00a0path,\n- int\u00a0 pathmax\u00a0\n- )\n-Ask the system for the current working directory.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n-\n- Consider it an error if we can't return something useful; therefore we\n- will VASSERT(path!=VNULL) before returning.\n-\n- Note that unlike Vnm_gethome, a call to Vnm_getcwd returns the current\n- directory, possibly modified from call to call.\n-\n- I.e., calls to Vnm_chdir can change the current working\n- directory; Vnm_getcwd returns the current directory, whatever that might\n- be.\n- Returns\n- the current working directory\n- Parameters\n- path Pointer to the path\n- pathmax index for the size of path\n-***** \u25c6\u00a0Vnm_gethome() *****\n-char * Vnm_gethome ( char *\u00a0path,\n- int\u00a0 pathmax\u00a0\n- )\n-Ask the system for the home directory.\n-=\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n-\n- The following preference order is used to set the home directory:\n-\n- MCSH_HOME (the user must define this in his environment)\n- CWD (always defined as the current working directory)\n-\n- We consider it an error if we can't return something useful;\n- therefore we will VASSERT(path!=VNULL) before returning.\n-\n- We settle on a home directory the first time we are called, and then we\n- simply return this fixed home directory forever.\n- In other words, the first call to Vnm_gethome, regardless of\n- who makes the call, establishes the home directory for everyone else (as\n- long as everyone goes through Vnm_gethome!).\n- Returns\n- the home directory\n- Parameters\n- path Pointer to the path\n- pathmax index for the size of path\n-***** \u25c6\u00a0Vnm_gethost() *****\n-char * Vnm_gethost ( char *\u00a0host,\n- int\u00a0 hostmax\u00a0\n- )\n-Ask the system for the hostname.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- the hostname\n- Parameters\n- host Pointer to the hostname.\n- hostmax index for maximal size of host name\n-***** \u25c6\u00a0Vnm_getos() *****\n-char * Vnm_getos ( char *\u00a0os,\n- int\u00a0 osmax\u00a0\n- )\n-Ask the system for the operating system name.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- the operating system name\n- Parameters\n- os Pointer to the OS type\n- osmax index for maximal size of OS name\n-***** \u25c6\u00a0Vnm_getuser() *****\n-char * Vnm_getuser ( char *\u00a0user,\n- int\u00a0 usermax\u00a0\n- )\n-Ask the system for the username.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- the username of the system\n- Parameters\n- user Pointer to the username of the system\n- usermax index for maximal size of user name\n-***** \u25c6\u00a0Vnm_ioTag() *****\n-int Vnm_ioTag ( void\u00a0 )\n-Return my I/O tag.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- my I/O tag.\n-***** \u25c6\u00a0Vnm_jmpOk() *****\n-int Vnm_jmpOk ( void\u00a0 )\n-Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- \"ok-to-jump\" flag.\n-***** \u25c6\u00a0Vnm_jmpOkClear() *****\n-void Vnm_jmpOkClear ( void\u00a0 )\n-Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n-***** \u25c6\u00a0Vnm_jmpOkSet() *****\n-void Vnm_jmpOkSet ( void\u00a0 )\n-Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Author\n- Michael Holst\n- Returns\n- None\n-***** \u25c6\u00a0Vnm_mkdir() *****\n-int Vnm_mkdir ( const char *\u00a0path )\n-Interact with the system to make a new directory.\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Author\n- Michael Holst\n- Returns\n- Success enumeration\n- Parameters\n- path Pointer to the path\n-***** \u25c6\u00a0Vnm_nTags() *****\n-int Vnm_nTags ( void\u00a0 )\n-Return the total number of tags.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- total number of tags.\n-***** \u25c6\u00a0Vnm_open() *****\n-FILE * Vnm_open ( const int\u00a0unit )\n-Open an I/O console.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n-\n- The following codes are used:\n-\n-\n- unit# C output unit\n- ------- -------------\n-\n- unit==0 garbage -- Non-interactive i/o; lots of stuff\n-\n- (can be redirected to ${MCSH_HOME/io.mc)\n-\n- unit==1 stdout -- standard output (Interactive I/O)\n-\n- unit==2 stderr -- standard error (IMPORTANT interactive I/O)\n-\n-\n- unit==3 history -- History file ${MCSH_HOME}/hist.mcsh\n-\n-\n- unit==else /dev/null -- Error...\n- Returns\n- None\n- Parameters\n- unit index for the file unit\n-***** \u25c6\u00a0Vnm_powsafe() *****\n-double Vnm_powsafe ( double\u00a0x,\n- double\u00a0y\u00a0\n- )\n-A safe VPOW function (avoids division by zero).\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- output value of a VPOW function\n- Parameters\n- x input parameter\n- y input parameter\n-***** \u25c6\u00a0Vnm_print() *****\n-void Vnm_print ( const int\u00a0 unit,\n- const char *\u00a0format,\n- \u00a0 ...\u00a0\n- )\n-External interface to the console i/o routine.\n-We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- unit index for the file unit\n- format Pointer to the print format\n-***** \u25c6\u00a0Vnm_qsort() *****\n-void Vnm_qsort ( int *\u00a0u,\n- int\u00a0 size\u00a0\n- )\n-Front-end to quick sort integer array from [-large] to [+large].\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- u Pointer to quick sort integer array\n- size size of the integer array\n-***** \u25c6\u00a0Vnm_qsortOrd() *****\n-void Vnm_qsortOrd ( int *\u00a0u,\n- int *\u00a0ord,\n- int\u00a0 size\u00a0\n- )\n-Front-end to quick sort integer array from [-large] to [+large].\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None *\n- Author\n- Michael Holst\n- Parameters\n- u Pointer to quick sort integer array\n- ord Pointer to reordered array\n- size size of the integer array\n-***** \u25c6\u00a0Vnm_redirect() *****\n-void Vnm_redirect ( const int\u00a0flag )\n-Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the\n-file: ${MCSH_HOME}/io.mc. We MUST NOT use VASSERT (or Vnm_print!) in this\n-routine.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- flag index for the redirect flag\n-***** \u25c6\u00a0Vnm_regHand() *****\n-void Vnm_regHand ( void\u00a0 )\n-Register the signal handler with the operating system.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n-***** \u25c6\u00a0Vnm_setIoTag() *****\n-void Vnm_setIoTag ( int\u00a0myTag,\n- int\u00a0numTags\u00a0\n- )\n-Set my id.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- myTag index for the tag\n- numTags number of tags\n-***** \u25c6\u00a0Vnm_sigHand() *****\n-void Vnm_sigHand ( int\u00a0num )\n-Handle events such as SIGINT. We must have first been registered with\n-\"Vnm_signalInit\".\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n-***** \u25c6\u00a0Vnm_sigInt() *****\n-int Vnm_sigInt ( void\u00a0 )\n-Signal and setjmp handling routine. Return the signal interrupt flag.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- Signal interrupt flag.\n-***** \u25c6\u00a0Vnm_sigIntClear() *****\n-void Vnm_sigIntClear ( void\u00a0 )\n-Signal and setjmp handling routine. Clear the signal interrupt flag.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n-***** \u25c6\u00a0Vnm_sigIntSet() *****\n-void Vnm_sigIntSet ( void\u00a0 )\n-Signal and setjmp handling routine. Set the signal interrupt flag.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n-***** \u25c6\u00a0Vnm_signalInit() *****\n-jmp_buf * Vnm_signalInit ( void\u00a0 )\n-Initialize the signal handling data structures.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- the signal handling data structures\n-***** \u25c6\u00a0Vnm_sleep() *****\n-void Vnm_sleep ( int\u00a0nusecs )\n-Implement a sleep function with microsecond resolution.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- This is hacked out of the \"sleep_us\" example in Rick Steven's Advance\n- Unix Programming book.\n- Returns\n- None\n- Parameters\n- nusecs number of microseconds\n-***** \u25c6\u00a0Vnm_system() *****\n-int Vnm_system ( const char *\u00a0cmd )\n-An improved ANSI-C \"system\" call.\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Author\n- Michael Holst\n- Returns\n- Success enumeration\n- Parameters\n- cmd Pointer to the command\n-***** \u25c6\u00a0Vnm_systemBack() *****\n-int Vnm_systemBack ( const char *\u00a0cmd )\n-A background variant of the ANSI-C \"system\" call.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- Success enumeration\n- Parameters\n- cmd Pointer to the command\n-***** \u25c6\u00a0Vnm_systemKill() *****\n-int Vnm_systemKill ( const char *\u00a0cmd )\n-Something like a UNIX \"killall\" call.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- Success enumeration\n- Parameters\n- cmd Pointer to the command\n-***** \u25c6\u00a0Vnm_tprint() *****\n-void Vnm_tprint ( const int\u00a0 unit,\n- const char *\u00a0format,\n- \u00a0 ...\u00a0\n- )\n-Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in\n-this routine.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- For a tag to be added, both of the following conditions must hold:\n- Vnm_ioTag() >= 0 (I.e., I must have been given a tag)\n- Vnm_nTags() > 1 (I must not be the only one given a tag)\n- Returns\n- None\n- Parameters\n- unit index for the file unit\n- format Pointer to the print format\n-***** \u25c6\u00a0Vnm_tstart() *****\n-void Vnm_tstart ( int\u00a0 timer,\n- const char *\u00a0name\u00a0\n- )\n-Starts the timer on the particular machine.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- timer index for the starting timer\n- name Pointer to the object\n-***** \u25c6\u00a0Vnm_tstop() *****\n-void Vnm_tstop ( int\u00a0 timer,\n- const char *\u00a0name\u00a0\n- )\n-Stops the timer on the particular machine.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n- Parameters\n- timer index for the starting timer\n- name Pointer to the object\n-***** \u25c6\u00a0Vnm_typeChk() *****\n-void Vnm_typeChk ( void\u00a0 )\n-Check out the sizes of various datatypes.\n- Author\n- Michael Holst\n- Note\n- Useful constants and functions (timers, epsilon, token generators, i/o)\n- Returns\n- None\n+***** \u25c6\u00a0VIO_MAXBUF *****\n+#define VIO_MAXBUF\u00a0\u00a0\u00a010\n+number of internal buffers (BUFF datatype)\n+***** \u25c6\u00a0VPORTNUMBER *****\n+#define VPORTNUMBER\u00a0\u00a0\u00a014916\n+our portbase; 5000 < VPORTNUMBER < 49152\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00035_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00035_source.html", "unified_diff": "@@ -1,15 +1,15 @@\n \n \n \n \n \n \n \n-MALOC: vnm.h Source File\n+MALOC: vio.h Source File\n \n \n \n \n \n \n
    \n@@ -44,152 +44,219 @@\n \n
    \n \n
    \n
    \n
    \n-
    vnm.h
    \n+
    vio.h
    \n
    \n
    \n Go to the documentation of this file.
    1
    \n-
    33#ifndef _VNM_H_
    \n-
    34#define _VNM_H_
    \n-
    35
    \n-
    36#include <maloc/maloc_base.h>
    \n-
    37
    \n-
    38
    \n-
    46int Vnm_sigInt(void);
    \n-
    47
    \n-
    55void Vnm_sigIntSet(void);
    \n+
    39#ifndef _VIO_H_
    \n+
    40#define _VIO_H_
    \n+
    41
    \n+
    42#include <maloc/maloc_base.h>
    \n+
    43
    \n+
    44#include <maloc/vnm.h>
    \n+
    45
    \n+
    46/*
    \n+
    47 * ***************************************************************************
    \n+
    48 * Class Vio: Parameters and datatypes
    \n+
    49 * ***************************************************************************
    \n+
    50 */
    \n+
    51
    \n+
    53#define VPORTNUMBER 14916
    \n+
    55#define VIO_MAXBUF 10
    \n
    56
    \n-
    64void Vnm_sigIntClear(void);
    \n-
    65
    \n-
    73int Vnm_jmpOk(void);
    \n-
    74
    \n-
    82void Vnm_jmpOkSet(void);
    \n-
    83
    \n-
    91void Vnm_jmpOkClear(void);
    \n+
    \n+
    62typedef enum VIOtype {
    \n+\n+\n+\n+\n+\n+\n+\n+
    \n+
    70
    \n+
    \n+
    76typedef enum VIOfrmt {
    \n+\n+\n+\n+\n+
    \n+
    81
    \n+
    \n+
    87typedef enum VIOrwkey {
    \n+\n+\n+
    90 VIO_W
    \n+\n+
    \n
    92
    \n-
    100jmp_buf *Vnm_signalInit(void);
    \n-
    101
    \n-
    109void Vnm_regHand(void);
    \n-
    110
    \n-
    119void Vnm_sigHand(int num);
    \n-
    120
    \n-
    125#define VPOW_SAFE(x,y) (Vnm_powsafe(x,y))
    \n-
    126
    \n-
    136double Vnm_powsafe(double x, double y);
    \n-
    137
    \n-
    145void Vnm_typeChk(void);
    \n-
    146
    \n-
    160double Vnm_epsmac(void);
    \n-
    161
    \n-
    196int Vnm_gentokens(char *buf, char **argv,
    \n-
    197 const int argvmax, const char *white, const char *comment);
    \n-
    198
    \n-
    203#define VTIMERS 100
    \n-
    204
    \n-
    214void Vnm_tstart(int timer, const char *name);
    \n-
    215
    \n-
    225void Vnm_tstop(int timer, const char *name);
    \n-
    226
    \n-
    236char *Vnm_getuser(char *user, int usermax);
    \n+
    \n+
    98struct sVio {
    \n+
    99
    \n+\n+\n+\n+\n+\n+\n+
    122 int error;
    \n+
    123 int dirty;
    \n+
    125 FILE *fp;
    \n+
    126 int so;
    \n+
    127 int soc;
    \n+
    128 void *name;
    \n+
    129 void *axdr;
    \n+\n+\n+\n+\n+\n+\n+
    140 char *VIObuffer;
    \n+\n+\n+
    144};
    \n+
    \n+
    145
    \n+
    151typedef struct sVio Vio;
    \n+
    152
    \n+
    153/*
    \n+
    154 * ***************************************************************************
    \n+
    155 * Class Vio: Inlineable methods (vio.c)
    \n+
    156 * ***************************************************************************
    \n+
    157 */
    \n+
    158
    \n+
    159#if !defined(VINLINE_MALOC)
    \n+
    160#else /* if defined(VINLINE_MALOC) */
    \n+
    161#endif /* if !defined(VINLINE_MALOC) */
    \n+
    162
    \n+
    163/*
    \n+
    164 * ***************************************************************************
    \n+
    165 * Class Vio: Non-Inlineable methods (vio.c)
    \n+
    166 * ***************************************************************************
    \n+
    167 */
    \n+
    168
    \n+
    176void Vio_start(void);
    \n+
    177
    \n+
    185void Vio_stop(void);
    \n+
    186
    \n+
    199Vio* Vio_ctor(const char *socktype, const char *datafrmt,
    \n+
    200 const char *hostname, const char *filename, const char *rwkey);
    \n+
    201
    \n+
    215int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt,
    \n+
    216 const char *hostname, const char *filename, const char *rwkey);
    \n+
    217
    \n+
    226void Vio_dtor(Vio **thee);
    \n+
    227
    \n+
    236void Vio_dtor2(Vio *thee);
    \n
    237
    \n-
    247char *Vnm_getos(char *os, int osmax);
    \n+\n
    248
    \n-
    258char *Vnm_gethost(char *host, int hostmax);
    \n+
    258void Vio_setCommChars(Vio *thee, char *commChars);
    \n
    259
    \n-
    279char *Vnm_gethome(char *path, int pathmax);
    \n-
    280
    \n-
    297char *Vnm_getcwd(char *path, int pathmax);
    \n-
    298
    \n-
    307int Vnm_chdir(const char *path);
    \n-
    308
    \n-
    317int Vnm_mkdir(const char *path);
    \n+
    272int Vio_accept(Vio *thee, int nonblock);
    \n+
    273
    \n+
    282void Vio_acceptFree(Vio *thee);
    \n+
    283
    \n+
    296int Vio_connect(Vio *thee, int nonblock);
    \n+
    297
    \n+\n+
    307
    \n+
    317int Vio_scanf(Vio *thee, char *parms, ...);
    \n
    318
    \n-
    327int Vnm_system(const char *cmd);
    \n-
    328
    \n-
    337int Vnm_systemBack(const char *cmd);
    \n-
    338
    \n-
    347int Vnm_systemKill(const char *cmd);
    \n-
    348
    \n-
    359int Vnm_exec(int argc, char **argv);
    \n-
    360
    \n-
    371void Vnm_sleep(int nusecs);
    \n-
    372
    \n-
    380int Vnm_ioTag(void);
    \n-
    381
    \n-
    389int Vnm_nTags(void);
    \n-
    390
    \n-
    400void Vnm_setIoTag(int myTag, int numTags);
    \n+
    328int Vio_printf(Vio *thee, char *parms, ...);
    \n+
    329
    \n+
    340int Vio_read(Vio *thee, char *buf, int bufsize);
    \n+
    341
    \n+
    352int Vio_write(Vio *thee, char *buf, int bufsize);
    \n+
    353
    \n+
    364void Vio_bufTake(Vio *thee, char *buf, int bufsize);
    \n+
    365
    \n+
    374char* Vio_bufGive(Vio *thee);
    \n+
    375
    \n+
    384int Vio_bufSize(Vio *thee);
    \n+
    385
    \n+\n+
    399 const char *iodev, const char *iofmt,
    \n+
    400 const char *iohost, const char *iofile);
    \n
    401
    \n-
    429FILE *Vnm_open(const int unit);
    \n-
    430
    \n-
    440int Vnm_close(const int unit);
    \n-
    441
    \n-
    451void Vnm_flush(const int unit);
    \n-
    452
    \n-
    463void Vnm_redirect(const int flag);
    \n-
    464
    \n-
    475void Vnm_print(const int unit, const char *format, ...);
    \n-
    476
    \n-
    490void Vnm_tprint(const int unit, const char *format, ...);
    \n-
    491
    \n-
    501void Vnm_qsort(int *u, int size);
    \n-
    502
    \n-
    513void Vnm_qsortOrd(int *u, int *ord, int size);
    \n-
    514
    \n-
    524void Vnm_dqsort(double *u, int size);
    \n-
    525
    \n-
    536void Vnm_dqsortOrd(double *u, int *ord, int size);
    \n-
    537
    \n-
    538#endif /* _VNM_H_ */
    \n-
    539
    \n+
    410void Vio_socketClose(Vio **sock);
    \n+
    411
    \n+
    412#endif /* _VIO_H_ */
    \n+
    413
    \n
    The base (or foundation) header for MALOC.
    \n-
    int Vnm_mkdir(const char *path)
    Interact with the system to make a new directory.
    \n-
    void Vnm_sigHand(int num)
    Handle events such as SIGINT. We must have first been registered with "Vnm_signalInit".
    \n-
    int Vnm_close(const int unit)
    Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
    \n-
    char * Vnm_getos(char *os, int osmax)
    Ask the system for the operating system name.
    \n-
    int Vnm_ioTag(void)
    Return my I/O tag.
    \n-
    void Vnm_print(const int unit, const char *format,...)
    External interface to the console i/o routine. We MUST NOT use VASSERT (or Vnm_print!...
    \n-
    void Vnm_setIoTag(int myTag, int numTags)
    Set my id.
    \n-
    double Vnm_powsafe(double x, double y)
    A safe VPOW function (avoids division by zero).
    \n-
    void Vnm_qsortOrd(int *u, int *ord, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n-
    int Vnm_nTags(void)
    Return the total number of tags.
    \n-
    void Vnm_sigIntClear(void)
    Signal and setjmp handling routine. Clear the signal interrupt flag.
    \n-
    void Vnm_flush(const int unit)
    Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
    \n-
    FILE * Vnm_open(const int unit)
    Open an I/O console.
    \n-
    int Vnm_sigInt(void)
    Signal and setjmp handling routine. Return the signal interrupt flag.
    \n-
    int Vnm_system(const char *cmd)
    An improved ANSI-C "system" call.
    \n-
    int Vnm_exec(int argc, char **argv)
    An improved UNIX "exec" call. This routine does not return except on error.
    \n-
    void Vnm_dqsortOrd(double *u, int *ord, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n-
    void Vnm_jmpOkSet(void)
    Signal and setjmp handling routine. Set the "okay-to-jump" flag.
    \n-
    void Vnm_tstart(int timer, const char *name)
    Starts the timer on the particular machine.
    \n-
    char * Vnm_gethost(char *host, int hostmax)
    Ask the system for the hostname.
    \n-
    void Vnm_sleep(int nusecs)
    Implement a sleep function with microsecond resolution.
    \n-
    void Vnm_jmpOkClear(void)
    Signal and setjmp handling routine. Clear the "okay-to-jump" flag.
    \n-
    jmp_buf * Vnm_signalInit(void)
    Initialize the signal handling data structures.
    \n-
    int Vnm_chdir(const char *path)
    Interact with the system to change the working directory.
    \n-
    void Vnm_typeChk(void)
    Check out the sizes of various datatypes.
    \n-
    int Vnm_jmpOk(void)
    Signal and setjmp handling routine. Return the "ok-to-jump" flag.
    \n-
    void Vnm_tprint(const int unit, const char *format,...)
    Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in this routine.
    \n-
    char * Vnm_gethome(char *path, int pathmax)
    Ask the system for the home directory.
    \n-
    double Vnm_epsmac(void)
    Computes the unit roundoff of the machine in single precision. This is defined as the smallest posi...
    \n-
    int Vnm_systemBack(const char *cmd)
    A background variant of the ANSI-C "system" call.
    \n-
    int Vnm_gentokens(char *buf, char **argv, const int argvmax, const char *white, const char *comment)
    Generate an [argv,argc] pair from a character string "buf" (assumed NULL-terminated) in which tokens ...
    \n-
    int Vnm_systemKill(const char *cmd)
    Something like a UNIX "killall" call.
    \n-
    void Vnm_qsort(int *u, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n-
    void Vnm_sigIntSet(void)
    Signal and setjmp handling routine. Set the signal interrupt flag.
    \n-
    void Vnm_redirect(const int flag)
    Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the file: ${MCSH_HOME}/io....
    \n-
    char * Vnm_getcwd(char *path, int pathmax)
    Ask the system for the current working directory.
    \n-
    char * Vnm_getuser(char *user, int usermax)
    Ask the system for the username.
    \n-
    void Vnm_regHand(void)
    Register the signal handler with the operating system.
    \n-
    void Vnm_dqsort(double *u, int size)
    Front-end to quick sort integer array from [-large] to [+large].
    \n-
    void Vnm_tstop(int timer, const char *name)
    Stops the timer on the particular machine.
    \n+
    #define VMAX_ARGNUM
    Global constant.
    Definition maloc_base.h:225
    \n+
    #define VMAX_BUFSIZE
    Global constant.
    Definition maloc_base.h:229
    \n+
    #define VMAX_ARGLEN
    Global constant.
    Definition maloc_base.h:227
    \n+
    Header file for an ISO C [V]irtual [N]umerical [M]achine.
    \n+
    int Vio_bufSize(Vio *thee)
    Return the length to the internal buffer.
    \n+
    void Vio_stop(void)
    Shutdown Vio communication layer.
    \n+
    int Vio_write(Vio *thee, char *buf, int bufsize)
    Write bufsize characters from buf to output device.
    \n+
    int Vio_scanf(Vio *thee, char *parms,...)
    Mimic "scanf" from an arbitrary Vio device.
    \n+
    void Vio_acceptFree(Vio *thee)
    Free the socket child that was used for the last accept.
    \n+
    void Vio_start(void)
    Start Vio communication layer (init internal variables/buffers)
    \n+
    int Vio_printf(Vio *thee, char *parms,...)
    Mimic "printf" from an arbitrary Vio device.
    \n+
    Vio * Vio_socketOpen(char *key, const char *iodev, const char *iofmt, const char *iohost, const char *iofile)
    Socket open for read or write.
    \n+
    void Vio_setWhiteChars(Vio *thee, char *whiteChars)
    Set the white character set for I/O stream.
    \n+
    void Vio_socketClose(Vio **sock)
    Socket close from read or write.
    \n+
    int Vio_connect(Vio *thee, int nonblock)
    Connect to some socket on a remote machine (or on our machine)
    \n+
    VIOfrmt
    Parameter for compression type (XDR,ASC)
    Definition vio.h:76
    \n+
    int Vio_accept(Vio *thee, int nonblock)
    Accept any waiting connect attempt to our socket on our machine.
    \n+
    Vio * Vio_ctor(const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
    Construct the Vio object.
    \n+
    VIOtype
    Parameter for I/O type (sdio,buff,file,unix,inet)
    Definition vio.h:62
    \n+
    void Vio_dtor(Vio **thee)
    Destruct the Vio object.
    \n+
    int Vio_read(Vio *thee, char *buf, int bufsize)
    Read (up to) bufsize characters into buf from input device.
    \n+
    void Vio_bufTake(Vio *thee, char *buf, int bufsize)
    Set the pointer to the internal buffer.
    \n+
    void Vio_connectFree(Vio *thee)
    Purge any output buffers (for <UNIX/INET>, else a no-op)
    \n+
    void Vio_setCommChars(Vio *thee, char *commChars)
    Set the comment character set for I/O stream.
    \n+
    char * Vio_bufGive(Vio *thee)
    Return the pointer to the internal buffer.
    \n+
    VIOrwkey
    Parameter for rw type (R,RW)
    Definition vio.h:87
    \n+
    void Vio_dtor2(Vio *thee)
    Work routine that Vio_dtor calls to do most of the destruction.
    \n+
    int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt, const char *hostname, const char *filename, const char *rwkey)
    Work routine that Vio_ctor calls to do most of the construction.
    \n+
    @ VIO_XDR
    Definition vio.h:78
    \n+
    @ VIO_NO_FRMT
    Definition vio.h:77
    \n+
    @ VIO_ASC
    Definition vio.h:79
    \n+
    @ VIO_NO_TYPE
    Definition vio.h:63
    \n+
    @ VIO_FILE
    Definition vio.h:66
    \n+
    @ VIO_UNIX
    Definition vio.h:67
    \n+
    @ VIO_BUFF
    Definition vio.h:65
    \n+
    @ VIO_SDIO
    Definition vio.h:64
    \n+
    @ VIO_INET
    Definition vio.h:68
    \n+
    @ VIO_NO_RW
    Definition vio.h:88
    \n+
    @ VIO_W
    Definition vio.h:90
    \n+
    @ VIO_R
    Definition vio.h:89
    \n+
    Contains public data members for Vio class.
    Definition vio.h:98
    \n+
    char putBuffer[VMAX_BUFSIZE]
    Definition vio.h:137
    \n+
    VIOtype type
    Definition vio.h:100
    \n+
    int ioBufferLen
    Definition vio.h:135
    \n+
    VIOrwkey rwkey
    Definition vio.h:113
    \n+
    char commChars[VMAX_ARGNUM]
    Definition vio.h:132
    \n+
    int VIObufferPtr
    Definition vio.h:142
    \n+
    FILE * fp
    Definition vio.h:125
    \n+
    VIOfrmt frmt
    Definition vio.h:108
    \n+
    int dirty
    Definition vio.h:123
    \n+
    int soc
    Definition vio.h:127
    \n+
    char lhost[VMAX_ARGLEN]
    Definition vio.h:119
    \n+
    char whiteChars[VMAX_ARGNUM]
    Definition vio.h:131
    \n+
    char ioBuffer[VMAX_BUFSIZE]
    Definition vio.h:134
    \n+
    int VIObufferLen
    Definition vio.h:141
    \n+
    char file[VMAX_ARGLEN]
    Definition vio.h:118
    \n+
    void * name
    Definition vio.h:128
    \n+
    void * axdr
    Definition vio.h:129
    \n+
    char * VIObuffer
    Definition vio.h:140
    \n+
    int putBufferLen
    Definition vio.h:138
    \n+
    int so
    Definition vio.h:126
    \n+
    char rhost[VMAX_ARGLEN]
    Definition vio.h:120
    \n+
    int error
    Definition vio.h:122
    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n", "details": [{"source1": "html2text {}", "source2": "html2text {}", "unified_diff": "@@ -3,236 +3,347 @@\n \n \n MALOC\u00a00.1\n \n * src\n * vsys\n * maloc\n-vnm.h\n+vio.h\n Go_to_the_documentation_of_this_file.\n 1\n- 33#ifndef _VNM_H_\n- 34#define _VNM_H_\n- 35\n- 36#include \n- 37\n- 38\n-46int Vnm_sigInt(void);\n- 47\n-55void Vnm_sigIntSet(void);\n+ 39#ifndef _VIO_H_\n+ 40#define _VIO_H_\n+ 41\n+ 42#include \n+ 43\n+ 44#include \n+ 45\n+ 46/*\n+ 47 *\n+***************************************************************************\n+ 48 * Class Vio: Parameters and datatypes\n+ 49 *\n+***************************************************************************\n+ 50 */\n+ 51\n+53#define VPORTNUMBER 14916\n+55#define VIO_MAXBUF 10\n 56\n-64void Vnm_sigIntClear(void);\n- 65\n-73int Vnm_jmpOk(void);\n- 74\n-82void Vnm_jmpOkSet(void);\n- 83\n-91void Vnm_jmpOkClear(void);\n+62typedef enum VIOtype {\n+63 VIO_NO_TYPE,\n+64 VIO_SDIO,\n+65 VIO_BUFF,\n+66 VIO_FILE,\n+67 VIO_UNIX,\n+ 68 VIO_INET\n+69} VIOtype;\n+ 70\n+76typedef enum VIOfrmt {\n+77 VIO_NO_FRMT,\n+78 VIO_XDR,\n+ 79 VIO_ASC\n+80} VIOfrmt;\n+ 81\n+87typedef enum VIOrwkey {\n+88 VIO_NO_RW,\n+89 VIO_R,\n+ 90 VIO_W\n+91} VIOrwkey;\n 92\n-100jmp_buf *Vnm_signalInit(void);\n- 101\n-109void Vnm_regHand(void);\n- 110\n-119void Vnm_sigHand(int num);\n- 120\n-125#define VPOW_SAFE(x,y) (Vnm_powsafe(x,y))\n- 126\n-136double Vnm_powsafe(double x, double y);\n- 137\n-145void Vnm_typeChk(void);\n- 146\n-160double Vnm_epsmac(void);\n- 161\n-196int Vnm_gentokens(char *buf, char **argv,\n- 197 const int argvmax, const char *white, const char *comment);\n- 198\n-203#define VTIMERS 100\n- 204\n-214void Vnm_tstart(int timer, const char *name);\n- 215\n-225void Vnm_tstop(int timer, const char *name);\n- 226\n-236char *Vnm_getuser(char *user, int usermax);\n+98struct sVio {\n+ 99\n+100 VIOtype type;\n+108 VIOfrmt frmt;\n+113 VIOrwkey rwkey;\n+118 char file[VMAX_ARGLEN];\n+119 char lhost[VMAX_ARGLEN];\n+120 char rhost[VMAX_ARGLEN];\n+122 int error;\n+123 int dirty;\n+125 FILE *fp;\n+126 int so;\n+127 int soc;\n+128 void *name;\n+129 void *axdr;\n+131 char whiteChars[VMAX_ARGNUM];\n+132 char commChars[VMAX_ARGNUM];\n+134 char ioBuffer[VMAX_BUFSIZE];\n+135 int ioBufferLen;\n+137 char putBuffer[VMAX_BUFSIZE];\n+138 int putBufferLen;\n+140 char *VIObuffer;\n+141 int VIObufferLen;\n+142 int VIObufferPtr;\n+ 144};\n+ 145\n+151typedef struct sVio Vio;\n+ 152\n+ 153/*\n+ 154 *\n+***************************************************************************\n+ 155 * Class Vio: Inlineable methods (vio.c)\n+ 156 *\n+***************************************************************************\n+ 157 */\n+ 158\n+ 159#if !defined(VINLINE_MALOC)\n+ 160#else /* if defined(VINLINE_MALOC) */\n+ 161#endif /* if !defined(VINLINE_MALOC) */\n+ 162\n+ 163/*\n+ 164 *\n+***************************************************************************\n+ 165 * Class Vio: Non-Inlineable methods (vio.c)\n+ 166 *\n+***************************************************************************\n+ 167 */\n+ 168\n+176void Vio_start(void);\n+ 177\n+185void Vio_stop(void);\n+ 186\n+199Vio* Vio_ctor(const char *socktype, const char *datafrmt,\n+ 200 const char *hostname, const char *filename, const char *rwkey);\n+ 201\n+215int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt,\n+ 216 const char *hostname, const char *filename, const char *rwkey);\n+ 217\n+226void Vio_dtor(Vio **thee);\n+ 227\n+236void Vio_dtor2(Vio *thee);\n 237\n-247char *Vnm_getos(char *os, int osmax);\n+247void Vio_setWhiteChars(Vio *thee, char *whiteChars);\n 248\n-258char *Vnm_gethost(char *host, int hostmax);\n+258void Vio_setCommChars(Vio *thee, char *commChars);\n 259\n-279char *Vnm_gethome(char *path, int pathmax);\n- 280\n-297char *Vnm_getcwd(char *path, int pathmax);\n- 298\n-307int Vnm_chdir(const char *path);\n- 308\n-317int Vnm_mkdir(const char *path);\n+272int Vio_accept(Vio *thee, int nonblock);\n+ 273\n+282void Vio_acceptFree(Vio *thee);\n+ 283\n+296int Vio_connect(Vio *thee, int nonblock);\n+ 297\n+306void Vio_connectFree(Vio *thee);\n+ 307\n+317int Vio_scanf(Vio *thee, char *parms, ...);\n 318\n-327int Vnm_system(const char *cmd);\n- 328\n-337int Vnm_systemBack(const char *cmd);\n- 338\n-347int Vnm_systemKill(const char *cmd);\n- 348\n-359int Vnm_exec(int argc, char **argv);\n- 360\n-371void Vnm_sleep(int nusecs);\n- 372\n-380int Vnm_ioTag(void);\n- 381\n-389int Vnm_nTags(void);\n- 390\n-400void Vnm_setIoTag(int myTag, int numTags);\n+328int Vio_printf(Vio *thee, char *parms, ...);\n+ 329\n+340int Vio_read(Vio *thee, char *buf, int bufsize);\n+ 341\n+352int Vio_write(Vio *thee, char *buf, int bufsize);\n+ 353\n+364void Vio_bufTake(Vio *thee, char *buf, int bufsize);\n+ 365\n+374char* Vio_bufGive(Vio *thee);\n+ 375\n+384int Vio_bufSize(Vio *thee);\n+ 385\n+398Vio *Vio_socketOpen(char *key,\n+ 399 const char *iodev, const char *iofmt,\n+ 400 const char *iohost, const char *iofile);\n 401\n-429FILE *Vnm_open(const int unit);\n- 430\n-440int Vnm_close(const int unit);\n- 441\n-451void Vnm_flush(const int unit);\n- 452\n-463void Vnm_redirect(const int flag);\n- 464\n-475void Vnm_print(const int unit, const char *format, ...);\n- 476\n-490void Vnm_tprint(const int unit, const char *format, ...);\n- 491\n-501void Vnm_qsort(int *u, int size);\n- 502\n-513void Vnm_qsortOrd(int *u, int *ord, int size);\n- 514\n-524void Vnm_dqsort(double *u, int size);\n- 525\n-536void Vnm_dqsortOrd(double *u, int *ord, int size);\n- 537\n- 538#endif /* _VNM_H_ */\n- 539\n+410void Vio_socketClose(Vio **sock);\n+ 411\n+ 412#endif /* _VIO_H_ */\n+ 413\n maloc_base.h\n The base (or foundation) header for MALOC.\n-Vnm_mkdir\n-int Vnm_mkdir(const char *path)\n-Interact with the system to make a new directory.\n-Vnm_sigHand\n-void Vnm_sigHand(int num)\n-Handle events such as SIGINT. We must have first been registered with\n-\"Vnm_signalInit\".\n-Vnm_close\n-int Vnm_close(const int unit)\n-Close an I/O console. We MUST NOT use VASSERT (or Vnm_print!) in this routine.\n-Vnm_getos\n-char * Vnm_getos(char *os, int osmax)\n-Ask the system for the operating system name.\n-Vnm_ioTag\n-int Vnm_ioTag(void)\n-Return my I/O tag.\n-Vnm_print\n-void Vnm_print(const int unit, const char *format,...)\n-External interface to the console i/o routine. We MUST NOT use VASSERT (or\n-Vnm_print!...\n-Vnm_setIoTag\n-void Vnm_setIoTag(int myTag, int numTags)\n-Set my id.\n-Vnm_powsafe\n-double Vnm_powsafe(double x, double y)\n-A safe VPOW function (avoids division by zero).\n-Vnm_qsortOrd\n-void Vnm_qsortOrd(int *u, int *ord, int size)\n-Front-end to quick sort integer array from [-large] to [+large].\n-Vnm_nTags\n-int Vnm_nTags(void)\n-Return the total number of tags.\n-Vnm_sigIntClear\n-void Vnm_sigIntClear(void)\n-Signal and setjmp handling routine. Clear the signal interrupt flag.\n-Vnm_flush\n-void Vnm_flush(const int unit)\n-Attempt to flush the specified i/o stream. We MUST NOT use VASSERT (or\n-Vnm_print!) in this routine.\n-Vnm_open\n-FILE * Vnm_open(const int unit)\n-Open an I/O console.\n-Vnm_sigInt\n-int Vnm_sigInt(void)\n-Signal and setjmp handling routine. Return the signal interrupt flag.\n-Vnm_system\n-int Vnm_system(const char *cmd)\n-An improved ANSI-C \"system\" call.\n-Vnm_exec\n-int Vnm_exec(int argc, char **argv)\n-An improved UNIX \"exec\" call. This routine does not return except on error.\n-Vnm_dqsortOrd\n-void Vnm_dqsortOrd(double *u, int *ord, int size)\n-Front-end to quick sort integer array from [-large] to [+large].\n-Vnm_jmpOkSet\n-void Vnm_jmpOkSet(void)\n-Signal and setjmp handling routine. Set the \"okay-to-jump\" flag.\n-Vnm_tstart\n-void Vnm_tstart(int timer, const char *name)\n-Starts the timer on the particular machine.\n-Vnm_gethost\n-char * Vnm_gethost(char *host, int hostmax)\n-Ask the system for the hostname.\n-Vnm_sleep\n-void Vnm_sleep(int nusecs)\n-Implement a sleep function with microsecond resolution.\n-Vnm_jmpOkClear\n-void Vnm_jmpOkClear(void)\n-Signal and setjmp handling routine. Clear the \"okay-to-jump\" flag.\n-Vnm_signalInit\n-jmp_buf * Vnm_signalInit(void)\n-Initialize the signal handling data structures.\n-Vnm_chdir\n-int Vnm_chdir(const char *path)\n-Interact with the system to change the working directory.\n-Vnm_typeChk\n-void Vnm_typeChk(void)\n-Check out the sizes of various datatypes.\n-Vnm_jmpOk\n-int Vnm_jmpOk(void)\n-Signal and setjmp handling routine. Return the \"ok-to-jump\" flag.\n-Vnm_tprint\n-void Vnm_tprint(const int unit, const char *format,...)\n-Add our ioTag to Vnm_print output. We MUST NOT use VASSERT (or Vnm_print!) in\n-this routine.\n-Vnm_gethome\n-char * Vnm_gethome(char *path, int pathmax)\n-Ask the system for the home directory.\n-Vnm_epsmac\n-double Vnm_epsmac(void)\n-Computes the unit roundoff of the machine in single precision. This is defined\n-as the smallest posi...\n-Vnm_systemBack\n-int Vnm_systemBack(const char *cmd)\n-A background variant of the ANSI-C \"system\" call.\n-Vnm_gentokens\n-int Vnm_gentokens(char *buf, char **argv, const int argvmax, const char *white,\n-const char *comment)\n-Generate an [argv,argc] pair from a character string \"buf\" (assumed NULL-\n-terminated) in which tokens ...\n-Vnm_systemKill\n-int Vnm_systemKill(const char *cmd)\n-Something like a UNIX \"killall\" call.\n-Vnm_qsort\n-void Vnm_qsort(int *u, int size)\n-Front-end to quick sort integer array from [-large] to [+large].\n-Vnm_sigIntSet\n-void Vnm_sigIntSet(void)\n-Signal and setjmp handling routine. Set the signal interrupt flag.\n-Vnm_redirect\n-void Vnm_redirect(const int flag)\n-Set/unset the redirect flag for UNIT zero. When redirected, I/O goes to the\n-file: ${MCSH_HOME}/io....\n-Vnm_getcwd\n-char * Vnm_getcwd(char *path, int pathmax)\n-Ask the system for the current working directory.\n-Vnm_getuser\n-char * Vnm_getuser(char *user, int usermax)\n-Ask the system for the username.\n-Vnm_regHand\n-void Vnm_regHand(void)\n-Register the signal handler with the operating system.\n-Vnm_dqsort\n-void Vnm_dqsort(double *u, int size)\n-Front-end to quick sort integer array from [-large] to [+large].\n-Vnm_tstop\n-void Vnm_tstop(int timer, const char *name)\n-Stops the timer on the particular machine.\n+VMAX_ARGNUM\n+#define VMAX_ARGNUM\n+Global constant.\n+Definition maloc_base.h:225\n+VMAX_BUFSIZE\n+#define VMAX_BUFSIZE\n+Global constant.\n+Definition maloc_base.h:229\n+VMAX_ARGLEN\n+#define VMAX_ARGLEN\n+Global constant.\n+Definition maloc_base.h:227\n+vnm.h\n+Header file for an ISO C [V]irtual [N]umerical [M]achine.\n+Vio_bufSize\n+int Vio_bufSize(Vio *thee)\n+Return the length to the internal buffer.\n+Vio_stop\n+void Vio_stop(void)\n+Shutdown Vio communication layer.\n+Vio_write\n+int Vio_write(Vio *thee, char *buf, int bufsize)\n+Write bufsize characters from buf to output device.\n+Vio_scanf\n+int Vio_scanf(Vio *thee, char *parms,...)\n+Mimic \"scanf\" from an arbitrary Vio device.\n+Vio_acceptFree\n+void Vio_acceptFree(Vio *thee)\n+Free the socket child that was used for the last accept.\n+Vio_start\n+void Vio_start(void)\n+Start Vio communication layer (init internal variables/buffers)\n+Vio_printf\n+int Vio_printf(Vio *thee, char *parms,...)\n+Mimic \"printf\" from an arbitrary Vio device.\n+Vio_socketOpen\n+Vio * Vio_socketOpen(char *key, const char *iodev, const char *iofmt, const\n+char *iohost, const char *iofile)\n+Socket open for read or write.\n+Vio_setWhiteChars\n+void Vio_setWhiteChars(Vio *thee, char *whiteChars)\n+Set the white character set for I/O stream.\n+Vio_socketClose\n+void Vio_socketClose(Vio **sock)\n+Socket close from read or write.\n+Vio_connect\n+int Vio_connect(Vio *thee, int nonblock)\n+Connect to some socket on a remote machine (or on our machine)\n+VIOfrmt\n+VIOfrmt\n+Parameter for compression type (XDR,ASC)\n+Definition vio.h:76\n+Vio_accept\n+int Vio_accept(Vio *thee, int nonblock)\n+Accept any waiting connect attempt to our socket on our machine.\n+Vio_ctor\n+Vio * Vio_ctor(const char *socktype, const char *datafrmt, const char\n+*hostname, const char *filename, const char *rwkey)\n+Construct the Vio object.\n+VIOtype\n+VIOtype\n+Parameter for I/O type (sdio,buff,file,unix,inet)\n+Definition vio.h:62\n+Vio_dtor\n+void Vio_dtor(Vio **thee)\n+Destruct the Vio object.\n+Vio_read\n+int Vio_read(Vio *thee, char *buf, int bufsize)\n+Read (up to) bufsize characters into buf from input device.\n+Vio_bufTake\n+void Vio_bufTake(Vio *thee, char *buf, int bufsize)\n+Set the pointer to the internal buffer.\n+Vio_connectFree\n+void Vio_connectFree(Vio *thee)\n+Purge any output buffers (for , else a no-op)\n+Vio_setCommChars\n+void Vio_setCommChars(Vio *thee, char *commChars)\n+Set the comment character set for I/O stream.\n+Vio_bufGive\n+char * Vio_bufGive(Vio *thee)\n+Return the pointer to the internal buffer.\n+VIOrwkey\n+VIOrwkey\n+Parameter for rw type (R,RW)\n+Definition vio.h:87\n+Vio_dtor2\n+void Vio_dtor2(Vio *thee)\n+Work routine that Vio_dtor calls to do most of the destruction.\n+Vio_ctor2\n+int Vio_ctor2(Vio *thee, const char *socktype, const char *datafrmt, const char\n+*hostname, const char *filename, const char *rwkey)\n+Work routine that Vio_ctor calls to do most of the construction.\n+VIO_XDR\n+@ VIO_XDR\n+Definition vio.h:78\n+VIO_NO_FRMT\n+@ VIO_NO_FRMT\n+Definition vio.h:77\n+VIO_ASC\n+@ VIO_ASC\n+Definition vio.h:79\n+VIO_NO_TYPE\n+@ VIO_NO_TYPE\n+Definition vio.h:63\n+VIO_FILE\n+@ VIO_FILE\n+Definition vio.h:66\n+VIO_UNIX\n+@ VIO_UNIX\n+Definition vio.h:67\n+VIO_BUFF\n+@ VIO_BUFF\n+Definition vio.h:65\n+VIO_SDIO\n+@ VIO_SDIO\n+Definition vio.h:64\n+VIO_INET\n+@ VIO_INET\n+Definition vio.h:68\n+VIO_NO_RW\n+@ VIO_NO_RW\n+Definition vio.h:88\n+VIO_W\n+@ VIO_W\n+Definition vio.h:90\n+VIO_R\n+@ VIO_R\n+Definition vio.h:89\n+sVio\n+Contains public data members for Vio class.\n+Definition vio.h:98\n+sVio::putBuffer\n+char putBuffer[VMAX_BUFSIZE]\n+Definition vio.h:137\n+sVio::type\n+VIOtype type\n+Definition vio.h:100\n+sVio::ioBufferLen\n+int ioBufferLen\n+Definition vio.h:135\n+sVio::rwkey\n+VIOrwkey rwkey\n+Definition vio.h:113\n+sVio::commChars\n+char commChars[VMAX_ARGNUM]\n+Definition vio.h:132\n+sVio::VIObufferPtr\n+int VIObufferPtr\n+Definition vio.h:142\n+sVio::fp\n+FILE * fp\n+Definition vio.h:125\n+sVio::frmt\n+VIOfrmt frmt\n+Definition vio.h:108\n+sVio::dirty\n+int dirty\n+Definition vio.h:123\n+sVio::soc\n+int soc\n+Definition vio.h:127\n+sVio::lhost\n+char lhost[VMAX_ARGLEN]\n+Definition vio.h:119\n+sVio::whiteChars\n+char whiteChars[VMAX_ARGNUM]\n+Definition vio.h:131\n+sVio::ioBuffer\n+char ioBuffer[VMAX_BUFSIZE]\n+Definition vio.h:134\n+sVio::VIObufferLen\n+int VIObufferLen\n+Definition vio.h:141\n+sVio::file\n+char file[VMAX_ARGLEN]\n+Definition vio.h:118\n+sVio::name\n+void * name\n+Definition vio.h:128\n+sVio::axdr\n+void * axdr\n+Definition vio.h:129\n+sVio::VIObuffer\n+char * VIObuffer\n+Definition vio.h:140\n+sVio::putBufferLen\n+int putBufferLen\n+Definition vio.h:138\n+sVio::so\n+int so\n+Definition vio.h:126\n+sVio::rhost\n+char rhost[VMAX_ARGLEN]\n+Definition vio.h:120\n+sVio::error\n+int error\n+Definition vio.h:122\n \n ===============================================================================\n Generated by\u00a0[doxygen] 1.9.8\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00036.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00036.dot.gz", "unified_diff": null, "details": [{"source1": "a00036.dot", "source2": "a00036.dot", "unified_diff": "@@ -1,14 +1,14 @@\n-digraph \"vnm.h\"\n+digraph \"vio.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vnm.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node1 [id=\"Node000001\",label=\"vio.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node2 [id=\"Node000002\",label=\"maloc/maloc_base.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00002.html\",tooltip=\"The base (or foundation) header for MALOC.\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node3 [id=\"Node000003\",label=\"assert.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node4 [id=\"Node000004\",label=\"ctype.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node5 [id=\"edge4_Node000002_Node000005\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n@@ -33,8 +33,11 @@\n Node14 [id=\"Node000014\",label=\"stdlib.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n+ Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00037.dot", "source2": "./usr/share/doc/libmaloc-dev/html/a00037.dot", "unified_diff": "@@ -1,34 +1,28 @@\n-digraph \"vnm.h\"\n+digraph \"vio.h\"\n {\n // LATEX_PDF_SIZE\n bgcolor=\"transparent\";\n edge [fontname=FreeSans,fontsize=10,labelfontname=FreeSans,labelfontsize=10];\n node [fontname=FreeSans,fontsize=10,shape=box,height=0.2,width=0.4];\n- Node1 [id=\"Node000001\",label=\"vnm.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node1 [id=\"Node000001\",label=\"vio.h\",height=0.2,width=0.4,color=\"gray40\", fillcolor=\"grey60\", style=\"filled\", fontcolor=\"black\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node1 -> Node2 [id=\"edge1_Node000001_Node000002\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node2 [id=\"Node000002\",label=\"vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node2 [id=\"Node000002\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node2 -> Node3 [id=\"edge2_Node000002_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 [id=\"Node000003\",label=\"vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n- Node3 -> Node4 [id=\"edge3_Node000003_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node4 [id=\"Node000004\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n- Node3 -> Node5 [id=\"edge4_Node000003_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node5 [id=\"Node000005\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n- Node5 -> Node4 [id=\"edge5_Node000005_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 -> Node6 [id=\"edge6_Node000003_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node6 [id=\"Node000006\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n- Node6 -> Node7 [id=\"edge7_Node000006_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node7 [id=\"Node000007\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n- Node7 -> Node5 [id=\"edge8_Node000007_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 -> Node7 [id=\"edge9_Node000003_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 -> Node8 [id=\"edge10_Node000003_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node8 [id=\"Node000008\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n- Node8 -> Node7 [id=\"edge11_Node000008_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node3 -> Node9 [id=\"edge12_Node000003_Node000009\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node9 [id=\"Node000009\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n- Node9 -> Node4 [id=\"edge13_Node000009_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node9 -> Node5 [id=\"edge14_Node000009_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node10 [id=\"edge15_Node000001_Node000010\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node10 [id=\"Node000010\",label=\"vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n- Node10 -> Node3 [id=\"edge16_Node000010_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node1 -> Node3 [id=\"edge17_Node000001_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node3 [id=\"Node000003\",label=\"maloc.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00038.html\",tooltip=\"The foundation header for MALOC.\"];\n+ Node2 -> Node4 [id=\"edge3_Node000002_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node4 [id=\"Node000004\",label=\"psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node4 -> Node3 [id=\"edge4_Node000004_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node5 [id=\"edge5_Node000002_Node000005\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node5 [id=\"Node000005\",label=\"vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node5 -> Node6 [id=\"edge6_Node000005_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node6 [id=\"Node000006\",label=\"vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node6 -> Node4 [id=\"edge7_Node000006_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node6 [id=\"edge8_Node000002_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node7 [id=\"edge9_Node000002_Node000007\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node7 [id=\"Node000007\",label=\"vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n+ Node7 -> Node6 [id=\"edge10_Node000007_Node000006\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node2 -> Node8 [id=\"edge11_Node000002_Node000008\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node8 [id=\"Node000008\",label=\"vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n+ Node8 -> Node3 [id=\"edge12_Node000008_Node000003\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n+ Node8 -> Node4 [id=\"edge13_Node000008_Node000004\",dir=\"back\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00038.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00038.html", "unified_diff": "@@ -47,17 +47,17 @@\n
    \n
    \n \n

    The foundation header for MALOC.
    \n \n More...

    \n
    #include <maloc/maloc_base.h>
    \n-#include <maloc/vsys.h>
    \n+#include <maloc/vsys.h>
    \n #include <maloc/vsh.h>
    \n-#include <maloc/psh.h>
    \n+#include <maloc/psh.h>
    \n
    \n Include dependency graph for maloc.h:
    \n
    \n
    \"\"/
    \n
    \n
    \n

    Go to the source code of this file.

    \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00038_source.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00038_source.html", "unified_diff": "@@ -53,24 +53,24 @@\n
    \n Go to the documentation of this file.
    1
    \n
    35#ifndef _MALOC_H_
    \n
    36#define _MALOC_H_
    \n
    37
    \n
    38#include <maloc/maloc_base.h>
    \n
    39
    \n-
    40#include <maloc/vsys.h>
    \n+
    40#include <maloc/vsys.h>
    \n
    41#include <maloc/vsh.h>
    \n-
    42#include <maloc/psh.h>
    \n+
    42#include <maloc/psh.h>
    \n
    43
    \n
    44#endif /* _MALOC_H_ */
    \n
    45
    \n
    The base (or foundation) header for MALOC.
    \n-
    Header file for a simple parallel extension of ALOC's VSH.
    \n+
    Header file for a simple parallel extension of ALOC's VSH.
    \n
    Header file for vsh, a bourne-compatible shell.
    \n-
    The primary header for VSYS. (Virtual SYStem utilities library.)
    \n+
    The primary header for VSYS. (Virtual SYStem utilities library.)
    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00039.dot.gz", "source2": "./usr/share/doc/libmaloc-dev/html/a00039.dot.gz", "unified_diff": null, "details": [{"source1": "a00039.dot", "source2": "a00039.dot", "unified_diff": "@@ -34,49 +34,49 @@\n Node2 -> Node15 [id=\"edge14_Node000002_Node000015\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node15 [id=\"Node000015\",label=\"string.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node16 [id=\"edge15_Node000002_Node000016\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node16 [id=\"Node000016\",label=\"time.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node2 -> Node17 [id=\"edge16_Node000002_Node000017\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node17 [id=\"Node000017\",label=\"setjmp.h\",height=0.2,width=0.4,color=\"grey60\", fillcolor=\"#E0E0E0\", style=\"filled\",tooltip=\" \"];\n Node1 -> Node18 [id=\"edge17_Node000001_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n+ Node18 [id=\"Node000018\",label=\"maloc/vsys.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"The primary header for VSYS. (Virtual SYStem utilities library.)\"];\n Node18 -> Node2 [id=\"edge18_Node000018_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node19 [id=\"edge19_Node000018_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n+ Node19 [id=\"Node000019\",label=\"maloc/vnm.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for an ISO C [V]irtual [N]umerical [M]achine.\"];\n Node19 -> Node2 [id=\"edge20_Node000019_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node20 [id=\"edge21_Node000018_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node20 [id=\"Node000020\",label=\"maloc/vmem.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00029.html\",tooltip=\"Class Vmem: A safer, object-oriented, malloc/free object.\"];\n Node20 -> Node2 [id=\"edge22_Node000020_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node21 [id=\"edge23_Node000018_Node000021\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00023.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n+ Node21 [id=\"Node000021\",label=\"maloc/vio.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00035.html\",tooltip=\"Class Vio: virtual I/O layer.\"];\n Node21 -> Node2 [id=\"edge24_Node000021_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node21 -> Node19 [id=\"edge25_Node000021_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node22 [id=\"edge26_Node000018_Node000022\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 [id=\"Node000022\",label=\"maloc/vset.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00026.html\",tooltip=\"Class Vset: a dynamic set object.\"];\n Node22 -> Node2 [id=\"edge27_Node000022_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node19 [id=\"edge28_Node000022_Node000019\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node22 -> Node20 [id=\"edge29_Node000022_Node000020\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node18 -> Node23 [id=\"edge30_Node000018_Node000023\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00032.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n+ Node23 [id=\"Node000023\",label=\"maloc/vpred.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00020.html\",tooltip=\"Header file for the Geometric Predicates.\"];\n Node23 -> Node2 [id=\"edge31_Node000023_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node24 [id=\"edge32_Node000001_Node000024\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node24 [id=\"Node000024\",label=\"maloc/vsh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00017.html\",tooltip=\"Header file for vsh, a bourne-compatible shell.\"];\n Node24 -> Node2 [id=\"edge33_Node000024_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node24 -> Node18 [id=\"edge34_Node000024_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node1 -> Node25 [id=\"edge35_Node000001_Node000025\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node25 [id=\"Node000025\",label=\"maloc/psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n+ Node25 [id=\"Node000025\",label=\"maloc/psh.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Header file for a simple parallel extension of ALOC's VSH.\"];\n Node25 -> Node2 [id=\"edge36_Node000025_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node25 -> Node18 [id=\"edge37_Node000025_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node25 -> Node24 [id=\"edge38_Node000025_Node000024\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node25 -> Node26 [id=\"edge39_Node000025_Node000026\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node26 [id=\"Node000026\",label=\"maloc/vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00011.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n+ Node26 [id=\"Node000026\",label=\"maloc/vmp.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vmp: a Virtual MPI communication layer object.\"];\n Node26 -> Node2 [id=\"edge40_Node000026_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node26 -> Node18 [id=\"edge41_Node000026_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node26 -> Node27 [id=\"edge42_Node000026_Node000027\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node27 [id=\"Node000027\",label=\"maloc/vmpi.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00014.html\",tooltip=\"Class Vmpi: a Virtual MPI communication layer object.\"];\n Node27 -> Node2 [id=\"edge43_Node000027_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node27 -> Node18 [id=\"edge44_Node000027_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node26 -> Node28 [id=\"edge45_Node000026_Node000028\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n- Node28 [id=\"Node000028\",label=\"maloc/vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00005.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n+ Node28 [id=\"Node000028\",label=\"maloc/vcom.h\",height=0.2,width=0.4,color=\"grey40\", fillcolor=\"white\", style=\"filled\",URL=\"$a00008.html\",tooltip=\"Class Vcom: virtual (currently just MPI) communications layer.\"];\n Node28 -> Node2 [id=\"edge46_Node000028_Node000002\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n Node28 -> Node18 [id=\"edge47_Node000028_Node000018\",color=\"steelblue1\",style=\"solid\",tooltip=\" \"];\n }\n"}]}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00047.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00047.html", "unified_diff": "@@ -49,16 +49,16 @@\n More...

    \n \n \n \n \n \n-\n-\n+\n+\n \n \n \n \n

    \n Files

    file  maloc_base.h
     The base (or foundation) header for MALOC.
     
    file  vsys.h
     The primary header for VSYS. (Virtual SYStem utilities library.)
    file  vsys.h
     The primary header for VSYS. (Virtual SYStem utilities library.)
     
    file  maloc.h
     The foundation header for MALOC.
    \n
     
    \n

    Detailed Description

    \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00048.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00048.html", "unified_diff": "@@ -49,16 +49,16 @@\n
    \n \n

    Virtual (currently just MPI) communications layer. \n More...

    \n \n \n-\n-\n+\n+\n \n

    \n Files

    file  vcom.h
     Class Vcom: virtual (currently just MPI) communications layer.
    file  vcom.h
     Class Vcom: virtual (currently just MPI) communications layer.
     
    \n \n \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00049.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00049.html", "unified_diff": "@@ -49,16 +49,16 @@\n
    \n \n

    A Virtual MPI communication layer object. \n More...

    \n

    \n Classes

    struct  sVcom
     Contains public data members for Vcom class. More...
     
    \n \n-\n-\n+\n+\n \n

    \n Files

    file  vmp.h
     Class Vmp: a Virtual MPI communication layer object.
    file  vmp.h
     Class Vmp: a Virtual MPI communication layer object.
     
    \n \n \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00051.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00051.html", "unified_diff": "@@ -49,16 +49,16 @@\n
    \n \n

    A bourne-compatible shell. \n More...

    \n

    \n Classes

    struct  sVmp
     Contains public data members for Vmp class. More...
     
    \n \n-\n-\n+\n+\n \n \n \n \n

    \n Files

    file  psh.h
     Header file for a simple parallel extension of ALOC's VSH.
    file  psh.h
     Header file for a simple parallel extension of ALOC's VSH.
     
    file  vsh.h
     Header file for vsh, a bourne-compatible shell.
     
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00052.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00052.html", "unified_diff": "@@ -50,16 +50,16 @@\n
    \n \n

    This class provides an I/O layer for files/bufferes/pipes/sockets. \n More...

    \n

    \n Classes

    \n \n-\n-\n+\n+\n \n

    \n Files

    file  vio.h
     Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.
    file  vio.h
     Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.
     
    \n \n \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00058.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00058.html", "unified_diff": "@@ -45,15 +45,15 @@\n
    sVcom Struct Reference
    \n \n
    \n \n

    Contains public data members for Vcom class. \n More...

    \n \n-

    #include <vcom.h>

    \n+

    #include <vcom.h>

    \n

    \n Classes

    struct  sVio
     Contains public data members for Vio class. More...
     
    \n \n \n \n \n \n@@ -155,15 +155,15 @@\n

    Communication type.
    \n 0 = not initialized
    \n 1 = Message Passing Interface 1.1.

    \n \n \n \n
    The documentation for this struct was generated from the following file:\n \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00062.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00062.html", "unified_diff": "@@ -45,15 +45,15 @@\n
    sVmp Struct Reference
    \n \n
    \n \n

    Contains public data members for Vmp class. \n More...

    \n \n-

    #include <vmp.h>

    \n+

    #include <vmp.h>

    \n

    \n Public Attributes

    int mpi_rank
     Local PE rank from MPI.
     
    int mpi_size
    \n \n \n \n \n \n@@ -92,15 +92,15 @@\n
    \n

    number of processess in this execution
    \n

    \n \n
    \n \n
    The documentation for this struct was generated from the following file:\n \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/a00074.html", "source2": "./usr/share/doc/libmaloc-dev/html/a00074.html", "unified_diff": "@@ -45,15 +45,15 @@\n
    sVio Struct Reference
    \n \n
    \n \n

    Contains public data members for Vio class. \n More...

    \n \n-

    #include <vio.h>

    \n+

    #include <vio.h>

    \n

    \n Public Attributes

    int mpi_rank
     
    int mpi_size
     
    \n \n \n \n \n \n@@ -450,15 +450,15 @@\n
    \n

    white space character set (ASC)
    \n

    \n \n
    \n \n
    The documentation for this struct was generated from the following file:\n \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000000_000007.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000000_000007.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    aaa_inc → psh Relation

    \n Public Attributes

    VIOtype type
     
    VIOfrmt frmt
     
    File in src/aaa_incIncludes file in src/psh
    maloc / maloc.hmaloc / psh.h
    \n+

    aaa_inc → psh Relation

    File in src/aaa_incIncludes file in src/psh
    maloc / maloc.hmaloc / psh.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000000_000010.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000000_000010.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n
    \n
    \n-

    aaa_inc → vsys Relation

    File in src/aaa_incIncludes file in src/vsys
    maloc / maloc.hmaloc / vsys.h
    \n+

    aaa_inc → vsys Relation

    File in src/aaa_incIncludes file in src/vsys
    maloc / maloc.hmaloc / vsys.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000002_000007.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000002_000007.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n
    \n
    \n-

    maloc → psh Relation

    File in src/aaa_inc/malocIncludes file in src/psh
    maloc.hmaloc / psh.h
    \n+

    maloc → psh Relation

    File in src/aaa_inc/malocIncludes file in src/psh
    maloc.hmaloc / psh.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000002_000010.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000002_000010.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n
    \n
    \n-

    maloc → vsys Relation

    File in src/aaa_inc/malocIncludes file in src/vsys
    maloc.hmaloc / vsys.h
    \n+

    maloc → vsys Relation

    File in src/aaa_inc/malocIncludes file in src/vsys
    maloc.hmaloc / vsys.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000004_000001.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000004_000001.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    maloc → base Relation

    File in src/psh/malocIncludes file in src/base
    psh.hmaloc / maloc_base.h
    vcom.hmaloc / maloc_base.h
    vmp.hmaloc / maloc_base.h
    vmpi.hmaloc / maloc_base.h
    \n+

    maloc → base Relation

    File in src/psh/malocIncludes file in src/base
    psh.hmaloc / maloc_base.h
    vcom.hmaloc / maloc_base.h
    vmp.hmaloc / maloc_base.h
    vmpi.hmaloc / maloc_base.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000004_000009.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000004_000009.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    maloc → vsh Relation

    File in src/psh/malocIncludes file in src/vsh
    psh.hmaloc / vsh.h
    \n+

    maloc → vsh Relation

    File in src/psh/malocIncludes file in src/vsh
    psh.hmaloc / vsh.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000004_000010.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000004_000010.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    maloc → vsys Relation

    File in src/psh/malocIncludes file in src/vsys
    psh.hmaloc / vsys.h
    vcom.hmaloc / vsys.h
    vmp.hmaloc / vsys.h
    vmpi.hmaloc / vsys.h
    \n+

    maloc → vsys Relation

    File in src/psh/malocIncludes file in src/vsys
    psh.hmaloc / vsys.h
    vcom.hmaloc / vsys.h
    vmp.hmaloc / vsys.h
    vmpi.hmaloc / vsys.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000005_000010.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000005_000010.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    maloc → vsys Relation

    File in src/vsh/malocIncludes file in src/vsys
    vsh.hmaloc / vsys.h
    \n+

    maloc → vsys Relation

    File in src/vsh/malocIncludes file in src/vsys
    vsh.hmaloc / vsys.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000006_000001.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000006_000001.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    maloc → base Relation

    File in src/vsys/malocIncludes file in src/base
    vio.hmaloc / maloc_base.h
    vmem.hmaloc / maloc_base.h
    vnm.hmaloc / maloc_base.h
    vpred.hmaloc / maloc_base.h
    vset.hmaloc / maloc_base.h
    vsys.hmaloc / maloc_base.h
    \n+

    maloc → base Relation

    File in src/vsys/malocIncludes file in src/base
    vio.hmaloc / maloc_base.h
    vmem.hmaloc / maloc_base.h
    vnm.hmaloc / maloc_base.h
    vpred.hmaloc / maloc_base.h
    vset.hmaloc / maloc_base.h
    vsys.hmaloc / maloc_base.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000007_000001.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000007_000001.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    psh → base Relation

    File in src/pshIncludes file in src/base
    maloc / psh.hmaloc / maloc_base.h
    maloc / vcom.hmaloc / maloc_base.h
    maloc / vmp.hmaloc / maloc_base.h
    maloc / vmpi.hmaloc / maloc_base.h
    \n+

    psh → base Relation

    File in src/pshIncludes file in src/base
    maloc / psh.hmaloc / maloc_base.h
    maloc / vcom.hmaloc / maloc_base.h
    maloc / vmp.hmaloc / maloc_base.h
    maloc / vmpi.hmaloc / maloc_base.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000007_000009.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000007_000009.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    psh → vsh Relation

    File in src/pshIncludes file in src/vsh
    maloc / psh.hmaloc / vsh.h
    \n+

    psh → vsh Relation

    File in src/pshIncludes file in src/vsh
    maloc / psh.hmaloc / vsh.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000007_000010.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000007_000010.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    psh → vsys Relation

    File in src/pshIncludes file in src/vsys
    maloc / psh.hmaloc / vsys.h
    maloc / vcom.hmaloc / vsys.h
    maloc / vmp.hmaloc / vsys.h
    maloc / vmpi.hmaloc / vsys.h
    \n+

    psh → vsys Relation

    File in src/pshIncludes file in src/vsys
    maloc / psh.hmaloc / vsys.h
    maloc / vcom.hmaloc / vsys.h
    maloc / vmp.hmaloc / vsys.h
    maloc / vmpi.hmaloc / vsys.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000009_000010.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000009_000010.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    vsh → vsys Relation

    File in src/vshIncludes file in src/vsys
    maloc / vsh.hmaloc / vsys.h
    \n+

    vsh → vsys Relation

    File in src/vshIncludes file in src/vsys
    maloc / vsh.hmaloc / vsys.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_000010_000001.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_000010_000001.html", "unified_diff": "@@ -39,14 +39,14 @@\n
    \n
    \n \n
    \n \n
    \n-

    vsys → base Relation

    File in src/vsysIncludes file in src/base
    maloc / vio.hmaloc / maloc_base.h
    maloc / vmem.hmaloc / maloc_base.h
    maloc / vnm.hmaloc / maloc_base.h
    maloc / vpred.hmaloc / maloc_base.h
    maloc / vset.hmaloc / maloc_base.h
    maloc / vsys.hmaloc / maloc_base.h
    \n+

    vsys → base Relation

    File in src/vsysIncludes file in src/base
    maloc / vio.hmaloc / maloc_base.h
    maloc / vmem.hmaloc / maloc_base.h
    maloc / vnm.hmaloc / maloc_base.h
    maloc / vpred.hmaloc / maloc_base.h
    maloc / vset.hmaloc / maloc_base.h
    maloc / vsys.hmaloc / maloc_base.h
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_4487082feb20b0a33d872f1cd04ae7e1.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_4487082feb20b0a33d872f1cd04ae7e1.html", "unified_diff": "@@ -50,22 +50,22 @@\n Directory dependency graph for maloc:\n
    \n
    \"maloc\"/
    \n
    \n \n \n-\n-\n+\n+\n \n-\n-\n+\n+\n \n-\n-\n+\n+\n \n \n \n \n

    \n Files

     psh.h
     Header file for a simple parallel extension of ALOC's VSH.
     psh.h
     Header file for a simple parallel extension of ALOC's VSH.
     
     vcom.h
     Class Vcom: virtual (currently just MPI) communications layer.
     vcom.h
     Class Vcom: virtual (currently just MPI) communications layer.
     
     vmp.h
     Class Vmp: a Virtual MPI communication layer object.
     vmp.h
     Class Vmp: a Virtual MPI communication layer object.
     
     vmpi.h
     Class Vmpi: a Virtual MPI communication layer object.
     
    \n \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/dir_dd09f1089953cfb53b7653deda4818f6.html", "source2": "./usr/share/doc/libmaloc-dev/html/dir_dd09f1089953cfb53b7653deda4818f6.html", "unified_diff": "@@ -50,31 +50,31 @@\n Directory dependency graph for maloc:\n
    \n
    \"maloc\"/
    \n
    \n \n \n-\n-\n+\n+\n \n \n \n \n-\n-\n+\n+\n \n-\n-\n+\n+\n \n \n \n \n-\n-\n+\n+\n \n

    \n Files

     vio.h
     Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.
     vio.h
     Class Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer.
     
     vmem.h
     Class Vmem: A safer, object-oriented, malloc/free object.
     
     vnm.h
     Header file for an ISO C [V]irtual [N]umerical [M]achine.
     vnm.h
     Header file for an ISO C [V]irtual [N]umerical [M]achine.
     
     vpred.h
     Header file for the Geometric Predicates.
     vpred.h
     Header file for the Geometric Predicates.
     
     vset.h
     Class Vset: a dynamic set object.
     
     vsys.h
     The primary header for VSYS. (Virtual SYStem utilities library.)
     vsys.h
     The primary header for VSYS. (Virtual SYStem utilities library.)
     
    \n \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/files.html", "source2": "./usr/share/doc/libmaloc-dev/html/files.html", "unified_diff": "@@ -50,29 +50,29 @@\n  maloc.hThe foundation header for MALOC.
    \n \n   base\n   maloc\n  maloc_base.hThe base (or foundation) header for MALOC \n   psh\n   maloc\n- psh.hHeader file for a simple parallel extension of ALOC's VSH \n- vcom.hClass Vcom: virtual (currently just MPI) communications layer \n- vmp.hClass Vmp: a Virtual MPI communication layer object \n+ psh.hHeader file for a simple parallel extension of ALOC's VSH \n+ vcom.hClass Vcom: virtual (currently just MPI) communications layer \n+ vmp.hClass Vmp: a Virtual MPI communication layer object \n  vmpi.hClass Vmpi: a Virtual MPI communication layer object \n   vsh\n   maloc\n  vsh.hHeader file for vsh, a bourne-compatible shell \n   vsys\n   maloc\n- vio.hClass Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer \n+ vio.hClass Vio: virtual <SDIO/FILE/BUFF/UNIX/INET> I/O layer \n  vmem.hClass Vmem: A safer, object-oriented, malloc/free object \n- vnm.hHeader file for an ISO C [V]irtual [N]umerical [M]achine \n- vpred.hHeader file for the Geometric Predicates \n+ vnm.hHeader file for an ISO C [V]irtual [N]umerical [M]achine \n+ vpred.hHeader file for the Geometric Predicates \n  vset.hClass Vset: a dynamic set object \n- vsys.hThe primary header for VSYS. (Virtual SYStem utilities library.) \n+ vsys.hThe primary header for VSYS. (Virtual SYStem utilities library.) \n  prog.h\n  license.h\n \n \n \n \n
    \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/globals_defs.html", "source2": "./usr/share/doc/libmaloc-dev/html/globals_defs.html", "unified_diff": "@@ -54,32 +54,32 @@\n \n

    - e -

    \n \n \n

    - i -

    \n \n \n

    - n -

    \n \n \n

    - r -

    \n \n \n

    - u -

    \n \n \n

    - v -

    \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/globals_func.html", "source2": "./usr/share/doc/libmaloc-dev/html/globals_func.html", "unified_diff": "@@ -111,67 +111,67 @@\n
  • Vmpi_init() : vmpi.h
  • \n
  • Vmpi_isend() : vmpi.h
  • \n
  • Vmpi_rank() : vmpi.h
  • \n
  • Vmpi_recv() : vmpi.h
  • \n
  • Vmpi_reduce() : vmpi.h
  • \n
  • Vmpi_send() : vmpi.h
  • \n
  • Vmpi_size() : vmpi.h
  • \n-
  • Vnm_chdir() : vnm.h
  • \n-
  • Vnm_close() : vnm.h
  • \n-
  • Vnm_dqsort() : vnm.h
  • \n-
  • Vnm_dqsortOrd() : vnm.h
  • \n-
  • Vnm_epsmac() : vnm.h
  • \n-
  • Vnm_exec() : vnm.h
  • \n-
  • Vnm_flush() : vnm.h
  • \n-
  • Vnm_gentokens() : vnm.h
  • \n-
  • Vnm_getcwd() : vnm.h
  • \n-
  • Vnm_gethome() : vnm.h
  • \n-
  • Vnm_gethost() : vnm.h
  • \n-
  • Vnm_getos() : vnm.h
  • \n-
  • Vnm_getuser() : vnm.h
  • \n-
  • Vnm_ioTag() : vnm.h
  • \n-
  • Vnm_jmpOk() : vnm.h
  • \n-
  • Vnm_jmpOkClear() : vnm.h
  • \n-
  • Vnm_jmpOkSet() : vnm.h
  • \n-
  • Vnm_mkdir() : vnm.h
  • \n-
  • Vnm_nTags() : vnm.h
  • \n-
  • Vnm_open() : vnm.h
  • \n-
  • Vnm_powsafe() : vnm.h
  • \n-
  • Vnm_print() : vnm.h
  • \n-
  • Vnm_qsort() : vnm.h
  • \n-
  • Vnm_qsortOrd() : vnm.h
  • \n-
  • Vnm_redirect() : vnm.h
  • \n-
  • Vnm_regHand() : vnm.h
  • \n-
  • Vnm_setIoTag() : vnm.h
  • \n-
  • Vnm_sigHand() : vnm.h
  • \n-
  • Vnm_sigInt() : vnm.h
  • \n-
  • Vnm_sigIntClear() : vnm.h
  • \n-
  • Vnm_sigIntSet() : vnm.h
  • \n-
  • Vnm_signalInit() : vnm.h
  • \n-
  • Vnm_sleep() : vnm.h
  • \n-
  • Vnm_system() : vnm.h
  • \n-
  • Vnm_systemBack() : vnm.h
  • \n-
  • Vnm_systemKill() : vnm.h
  • \n-
  • Vnm_tprint() : vnm.h
  • \n-
  • Vnm_tstart() : vnm.h
  • \n-
  • Vnm_tstop() : vnm.h
  • \n-
  • Vnm_typeChk() : vnm.h
  • \n-
  • Vpred_exactinit() : vpred.h
  • \n-
  • Vpred_incircle() : vpred.h
  • \n-
  • Vpred_incircleexact() : vpred.h
  • \n-
  • Vpred_incirclefast() : vpred.h
  • \n-
  • Vpred_insphere() : vpred.h
  • \n-
  • Vpred_insphereexact() : vpred.h
  • \n-
  • Vpred_inspherefast() : vpred.h
  • \n-
  • Vpred_orient2d() : vpred.h
  • \n-
  • Vpred_orient2dexact() : vpred.h
  • \n-
  • Vpred_orient2dfast() : vpred.h
  • \n-
  • Vpred_orient3d() : vpred.h
  • \n-
  • Vpred_orient3dexact() : vpred.h
  • \n-
  • Vpred_orient3dfast() : vpred.h
  • \n+
  • Vnm_chdir() : vnm.h
  • \n+
  • Vnm_close() : vnm.h
  • \n+
  • Vnm_dqsort() : vnm.h
  • \n+
  • Vnm_dqsortOrd() : vnm.h
  • \n+
  • Vnm_epsmac() : vnm.h
  • \n+
  • Vnm_exec() : vnm.h
  • \n+
  • Vnm_flush() : vnm.h
  • \n+
  • Vnm_gentokens() : vnm.h
  • \n+
  • Vnm_getcwd() : vnm.h
  • \n+
  • Vnm_gethome() : vnm.h
  • \n+
  • Vnm_gethost() : vnm.h
  • \n+
  • Vnm_getos() : vnm.h
  • \n+
  • Vnm_getuser() : vnm.h
  • \n+
  • Vnm_ioTag() : vnm.h
  • \n+
  • Vnm_jmpOk() : vnm.h
  • \n+
  • Vnm_jmpOkClear() : vnm.h
  • \n+
  • Vnm_jmpOkSet() : vnm.h
  • \n+
  • Vnm_mkdir() : vnm.h
  • \n+
  • Vnm_nTags() : vnm.h
  • \n+
  • Vnm_open() : vnm.h
  • \n+
  • Vnm_powsafe() : vnm.h
  • \n+
  • Vnm_print() : vnm.h
  • \n+
  • Vnm_qsort() : vnm.h
  • \n+
  • Vnm_qsortOrd() : vnm.h
  • \n+
  • Vnm_redirect() : vnm.h
  • \n+
  • Vnm_regHand() : vnm.h
  • \n+
  • Vnm_setIoTag() : vnm.h
  • \n+
  • Vnm_sigHand() : vnm.h
  • \n+
  • Vnm_sigInt() : vnm.h
  • \n+
  • Vnm_sigIntClear() : vnm.h
  • \n+
  • Vnm_sigIntSet() : vnm.h
  • \n+
  • Vnm_signalInit() : vnm.h
  • \n+
  • Vnm_sleep() : vnm.h
  • \n+
  • Vnm_system() : vnm.h
  • \n+
  • Vnm_systemBack() : vnm.h
  • \n+
  • Vnm_systemKill() : vnm.h
  • \n+
  • Vnm_tprint() : vnm.h
  • \n+
  • Vnm_tstart() : vnm.h
  • \n+
  • Vnm_tstop() : vnm.h
  • \n+
  • Vnm_typeChk() : vnm.h
  • \n+
  • Vpred_exactinit() : vpred.h
  • \n+
  • Vpred_incircle() : vpred.h
  • \n+
  • Vpred_incircleexact() : vpred.h
  • \n+
  • Vpred_incirclefast() : vpred.h
  • \n+
  • Vpred_insphere() : vpred.h
  • \n+
  • Vpred_insphereexact() : vpred.h
  • \n+
  • Vpred_inspherefast() : vpred.h
  • \n+
  • Vpred_orient2d() : vpred.h
  • \n+
  • Vpred_orient2dexact() : vpred.h
  • \n+
  • Vpred_orient2dfast() : vpred.h
  • \n+
  • Vpred_orient3d() : vpred.h
  • \n+
  • Vpred_orient3dexact() : vpred.h
  • \n+
  • Vpred_orient3dfast() : vpred.h
  • \n
  • Vset_access() : vset.h
  • \n
  • Vset_check() : vset.h
  • \n
  • Vset_create() : vset.h
  • \n
  • Vset_createLast() : vset.h
  • \n
  • Vset_ctor() : vset.h
  • \n
  • Vset_destroy() : vset.h
  • \n
  • Vset_destroyLast() : vset.h
  • \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/globals_i.html", "source2": "./usr/share/doc/libmaloc-dev/html/globals_i.html", "unified_diff": "@@ -38,15 +38,15 @@\n \n
    \n \n
    \n
    Here is a list of all file members with links to the files they belong to:
    \n \n

    - i -

    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/globals_n.html", "source2": "./usr/share/doc/libmaloc-dev/html/globals_n.html", "unified_diff": "@@ -38,15 +38,15 @@\n \n
    \n \n
    \n
    Here is a list of all file members with links to the files they belong to:
    \n \n

    - n -

    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/globals_r.html", "source2": "./usr/share/doc/libmaloc-dev/html/globals_r.html", "unified_diff": "@@ -38,17 +38,17 @@\n \n
    \n \n
    \n
    Here is a list of all file members with links to the files they belong to:
    \n \n

    - r -

    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/globals_u.html", "source2": "./usr/share/doc/libmaloc-dev/html/globals_u.html", "unified_diff": "@@ -38,15 +38,15 @@\n \n
    \n \n
    \n
    Here is a list of all file members with links to the files they belong to:
    \n \n

    - u -

    \n
    \n \n
    \n Generated by \"doxygen\"/ 1.9.8\n
    \n \n"}, {"source1": "./usr/share/doc/libmaloc-dev/html/globals_v.html", "source2": "./usr/share/doc/libmaloc-dev/html/globals_v.html", "unified_diff": "@@ -59,15 +59,15 @@\n
  • Vcom_ctor() : vcom.h
  • \n
  • Vcom_ctor2() : vcom.h
  • \n
  • Vcom_dtor() : vcom.h
  • \n
  • Vcom_dtor2() : vcom.h
  • \n
  • Vcom_finalize() : vcom.h
  • \n
  • Vcom_getCount() : vcom.h
  • \n
  • Vcom_init() : vcom.h
  • \n-
  • VCOM_MPI_TAG : vcom.h
  • \n+
  • VCOM_MPI_TAG : vcom.h
  • \n
  • Vcom_rank() : vcom.h
  • \n
  • Vcom_recv() : vcom.h
  • \n
  • Vcom_reduce() : vcom.h
  • \n
  • Vcom_resize() : vcom.h
  • \n
  • Vcom_send() : vcom.h
  • \n
  • Vcom_size() : vcom.h
  • \n
  • VCOS : maloc_base.h
  • \n@@ -92,15 +92,15 @@\n
  • Vio_connectFree() : vio.h
  • \n
  • Vio_ctor() : vio.h
  • \n
  • Vio_ctor2() : vio.h
  • \n
  • Vio_dtor() : vio.h
  • \n
  • Vio_dtor2() : vio.h
  • \n
  • VIO_FILE : vio.h
  • \n
  • VIO_INET : vio.h
  • \n-
  • VIO_MAXBUF : vio.h
  • \n+
  • VIO_MAXBUF : vio.h
  • \n
  • VIO_NO_FRMT : vio.h
  • \n
  • VIO_NO_RW : vio.h
  • \n
  • VIO_NO_TYPE : vio.h
  • \n
  • Vio_printf() : vio.h
  • \n
  • VIO_R : vio.h
  • \n
  • Vio_read() : vio.h
  • \n
  • Vio_scanf() : vio.h
  • \n@@ -176,77 +176,77 @@\n
  • Vmpi_recv() : vmpi.h
  • \n
  • Vmpi_reduce() : vmpi.h
  • \n
  • Vmpi_send() : vmpi.h
  • \n
  • Vmpi_size() : vmpi.h
  • \n
  • VNEG : maloc_base.h
  • \n
  • VNEWLINE_STRING : maloc_base.h
  • \n
  • VNEWLINE_SYMBOL : maloc_base.h
  • \n-
  • Vnm_chdir() : vnm.h
  • \n-
  • Vnm_close() : vnm.h
  • \n-
  • Vnm_dqsort() : vnm.h
  • \n-
  • Vnm_dqsortOrd() : vnm.h
  • \n-
  • Vnm_epsmac() : vnm.h
  • \n-
  • Vnm_exec() : vnm.h
  • \n-
  • Vnm_flush() : vnm.h
  • \n-
  • Vnm_gentokens() : vnm.h
  • \n-
  • Vnm_getcwd() : vnm.h
  • \n-
  • Vnm_gethome() : vnm.h
  • \n-
  • Vnm_gethost() : vnm.h
  • \n-
  • Vnm_getos() : vnm.h
  • \n-
  • Vnm_getuser() : vnm.h
  • \n-
  • Vnm_ioTag() : vnm.h
  • \n-
  • Vnm_jmpOk() : vnm.h
  • \n-
  • Vnm_jmpOkClear() : vnm.h
  • \n-
  • Vnm_jmpOkSet() : vnm.h
  • \n-
  • Vnm_mkdir() : vnm.h
  • \n-
  • Vnm_nTags() : vnm.h
  • \n-
  • Vnm_open() : vnm.h
  • \n-
  • Vnm_powsafe() : vnm.h
  • \n-
  • Vnm_print() : vnm.h
  • \n-
  • Vnm_qsort() : vnm.h
  • \n-
  • Vnm_qsortOrd() : vnm.h
  • \n-
  • Vnm_redirect() : vnm.h
  • \n-
  • Vnm_regHand() : vnm.h
  • \n-
  • Vnm_setIoTag() : vnm.h
  • \n-
  • Vnm_sigHand() : vnm.h
  • \n-
  • Vnm_sigInt() : vnm.h
  • \n-
  • Vnm_sigIntClear() : vnm.h
  • \n-
  • Vnm_sigIntSet() : vnm.h
  • \n-
  • Vnm_signalInit() : vnm.h
  • \n-
  • Vnm_sleep() : vnm.h
  • \n-
  • Vnm_system() : vnm.h
  • \n-
  • Vnm_systemBack() : vnm.h
  • \n-
  • Vnm_systemKill() : vnm.h
  • \n-
  • Vnm_tprint() : vnm.h
  • \n-
  • Vnm_tstart() : vnm.h
  • \n-
  • Vnm_tstop() : vnm.h
  • \n-
  • Vnm_typeChk() : vnm.h
  • \n+
  • Vnm_chdir() : vnm.h
  • \n+
  • Vnm_close() : vnm.h
  • \n+
  • Vnm_dqsort() : vnm.h
  • \n+
  • Vnm_dqsortOrd() : vnm.h
  • \n+
  • Vnm_epsmac() : vnm.h
  • \n+
  • Vnm_exec() : vnm.h
  • \n+
  • Vnm_flush() : vnm.h
  • \n+
  • Vnm_gentokens() : vnm.h
  • \n+
  • Vnm_getcwd() : vnm.h
  • \n+
  • Vnm_gethome() : vnm.h
  • \n+
  • Vnm_gethost() : vnm.h
  • \n+
  • Vnm_getos() : vnm.h
  • \n+
  • Vnm_getuser() : vnm.h
  • \n+
  • Vnm_ioTag() : vnm.h
  • \n+
  • Vnm_jmpOk() : vnm.h
  • \n+
  • Vnm_jmpOkClear() : vnm.h
  • \n+
  • Vnm_jmpOkSet() : vnm.h
  • \n+
  • Vnm_mkdir() : vnm.h
  • \n+
  • Vnm_nTags() : vnm.h
  • \n+
  • Vnm_open() : vnm.h
  • \n+
  • Vnm_powsafe() : vnm.h
  • \n+
  • Vnm_print() : vnm.h
  • \n+
  • Vnm_qsort() : vnm.h
  • \n+
  • Vnm_qsortOrd() : vnm.h
  • \n+
  • Vnm_redirect() : vnm.h
  • \n+
  • Vnm_regHand() : vnm.h
  • \n+
  • Vnm_setIoTag() : vnm.h
  • \n+
  • Vnm_sigHand() : vnm.h
  • \n+
  • Vnm_sigInt() : vnm.h
  • \n+
  • Vnm_sigIntClear() : vnm.h
  • \n+
  • Vnm_sigIntSet() : vnm.h
  • \n+
  • Vnm_signalInit() : vnm.h
  • \n+
  • Vnm_sleep() : vnm.h
  • \n+
  • Vnm_system() : vnm.h
  • \n+
  • Vnm_systemBack() : vnm.h
  • \n+
  • Vnm_systemKill() : vnm.h
  • \n+
  • Vnm_tprint() : vnm.h
  • \n+
  • Vnm_tstart() : vnm.h
  • \n+
  • Vnm_tstop() : vnm.h
  • \n+
  • Vnm_typeChk() : vnm.h
  • \n
  • VNULL : maloc_base.h
  • \n
  • VNULL_STRING : maloc_base.h
  • \n
  • VNULL_SYMBOL : maloc_base.h
  • \n
  • VODD : maloc_base.h
  • \n
  • VPI : maloc_base.h
  • \n
  • VPIPE_SYMBOL : maloc_base.h
  • \n-
  • VPORTNUMBER : vio.h
  • \n+
  • VPORTNUMBER : vio.h
  • \n
  • VPOS : maloc_base.h
  • \n
  • VPOW : maloc_base.h
  • \n-
  • VPOW_SAFE : vnm.h
  • \n-
  • Vpred_exactinit() : vpred.h
  • \n-
  • Vpred_incircle() : vpred.h
  • \n-
  • Vpred_incircleexact() : vpred.h
  • \n-
  • Vpred_incirclefast() : vpred.h
  • \n-
  • Vpred_insphere() : vpred.h
  • \n-
  • Vpred_insphereexact() : vpred.h
  • \n-
  • Vpred_inspherefast() : vpred.h
  • \n-
  • Vpred_orient2d() : vpred.h
  • \n-
  • Vpred_orient2dexact() : vpred.h
  • \n-
  • Vpred_orient2dfast() : vpred.h
  • \n-
  • Vpred_orient3d() : vpred.h
  • \n-
  • Vpred_orient3dexact() : vpred.h
  • \n-
  • Vpred_orient3dfast() : vpred.h
  • \n+
  • VPOW_SAFE : vnm.h
  • \n+
  • Vpred_exactinit() : vpred.h
  • \n+
  • Vpred_incircle() : vpred.h
  • \n+
  • Vpred_incircleexact() : vpred.h
  • \n+
  • Vpred_incirclefast() : vpred.h
  • \n+
  • Vpred_insphere() : vpred.h
  • \n+
  • Vpred_insphereexact() : vpred.h
  • \n+
  • Vpred_inspherefast() : vpred.h
  • \n+
  • Vpred_orient2d() : vpred.h
  • \n+
  • Vpred_orient2dexact() : vpred.h
  • \n+
  • Vpred_orient2dfast() : vpred.h
  • \n+
  • Vpred_orient3d() : vpred.h
  • \n+
  • Vpred_orient3dexact() : vpred.h
  • \n+
  • Vpred_orient3dfast() : vpred.h
  • \n
  • VPRIVATE : maloc_base.h
  • \n
  • VPRTKEY : maloc_base.h
  • \n
  • VPTRSIZE : maloc_base.h
  • \n
  • VPUBLIC : maloc_base.h
  • \n
  • VRAND : maloc_base.h
  • \n
  • VRANDMAX : maloc_base.h
  • \n
  • VRDIN_SYMBOL : maloc_base.h
  • \n@@ -294,15 +294,15 @@\n
  • VSINH : maloc_base.h
  • \n
  • VSMALL : maloc_base.h
  • \n
  • VSQR : maloc_base.h
  • \n
  • VSQRT : maloc_base.h
  • \n
  • VSTDMODE : maloc_base.h
  • \n
  • VTAN : maloc_base.h
  • \n
  • VTANH : maloc_base.h
  • \n-
  • VTIMERS : vnm.h
  • \n+
  • VTIMERS : vnm.h
  • \n
  • VTRUE : maloc_base.h
  • \n
  • VVLARGE : maloc_base.h
  • \n
  • VVSMALL : maloc_base.h
  • \n
  • VWARN : maloc_base.h
  • \n
  • VWARN1 : maloc_base.h
  • \n
  • VZERO : maloc_base.h
  • \n \n"}]}]}]}]}