@@ -108,6 +108,20 @@ pub enum PolicyError {
108
108
DuplicatePubKeys ,
109
109
}
110
110
111
+ /// Descriptor context for [`Policy`] compilation into a [`Descriptor`]
112
+ pub enum DescriptorCtx < Pk > {
113
+ /// Bare
114
+ Bare ,
115
+ /// Sh
116
+ Sh ,
117
+ /// Wsh
118
+ Wsh ,
119
+ /// ShWsh
120
+ ShWsh ,
121
+ /// Tr
122
+ Tr ( Option < Pk > ) ,
123
+ }
124
+
111
125
impl error:: Error for PolicyError { }
112
126
113
127
impl fmt:: Display for PolicyError {
@@ -329,6 +343,28 @@ impl<Pk: MiniscriptKey> Policy<Pk> {
329
343
}
330
344
}
331
345
346
+ /// Compile the [`Policy`] into desc_ctx [`Descriptor`]
347
+ #[ cfg( feature = "compiler" ) ]
348
+ pub fn compile_to_descriptor < Ctx : ScriptContext > (
349
+ & self ,
350
+ desc_ctx : DescriptorCtx < Pk > ,
351
+ ) -> Result < Descriptor < Pk > , Error > {
352
+ self . is_valid ( ) ?;
353
+ match self . is_safe_nonmalleable ( ) {
354
+ ( false , _) => Err ( Error :: from ( CompilerError :: TopLevelNonSafe ) ) ,
355
+ ( _, false ) => Err ( Error :: from (
356
+ CompilerError :: ImpossibleNonMalleableCompilation ,
357
+ ) ) ,
358
+ _ => match desc_ctx {
359
+ DescriptorCtx :: Bare => Descriptor :: new_bare ( compiler:: best_compilation ( self ) ?) ,
360
+ DescriptorCtx :: Sh => Descriptor :: new_sh ( compiler:: best_compilation ( self ) ?) ,
361
+ DescriptorCtx :: Wsh => Descriptor :: new_wsh ( compiler:: best_compilation ( self ) ?) ,
362
+ DescriptorCtx :: ShWsh => Descriptor :: new_sh_wsh ( compiler:: best_compilation ( self ) ?) ,
363
+ DescriptorCtx :: Tr ( unspendable_key) => self . compile_tr ( unspendable_key) ,
364
+ } ,
365
+ }
366
+ }
367
+
332
368
/// Compile the descriptor into an optimized `Miniscript` representation
333
369
#[ cfg( feature = "compiler" ) ]
334
370
pub fn compile < Ctx : ScriptContext > ( & self ) -> Result < Miniscript < Pk , Ctx > , CompilerError > {
0 commit comments