Skip to content

Commit

Permalink
cross-platform compatibility
Browse files Browse the repository at this point in the history
  • Loading branch information
wannesm committed Oct 11, 2023
1 parent 1dd5faa commit 7af60d6
Show file tree
Hide file tree
Showing 7 changed files with 22 additions and 17 deletions.
4 changes: 4 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -45,3 +45,7 @@ docs:
view-docs: docs
open docs/_build/html/index.html

.PHONY: test
test:
export PYTHONPATH=.;py.test --ignore=venv --ignore-glob="venv_*"

4 changes: 2 additions & 2 deletions pysdd/lib/sdd-2.0/include/sddapi.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,8 @@

//sdd types
typedef size_t SddSize; //number of nodes, sizes of hash tables, etc
typedef unsigned int SddNodeSize; //size of decomposition for sdd nodes
typedef unsigned int SddRefCount; //refcount
typedef size_t SddNodeSize; //size of decomposition for sdd nodes, changed to size_t for cross-platform compatibility
typedef size_t SddRefCount; //refcount, changed to size_t for cross-platform compatibility
typedef unsigned long long SddModelCount; //model counts
typedef double SddWmc; // weighted model count
typedef long SddLiteral; //literals of clauses
Expand Down
6 changes: 3 additions & 3 deletions pysdd/lib/sdd-2.0/src/fnf/compiler.c
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ SddNode* degenerate_fnf_test(Fnf* fnf, SddManager* manager) {

if(count==0) return ONE(manager,op);

for(int i=0; i<count; i++) {
for(SddSize i=0; i<count; i++) {
if (fnf->litsets[i].literal_count == 0)
return ZERO(manager,op);
}
Expand All @@ -43,7 +43,7 @@ SddNode* fnf_to_sdd_auto(Fnf* fnf, SddManager* manager) {

if(verbose) { printf("\nclauses: %ld ",count); fflush(stdout); }
SddNode* node = ONE(manager,op);
for(int i=0; i<count; i++) {
for(SddSize i=0; i<count; i++) {
sort_litsets_by_lca(litsets+i,count-i,manager);
sdd_ref(node,manager);
SddNode* l = apply_litset(litsets[i],manager);
Expand All @@ -67,7 +67,7 @@ SddNode* fnf_to_sdd_manual(Fnf* fnf, SddManager* manager) {

if(verbose) { printf("\nclauses: %ld ",count); fflush(stdout); }
SddNode* node = ONE(manager,op);
for(int i=0; i<count; i++) {
for(SddSize i=0; i<count; i++) {
if(period > 0 && i > 0 && i%period==0) {
// after every period clauses
sdd_ref(node,manager);
Expand Down
3 changes: 2 additions & 1 deletion pysdd/lib/sdd-2.0/src/fnf/utils.c
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,8 @@ int litset_cmp_lca(const void* litset1_loc, const void* litset2_loc) {
//last: by id to obtain unique order
void sort_litsets_by_lca(LitSet** litsets, SddSize size, SddManager* manager) {
//compute lcas of litsets
for(SddLiteral i=0; i<size; i++) {
// i was SddLiteral but to be type compatible and since i is always positive, changed to SddSize
for(SddSize i=0; i<size; i++) {
LitSet* litset = litsets[i];
litset->vtree = sdd_manager_lca_of_literals(litset->literal_count,litset->literals,manager);
}
Expand Down
16 changes: 8 additions & 8 deletions pysdd/sdd.pyx
Original file line number Diff line number Diff line change
Expand Up @@ -27,13 +27,13 @@ import cython
import collections


IF HAVE_CYSIGNALS:
from cysignals.signals cimport sig_on, sig_off
ELSE:
# for non-POSIX systems
noop = lambda: None
sig_on = noop
sig_off = noop
# IF HAVE_CYSIGNALS: # IF is deprecated in cython, drop cysignals support for now
# from cysignals.signals cimport sig_on, sig_off
# ELSE:
# for non-POSIX systems
noop = lambda: None
sig_on = noop
sig_off = noop


cdef class SddNode:
Expand Down Expand Up @@ -324,7 +324,7 @@ cdef class SddNode:
def print_ptr(self):
#cdef long t = <long>self._sddnode
#print(t)
print("{0:x}".format(<unsigned int>&self._sddnode))
print("{0:x}".format(<size_t>&self._sddnode))

def save(self, char* filename):
return self._manager.save(filename, self)
Expand Down
4 changes: 2 additions & 2 deletions pysdd/sddapi_c.pxd
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ pysdd.sddapi_c
"""
cdef extern from "sddapi.h":
ctypedef size_t SddSize; # TODO: only for 64bit
ctypedef unsigned int SddNodeSize
ctypedef unsigned int SddRefCount
ctypedef size_t SddNodeSize
ctypedef size_t SddRefCount
ctypedef unsigned long long SddModelCount
ctypedef double SddWmc
ctypedef long SddLiteral
Expand Down
2 changes: 1 addition & 1 deletion setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ def __init__(self, attrs=None):
# compile_time_env['HAVE_CYSIGNALS'] = True

c_args = {
'unix': ['-O3'],
'unix': ['-O3', '-Wall'],
'msvc': ['/Ox', '/fp:fast', '/favor:INTEL64', '/Og'],
'mingw32': ['-O3', '-march=native']
}
Expand Down

0 comments on commit 7af60d6

Please sign in to comment.