This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Folder Setup - Path With '-' character

Dear Sirs

I have an ARM project on followind folder
D:\Firmware\APIDM01\B - Releases\V1\A - Source

When a I use the default folder filled by UV3 on folders path of compiler, I have the follwing path

..\A - Source

It cause an error when compilling the source code.

MAIN.C: Error: C3078E: stdin ('-') combined with other files

I suppose because the PARSER of compiler. I didn't find
this error using C51 8.12 compiler.

LEt's See the string control

-c --device DARMP -g -O0 --apcs=interwork -I..\A - Source -I "C:\Keil MDK 3.20\ARM\INC\Philips" -o "*.o" --omf_browse "*.crf" --depend "*.d"

-I..\A - Source <--- IT's parsing error

So, on folder path I've change the files path to
"D:\Firmware\APIDM01\B - Releases\V1\A - Source"
and the project compiles normally....

Let's see the final string control

-c --device DARMP -g -O0 --apcs=interwork -I"D:\Firmware\APIDM01\B - Releases\V1\A - Source" -I "C:\Keil MDK 3.20\ARM\INC\Philips" -o "*.o" --omf_browse "*.crf" --depend "*.d"

Is it a parser compiler bug or I can't use '-' char on ppath of my folders ?

Regards.

Parents Reply Children
  • You still haven't realized how a command line works.

    Your first example (that gave an error) will split into the following (by windows itself):

    1: -c
    2: --device
    3: DARMP
    4: -g
    5: -O0
    6: --apcs=interwork
    7: -I..\A
    8: -
    9: Source
    10: -I
    11: C:\Keil MDK 3.20\ARM\INC\Philips
    12: -o
    13: *.o
    14: --omf_browse
    15: *.crf
    16: --depend
    17: *.d
    


    And as you can see, your path "..\A - Source" gets splitted into three parameters. Not by the Keil compiler, but the Windows. The same thing would happen if the command line was processed on a Unix system.

    Your second example - after you have added quotation marks - gets expanded into:

    1: -c
    2: --device
    3: DARMP
    4: -g
    5: -O0
    6: --apcs=interwork
    7: -ID:\Firmware\APIDM01\B - Releases\V1\A - Source
    8: -I
    9: C:\Keil MDK 3.20\ARM\INC\Philips
    10: -o
    11: *.o
    12: --omf_browse
    13: *.crf
    14: --depend
    15: *.d
    


    And in this case, the compiler will get the include path as a single parameter.

    Then you make a new post, where you compare with the C51 environment. But we never get to know if the data is sent to the compiler on a command line, or by the use of a file. C51 is old, and a lot of Windows-based IDE made use of parameter files to get around the short command line supported by MS-DOS and early versions of Windows.

    However, note that the path is bracketed:

    INCDIR(..\A - Source)
    


    In this case, the compiler can use this bracketing to handle a path with spaces.

    So, once more: Your problem is with spaces, not with the '-' character. And as soon as you make sure that any path containing spaces are put within quotation marks, the operating system - not the compiler - will stop splitting the path into multiple parameters.

  • Just a footnote, since you are not so comfortable with command lines.

    Quote a lot of programs have a special meaning for a command line parameter that consists of a single dash.

    It normally means that the program should read from stdin or should write to stdout.

    That is probably the reason why you get the strange error message. When processing a file, the compiler can specify a file name and line number. That isn't so easy when it is requested to read from stdin.