123 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Prolog
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Prolog
		
	
	
	
	
	
| 
 | |
| :-	 use_module(library(yapi)).
 | |
| :-	 use_module(library(lists)).
 | |
| :-	 use_module(library(maplist)).
 | |
| :-	 use_module(library(python)).
 | |
| 
 | |
| :- python_import(sys).
 | |
| 
 | |
| jupyter_query(Self, Cell) :-
 | |
| 	setup_call_cleanup(
 | |
| 			   enter_cell(Self),
 | |
| 			   python_query(Self, Cell),
 | |
| 			   exit_cell(Self)
 | |
| 			  ).
 | |
| 
 | |
| enter_cell(_Self) :-
 | |
| 	open('//python/sys.stdout', append, _Output, [alias(jupo)]),
 | |
| 	open('//python/sys.stdout', append, _, [alias(jupe)]),
 | |
| 	set_prolog_flag(user_output, jupo),
 | |
| 	set_prolog_flag(user_error, jupe).
 | |
| 
 | |
| exit_cell(_Self) :-
 | |
| 	close( jupo),
 | |
| 	close( jupe).
 | |
| 
 | |
| 
 | |
| completions(S, Self) :-
 | |
| 	open_mem_read_stream(S, St),
 | |
| 	scan_to_list(St, Tokens),
 | |
| 	close(St),
 | |
| 	reverse(Tokens, RTokens),
 | |
| 	strip_final_tokens(RTokens, MyTokens),
 | |
| 	setof( Completion, complete(MyTokens, Completion), Cs),
 | |
| 	Self.completions := Cs.
 | |
| 
 | |
| 
 | |
| strip_final_tokens(['EOT'|Ts], Ts) :- !.
 | |
| strip_final_tokens( Ts, Ts ).|_],
 | |
| complete([E,l,C,l,A|More],
 | |
| 	 isconsult(A),
 | |
| 	  %B = l,
 | |
| 	  library(C,Lib),
 | |
| 	  %D=l,
 | |
| 	  E=atom(Prefix),
 | |
| 	\+ arg( Rest ),
 | |
| 	check_library( Prefix, Lib, C).
 | |
| complete([E,l,C,l,-,'['|More],
 | |
| 	 isconsult(A),
 | |
| 	  %B = l,
 | |
| 	  library(C,Lib),
 | |
| 	  %D=l,
 | |
| 	  E=atom(Prefix),
 | |
| 	\+ arg( Rest ),
 | |
| 	check_library( Prefix, Lib, C).
 | |
| complete([C,l,A|More],
 | |
| 	 isconsult(A),
 | |
| 	  %B = l,
 | |
| 	  C=atom(Prefix),
 | |
| 	\+ arg( Rest ),
 | |
| 	file_or_library( Prefix, C).
 | |
| complete([C,l,-,'['|More],
 | |
| 	 isconsult(A),
 | |
| 	  %B = l,
 | |
| 	  C=atom(Prefix),
 | |
| 	\+ arg( Rest ),
 | |
| 	file_or_library( Prefix, C).
 | |
| complete( [atom(F)|Rest], C) :-
 | |
| 	\+ arg( Rest ),
 | |
| 	predicate( F, Pred, Arity ),
 | |
| 	cont( Arity, F, Pred, C).
 | |
| 
 | |
| isconsult( atom(use_module) ).
 | |
| isconsult( atom(ensure_loaded) ).
 | |
| isconsult( atom(compile) ).
 | |
| isconsult( atom(consult) ).
 | |
| isconsult( atom(reconsult) ).
 | |
| isconsult( atom(load_files) ).
 | |
| isconsult( '['   ).
 | |
| 
 | |
| arg([']'|_]).
 | |
| arg([l|_]).
 | |
| 
 | |
| fileerrors-or_library(F,C) :-
 | |
| 	libsym(C0),
 | |
| 	atom_cooncat(F,C,Co).
 | |
| fileerrors-or_library(F,C) :-     
 | |
| 	check_file(F0,C).
 | |
| 		      
 | |
| check_file(F0,C) :-
 | |
| 	atom_concat('\'',F,F0),
 | |
| 	!,
 | |
| 	absolute_file_name( F, FF, [access(none)]  ),
 | |
| 	atom_concat( F, '*'	, Pat),
 | |
| 	absolute_file_name( Pat, C0, [glob(true)]  ),
 | |
| 	atom_concat(Pat,C00,C0),
 | |
| 	atom_conct(C00,'\'',C).
 | |
| check_file(F0,C) :-
 | |
| 	atom_concat( F, '*'	, Pat),
 | |
| 	absolute_file_name( Pat, C0, [glob(true)]  ),
 | |
| 	atom_concat(Pat,C,C0).
 | |
| 
 | |
| check_library( Lib, F, C) :-
 | |
| 	atom_concat( F, '*'	, Pat),
 | |
| 	LibF =.. [Lib(Pat)],
 | |
| 	absolute_file_name( LibF, Lib, [glob(true)]  ),
 | |
| 	file_directory_name( Lib, Name),
 | |
| 	( atom_concat(C, '.yap', Name) -> true ;
 | |
| 	 atom_concat(C, '.ypp', Name) -> true ;
 | |
| 	 atom_concat(C, '.prolog', Name) -> true
 | |
| 	).
 | |
| 
 | |
| predicate(N,P,A) :-
 | |
| 	system_predicate(P0/A),
 | |
| 	atom_concat(N,P,P0).
 | |
| predicate(N,P,A) :-
 | |
| 	current_predicate(P0/A),
 | |
| 	atom_concat(N,P,P0).
 | |
| 
 | |
| cont(0, F, P, P0)- :-
 | |
| 		atom_concat( F, P, PB ).
 | |
| cont( _, F, P, PB ):-
 | |
| 	atom_concat( [F, P, '('], PB ).
 |