On Mon, Dec 09, 2024 at 06:39:19PM -0800, Steve Kargl wrote:
> 
> I've an almost complete implementation of F_C_STRING,
> but need a bit of insight on the inlining that I'm
> trying to implement.  In pseudo-code, F_C_STRING is
> 
> case 1.  f_c_string(string)               = trim(string) // c_null_char
> case 2.  f_c_string(string, asis=.false.) = trim(string) // c_null_char
> case 3.  f_c_string(string, asis=.true.)  = string       // c_null_char
> 

Here's where I'm stuck.

      if (asis)
        {
          /* f_c_string(string, .true.) = string // c_null_char  */

          len = fold_build2_loc (input_location, PLUS_EXPR, cnode,
                                 fold_convert (cnode, lse.string_length),
                                 fold_convert (cnode, rse.string_length));

          var = gfc_conv_string_tmp (se, pchar_type_node, len);
          tmp = build_call_expr_loc (input_location, gfor_fndecl_concat_string,
                                     6, len, var, 
                                     lse.string_length, lse.expr,
                                     rse.string_length, rse.expr);

//  
//        /* f_c_string(string, .false.) = trim(string) // c_null_char  */
//
//        gfc_init_se (&tse, se);
//        conv_trim (&tse, &lse);
//        gfc_add_block_to_block (&se->pre, &tse.pre);
//
//        len = fold_build2_loc (input_location, PLUS_EXPR, cnode,
//                               fold_convert (cnode, tse.string_length),
//                               fold_convert (cnode, rse.string_length));
//        var = gfc_conv_string_tmp (se, pchar_type_node, len);
//        tmp = build_call_expr_loc (input_location, gfor_fndecl_concat_string,
//                                   6, len, var, 
//                                   tse.string_length, tse.expr,
//                                   rse.string_length, rse.expr);


          gfc_add_expr_to_block (&se->pre, tmp);
          se->expr = var;
          se->string_length = len;
        }
      else

gfortran needs to select either uncommented code or the code,
based on the whether 'asis' is .true. or .false.  I've been
unable to suss out how to set up the conditional.  (It's been
too long since I hacked in the trans-* files.)

Any suggestions?

-- 
Steve

Reply via email to